view src/mule.c @ 622:11502791fc1c

[xemacs-hg @ 2001-06-22 01:49:57 by ben] dired-msw.c: Fix problem noted by Michael Sperber with directories containing [] and code that destructively modifies an existing string. term\AT386.el: Fix warnings. term\apollo.el: Removed. Kill kill kill. Sync with FSF and remove most crap. term\linux.el: Removed. Sync with FSF. Don't define most defns, because they are automatically defined by termcap. But do add defns for keys that normally get defined as f13, f14, etc. and really ought to be shift-f3, shift-f4, etc. (NOTE: I did this based on Cygwin, which emulates the Linux console. I would appreciate it if someone on Linux could verify.) term\cygwin.el: New. Load term/linux. term\lk201.el, term\news.el, term\vt100.el: Sync with FSF. Fix warnings. dialog-gtk.el: Fix warning. For 21.4: help.el, update-elc.el: Compile in proper order. Maybe for 21.4: keydefs.el: Add a defn for M-?, previously undefined, to access help -- in case the terminal is not set up right, or f1 gets redefined. README: Rewrite.
author ben
date Fri, 22 Jun 2001 01:50:04 +0000
parents 183866b06e0b
children
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)
    invalid_argument ("Too complicated regular expression for word!", Qunbound);
  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
}