annotate lisp/cedet/semantic/bovine.el @ 104476:1da44e87bf90

lisp/cedet/semantic/sort.el (semantic-tag-external-class-default) (semantic-tag-external-member-children-default): Require semantic/db-mode instead of checking if semanticdb-minor-mode-p is bound.
author Chong Yidong <cyd@stupidchicken.com>
date Mon, 07 Sep 2009 16:34:35 +0000
parents a19d1a45b823
children bbd7017a25d9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
104453
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
1 ;;; semantic/bovine.el --- LL Parser/Analyzer core.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
2
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
3 ;;; Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2006, 2007
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
4 ;;; Free Software Foundation, Inc.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
5
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
6 ;; Author: Eric M. Ludlam <eric@siege-engine.com>
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
7
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
9
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
10 ;; GNU Emacs is free software: you can redistribute it and/or modify
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
12 ;; the Free Software Foundation, either version 3 of the License, or
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
13 ;; (at your option) any later version.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
14
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
18 ;; GNU General Public License for more details.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
19
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
21 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
22
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
23 ;;; Commentary:
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
24 ;;
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
25 ;; Semantix 1.x uses an LL parser named the "bovinator". This parser
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
26 ;; had several conveniences in it which made for parsing tags out of
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
27 ;; languages with list characters easy. This parser lives on as one
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
28 ;; of many available parsers for semantic the tool.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
29 ;;
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
30 ;; This parser should be used when the language is simple, such as
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
31 ;; makefiles or other data-declaritive langauges.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
32
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
33 ;;; Code:
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
34 (require 'semantic)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
35 (require 'semantic/bovine/debug)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
36
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
37 ;;; Variables
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
38 ;;
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
39 (defvar semantic-bovinate-nonterminal-check-obarray nil
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
40 "Obarray of streams already parsed for nonterminal symbols.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
41 Use this to detect infinite recursion during a parse.")
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
42 (make-variable-buffer-local 'semantic-bovinate-nonterminal-check-obarray)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
43
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
44
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
45
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
46 ;; These are functions that can be called from within a bovine table.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
47 ;; Most of these have code auto-generated from other construct in the
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
48 ;; bovine input grammar.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
49 (defmacro semantic-lambda (&rest return-val)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
50 "Create a lambda expression to return a list including RETURN-VAL.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
51 The return list is a lambda expression to be used in a bovine table."
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
52 `(lambda (vals start end)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
53 (append ,@return-val (list start end))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
54
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
55 ;;; Semantic Bovination
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
56 ;;
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
57 ;; Take a semantic token stream, and convert it using the bovinator.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
58 ;; The bovinator takes a state table, and converts the token stream
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
59 ;; into a new semantic stream defined by the bovination table.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
60 ;;
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
61 (defsubst semantic-bovinate-symbol-nonterminal-p (sym table)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
62 "Return non-nil if SYM is in TABLE, indicating it is NONTERMINAL."
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
63 ;; sym is always a sym, so assq should be ok.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
64 (if (assq sym table) t nil))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
65
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
66 (defmacro semantic-bovinate-nonterminal-db-nt ()
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
67 "Return the current nonterminal symbol.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
68 Part of the grammar source debugger. Depends on the existing
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
69 environment of `semantic-bovinate-stream'."
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
70 `(if nt-stack
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
71 (car (aref (car nt-stack) 2))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
72 nonterminal))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
73
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
74 (defun semantic-bovinate-nonterminal-check (stream nonterminal)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
75 "Check if STREAM not already parsed for NONTERMINAL.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
76 If so abort because an infinite recursive parse is suspected."
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
77 (or (vectorp semantic-bovinate-nonterminal-check-obarray)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
78 (setq semantic-bovinate-nonterminal-check-obarray
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
79 (make-vector 13 nil)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
80 (let* ((nt (symbol-name nonterminal))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
81 (vs (symbol-value
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
82 (intern-soft
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
83 nt semantic-bovinate-nonterminal-check-obarray))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
84 (if (memq stream vs)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
85 ;; Always enter debugger to see the backtrace
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
86 (let ((debug-on-signal t)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
87 (debug-on-error t))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
88 (setq semantic-bovinate-nonterminal-check-obarray nil)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
89 (error "Infinite recursive parse suspected on %s" nt))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
90 (set (intern nt semantic-bovinate-nonterminal-check-obarray)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
91 (cons stream vs)))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
92
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
93 ;;;###autoload
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
94 (defun semantic-bovinate-stream (stream &optional nonterminal)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
95 "Bovinate STREAM, starting at the first NONTERMINAL rule.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
96 Use `bovine-toplevel' if NONTERMINAL is not provided.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
97 This is the core routine for converting a stream into a table.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
98 Return the list (STREAM SEMANTIC-STREAM) where STREAM are those
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
99 elements of STREAM that have not been used. SEMANTIC-STREAM is the
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
100 list of semantic tokens found."
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
101 (if (not nonterminal)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
102 (setq nonterminal 'bovine-toplevel))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
103
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
104 ;; Try to detect infinite recursive parse when doing a full reparse.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
105 (or semantic--buffer-cache
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
106 (semantic-bovinate-nonterminal-check stream nonterminal))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
107
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
108 (let* ((table semantic--parse-table)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
109 (matchlist (cdr (assq nonterminal table)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
110 (starting-stream stream)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
111 (nt-loop t) ;non-terminal loop condition
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
112 nt-popup ;non-nil if return from nt recursion
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
113 nt-stack ;non-terminal recursion stack
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
114 s ;Temp Stream Tracker
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
115 lse ;Local Semantic Element
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
116 lte ;Local matchlist element
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
117 tev ;Matchlist entry values from buffer
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
118 val ;Value found in buffer.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
119 cvl ;collected values list.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
120 out ;Output
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
121 end ;End of match
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
122 result
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
123 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
124 (condition-case debug-condition
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
125 (while nt-loop
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
126 (catch 'push-non-terminal
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
127 (setq nt-popup nil
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
128 end (semantic-lex-token-end (car stream)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
129 (while (or nt-loop nt-popup)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
130 (setq nt-loop nil
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
131 out nil)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
132 (while (or nt-popup matchlist)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
133 (if nt-popup
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
134 ;; End of a non-terminal recursion
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
135 (setq nt-popup nil)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
136 ;; New matching process
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
137 (setq s stream ;init s from stream.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
138 cvl nil ;re-init the collected value list.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
139 lte (car matchlist) ;Get the local matchlist entry.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
140 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
141 (if (or (byte-code-function-p (car lte))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
142 (listp (car lte)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
143 ;; In this case, we have an EMPTY match! Make
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
144 ;; stuff up.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
145 (setq cvl (list nil))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
146
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
147 (while (and lte
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
148 (not (byte-code-function-p (car lte)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
149 (not (listp (car lte))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
150
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
151 ;; GRAMMAR SOURCE DEBUGGING!
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
152 (if semantic-debug-enabled
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
153 (let* ((db-nt (semantic-bovinate-nonterminal-db-nt))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
154 (db-ml (cdr (assq db-nt table)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
155 (db-mlen (length db-ml))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
156 (db-midx (- db-mlen (length matchlist)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
157 (db-tlen (length (nth db-midx db-ml)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
158 (db-tidx (- db-tlen (length lte)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
159 (frame (semantic-bovine-debug-create-frame
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
160 db-nt db-midx db-tidx cvl (car s)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
161 (cmd (semantic-debug-break frame))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
162 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
163 (cond ((eq 'fail cmd) (setq lte '(trash 0 . 0)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
164 ((eq 'quit cmd) (signal 'quit "Abort"))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
165 ((eq 'abort cmd) (error "Abort"))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
166 ;; support more commands here.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
167
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
168 )))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
169 ;; END GRAMMAR SOURCE DEBUGGING!
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
170
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
171 (cond
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
172 ;; We have a nonterminal symbol. Recurse inline.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
173 ((setq nt-loop (assq (car lte) table))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
174
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
175 (setq
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
176 ;; push state into the nt-stack
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
177 nt-stack (cons (vector matchlist cvl lte stream end
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
178 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
179 nt-stack)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
180 ;; new non-terminal matchlist
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
181 matchlist (cdr nt-loop)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
182 ;; new non-terminal stream
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
183 stream s)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
184
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
185 (throw 'push-non-terminal t)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
186
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
187 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
188 ;; Default case
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
189 (t
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
190 (setq lse (car s) ;Get the local stream element
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
191 s (cdr s)) ;update stream.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
192 ;; Do the compare
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
193 (if (eq (car lte) (semantic-lex-token-class lse)) ;syntactic match
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
194 (let ((valdot (semantic-lex-token-bounds lse)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
195 (setq val (semantic-lex-token-text lse))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
196 (setq lte (cdr lte))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
197 (if (stringp (car lte))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
198 (progn
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
199 (setq tev (car lte)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
200 lte (cdr lte))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
201 (if (string-match tev val)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
202 (setq cvl (cons
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
203 (if (memq (semantic-lex-token-class lse)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
204 '(comment semantic-list))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
205 valdot val)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
206 cvl)) ;append this value
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
207 (setq lte nil cvl nil))) ;clear the entry (exit)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
208 (setq cvl (cons
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
209 (if (memq (semantic-lex-token-class lse)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
210 '(comment semantic-list))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
211 valdot val) cvl))) ;append unchecked value.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
212 (setq end (semantic-lex-token-end lse))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
213 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
214 (setq lte nil cvl nil)) ;No more matches, exit
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
215 )))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
216 (if (not cvl) ;lte=nil; there was no match.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
217 (setq matchlist (cdr matchlist)) ;Move to next matchlist entry
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
218 (let ((start (semantic-lex-token-start (car stream))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
219 (setq out (cond
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
220 ((car lte)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
221 (funcall (car lte) ;call matchlist fn on values
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
222 (nreverse cvl) start end))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
223 ((and (= (length cvl) 1)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
224 (listp (car cvl))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
225 (not (numberp (car (car cvl)))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
226 (append (car cvl) (list start end)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
227 (t
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
228 ;;(append (nreverse cvl) (list start end))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
229 ;; MAYBE THE FOLLOWING NEEDS LESS CONS
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
230 ;; CELLS THAN THE ABOVE?
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
231 (nreverse (cons end (cons start cvl)))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
232 matchlist nil) ;;generate exit condition
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
233 (if (not end)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
234 (setq out nil)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
235 ;; Nothin?
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
236 ))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
237 (setq result
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
238 (if (eq s starting-stream)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
239 (list (cdr s) nil)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
240 (list s out)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
241 (if nt-stack
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
242 ;; pop previous state from the nt-stack
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
243 (let ((state (car nt-stack)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
244
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
245 (setq nt-popup t
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
246 ;; pop actual parser state
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
247 matchlist (aref state 0)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
248 cvl (aref state 1)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
249 lte (aref state 2)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
250 stream (aref state 3)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
251 end (aref state 4)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
252 ;; update the stack
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
253 nt-stack (cdr nt-stack))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
254
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
255 (if out
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
256 (let ((len (length out))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
257 (strip (nreverse (cdr (cdr (reverse out))))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
258 (setq end (nth (1- len) out) ;reset end to the end of exp
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
259 cvl (cons strip cvl) ;prepend value of exp
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
260 lte (cdr lte)) ;update the local table entry
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
261 )
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
262 ;; No value means that we need to terminate this
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
263 ;; match.
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
264 (setq lte nil cvl nil)) ;No match, exit
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
265 )))))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
266 (error
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
267 ;; On error just move forward the stream of lexical tokens
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
268 (setq result (list (cdr starting-stream) nil))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
269 (if semantic-debug-enabled
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
270 (let ((frame (semantic-create-bovine-debug-error-frame
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
271 debug-condition)))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
272 (semantic-debug-break frame)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
273 ))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
274 ))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
275 result))
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
276
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
277 ;; Make it the default parser
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
278 ;;;###autoload
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
279 (defalias 'semantic-parse-stream-default 'semantic-bovinate-stream)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
280
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
281 (provide 'semantic/bovine)
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
282
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
283 ;; Local variables:
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
284 ;; generated-autoload-file: "loaddefs.el"
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
285 ;; generated-autoload-feature: semantic/loaddefs
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
286 ;; generated-autoload-load-name: "semantic/bovine"
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
287 ;; End:
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
288
a19d1a45b823 lisp/cedet/semantic/bovine.el: New file.
Chong Yidong <cyd@stupidchicken.com>
parents:
diff changeset
289 ;;; semantic/bovine.el ends here