annotate lisp/progmodes/ebnf-ebx.el @ 89943:4c90ffeb71c5

Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15 Merge from emacs--cvs-trunk--0 Patches applied: * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-218 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-220 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-221 Restore deleted tagline in etc/TUTORIAL.ru * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-222 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-228 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-229 Remove TeX output files from the archive * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-230 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-247 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-248 src/lisp.h (CYCLE_CHECK): Macro moved from xfaces.c * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-249 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-256 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-258 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-263 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-264 Update from CVS: lispref/display.texi: emacs -> Emacs. * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-265 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-274 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-275 Update from CVS: man/makefile.w32-in: Revert last change * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-276 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-295 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-296 Allow restarting an existing debugger session that's exited * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-297 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-299 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-300 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-327 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-328 Update from CVS: src/.gdbinit (xsymbol): Fix last change. * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-329 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-344 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-345 Tweak source regexps so that building in place won't cause problems * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-346 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-351 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-352 Update from CVS: lisp/flymake.el: New file. * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-353 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-361 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-362 Support " [...]" style defaults in minibuffer-electric-default-mode * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-363 (read-number): Use canonical format for default in prompt. * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-364 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-367 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-368 Improve display-supports-face-attributes-p on non-ttys * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-369 Rewrite face-differs-from-default-p * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-370 Move `display-supports-face-attributes-p' entirely into C code * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-371 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-372 Simplify face-differs-from-default-p; don't consider :stipple. * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-373 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-374 (tty_supports_face_attributes_p): Ensure attributes differ from default * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-375 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-376 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-377 (Fdisplay_supports_face_attributes_p): Work around bootstrapping problem * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-378 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-380 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-381 Face merging cleanups * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-382 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-384 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-385 src/xfaces.c (push_named_merge_point): Return 0 if a cycle is detected * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-386 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-395 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-396 Tweak arch tagging to make build/install-in-place less annoying * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-397 Work around vc-arch problems when building eshell * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-398 Tweak permissions * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-399 Tweak directory permissions * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-400 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-401 More build-in-place tweaking of arch tagging * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-402 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-403 Yet more build-in-place tweaking of arch tagging * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-404 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-409 Update from CVS * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-410 Make sure image types are initialized for lookup too * miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-411 - miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-416 Update from CVS
author Miles Bader <miles@gnu.org>
date Mon, 28 Jun 2004 07:56:49 +0000
parents 68c22ea6027c
children 4da4a09e8b1b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
89909
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1 ;;; ebnf-ebx.el --- parser for EBNF used to specify XML (EBNFX)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3 ;; Copyright (C) 2004 Free Sofware Foundation, Inc.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
5 ;; Author: Vinicius Jose Latorre <viniciusjl@ig.com.br>
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
6 ;; Maintainer: Vinicius Jose Latorre <viniciusjl@ig.com.br>
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
7 ;; Time-stamp: <2004/04/03 16:45:34 vinicius>
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
8 ;; Keywords: wp, ebnf, PostScript
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
9 ;; Version: 1.1
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
10
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
11 ;; This file is part of GNU Emacs.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
12
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
13 ;; GNU Emacs is free software; you can redistribute it and/or modify
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
14 ;; it under the terms of the GNU General Public License as published by
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
15 ;; the Free Software Foundation; either version 2, or (at your option)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
16 ;; any later version.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
17
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
18 ;; GNU Emacs is distributed in the hope that it will be useful,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
19 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
20 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
21 ;; GNU General Public License for more details.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
22
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
23 ;; You should have received a copy of the GNU General Public License
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
24 ;; along with GNU Emacs; see the file COPYING. If not, write to the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
25 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
26 ;; Boston, MA 02111-1307, USA.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
27
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
28 ;;; Commentary:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
29
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
30 ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
31 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
32 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
33 ;; This is part of ebnf2ps package.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
34 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
35 ;; This package defines a parser for EBNF used to specify XML (EBNFX).
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
36 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
37 ;; See ebnf2ps.el for documentation.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
38 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
39 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
40 ;; EBNFX Syntax
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
41 ;; ------------
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
42 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
43 ;; See the URL:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
44 ;; `http://www.w3.org/TR/2004/REC-xml-20040204/#sec-notation'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
45 ;; (Extensible Markup Language (XML) 1.0 (Third Edition))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
46 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
47 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
48 ;; rule ::= symbol '::=' expression
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
49 ;; /* rules are separated by at least one blank line. */
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
50 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
51 ;; expression ::= concatenation ('|' concatenation)*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
52 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
53 ;; concatenation ::= exception*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
54 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
55 ;; exception ::= term ('-' term)?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
56 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
57 ;; term ::= factor ('*' | '+' | '?')?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
58 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
59 ;; factor ::= hex-char+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
60 ;; | '[' '^'? ( char ( '-' char )? )+ ']'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
61 ;; | '"' 'string' '"'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
62 ;; | "'" "string" "'"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
63 ;; | '(' expression ')'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
64 ;; | symbol
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
65 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
66 ;; symbol ::= 'upper or lower case letter'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
67 ;; ('upper or lower case letter' | '-' | '_')*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
68 ;; /* upper and lower 8-bit accentuated characters are included */
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
69 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
70 ;; hex-char ::= '#x' [0-9A-Fa-f]+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
71 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
72 ;; char ::= hex-char | 'any character except control characters'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
73 ;; /* 8-bit accentuated characters are included */
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
74 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
75 ;; any-char ::= char | 'newline' | 'tab'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
76 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
77 ;; ignore ::= '[' ('wfc' | 'WFC' | 'vc' | 'VC') ':' ( any-char - ']' )* ']'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
78 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
79 ;; comment ::= '/*' ( any-char - '*/' ) '*/'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
80 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
81 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
82 ;; Below is the Notation section extracted from the URL cited above.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
83 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
84 ;; 6 Notation
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
85 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
86 ;; The formal grammar of XML is given in this specification using a simple
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
87 ;; Extended Backus-Naur Form (EBNF) notation. Each rule in the grammar defines
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
88 ;; one symbol, in the form
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
89 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
90 ;; symbol ::= expression
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
91 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
92 ;; Symbols are written with an initial capital letter if they are the start
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
93 ;; symbol of a regular language, otherwise with an initial lowercase letter.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
94 ;; Literal strings are quoted.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
95 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
96 ;; Within the expression on the right-hand side of a rule, the following
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
97 ;; expressions are used to match strings of one or more characters:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
98 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
99 ;; #xN
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
100 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
101 ;; where N is a hexadecimal integer, the expression matches the character
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
102 ;; whose number (code point) in ISO/IEC 10646 is N. The number of leading
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
103 ;; zeros in the #xN form is insignificant.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
104 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
105 ;; [a-zA-Z], [#xN-#xN]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
106 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
107 ;; matches any Char with a value in the range(s) indicated (inclusive).
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
108 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
109 ;; [abc], [#xN#xN#xN]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
110 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
111 ;; matches any Char with a value among the characters enumerated.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
112 ;; Enumerations and ranges can be mixed in one set of brackets.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
113 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
114 ;; [^a-z], [^#xN-#xN]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
115 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
116 ;; matches any Char with a value outside the range indicated.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
117 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
118 ;; [^abc], [^#xN#xN#xN]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
119 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
120 ;; matches any Char with a value not among the characters given.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
121 ;; Enumerations and ranges of forbidden values can be mixed in one set of
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
122 ;; brackets.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
123 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
124 ;; "string"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
125 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
126 ;; matches a literal string matching that given inside the double quotes.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
127 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
128 ;; 'string'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
129 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
130 ;; matches a literal string matching that given inside the single quotes.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
131 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
132 ;; These symbols may be combined to match more complex patterns as follows,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
133 ;; where A and B represent simple expressions:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
134 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
135 ;; (expression)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
136 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
137 ;; expression is treated as a unit and may be combined as described in this
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
138 ;; list.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
139 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
140 ;; A?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
141 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
142 ;; matches A or nothing; optional A.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
143 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
144 ;; A B
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
145 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
146 ;; matches A followed by B. This operator has higher precedence than
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
147 ;; alternation; thus A B | C D is identical to (A B) | (C D).
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
148 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
149 ;; A | B
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
150 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
151 ;; matches A or B.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
152 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
153 ;; A - B
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
154 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
155 ;; matches any string that matches A but does not match B.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
156 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
157 ;; A+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
158 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
159 ;; matches one or more occurrences of A. Concatenation has higher
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
160 ;; precedence than alternation; thus A+ | B+ is identical to (A+) | (B+).
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
161 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
162 ;; A*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
163 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
164 ;; matches zero or more occurrences of A. Concatenation has higher
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
165 ;; precedence than alternation; thus A* | B* is identical to (A*) | (B*).
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
166 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
167 ;; Other notations used in the productions are:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
168 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
169 ;; /* ... */
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
170 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
171 ;; comment.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
172 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
173 ;; [ wfc: ... ]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
174 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
175 ;; well-formedness constraint; this identifies by name a constraint on
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
176 ;; well-formed documents associated with a production.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
177 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
178 ;; [ vc: ... ]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
179 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
180 ;; validity constraint; this identifies by name a constraint on valid
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
181 ;; documents associated with a production.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
182 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
183 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
184 ;; Differences Between EBNFX And ebnf2ps EBNFX
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
185 ;; -------------------------------------------
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
186 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
187 ;; Besides the characters that EBNFX accepts, ebnf2ps EBNFX accepts also the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
188 ;; underscore (_) and minus (-) for rule name and european 8-bit accentuated
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
189 ;; characters (from \240 to \377) for rule name, string and comment. Also
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
190 ;; rule name can start with upper case letter.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
191 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
192 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
193 ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
194
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
195 ;;; Code:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
196
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
197
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
198 (require 'ebnf-otz)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
199
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
200
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
201 (defvar ebnf-ebx-lex nil
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
202 "Value returned by `ebnf-ebx-lex' function.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
203
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
204
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
205 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
206 ;; Syntactic analyzer
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
207
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
208
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
209 ;;; rulelist ::= rule+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
210
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
211 (defun ebnf-ebx-parser (start)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
212 "EBNFX parser."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
213 (let ((total (+ (- ebnf-limit start) 1))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
214 (bias (1- start))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
215 (origin (point))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
216 rule-list token rule)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
217 (goto-char start)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
218 (setq token (ebnf-ebx-lex))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
219 (and (eq token 'end-of-input)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
220 (error "Invalid EBNFX file format"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
221 (and (eq token 'end-of-rule)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
222 (setq token (ebnf-ebx-lex)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
223 (while (not (eq token 'end-of-input))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
224 (ebnf-message-float
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
225 "Parsing...%s%%"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
226 (/ (* (- (point) bias) 100.0) total))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
227 (setq token (ebnf-ebx-rule token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
228 rule (cdr token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
229 token (car token))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
230 (or (ebnf-add-empty-rule-list rule)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
231 (setq rule-list (cons rule rule-list))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
232 (goto-char origin)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
233 rule-list))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
234
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
235
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
236 ;;; rule ::= symbol '::=' expression
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
237
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
238
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
239 (defun ebnf-ebx-rule (token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
240 (let ((name ebnf-ebx-lex)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
241 (action ebnf-action)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
242 elements)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
243 (setq ebnf-action nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
244 (or (eq token 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
245 (error "Invalid rule name"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
246 (setq token (ebnf-ebx-lex))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
247 (or (eq token 'production)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
248 (error "Invalid rule: missing `::='"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
249 (setq elements (ebnf-ebx-expression))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
250 (or (memq (car elements) '(end-of-rule end-of-input))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
251 (error "Invalid rule: there is no end of rule"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
252 (setq elements (cdr elements))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
253 (ebnf-eps-add-production name)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
254 (cons (ebnf-ebx-lex)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
255 (ebnf-make-production name elements action))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
256
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
257
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
258 ;; expression ::= concatenation ('|' concatenation)*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
259
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
260
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
261 (defun ebnf-ebx-expression ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
262 (let (body concatenation)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
263 (while (eq (car (setq concatenation
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
264 (ebnf-ebx-concatenation (ebnf-ebx-lex))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
265 'alternative)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
266 (setq body (cons (cdr concatenation) body)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
267 (ebnf-token-alternative body concatenation)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
268
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
269
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
270 ;; concatenation ::= exception*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
271
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
272
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
273 (defun ebnf-ebx-concatenation (token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
274 (let ((term (ebnf-ebx-exception token))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
275 seq)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
276 (or (setq token (car term)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
277 term (cdr term))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
278 (error "Empty element"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
279 (setq seq (cons term seq))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
280 (while (setq term (ebnf-ebx-exception token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
281 token (car term)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
282 term (cdr term))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
283 (setq seq (cons term seq)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
284 (cons token
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
285 (ebnf-token-sequence seq))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
286
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
287
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
288 ;;; exception ::= term ('-' term)?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
289
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
290
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
291 (defun ebnf-ebx-exception (token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
292 (let ((term (ebnf-ebx-term token)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
293 (if (eq (car term) 'exception)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
294 (let ((except (ebnf-ebx-term (ebnf-ebx-lex))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
295 (cons (car except)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
296 (ebnf-make-except (cdr term) (cdr except))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
297 term)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
298
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
299
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
300
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
301 ;;; term ::= factor ('*' | '+' | '?')?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
302
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
303
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
304 (defun ebnf-ebx-term (token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
305 (let ((factor (ebnf-ebx-factor token)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
306 (when factor
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
307 (setq token (ebnf-ebx-lex))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
308 (cond ((eq token 'zero-or-more)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
309 (setq factor (ebnf-make-zero-or-more factor)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
310 token (ebnf-ebx-lex)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
311 ((eq token 'one-or-more)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
312 (setq factor (ebnf-make-one-or-more factor)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
313 token (ebnf-ebx-lex)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
314 ((eq token 'optional)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
315 (setq factor (ebnf-token-optional factor)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
316 token (ebnf-ebx-lex)))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
317 (cons token factor)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
318
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
319
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
320 ;;; factor ::= hex-char+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
321 ;;; | '[' '^'? ( char ( '-' char )? )+ ']'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
322 ;;; | '"' 'string' '"'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
323 ;;; | "'" "string" "'"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
324 ;;; | '(' expression ')'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
325 ;;; | symbol
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
326 ;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
327 ;;; symbol ::= 'upper or lower case letter'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
328 ;;; ('upper or lower case letter' | '-' | '_')*
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
329 ;;; /* upper and lower 8-bit accentuated characters are included */
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
330 ;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
331 ;;; hex-char ::= '#x' [0-9A-Fa-f]+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
332 ;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
333 ;;; char ::= hex-char | 'any character except control characters'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
334 ;;; /* 8-bit accentuated characters are included */
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
335 ;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
336 ;;; any-char ::= char | 'newline' | 'tab'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
337
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
338
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
339 (defun ebnf-ebx-factor (token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
340 (cond
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
341 ;; terminal
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
342 ((eq token 'terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
343 (ebnf-make-terminal ebnf-ebx-lex))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
344 ;; non-terminal
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
345 ((eq token 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
346 (ebnf-make-non-terminal ebnf-ebx-lex))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
347 ;; group
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
348 ((eq token 'begin-group)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
349 (let ((body (ebnf-ebx-expression)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
350 (or (eq (car body) 'end-group)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
351 (error "Missing `)'"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
352 (cdr body)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
353 ;; no element
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
354 (t
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
355 nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
356 ))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
357
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
358
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
359 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
360 ;; Lexical analyzer
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
361
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
362
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
363 (defconst ebnf-ebx-token-table (make-vector 256 'error)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
364 "Vector used to map characters to a lexical token.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
365
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
366
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
367 (defun ebnf-ebx-initialize ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
368 "Initialize EBNFX token table."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
369 ;; control character & control 8-bit character are set to `error'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
370 (let ((char ?\101))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
371 ;; printable character: A-Z
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
372 (while (< char ?\133)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
373 (aset ebnf-ebx-token-table char 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
374 (setq char (1+ char)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
375 ;; printable character: a-z
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
376 (setq char ?\141)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
377 (while (< char ?\173)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
378 (aset ebnf-ebx-token-table char 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
379 (setq char (1+ char)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
380 ;; European 8-bit accentuated characters:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
381 (setq char ?\240)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
382 (while (< char ?\400)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
383 (aset ebnf-ebx-token-table char 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
384 (setq char (1+ char)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
385 ;; Override end of line characters:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
386 (aset ebnf-ebx-token-table ?\n 'end-of-rule) ; [NL] linefeed
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
387 (aset ebnf-ebx-token-table ?\r 'end-of-rule) ; [CR] carriage return
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
388 ;; Override space characters:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
389 (aset ebnf-ebx-token-table ?\013 'space) ; [VT] vertical tab
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
390 (aset ebnf-ebx-token-table ?\t 'space) ; [HT] horizontal tab
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
391 (aset ebnf-ebx-token-table ?\ 'space) ; [SP] space
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
392 ;; Override form feed character:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
393 (aset ebnf-ebx-token-table ?\f 'form-feed) ; [FF] form feed
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
394 ;; Override other lexical characters:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
395 (aset ebnf-ebx-token-table ?# 'hash)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
396 (aset ebnf-ebx-token-table ?\" 'double-quote)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
397 (aset ebnf-ebx-token-table ?\' 'single-quote)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
398 (aset ebnf-ebx-token-table ?\( 'begin-group)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
399 (aset ebnf-ebx-token-table ?\) 'end-group)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
400 (aset ebnf-ebx-token-table ?- 'exception)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
401 (aset ebnf-ebx-token-table ?: 'colon)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
402 (aset ebnf-ebx-token-table ?\[ 'begin-square)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
403 (aset ebnf-ebx-token-table ?| 'alternative)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
404 (aset ebnf-ebx-token-table ?* 'zero-or-more)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
405 (aset ebnf-ebx-token-table ?+ 'one-or-more)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
406 (aset ebnf-ebx-token-table ?\? 'optional)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
407 ;; Override comment character:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
408 (aset ebnf-ebx-token-table ?/ 'comment)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
409
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
410
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
411 ;; replace the range "\240-\377" (see `ebnf-range-regexp').
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
412 (defconst ebnf-ebx-non-terminal-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
413 (ebnf-range-regexp "-_A-Za-z" ?\240 ?\377))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
414 (defconst ebnf-ebx-non-terminal-letter-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
415 (ebnf-range-regexp "A-Za-z" ?\240 ?\377))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
416
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
417
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
418 (defun ebnf-ebx-lex ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
419 "Lexical analyser for EBNFX.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
420
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
421 Return a lexical token.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
422
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
423 See documentation for variable `ebnf-ebx-lex'."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
424 (if (>= (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
425 'end-of-input
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
426 (let (token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
427 ;; skip spaces and comments
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
428 (while (if (> (following-char) 255)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
429 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
430 (setq token 'error)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
431 nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
432 (setq token (aref ebnf-ebx-token-table (following-char)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
433 (cond
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
434 ((eq token 'space)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
435 (skip-chars-forward " \013\t" ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
436 (< (point) ebnf-limit))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
437 ((eq token 'comment)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
438 (ebnf-ebx-skip-comment))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
439 ((eq token 'form-feed)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
440 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
441 (setq ebnf-action 'form-feed))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
442 ((eq token 'end-of-rule)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
443 (ebnf-ebx-skip-end-of-rule))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
444 ((and (eq token 'begin-square)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
445 (let ((case-fold-search t))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
446 (looking-at "\\[\\(wfc\\|vc\\):")))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
447 (ebnf-ebx-skip-constraint))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
448 (t nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
449 )))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
450 (cond
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
451 ;; end of input
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
452 ((>= (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
453 'end-of-input)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
454 ;; error
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
455 ((eq token 'error)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
456 (error "Illegal character"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
457 ;; end of rule
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
458 ((eq token 'end-of-rule)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
459 'end-of-rule)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
460 ;; terminal: #x [0-9A-Fa-f]+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
461 ((eq token 'hash)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
462 (setq ebnf-ebx-lex (ebnf-ebx-character))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
463 'terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
464 ;; terminal: "string"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
465 ((eq token 'double-quote)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
466 (setq ebnf-ebx-lex (ebnf-ebx-string ?\"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
467 'terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
468 ;; terminal: 'string'
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
469 ((eq token 'single-quote)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
470 (setq ebnf-ebx-lex (ebnf-ebx-string ?\'))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
471 'terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
472 ;; terminal: [ ^? ( char ( - char )? )+ ]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
473 ((eq token 'begin-square)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
474 (setq ebnf-ebx-lex (ebnf-ebx-range))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
475 'terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
476 ;; non-terminal: NAME
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
477 ((eq token 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
478 (setq ebnf-ebx-lex
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
479 (ebnf-buffer-substring ebnf-ebx-non-terminal-chars))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
480 'non-terminal)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
481 ;; colon: ::=
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
482 ((eq token 'colon)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
483 (or (looking-at "::=")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
484 (error "Missing `::=' token"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
485 (forward-char 3)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
486 'production)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
487 ;; miscellaneous: (, ), *, +, ?, |, -
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
488 (t
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
489 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
490 token)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
491 ))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
492
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
493
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
494 ;; replace the range "\177-\237" (see `ebnf-range-regexp').
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
495 (defconst ebnf-ebx-constraint-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
496 (ebnf-range-regexp "^\000-\010\016-\037]" ?\177 ?\237))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
497
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
498
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
499 (defun ebnf-ebx-skip-constraint ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
500 (or (> (skip-chars-forward ebnf-ebx-constraint-chars ebnf-limit) 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
501 (error "Invalid character"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
502 (or (= (following-char) ?\])
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
503 (error "Missing end of constraint `]'"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
504 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
505 t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
506
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
507
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
508
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
509 (defun ebnf-ebx-skip-end-of-rule ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
510 (let (eor-p)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
511 (while (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
512 ;; end of rule ==> 2 or more consecutive end of lines
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
513 (setq eor-p (or (> (skip-chars-forward "\r\n" ebnf-limit) 1)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
514 eor-p))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
515 ;; skip spaces
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
516 (skip-chars-forward " \013\t" ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
517 ;; skip comments
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
518 (and (= (following-char) ?/)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
519 (ebnf-ebx-skip-comment))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
520 (not eor-p)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
521
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
522
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
523 ;; replace the range "\177-\237" (see `ebnf-range-regexp').
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
524 (defconst ebnf-ebx-comment-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
525 (ebnf-range-regexp "^\000-\010\016-\037\\*" ?\177 ?\237))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
526 (defconst ebnf-ebx-filename-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
527 (ebnf-range-regexp "^\000-\037\\*" ?\177 ?\237))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
528
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
529
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
530 (defun ebnf-ebx-skip-comment ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
531 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
532 (or (= (following-char) ?*)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
533 (error "Invalid beginning of comment"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
534 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
535 (cond
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
536 ;; open EPS file
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
537 ((and ebnf-eps-executing (= (following-char) ?\[))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
538 (ebnf-eps-add-context (ebnf-ebx-eps-filename)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
539 ;; close EPS file
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
540 ((and ebnf-eps-executing (= (following-char) ?\]))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
541 (ebnf-eps-remove-context (ebnf-ebx-eps-filename)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
542 ;; any other action in comment
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
543 (t
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
544 (setq ebnf-action (aref ebnf-comment-table (following-char))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
545 )
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
546 (while (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
547 (skip-chars-forward ebnf-ebx-comment-chars ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
548 (or (= (following-char) ?*)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
549 (error "Missing end of comment"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
550 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
551 (and (/= (following-char) ?/)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
552 (< (point) ebnf-limit))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
553 ;; check for a valid end of comment
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
554 (and (>= (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
555 (error "Missing end of comment"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
556 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
557 t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
558
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
559
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
560 (defun ebnf-ebx-eps-filename ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
561 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
562 (let (fname nchar)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
563 (while (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
564 (setq fname
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
565 (concat fname
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
566 (ebnf-buffer-substring ebnf-ebx-filename-chars)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
567 (and (< (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
568 (> (setq nchar (skip-chars-forward "*" ebnf-limit)) 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
569 (< (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
570 (/= (following-char) ?/)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
571 (setq fname (concat fname (make-string nchar ?*))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
572 nchar nil))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
573 (if (or (not nchar) (= nchar 0))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
574 fname
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
575 (and (< (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
576 (= (following-char) ?/)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
577 (setq nchar (1- nchar)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
578 (concat fname (make-string nchar ?*)))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
579
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
580
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
581 ;; replace the range "\240-\377" (see `ebnf-range-regexp').
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
582 (defconst ebnf-ebx-double-string-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
583 (ebnf-range-regexp "\t -!#-~" ?\240 ?\377))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
584 (defconst ebnf-ebx-single-string-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
585 (ebnf-range-regexp "\t -&(-~" ?\240 ?\377))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
586
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
587
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
588 (defun ebnf-ebx-string (delim)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
589 (buffer-substring-no-properties
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
590 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
591 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
592 (point))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
593 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
594 (skip-chars-forward (if (= delim ?\")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
595 ebnf-ebx-double-string-chars
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
596 ebnf-ebx-single-string-chars)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
597 ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
598 (or (= (following-char) delim)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
599 (error "Missing string delimiter `%c'" delim))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
600 (prog1
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
601 (point)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
602 (forward-char)))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
603
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
604
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
605 (defun ebnf-ebx-character ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
606 ;; #x [0-9A-Fa-f]+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
607 (buffer-substring-no-properties
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
608 (point)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
609 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
610 (ebnf-ebx-hex-character)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
611 (point))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
612
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
613
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
614 (defun ebnf-ebx-range ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
615 ;; [ ^? ( char ( - char )? )+ ]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
616 (buffer-substring-no-properties
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
617 (point)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
618 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
619 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
620 (and (= (following-char) ?^)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
621 (forward-char))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
622 (and (= (following-char) ?-)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
623 (forward-char))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
624 (while (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
625 (ebnf-ebx-any-character)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
626 (when (= (following-char) ?-)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
627 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
628 (ebnf-ebx-any-character))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
629 (and (/= (following-char) ?\])
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
630 (< (point) ebnf-limit))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
631 (and (>= (point) ebnf-limit)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
632 (error "Missing end of character range `]'"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
633 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
634 (point))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
635
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
636
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
637 (defun ebnf-ebx-any-character ()
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
638 (let ((char (following-char)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
639 (cond ((= char ?#)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
640 (ebnf-ebx-hex-character t))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
641 ((or (and (<= ?\ char) (<= char ?\")) ; #
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
642 (and (<= ?$ char) (<= char ?,)) ; -
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
643 (and (<= ?. char) (<= char ?\\)) ; ]
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
644 (and (<= ?^ char) (<= char ?~))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
645 (and (<= ?\240 char) (<= char ?\377)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
646 (forward-char))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
647 (t
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
648 (error "Invalid character `%c'" char)))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
649
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
650
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
651 (defun ebnf-ebx-hex-character (&optional no-error)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
652 ;; #x [0-9A-Fa-f]+
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
653 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
654 (if (/= (following-char) ?x)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
655 (or no-error
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
656 (error "Invalid hexadecimal character"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
657 (forward-char)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
658 (or (> (skip-chars-forward "0-9A-Fa-f" ebnf-limit) 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
659 (error "Invalid hexadecimal character"))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
660
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
661
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
662 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
663
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
664
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
665 (provide 'ebnf-ebx)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
666
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
667 ;;; arch-tag: bfe2f95b-66bc-4dc6-8b7e-b7831e68f5fb
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
668 ;;; ebnf-ebx.el ends here