Mercurial > hg > xemacs-beta
view src/mule.c @ 510:5bdbc721d46a
[xemacs-hg @ 2001-05-06 08:33:35 by ben]
implement printing the selection when it's selected.
force redisplay when set-charset-ccl-program called.
if bytecomp or byte-optimize need recompiling, then load
the .el version of them first, recompile them, and reload
the .elc versions to recompile everything else (so we won't
be waiting until the cows come home).
author | ben |
---|---|
date | Sun, 06 May 2001 08:33:41 +0000 |
parents | 8de8e3f6228a |
children | 183866b06e0b |
line wrap: on
line source
/* Copyright (C) 1995 Free Software Foundation. This file is part of XEmacs. XEmacs is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. XEmacs is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with XEmacs; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* Synched up with: Mule 2.3. Not in FSF. */ #include <config.h> #include "lisp.h" #include "regex.h" #ifdef MULE_REGEXP Lisp_Object Vre_word; int re_short_flag; DEFUN ("define-word-pattern", Fdefine_word_pattern, 1, 1, 0, /* Don't call this function directly, instead use 'define-word' which accept a pattern compiled by 'regexp-compile' with word-option t. */ (pattern)) { int i, len; char *p; Lisp_Object temp; Lisp_String *s; CHECK_CONS (pattern); len = XINT (Flength (pattern)); if (len > MAXWORDBUF) error ("Too complicated regular expression for word!"); for (i = 0; i < len; i++) { temp = XCAR (pattern); CHECK_VECTOR (temp); CHECK_STRING (XVECTOR_DATA (temp)[0]); s = XSTRING (XVECTOR_DATA (temp)[0]); if (!wordbuf[i]) wordbuf[i] = xnew (struct re_pattern_buffer); else if (wordbuf[i]->buffer) xfree (wordbuf[i]->buffer); wordbuf[i]->buffer = (char *) xmalloc (s->size + 1); wordbuf[i]->used = s->size; memcpy (wordbuf[i]->buffer, s->data, s->size + 1); #ifdef EMACS19_REGEXP wordbuf[i]->translate = 0; wordbuf[i]->fastmap_accurate = 0; wordbuf[i]->fastmap = 0; wordbuf[i]->can_be_null = 1; wordbuf[i]->mc_flag = 1; wordbuf[i]->short_flag = 0; wordbuf[i]->no_empty = 0; wordbuf[i]->syntax_version = 0; wordbuf[i]->category_version = 0; wordbuf[i]->regs_allocated = REGS_UNALLOCATED; wordbuf[i]->re_nsub = 0; wordbuf[i]->no_sub = 0; wordbuf[i]->newline_anchor = 1; wordbuf[i]->syntax = 0; wordbuf[i]->not_bol = wordbuf[i]->not_eol = 0; #endif /* EMACS19_REGEXP */ pattern = XCDR (pattern); } for (; i < MAXWORDBUF && wordbuf[i]; i++) { if (wordbuf[i]->buffer) xfree (wordbuf[i]->buffer); xfree (wordbuf[i]); wordbuf[i] = (struct re_pattern_buffer *) 0; } return Qnil; } #endif /* MULE_REGEXP */ void syms_of_mule (void) { #ifdef MULE_REGEXP DEFSUBR (Fdefine_word_pattern); #endif } void vars_of_mule (void) { #ifdef MULE_REGEXP DEFVAR_BOOL ("re-short-flag", &re_short_flag /* *T means regexp search success when the shortest match is found. */ ); re_short_flag = 0; #endif /* MULE_REGEXP */ Fprovide (intern ("mule")); #ifdef HAVE_EGG Fprovide (intern ("egg")); #endif #ifdef HAVE_WNN Fprovide (intern ("wnn")); #endif }