;ELC   
;;; Compiled
;;; in Emacs version 29.4
;;; with all optimizations.



(byte-code "\300\301!\210\300\302!\210\300\303!\210\300\304!\210\300\305!\210\300\306!\207" [require semantic semantic/grammar semantic/find semantic/lex semantic/wisent semantic/bovine] 2)#@175 Expand call to EXPAND grammar macro.
Return the form to parse from within a nonterminal between BOUNDS.
NONTERM is the nonterminal symbol to start with.

(fn BOUNDS NONTERM)
(defalias 'bovine-grammar-EXPAND #[514 "\300\301D\302D\303DF\207" [semantic-bovinate-from-nonterminal car cdr quote] 7 (#$ . 274)])#@174 Expand call to EXPANDFULL grammar macro.
Return the form to recursively parse the area between BOUNDS.
NONTERM is the nonterminal symbol to start with.

(fn BOUNDS NONTERM)
(defalias 'bovine-grammar-EXPANDFULL #[514 "\300\301D\302D\303D\304BBBB\207" [semantic-parse-region car cdr quote (1)] 7 (#$ . 589)])#@208 Expand call to TAG grammar macro.
Return the form to create a generic semantic tag.
See the function `semantic-tag' for the meaning of arguments NAME,
CLASS and ATTRIBUTES.

(fn NAME CLASS &rest ATTRIBUTES)
(defalias 'bovine-grammar-TAG #[642 "\300BBB\207" [semantic-tag] 7 (#$ . 905)])#@267 Expand call to VARIABLE-TAG grammar macro.
Return the form to create a semantic tag of class variable.
See the function `semantic-tag-new-variable' for the meaning of
arguments NAME, TYPE, DEFAULT-VALUE and ATTRIBUTES.

(fn NAME TYPE DEFAULT-VALUE &rest ATTRIBUTES)
(defalias 'bovine-grammar-VARIABLE-TAG #[899 "\300BBBB\207" [semantic-tag-new-variable] 9 (#$ . 1201)])#@257 Expand call to FUNCTION-TAG grammar macro.
Return the form to create a semantic tag of class function.
See the function `semantic-tag-new-function' for the meaning of
arguments NAME, TYPE, ARG-LIST and ATTRIBUTES.

(fn NAME TYPE ARG-LIST &rest ATTRIBUTES)
(defalias 'bovine-grammar-FUNCTION-TAG #[899 "\300BBBB\207" [semantic-tag-new-function] 9 (#$ . 1581)])#@260 Expand call to TYPE-TAG grammar macro.
Return the form to create a semantic tag of class type.
See the function `semantic-tag-new-type' for the meaning of arguments
NAME, TYPE, MEMBERS, PARENTS and ATTRIBUTES.

(fn NAME TYPE MEMBERS PARENTS &rest ATTRIBUTES)
(defalias 'bovine-grammar-TYPE-TAG #[1156 "\300BBBBB\207" [semantic-tag-new-type] 11 (#$ . 1951)])#@249 Expand call to INCLUDE-TAG grammar macro.
Return the form to create a semantic tag of class include.
See the function `semantic-tag-new-include' for the meaning of
arguments NAME, SYSTEM-FLAG and ATTRIBUTES.

(fn NAME SYSTEM-FLAG &rest ATTRIBUTES)
(defalias 'bovine-grammar-INCLUDE-TAG #[642 "\300BBB\207" [semantic-tag-new-include] 7 (#$ . 2320)])#@239 Expand call to PACKAGE-TAG grammar macro.
Return the form to create a semantic tag of class package.
See the function `semantic-tag-new-package' for the meaning of
arguments NAME, DETAIL and ATTRIBUTES.

(fn NAME DETAIL &rest ATTRIBUTES)
(defalias 'bovine-grammar-PACKAGE-TAG #[642 "\300BBB\207" [semantic-tag-new-package] 7 (#$ . 2678)])#@230 Expand call to CODE-TAG grammar macro.
Return the form to create a semantic tag of class code.
See the function `semantic-tag-new-code' for the meaning of arguments
NAME, DETAIL and ATTRIBUTES.

(fn NAME DETAIL &rest ATTRIBUTES)
(defalias 'bovine-grammar-CODE-TAG #[642 "\300BBB\207" [semantic-tag-new-code] 7 (#$ . 3026)])#@264 Expand call to ALIAS-TAG grammar macro.
Return the form to create a semantic tag of class alias.
See the function `semantic-tag-new-alias' for the meaning of arguments
NAME, ALIASCLASS, DEFINITION and ATTRIBUTES.

(fn NAME ALIASCLASS DEFINITION &rest ATTRIBUTES)
(defalias 'bovine-grammar-ALIAS-TAG #[899 "\300BBBB\207" [semantic-tag-new-alias] 9 (#$ . 3359)])
(defvar bovine--grammar-macros nil)#@296 Expand FORM into a new one suitable to the bovine parser.
FORM is a list in which we are substituting.
Argument QUOTEMODE is non-nil if we are in backquote mode.
When non-nil, optional argument INPLACE indicates that FORM is being
expanded from elsewhere.

(fn FORM QUOTEMODE &optional INPLACE)
(defalias 'bovine-grammar-expand-form #[770 "@\301=\203R A\262G\302U\203. @<\203. \303c\210\304@\305#\210\306c\210\305\262\305\262\202R G\302U\203L @9\203L \307\310@!\261\210\305\262\305\262\202R \311c\210\312\262@\236\305\211\211\211\211\203m \304\313AA\"	\312#\207\203u \314c\210\203\355@\262A\262	<\203\274 @\315=\204\227 @\316=\203\274 A@<\203\255 \317A\n\"\262	@\262\202\274 \320\310@!\310A@!P!\262\204\325 \204\317 \204\317 \311c\210\312\262\321c\210\202u <\203\363 \204\351 \204\351 \311c\210\312\262\304	\312#\210\202u 9\203\325\310!\262\262\305\262\322H\323=\203=\2034\302H\324=\203(\325\305O\262\305\262\312\262\202=\302\305O\262\305\262\202=\302\305O\262\312\262\326\230\203T\304	@	\312#\210A\262	\202u \322H\327=\203\243\204\243\211\204s\204s\204s\311c\210\202\206\211\203\206\203\206\204\206\306c\210\305\262\330\331\332\302\305O!S!\333\261\210\211\204u \204u \312\262\202u \204\262\204\262\311c\210\312\262\334`Sf\335\"\204\276\336c\210\204\311\312=\203\315\326\202\316\337\261\210\202u \204\344\204\344\311c\210\312\262\340\341\"c\210\202u \203\364\306c\210\205\373\306c\207" [bovine--grammar-macros quote 1 "\n(append" bovine-grammar-expand-form nil ")" "\n'" symbol-name "\n(list" t apply "\n(" \, \,@ append intern " nil" 0 44 64 2 "" 36 "\n(nth " int-to-string string-to-number " vals)" char-equal 40 " " "'" format "\n%S"] 15 (#$ . 3766)])#@140 Expand semantic action string TEXTFORM into Lisp code.
QUOTEMODE is the mode in which quoted symbols are slurred.

(fn TEXTFORM QUOTEMODE)
(defalias 'bovine-grammar-expand-action #[514 "\301\230?\205C \302!\303c\210\211@\304=\203) \305\306\261\210\307\310\304\236AA\"\311#\210\202? \211@<\2037 \211@@\312=\204? \313c\210\307\"\210\314c\262\207" [bovine--grammar-macros "" read "\n" EXPAND ",(lambda (vals start end)" "\n(ignore vals start end)" bovine-grammar-expand-form apply t EVAL ",(semantic-lambda" ")\n"] 7 (#$ . 5568)])#@1331 Return the parser table expression as a string value.
The format of a bovine parser table is:

 ( ( NONTERMINAL-SYMBOL1 MATCH-LIST1 )
   ( NONTERMINAL-SYMBOL2 MATCH-LIST2 )
   ...
   ( NONTERMINAL-SYMBOLn MATCH-LISTn )

Where each NONTERMINAL-SYMBOL is an artificial symbol which can appear
in any child state.  As a starting place, one of the NONTERMINAL-SYMBOLS
must be `bovine-toplevel'.

A MATCH-LIST is a list of possible matches of the form:

 ( STATE-LIST1
   STATE-LIST2
   ...
   STATE-LISTN )

where STATE-LIST is of the form:
  ( TYPE1 [ "VALUE1" ] TYPE2 [ "VALUE2" ] ... LAMBDA )

where TYPE is one of the returned types of the token stream.
VALUE is a value, or range of values to match against.  For
example, a SYMBOL might need to match "foo".  Some TYPES will not
have matching criteria.

LAMBDA is a lambda expression which is evalled with the text of the
type when it is found.  It is passed the list of all buffer text
elements found since the last lambda expression.  It should return a
semantic element (see below.)

For consistency between languages, try to use common return values
from your parser.  Please reference the chapter "Writing Parsers" in
the "Language Support Developer's Guide -" in the semantic texinfo
manual.
Override `semantic-grammar-parsetable-builder' in
`bovine-grammar-mode' buffers.
(defalias 'semantic-grammar-parsetable-builder-bovine-grammar-mode #[0 "\302\303!\304\305\306!\206 \307!\304\305\310!\206 \307!\311p!\312\2036 @\211A@\262\313=\203/ @B\262A\262\202 \211\237\266\202\311p!\312\203[ @\211A@\262\314=\203T @B\262A\262\202> \211\237\266\202\315 \312\211\211\211\211\211\211\211\211	\204w \316\317!\210\202\253 \203\242 A\203\211 \320\321A\"\210\322@!\262\323\"\204\253 \316\324\"\210\202\253 	@\211@\262\262\f\203\305 \322!\262\323\"\204\305 \316\325\"\210\326\327\330\"r\211q\210\331\332\"\216\333 \210\334c\210\335\336\261\210\203\353 \337\340\261\210\n\203 \n@\262\n\341\n!\262		\211@\262\262\n\nA\262	\342\235\203\316\343\"\210\344\n\261\210\203@\345\346\3478\262\"\266\202\262@\350\346\3478\262\"\266\202\262@\351\346\3478\262\"\266\202\262A\262	\344c\210\204q\352\203j\353\202k\354\261\210\202\373\203\373@\262A\262:\203\217\320\355\"\210\202q\356`Sf\357\"\204\233\354c\210\360\235\203\253\316\343\"\210\202q\323\"\262\361\346\3478\262\"\266\202\211\262\203\345c\210\345\346\3478\262\"\266\202\211\262\203q\362\363\"c\210\202q\364	\"\203\366\365\366\367OP\262c\210\202q\203\320\370\"\210\203\371\"\210\372c\210\202\373\n\354\261\210\202\353 \374c\210\375 +\207" [bovine--grammar-macros semantic-grammar-lex-c-char-re semantic-grammar-tag-symbols start intern semantic-grammar-first-tag-name scopestart "nil" quotemode semantic-something-to-tag-table nil token nonterminal semantic-grammar-macros error "Bad input grammar" message "Extra start symbols %S ignored" symbol-name semantic-find-first-tag-by-name "start symbol `%s' has no rule" "scopestart symbol `%s' has no rule" generate-new-buffer " *temp*" t make-closure #[0 "\301\300!\205	 \302\300!\207" [V0 buffer-name kill-buffer] 2] erase-buffer "`(" "\n(bovine-toplevel \n(" ")\n) ;; end bovine-toplevel\n" "\n(bovine-inner-scope \n(" ")\n) ;; end bovine-inner-scope\n" semantic-tag-components-semantic-grammar-mode ("bovine-toplevel" "bovine-inner-scope") "`%s' is a reserved internal name" "\n(" :value plist-get 2 :prec :expr ";;EMPTY" "" "\n" "Mid-rule action %S ignored" char-equal 40 ("bovine-toplevel" "bovine-inner-scope") :type format "\n%S" string-match "?" 1 -1 "%%prec %S ignored" bovine-grammar-expand-action ")" "\n) ;; end " ")\n" buffer-string] 21 (#$ . 6112)])
(byte-code "\300\301\302\303#\210\304\305\306\307#\207" [put semantic-grammar-parsetable-builder-bovine-grammar-mode definition-name semantic-grammar-parsetable-builder mode-local-bind ((semantic-grammar-parsetable-builder . semantic-grammar-parsetable-builder-bovine-grammar-mode)) (override-flag t) bovine-grammar-mode] 4)#@122 Calculate the location of the source for current buffer.
The source directory is relative to some root in the load path.
(defalias 'bovine-grammar-calculate-source-on-path #[0 "\30018 \301\302 \303\"\237\211@A\262\304!\204( \203( @\303Q\262A\262\202 \2043 \305 \266\202\2026 \211\266\2020\207\210\305 \207" [(error) split-string buffer-file-name "/" locate-library buffer-name] 5 (#$ . 10217)])#@116 Return the text of the setup code.
Override `semantic-grammar-setupcode-builder' in `bovine-grammar-mode'
buffers.
(defalias 'semantic-grammar-setupcode-builder-bovine-grammar-mode #[0 "\301\302\303P\304 \305P\306\307!\211<\203  \211G\310V\203  \301\311\"\202! \312\262%\207" [semantic--grammar-package format "(setq semantic--parse-table %s\n          semantic-debug-parser-source %S\n          semantic-debug-parser-class 'semantic-bovine-debug-parser\n          semantic-debug-parser-debugger-source 'semantic/bovine/debug\n          semantic-flex-keywords-obarray %s\n          %s)" "--parse-table" bovine-grammar-calculate-source-on-path "--keyword-table" semantic-grammar-tag-symbols languagemode 1 "semantic-equivalent-major-modes '%S\n" ""] 9 (#$ . 10629)])
(byte-code "\300\301\302\303#\210\304\305\306\307#\207" [put semantic-grammar-setupcode-builder-bovine-grammar-mode definition-name semantic-grammar-setupcode-builder mode-local-bind ((semantic-grammar-setupcode-builder . semantic-grammar-setupcode-builder-bovine-grammar-mode)) (override-flag t) bovine-grammar-mode] 4)#@84 BY mode specific grammar menu.
Menu items are appended to the common grammar menu.
(defvar bovine-grammar-menu '("BY Grammar") (#$ . 11725))
(defvar bovine-grammar-mode-hook nil)
(byte-code "\300\301N\204\f \302\300\301\303#\210\304\305!\204 \302\305\306\307#\210\300\207" [bovine-grammar-mode-hook variable-documentation put "Hook run after entering BY mode.\nNo problems result if this variable is not bound.\n`add-hook' automatically binds it.  (This is true for all hook variables.)" boundp bovine-grammar-mode-map definition-name bovine-grammar-mode] 4)
(defvar bovine-grammar-mode-map (make-sparse-keymap))
(byte-code "\301\302N\204 \303\301\302\304\305!#\210\306\307!\204* \303\307\310\311#\210\312\307\306\307!\203& \313\202( \314 \"\210\307\302N\2048 \303\307\302\304\315!#\210\306\300!\204X \303\300\310\311#\210\312\300\306\300!\203P \313\202V \316\300\313\"\210\"\210\300\302N\204f \303\300\302\304\317!#\210\303\311\320\321#\207" [bovine-grammar-mode-abbrev-table bovine-grammar-mode-map variable-documentation put purecopy "Keymap for `bovine-grammar-mode'." boundp bovine-grammar-mode-syntax-table definition-name bovine-grammar-mode defvar-1 nil make-syntax-table "Syntax table for `bovine-grammar-mode'." define-abbrev-table "Abbrev table for `bovine-grammar-mode'." derived-mode-parent semantic-grammar-mode] 5)#@259 Major mode for editing Bovine grammars.

In addition to any hooks its parent mode `semantic-grammar-mode' might
have run, this mode runs the hook `bovine-grammar-mode-hook', as the
final or penultimate step during initialization.

\{bovine-grammar-mode-map}
(defalias 'bovine-grammar-mode #[0 "\306\300!\210\307\310 \210\311\312\310\313N\203 \314\311\313\310\313N#\210\315!\204' \316\317 \"\210\320\f!\211\2035 \211\321 =\203; \322\f\323 \"\210\210\324\325\"\204R #=\204R \326\325#C#\210\327!\210\330\f!\210#\331\332!\204\224 \333\332\334\335#\210\336\332\317 \335$$\210%A\211\203\223 \337\334\340#\210\211\203\223 \337\334@#\210\211A\262\202\200 \210)\341\342!\207" [delay-mode-hooks major-mode mode-name bovine-grammar-mode-map bovine-grammar-mode-syntax-table bovine-grammar-mode-abbrev-table make-local-variable t semantic-grammar-mode bovine-grammar-mode "BY" mode-class put keymap-parent set-keymap-parent current-local-map char-table-parent standard-syntax-table set-char-table-parent syntax-table abbrev-table-get :parents abbrev-table-put use-local-map set-syntax-table boundp emacs-lisp-mode-menu defvar-1 nil "Grammar Menu" easy-menu-do-define easy-menu-add-item "--" run-mode-hooks bovine-grammar-mode-hook local-abbrev-table semantic-grammar-menu bovine-grammar-menu] 5 (#$ . 13064) nil])
(byte-code "\303\304\305\"\210\306\307\310BC\311\312#\210\313\314\315\"\312\"\266\316\310\312\317!\320\2047 \211\262\2047 	\262\n\2055 \321\n\"\262\203b \211\204b \302N\203Q \321\302N\"\211\262\2047 \211\322N\206[ \211\323N\262\262\2027 \266\203\324\325#\207" [mode-local-active-mode major-mode mode-local-symbol-table add-to-list auto-mode-alist ("\\.by\\'" . bovine-grammar-mode) ((ASSOC . semantic-grammar-ASSOC) (EXPAND . bovine-grammar-EXPAND) (EXPANDFULL . bovine-grammar-EXPANDFULL) (TAG . bovine-grammar-TAG) (VARIABLE-TAG . bovine-grammar-VARIABLE-TAG) (FUNCTION-TAG . bovine-grammar-FUNCTION-TAG) (TYPE-TAG . bovine-grammar-TYPE-TAG) (INCLUDE-TAG . bovine-grammar-INCLUDE-TAG) (PACKAGE-TAG . bovine-grammar-PACKAGE-TAG) (CODE-TAG . bovine-grammar-CODE-TAG) (ALIAS-TAG . bovine-grammar-ALIAS-TAG)) mode-local-bind semantic-grammar-macros (mode-variable-flag t) bovine-grammar-mode mode-local-map-mode-buffers make-closure #[0 "\302\301!\210\300\211\207" [V0 semantic-grammar-macros make-local-variable] 2] put symbol-name nil intern-soft mode-local-parent derived-mode-parent variable-documentation "Semantic grammar macros used in bovine grammars."] 9)#@32 

(fn INFILE &optional OUTDIR)
(defalias 'bovine--make-parser-1 #[513 "\211\203 \302\303!!\262\3041' r\305!q\210\262\211\203 \211\306\307\211\")0\2021 \310\311\312!\"\210\313\262\313\211\211\205\307 \314\315\"\205\307 \316\317\"\262\303\320P\"\262\321\322\307\"\323\324\"\216r\211q\210\325!\210eb\210\326\327!\210\330\224\262\326\331!\210\330\225|\210b\210\332\314\333	\"\203\207 \316\317	\"\202\225 \334\335\230\203\222 \336\202\223 \337Q\340\261\210eb\210e\341 |\210\342\343\344\261\210\345 \210\326\346!\210\347\313\211\211\317%)rq\210\350\313\211\313\330%*\210\262\207" [buffer-file-name default-directory file-name-directory expand-file-name (error) find-file-noselect semantic-grammar-create-package t message "%s" error-message-string nil string-match "^.*/\\(.*\\)-by\\.el\\'" match-string 1 "-by.el" generate-new-buffer " *temp file*" make-closure #[0 "\301\300!\205	 \302\300!\207" [V0 buffer-name kill-buffer] 2] insert-file-contents re-search-forward "^;; Author:" 0 "^;;; Code:\n" ";; This file is part of GNU Emacs.\n\n;; GNU Emacs is free software: you can redistribute it and/or modify\n;; it under the terms of the GNU General Public License as published by\n;; the Free Software Foundation, either version 3 of the License, or\n;; (at your option) any later version.\n\n;; GNU Emacs is distributed in the hope that it will be useful,\n;; but WITHOUT ANY WARRANTY; without even the implied warranty of\n;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n;; GNU General Public License for more details.\n\n;; You should have received a copy of the GNU General Public License\n;; along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.\n\n;;; Commentary:\n;;\n;; This file was generated from " "\\(admin/grammars/.*\\.by\\)\\'" "admin/grammars/" "scm" "scheme" ".by" ".\n\n;;; Code:\n" line-end-position ";;; " " --- Generated parser support file  " "-*- lexical-binding:t -*-" delete-trailing-whitespace ";;; \\(.*\\) ends here" replace-match write-region] 14 (#$ . 15575)])#@54 Generate Emacs's built-in Bovine-based parser files.
(defalias 'bovine-make-parsers #[0 "\301\302!\210\303\304\305#\211\205 \211@\306!\210A\266\202\202	 \207" [default-directory semantic-mode 1 directory-files nil "\\.by\\'" bovine--make-parser-1] 4 (#$ . 17633) nil])#@311 Generate a Bovine parser from input INFILE, writing to OUTDIR.
This is mainly intended for use in batch mode:

emacs -batch -l semantic/bovine/grammar -f bovine-make-parser-batch \
   [-dir output-dir | -o output-file] file.by

If -o is supplied, only the directory part is used.

(fn &optional INFILE OUTDIR)
(defalias 'bovine-batch-make-parser #[512 "\302\303!\210\203A \204A \304	\203@ 	\211A\242\262\211\305\230\203( 	\211A\242\262\202 \211\306\230\203: \307	\211A\242!\262\202 \211\262\202 \210\204I \310\311!\210\312!\204T \310\313\"\210\314\"\207" [noninteractive command-line-args-left semantic-mode 1 nil "-dir" "-o" file-name-directory error "No input file specified" file-readable-p "Input file `%s' not readable" bovine--make-parser-1] 6 (#$ . 17912)])
(provide 'semantic/bovine/grammar)
