Mercurial > emacs
view lisp/cedet/semantic/bovine/scm-by.el @ 112150:14a97ab281d5
* install-sh, mkinstalldirs, move-if-change: Update from master
author | Paul Eggert <eggert@cs.ucla.edu> |
---|---|
date | Fri, 07 Jan 2011 12:42:11 -0800 |
parents | 1d1d5d9bd884 |
children | 376148b31b5e |
line wrap: on
line source
;;; semantic-scm-by.el --- Generated parser support file ;; Copyright (C) 2001, 2003, 2009, 2010 Free Software Foundation, Inc. ;; This file is part of GNU Emacs. ;; GNU Emacs is free software: you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation, either version 3 of the License, or ;; (at your option) any later version. ;; GNU Emacs is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. ;;; Commentary: ;; ;; This file was generated from the grammar file ;; semantic/bovine/scm.by in the CEDET repository. ;;; Code: (require 'semantic/lex) (eval-when-compile (require 'semantic/bovine)) ;;; Prologue ;; ;;; Declarations ;; (defconst semantic-scm-by--keyword-table (semantic-lex-make-keyword-table '(("define" . DEFINE) ("define-module" . DEFINE-MODULE) ("load" . LOAD)) '(("load" summary "Function: (load \"filename\")") ("define-module" summary "Function: (define-module (name arg1 ...)) ") ("define" summary "Function: (define symbol expression)"))) "Table of language keywords.") (defconst semantic-scm-by--token-table (semantic-lex-make-type-table '(("close-paren" (CLOSEPAREN . ")")) ("open-paren" (OPENPAREN . "("))) 'nil) "Table of lexical tokens.") (defconst semantic-scm-by--parse-table `( (bovine-toplevel (scheme) ) ;; end bovine-toplevel (scheme (semantic-list ,(lambda (vals start end) (semantic-bovinate-from-nonterminal (car (nth 0 vals)) (cdr (nth 0 vals)) 'scheme-list)) ) ) ;; end scheme (scheme-list (open-paren "(" scheme-in-list close-paren ")" ,(semantic-lambda (nth 1 vals)) ) ) ;; end scheme-list (scheme-in-list (DEFINE symbol expression ,(semantic-lambda (semantic-tag-new-variable (nth 1 vals) nil (nth 2 vals))) ) (DEFINE name-args opt-doc sequence ,(semantic-lambda (semantic-tag-new-function (car (nth 1 vals)) nil (cdr (nth 1 vals)))) ) (DEFINE-MODULE name-args ,(semantic-lambda (semantic-tag-new-package (nth (length (nth 1 vals)) (nth 1 vals)) nil)) ) (LOAD string ,(semantic-lambda (semantic-tag-new-include (file-name-nondirectory (read (nth 1 vals))) (read (nth 1 vals)))) ) (symbol ,(semantic-lambda (semantic-tag-new-code (nth 0 vals) nil)) ) ) ;; end scheme-in-list (name-args (semantic-list ,(lambda (vals start end) (semantic-bovinate-from-nonterminal (car (nth 0 vals)) (cdr (nth 0 vals)) 'name-arg-expand)) ) ) ;; end name-args (name-arg-expand (open-paren name-arg-expand ,(semantic-lambda (nth 1 vals)) ) (symbol name-arg-expand ,(semantic-lambda (cons (nth 0 vals) (nth 1 vals))) ) ( ;;EMPTY ,(semantic-lambda) ) ) ;; end name-arg-expand (opt-doc (string) ( ;;EMPTY ) ) ;; end opt-doc (sequence (expression sequence) (expression) ) ;; end sequence (expression (symbol) (semantic-list) (string) (number) ) ;; end expression ) "Parser table.") (defun semantic-scm-by--install-parser () "Setup the Semantic Parser." (setq semantic--parse-table semantic-scm-by--parse-table semantic-debug-parser-source "scheme.by" semantic-debug-parser-class 'semantic-bovine-debug-parser semantic-flex-keywords-obarray semantic-scm-by--keyword-table )) (provide 'semantic/bovine/scm-by) ;; arch-tag: 945749cc-a039-434f-bf95-bf2480a506c3 ;;; semantic/bovine/scm-by.el ends here