[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Emacs-diffs] emacs/doc/misc ChangeLog Makefile.in ede.texi s...
From: |
Chong Yidong |
Subject: |
[Emacs-diffs] emacs/doc/misc ChangeLog Makefile.in ede.texi s... |
Date: |
Mon, 16 Nov 2009 22:25:49 +0000 |
CVSROOT: /sources/emacs
Module name: emacs
Changes by: Chong Yidong <cyd> 09/11/16 22:25:49
Modified files:
doc/misc : ChangeLog Makefile.in ede.texi
Added files:
doc/misc : sem-user.texi semantic.texi
Log message:
* Makefile.in: Build the Semantic manual.
* semantic.texi, sem-user.texi: New files, adapted from the Semantic
repository.
CVSWeb URLs:
http://cvs.savannah.gnu.org/viewcvs/emacs/doc/misc/ChangeLog?cvsroot=emacs&r1=1.337&r2=1.338
http://cvs.savannah.gnu.org/viewcvs/emacs/doc/misc/Makefile.in?cvsroot=emacs&r1=1.17&r2=1.18
http://cvs.savannah.gnu.org/viewcvs/emacs/doc/misc/ede.texi?cvsroot=emacs&r1=1.2&r2=1.3
http://cvs.savannah.gnu.org/viewcvs/emacs/doc/misc/sem-user.texi?cvsroot=emacs&rev=1.1
http://cvs.savannah.gnu.org/viewcvs/emacs/doc/misc/semantic.texi?cvsroot=emacs&rev=1.1
Patches:
Index: ChangeLog
===================================================================
RCS file: /sources/emacs/emacs/doc/misc/ChangeLog,v
retrieving revision 1.337
retrieving revision 1.338
diff -u -b -r1.337 -r1.338
--- ChangeLog 16 Nov 2009 14:29:55 -0000 1.337
+++ ChangeLog 16 Nov 2009 22:25:49 -0000 1.338
@@ -1,3 +1,10 @@
+2009-11-16 Chong Yidong <address@hidden>
+
+ * Makefile.in: Build the Semantic manual.
+
+ * semantic.texi, sem-user.texi: New files, adapted from the Semantic
+ repository.
+
2009-11-16 Michael Albinus <address@hidden>
* dbus.texi (Receiving Method Calls): New defun
Index: Makefile.in
===================================================================
RCS file: /sources/emacs/emacs/doc/misc/Makefile.in,v
retrieving revision 1.17
retrieving revision 1.18
diff -u -b -r1.17 -r1.18
--- Makefile.in 7 Oct 2009 01:10:53 -0000 1.17
+++ Makefile.in 16 Nov 2009 22:25:49 -0000 1.18
@@ -74,6 +74,7 @@
$(infodir)/reftex \
$(infodir)/sasl \
$(infodir)/sc \
+ $(infodir)/semantic \
$(infodir)/ses \
$(infodir)/sieve \
$(infodir)/smtpmail \
@@ -122,6 +123,7 @@
remember.dvi \
sasl.dvi \
sc.dvi \
+ semantic.dvi \
ses.dvi \
sieve.dvi \
smtpmail.dvi \
@@ -383,6 +385,12 @@
sc.dvi: sc.texi
$(ENVADD) $(TEXI2DVI) ${srcdir}/sc.texi
+semantic : $(infodir)/semantic
+$(infodir)/semantic: semantic.texi sem-user.texi
+ cd $(srcdir); $(MAKEINFO) semantic.texi
+semantic.dvi: semantic.texi
+ $(ENVADD) $(TEXI2DVI) ${srcdir}/semantic.texi
+
ses : $(infodir)/ses
$(infodir)/ses: ses.texi
cd $(srcdir); $(MAKEINFO) ses.texi
Index: ede.texi
===================================================================
RCS file: /sources/emacs/emacs/doc/misc/ede.texi,v
retrieving revision 1.2
retrieving revision 1.3
diff -u -b -r1.2 -r1.3
--- ede.texi 24 Oct 2009 21:31:16 -0000 1.2
+++ ede.texi 16 Nov 2009 22:25:49 -0000 1.3
@@ -132,9 +132,9 @@
@node EDE Mode, Creating a project, EDE Project Concepts, top
@chapter @ede{} Mode
address@hidden is implemented as a minor-mode, which augments other modes such
as C
-mode, and Texinfo mode. You can turn @ede{} on for all buffers by running
-the command @code{global-ede-mode}, or by putting this in your
address@hidden is implemented as a minor-mode, which augments other modes such
+as C mode, and Texinfo mode. You can enable @ede{} for all buffers by
+running the command @code{global-ede-mode}, or by putting this in your
@file{~/.emacs} file:
@example
Index: sem-user.texi
===================================================================
RCS file: sem-user.texi
diff -N sem-user.texi
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ sem-user.texi 16 Nov 2009 22:25:49 -0000 1.1
@@ -0,0 +1,787 @@
address@hidden This file is included by semantic.texi
+
address@hidden Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007
address@hidden Free Software Foundation, Inc.
+
address@hidden Permission is granted to copy, distribute and/or modify this
address@hidden document under the terms of the GNU Free Documentation License,
address@hidden Version 1.3 or any later version published by the Free Software
address@hidden Foundation; with no Invariant Sections, no Front-Cover Texts, and
address@hidden no Back-Cover Texts. A copy of the license is included in the
address@hidden section entitled ``GNU Free Documentation License''.
+
+You can begin using @semantic{} by enabling Semantic mode, a global
+minor mode: type @kbd{M-x semantic-mode}, or click on the @samp{Source
+Code Parsers (Semantic)} menu item in the @samp{Tools} menu.
+
+When Semantic mode is turned on, Emacs automatically parses each file
+you visit. This allows you to use @semantic{} user commands in those
+buffers. It also enables a number of ``helper'' minor modes for
+saving tags, displaying tag information, and so forth. @xref{Semantic
+mode}.
+
+To enable Semantic mode each time you start Emacs, add the line
address@hidden(semantic-mode 1)} to your initialization file. @xref{Init
+File,,,emacs,Emacs manual}.
+
address@hidden
+* Semantic mode:: Global minor mode for @semantic{}.
+* SemanticDB:: Caching parsed buffers between sessions.
+* Idle Scheduler:: Performing @semantic{} operations when idle.
address@hidden menu
+
address@hidden Semantic mode
address@hidden Semantic mode
address@hidden Semantic mode
+
+Semantic mode is a global minor mode for @semantic{} as a whole. When
+enabled, each file you visit is automatically parsed, provided its
+major mode is specified in the variable
address@hidden (the default is to parse
+every buffer @semantic{} knows how to parse).
+
+In each parser-enabled buffer, a number of @semantic{} commands are
+available for navigating, querying, and editing source code.
address@hidden mode user commands}. Enabling Semantic mode also
+installs a @samp{Development} menu on the menu-bar, with many of these
+commands.
+
+In addition, enabling Semantic mode turns on certain auxilliary global
+minor modes, as specified by the variable
address@hidden The default auxilliary modes are
+SemanticDB mode (@pxref{SemanticDB}) and Global Semantic Idle
+Scheduler mode. You can also toggle the auxilliary minor modes
+separately, using their mode functions (e.g. @kbd{M-x
+semanticdb-minor-mode}), or via the @samp{Development} menu. These
+auxilliary minor modes are described in the following sections.
+
address@hidden semantic-new-buffer-setup-functions
+The value of this variable is an alist of functions to call for
+setting up @semantic{} parsing in the buffer. Each element has the
+form @code{(@var{mode} . @var{fn})}, where @var{mode} is a value of
address@hidden for the buffer and @var{fn} is the corresponding
+function for setting up the parser. @var{fn} is called, with no
+arguments, after the major mode is initialized (and after the mode
+hooks have been run).
+
+The default value enables @semantic{} for all supported major modes
+(i.e., C, C++, Scheme, Javascript, Java, HTML, SRecode, and Make), but
+you can remove modes from this list if you don't want to use
address@hidden with them.
address@hidden defvar
+
address@hidden semantic-default-submodes
+The value of this variable is a list of symbols, specifying the
+auxilliary minor modes to enable when enabling Semantic mode. The
+valid mode symbols are:
+
address@hidden
address@hidden @code{semantic-idle-scheduler-mode} (@pxref{Idle Scheduler}).
address@hidden @code{semanticdb-minor-mode} (@pxref{SemanticDB}).
address@hidden @code{semantic-idle-summary-mode} (@pxref{Idle Summary Mode}).
address@hidden @code{semantic-idle-completions-mode} (@pxref{Idle Completions
Mode}).
address@hidden @code{semantic-highlight-func-mode}
address@hidden @code{semantic-decoration-mode}
address@hidden @code{semantic-stickyfunc-mode}
address@hidden @code{semantic-mru-bookmark-mode}
address@hidden itemize
address@hidden defvar
+
address@hidden
+* Semantic mode user commands::
address@hidden menu
+
address@hidden Semantic mode user commands
address@hidden Semantic mode user commands
+
+Semantic mode provides a number of commands for navigating, querying,
+and editing source code in a language-aware manner. These commands
+generally act on @dfn{tags}, which are the source-code units deemed
+``important'' by the present programming language (e.g. functions in
+the C programming language).
+
+These commands may be used in any buffer that has been parsed by
address@hidden Several of them prompt for a tag name using the
+minibuffer; here, the @kbd{TAB} key can be used to complete tag names.
+Others act on the @dfn{current tag}, meaning the tag at (or around)
+point.
+
address@hidden @kbd
address@hidden \C-c , j
+Prompt for a tag defined in the current file, and move point to it
+(@code{semantic-complete-jump-local}).
+
address@hidden \C-c , J
+Prompt for a tag defined in any file that Emacs has parsed, and move
+point to it (@code{semantic-complete-jump}).
+
address@hidden \C-c , l
+Display a list of the possible completions of the current tag
+(@code{semantic-analyze-possible-completions}).
+
address@hidden \C-c , g
+Prompt for a tag, and display a list of tags that call it
+(@code{semantic-symref-symbol}).
+
address@hidden \C-c , G
+Display a list of tags that call the current tag
+(@code{semantic-symref}).
+
address@hidden \C-c , p
+Move point to the previous tag (@code{senator-previous-tag}).
+
address@hidden \C-c , n
+Move point to the next tag (@code{senator-next-tag}).
+
address@hidden \C-c , u
+Move point ``up'' one reference (@code{senator-go-to-up-reference}).
+The meaning of ``up'' is language-dependent; in C++, for instance,
+this means moving to the parent of the current tag.
+
address@hidden \C-c, @key{SPC}
+(@code{semantic-complete-analyze-inline})
+
address@hidden \C-c,\C-w
+Kill the current tag (@code{senator-kill-tag}). This removes the text
+for that tag, placing it in the kill ring. You can retrieve the text
+with @kbd{C-y}. This also places the tag in the @dfn{tag ring}, so
+that you can yank it with @kbd{\C-c,\C-y}, below.
+
address@hidden \C-c,\M-w
+Copy the current tag into the kill ring as well as the tag ring
+(@code{senator-copy-tag}).
+
address@hidden \C-c,\C-y
+Yank a tag from the tag ring (@code{senator-yank-tag}).
+
address@hidden \C-c,r
+Copy the current tag into a register
+(@code{senator-copy-tag-to-register}). With an optional argument,
+kill it as well. This allows you to insert or jump to that tag with
+the usual register commands. @xref{Registers,,,emacs,Emacs manual}.
+
address@hidden ?\C-c , @kbd{up}
+Transpose the current tag with the previous one
+(@code{senator-transpose-tags-up}).
+
address@hidden ?\C-c ?, @kbd{down}
+Transpose the current tag with the next one
+(@code{senator-transpose-tags-down}).
address@hidden table
+
address@hidden SemanticDB
address@hidden Semantic Database
address@hidden SemanticDB
+
+The Semantic Database (SemanticDB) caches the results of parsing
+source code files. This data can be saved to disk when you exit
+Emacs, and reloaded automatically when you subsequently revisit the
+same source code files. This saves time by eliminating the need to
+re-parse unmodified files.
+
+SemanticDB also provides an @acronym{API} that programs can use to
+acquire information about source code tags. This information can be
+accessed without loading the original the source files into memory.
+It can also be used to create alternate ``back-ends'' for storing tag
+information in alternative on-disk formats.
+
+By default, SemanticDB is enabled together with Semantic mode. To
+disable it, remove it from @code{semantic-default-submodes}
+(@pxref{Semantic mode}). You can also enable or disable SemanticDB
+with @kbd{M-x global-semanticdb-minor-mode}.
+
address@hidden Command global-semanticdb-minor-mode
+Toggle SemanticDB mode. When enabled, any source code parsed by
address@hidden is cached in a database.
address@hidden deffn
+
+SemanticDB offers a large number of customizable options, which are
+described in the following subsections.
+
address@hidden
+* Semanticdb Tag Storage::
+* Semanticdb Search Configuration::
+* Changing Backends::
+* Script Generated Cache Files::
+* Create System Databases::
address@hidden menu
+
address@hidden Semanticdb Tag Storage
address@hidden Semanticdb Tag Storage
+
+Each time you exit Emacs, any data cached by SemanticDB is saved in
+the directory @file{.emacs.d/semanticdb/}, located in your home
+directory. Within this directory, the cache data is written into a
+set of files according to a SemanticDB-specific filename convention.
+If the SemanticDB directory does not exist, Emacs first asks if you
+want to create it.
+
+You can change the name of the SemanticDB directory by customizing the
+variable @code{semanticdb-default-save-directory}.
+
address@hidden
address@hidden Option semanticdb-default-save-directory
+The name of the directory where SemanticDB cache files are saved. If
+the value is @code{nil}, SemanticDB saves its data into a single file,
+in the current directory, whose filename is given by
address@hidden
address@hidden deffn
+
address@hidden
address@hidden Option semanticdb-default-file-name
+The name of a cache file in which to save SemanticDB, when
address@hidden is @code{nil}.
address@hidden deffn
+
+You can force SemanticDB to save the data from only certain files, or
+suppress saving altogether, by customizing
address@hidden:
+
address@hidden
address@hidden Option semanticdb-persistent-path
+List of valid paths for SemanticDB to cache. Each element should be a
+directory name (a string); then the parse data from any file in that
+directory is saved.
+
+As a special exception, the value of this variable can be a list
+containing a single symbol: @code{never}, @code{always}, or
address@hidden The symbol @code{never} disables saving anywhere;
address@hidden enables saving everywhere; and @code{project} enables
+saving directory based on the variable
address@hidden
+
+The default value is @code{(always)}.
address@hidden deffn
+
address@hidden
address@hidden semanticdb-project-predicate-functions
+The value of this variable is a list of predicates for indicating that
+a directory belongs to a project. This list is used when the value of
address@hidden is @code{(project)}. If the list is
+empty, all paths are considered valid.
+
+Project management packages, such as EDE (@pxref{Top,,,ede,EDE
+manual}), may add their own predicates with @dfn{add-hook} to this
+variable. This allows SemanticDB to save tag caches in directories
+controlled by them.
address@hidden defvar
+
address@hidden
address@hidden Option semanticdb-save-database-hooks
+Abnormal hook run after a database is saved. Each function is called
+with one argument, the object representing the database recently
+written.
address@hidden deffn
+
address@hidden Semanticdb Search Configuration
address@hidden Semanticdb Search Configuration
+
+ When another part of @semantic{} (or another Emacs package using
address@hidden) searches for a tag within SemanticDB, the SemanticDB
+library may perform a search in the locations of the database:
+
address@hidden
address@hidden
+The entries defined by the current file.
address@hidden
+The entries defined by the @dfn{include files} of the current file.
address@hidden
+The entries defined by the include files included from the include
+files (and so on, recursively).
address@hidden enumerate
+
+In C and C++, for instance, include files are defined with the
address@hidden preprocessor directive (SemanticDB tries to
+distinguish between project and system headers, based on the @code{""}
+and @code{<>} filename delimiters). Include directives are matched to
+filenames in the SemanticDB cache using the following criteria:
+
address@hidden
address@hidden
+Whether the file is in the same directory as the current file
address@hidden
+Whether the file is in the same project, as defined by EDE
+(@pxref{Top,,,ede,EDE manual}) or the @code{semanticdb-project-roots}
+variable (@pxref{Semanticdb Roots}).
address@hidden
+Whether the file is in the @dfn{system include path} (@pxref{Include
+paths}).
address@hidden enumerate
+
address@hidden
+* Semanticdb Roots:: Specifying the root of different projects
+* Include paths:: Add/Remove directories to include search paths
+* Search Throttle:: Controlling how semanticdb searches occur
+* Semanticdb search debugging commands::
address@hidden menu
+
address@hidden Semanticdb Roots
address@hidden SemanticDB project roots
+
+Project roots are the ``top-level'' directories for a single code
+project. With the exception of system directories, SemanticDB
+searches are usually limited to the current single code project.
+Therefore, it is helpful to specify the project root if you want
address@hidden tag searches to work correctly.
+
address@hidden
address@hidden Option semanticdb-project-roots
+The value of this variable is a list of directories (strings) that are
+project root. All subdirectories of a project root are considered
+part of the same project. This variable can be overriden by project
+management programs via @code{semanticdb-project-root-functions}.
address@hidden deffn
+
address@hidden
address@hidden semanticdb-project-root-functions
+The value of this variable is a list of functions to determine a given
+directory's project root. These functions are called, one at a time,
+with one argument (the directory name), and must return either
address@hidden, a string (the project root), or a list of strings
+(multiple project roots, for complex systems). The first
address@hidden return value, if any, is taken to be the project root,
+overriding @code{semanticdb-project-roots}.
address@hidden defvar
+
+If you use EDE for project management, it will set
address@hidden automatically.
address@hidden,,,ede,EDE manual}.
+
address@hidden Include paths
address@hidden Include Paths
+
+System include paths are standard locations to find source code tags,
+such as the @dfn{header files} in @file{/usr/include} and its
+subdirectories on Unix-like operating systems. You can add and remove
+system include paths using the following commands:
+
address@hidden
address@hidden Command semantic-add-system-include dir &optional mode
+This command prompts for a directory, @var{dir}, and adds it as a
+system include path for the current major mode. When called
+non-interactively, the major mode can be specified with the @var{mode}
+argument.
address@hidden deffn
+
address@hidden
address@hidden Command semantic-remove-system-include dir &optional mode
+This command prompt for a directory, @var{dir}, and removes it from
+the system include path for the current major mode (or @var{mode}).
address@hidden deffn
+
address@hidden
address@hidden Command semantic-customize-system-include-path &optional mode
+Customize the system include path for the current major mode (or
address@hidden).
address@hidden deffn
+
address@hidden
address@hidden semanticdb-implied-include-tags
+Include tags implied for all files of a given mode. You can set this
+variable with @code{defvar-mode-local} for a particular mode so that
+any symbols that exist for all files for that mode are included.
address@hidden defun
+
address@hidden @xref{Search Optimization}, for more information on include
paths.
+
address@hidden Search Throttle
address@hidden SemanticDB Search Throttle
+
+The SemanticDB search throttle is a variable that may be configured by
+a language support author. If you need to customize this for
+yourself, you may need to override the mode values in a mode support
+hook.
+
address@hidden semanticdb-find-default-throttle
address@hidden
+The default throttle for @code{semanticdb-find} routines.
+The throttle controls how detailed the list of database
+tables is for a symbol lookup. The value is a list with
+the following keys:
+
address@hidden @code
address@hidden file
+The file the search is being performed from. This option is here for
+completeness only, and is assumed to always be on.
address@hidden local
+Tables from the same local directory are included. This includes
+files directly referenced by a file name which might be in a different
+directory.
address@hidden project
+Tables from the same local project are included If @code{project} is
+specified, then @code{local} is assumed.
address@hidden unloaded
+If a table is not in memory, load it. If it is not cached on disk
+either, get the source, parse it, and create the table.
address@hidden system
+Tables from system databases. These are specifically tables
+from system header files, or language equivalent.
address@hidden recursive
+For include based searches, includes tables referenced by included
+files.
address@hidden omniscience
+Included system databases which are omniscience, or somehow know
+everything. Omniscience databases are found in
address@hidden The Emacs Lisp system
address@hidden is an omniscience database.
address@hidden table
+
address@hidden defvar
+
+To set the throttle, use a command like this:
+
address@hidden
+(setq-mode-local c-mode
+ semanticdb-find-default-throttle
+ '(project unloaded system recursive))
address@hidden example
+
+The default value of the throttle is for maximum accuracy at the
+expense of time taken to perform a particular look-up. The throttle
+is tweaked by @code{semantic-idle-summary-mode} to remove 'unloaded,
+thus removing poor speed at unexpected times.
+
address@hidden Semanticdb search debugging commands
address@hidden Semanticdb search debugging commands
+
+You can use @kbd{M-x semanticdb-dump-all-table-summary RET} to see the
+list of databases that will be searched from a given buffer. It
+should include DBs for the directories you expect. You can follow up
+with @kbd{M-x semanticdb-find-test-translate-path RET} to then make
+sure specific tables from the path are discovered correctly.
+
+Alternately, you can get a list of include files @semantic{}
+encountered, but could not find on disk using
address@hidden semanticdb-find-adebug-lost-includes RET}.
+
+Once you have used the below functions to debug the problem, you may
+need to reconfigure how @semantic{} finds include files.
+See @ref{Semanticdb Search Configuration}. If the search config is
+ok, you may need to configure the search throttle. See @ref{Search Throttle}.
+
address@hidden Command semanticdb-dump-all-table-summary
address@hidden
+Dump a list of all databases in Emacs memory.
address@hidden deffn
+
address@hidden Command semanticdb-find-test-translate-path &optional arg
address@hidden
+Call and output results of @dfn{semanticdb-find-translate-path}
+With @var{arg} address@hidden, specify a @var{brutish} translation.
address@hidden deffn
+
address@hidden Command semanticdb-find-adebug-lost-includes
address@hidden
+Translate the current path, then display the lost includes.
+Examines the variable @code{semanticdb-find-lost-includes}.
address@hidden deffn
+
+Lastly, you can test an explicit search term using this command:
+
address@hidden Command semantic-adebug-searchdb regex
address@hidden
+Search the semanticdb for @var{regex} for the current buffer.
+Display the results as a debug list.
address@hidden deffn
+
address@hidden Changing Backends
address@hidden Changing Backends
+
+If you want to use some other form of backend, you can use this
+variable to choose which back end class to use for your general tag
+storage.
+
+The default is to save databases in flat files. Alternatively, you
+could write a new database backend that stores tags into a database,
+or other storage system.
+
address@hidden semanticdb-new-database-class
address@hidden
+The default type of database created for new files.
+This can be changed on a per file basis, so that some directories
+are saved using one mechanism, and some directories via a different
+mechanism.
address@hidden defvar
+
address@hidden Script Generated Cache Files
address@hidden Script Generated Cache Files
+
+You can create new semantic databases with the @file{semanticdb.sh}
+script file. Give this script the directory you want parsed, and it
+will create a cache file for you.
+
address@hidden
+$ semanticdb.sh *.el
address@hidden example
+
+To use these generated tables, you would likely need to restart Emacs.
+
address@hidden Create System Databases
address@hidden Create System Databases
+
+If your supported language stores the system libraries in readily
+available parsable source code, you can pre-generate database files
+for them once, which will be used over and over for tools such as
+summary-mode, or the analyzer.
+
address@hidden Command semanticdb-create-ebrowse-database dir
address@hidden
+Create an @var{ebrowse} database for directory @var{dir}.
+The database file is stored in ~/.semanticdb, or whichever directory
+is specified by @code{semanticdb-default-system-save-directory}.
address@hidden deffn
+
+
address@hidden Idle Scheduler
address@hidden Idle Scheduler
address@hidden Idle Scheduler
+
+The Idle Scheduler in @semantic{} performs multiple duties.
+
+The primary job is to schedule buffer parsing in idle time. The
+first buffer whose cache is checked is the current buffer. After
+this, all other buffers are checked.
+
+Once that has been accomplished, scheduled idle processes that use the
+semantic tag tables are run.
+
address@hidden Command global-semantic-idle-scheduler-mode &optional arg
address@hidden
+Toggle global use of option @dfn{semantic-idle-scheduler-mode}.
+The idle scheduler with automatically reparse buffers in idle time,
+and then schedule other jobs setup with @dfn{semantic-idle-scheduler-add}.
+If @var{ARG} is positive, enable, if it is negative, disable.
+If @var{ARG} is @code{nil}, then toggle.
address@hidden,global-semantic-idle-scheduler-mode}
address@hidden deffn
+
address@hidden, semantic-idle-scheduler-mode}
+
address@hidden Option semantic-idle-scheduler-idle-time
address@hidden
+Time in seconds of idle before scheduling events.
+This time should be short enough to ensure that idle-scheduler will be
+run as soon as Emacs is idle.
address@hidden deffn
+
address@hidden Option semantic-idle-scheduler-mode-hook
address@hidden
+Hook run at the end of function @dfn{semantic-idle-scheduler-mode}.
address@hidden deffn
+
address@hidden Option semantic-idle-scheduler-verbose-flag
address@hidden
address@hidden means that the idle scheduler should provide debug messages.
+Use this setting to debug idle activities.
address@hidden deffn
+
+You can add new functionality to the idle scheduler by reading the
+Application Developers Guide
address@hidden Scheduling, , semantic-appdev.info}.
+
address@hidden
+* Reparsing Options:: Reparsing the current buffer in idle time
+* Idle Working Options:: Options for extra work done at idle time
+* Debugging Idle Time Issues:: How to produce good bug reports.
+* Idle Summary Mode:: Display prototype of symbol under cursor
+* Idle Completions Mode:: Smart completion pop-up help.
address@hidden menu
+
address@hidden Reparsing Options
address@hidden Reparsing Options
+
+The Idle Scheduler will automatically reparse all buffers that need
+it. User input at any time will cancel the operations and return to
+normal editing.
+
address@hidden Option semantic-idle-scheduler-max-buffer-size
address@hidden
+Maximum size in bytes of buffers automatically reparsed.
+If this value is less than or equal to @var{0}, buffers are automatically
+reparsed regardless of their size.
address@hidden deffn
+
address@hidden Option semantic-idle-scheduler-no-working-message
address@hidden
+If address@hidden, disable display of working messages during parse.
address@hidden deffn
+
address@hidden Option semantic-idle-scheduler-working-in-modeline-flag
address@hidden
address@hidden means show working messages in the mode line.
+Typically, parsing will show messages in the minibuffer.
+This will move the parse message into the modeline.
address@hidden deffn
+
address@hidden semantic-before-idle-scheduler-reparse-hooks
address@hidden
+Hooks run before option @code{semantic-idle-scheduler} begins parsing.
+If any hook throws an error, this variable is reset to nil.
+This hook is not protected from lexical errors.
address@hidden defvar
+
address@hidden semantic-after-idle-scheduler-reparse-hooks
address@hidden
+Hooks run after option @code{semantic-idle-scheduler} has parsed.
+If any hook throws an error, this variable is reset to nil.
+This hook is not protected from lexical errors.
address@hidden defvar
+
address@hidden Idle Working Options
address@hidden Idle Working Options
+
+Similiar to the reparsing that occurs at short intervals in idle
+time, there is extra work that can be controlled to occur in idle time
+also.
+
+Idle work occurs after a longer delay, and can be very time
+consuming. The work done includes:
+
address@hidden @asis
address@hidden Create Include Path Caches
+Create the optimized search caches needed for symbol lookup.
address@hidden Create Type Cache
+Create the datatype caches needed for intellisense features.
address@hidden Save Databases
+All file-based @semantic{} databases are saved to disk.
address@hidden Parse neighboring files
+All files in the same directory as the current buffer are
+speculatively parsed.
address@hidden table
+
+These features can be controlled with the following variables:
+
address@hidden Option semantic-idle-scheduler-work-idle-time
address@hidden
+Time in seconds of idle before scheduling big work.
+This time should be long enough that once any big work is started, it is
+unlikely the user would be ready to type again right away.
address@hidden deffn
+
address@hidden Option semantic-idle-work-parse-neighboring-files-flag
address@hidden
address@hidden means to parse files in the same dir as the current buffer.
+Disable to prevent lots of excessive parsing in idle time.
address@hidden deffn
+
address@hidden Debugging Idle Time Issues
address@hidden Debugging Idle Time Issues
+
+If you see errors produced in idle time, it could be an indication of a
+more serious issue elsewhere. It is not enough to enable
address@hidden, as the idle timer tries to keep errors under
+wraps.
+
+Instead, there are two commands you can use whenever you see an idle
+error.
+
address@hidden Command semantic-debug-idle-function
address@hidden
+Run the Semantic idle function with debugging turned on.
address@hidden deffn
+
address@hidden Command semantic-debug-idle-work-function
address@hidden
+Run the Semantic idle work function with debugging turned on.
address@hidden deffn
+
+Once you identify the general location of the idle error, you can send
+the stack trace to the mailing list, or perhaps find a more focused
+way to reproduce the issue.
+
address@hidden Idle Summary Mode
address@hidden Idle Summary Mode
+
+Similar to the Emacs Lisp facility eldoc,
address@hidden will display the prototype, or other
+helpful doc about the symbol currently under point.
+
+
address@hidden semantic-idle-summary-mode &optional arg
address@hidden
+Display a tag summary of the lexical token under the cursor.
+This means for getting the current tag to display information can
+be overriden with @code{idle-summary-current-symbol-info}.
+This is a minor mode which performs actions during idle time.
+With prefix argument ARG, turn on if positive, otherwise off. The
+minor mode can be turned on only if semantic feature is available and
+the current buffer was set up for parsing. Return non-nil if the
+minor mode is enabled
address@hidden deffn
+
address@hidden, semantic-idle-summary-mode}
+
address@hidden Option semantic-idle-summary-function
address@hidden
+Function to use when displaying tag information during idle time.
+Some useful functions are found in @code{semantic-format-tag-functions}.
address@hidden deffn
+
address@hidden semantic-idle-summary-out-of-context-faces
address@hidden
+List of font-lock faces that indicate a useless summary context.
+Those are generally faces used to highlight comments or strings.
+
+It might be useful to override this variable to add comment faces
+specific to a major mode. For example, in jde mode:
+
address@hidden
+(defvar-mode-local jde-mode semantic-idle-summary-out-of-context-faces
+ (append (default-value 'semantic-idle-summary-out-of-context-faces)
+ '(jde-java-font-lock-doc-tag-face
+ jde-java-font-lock-link-face
+ jde-java-font-lock-bold-face
+ jde-java-font-lock-underline-face
+ jde-java-font-lock-pre-face
+ jde-java-font-lock-code-face)))
address@hidden example
+
address@hidden defvar
+
address@hidden Idle Completions Mode
address@hidden Idle Completions Mode
+
+The definition of smart completion is described in the Analyzer
+section @ref{Analyzer}.
+
+The Idle Completions mode will calculate the list of possible
+completions in idle time, and display them in a popup list, or other
+inline completion mechanism.
+
address@hidden semantic-idle-completions-mode &optional arg
address@hidden
+Display a tooltip with a list of possible completions near the cursor.
+There is no convenience for performing a completion replacement. For
+that you should bind @code{semantic-ia-complete-symbol}.
+This is a minor mode which performs actions during idle time.
+With prefix argument ARG, turn on if positive, otherwise off. The
+minor mode can be turned on only if semantic feature is available and
+the current buffer was set up for parsing. Return non-nil if the
+minor mode is enabled
address@hidden deffn
+
+This mode operates by using the command
address@hidden
+
+Idle completion uses the completion function
address@hidden Changing the behavior of
+the idle completion popups should be done through those utilities.
+
address@hidden Command semantic-complete-analyze-inline-idle
address@hidden
+Perform prompt completion to do in buffer completion.
address@hidden is used to determine the
+possible values.
+The function returns immediately, leaving the buffer in a mode that
+will perform the completion.
+Configure @code{semantic-complete-inline-analyzer-idle-displayor-class}
+to change how completion options are displayed.
address@hidden deffn
+
address@hidden Option semantic-complete-inline-analyzer-idle-displayor-class
address@hidden
+Class for displayor to use with inline completion at idle time.
+
+Customize this variable to get a list of options, such as popup
+tooltips, ghosting text, or traditional completion tools.
address@hidden deffn
Index: semantic.texi
===================================================================
RCS file: semantic.texi
diff -N semantic.texi
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ semantic.texi 16 Nov 2009 22:25:49 -0000 1.1
@@ -0,0 +1,638 @@
+\input texinfo
address@hidden ../../info/semantic
address@hidden TITLE Semantic Manual
address@hidden AUTHOR Eric M. Ludlam and David Ponce
address@hidden @value{TITLE}
+
address@hidden
*************************************************************************
address@hidden @ Header
address@hidden
*************************************************************************
+
address@hidden Merge all indexes into a single index for now.
address@hidden We can always separate them later into two or more as needed.
address@hidden vr cp
address@hidden fn cp
address@hidden ky cp
address@hidden pg cp
address@hidden tp cp
+
address@hidden @footnotestyle separate
address@hidden @paragraphindent 2
address@hidden @@smallbook
address@hidden %**end of header
+
address@hidden
+This manual documents the Semantic library and utilities.
+
+Copyright @copyright{} 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007,
+2009 Free Software Foundation, Inc.
+
address@hidden
+Permission is granted to copy, distribute and/or modify this document
+under the terms of the GNU Free Documentation License, Version 1.3 or
+any later version published by the Free Software Foundation; with no
+Invariant Sections, with the Front-Cover texts being ``A GNU Manual,''
+and with the Back-Cover Texts as in (a) below. A copy of the license
+is included in the section entitled ``GNU Free Documentation License.''
+
+(a) The FSF's Back-Cover Text is: ``You have the freedom to copy and
+modify this GNU manual. Buying copies from the FSF supports it in
+developing GNU and promoting software freedom.''
address@hidden quotation
address@hidden copying
+
address@hidden
address@hidden
+START-INFO-DIR-ENTRY
+* Semantic: (semantic). Source code parser library and utilities.
+END-INFO-DIR-ENTRY
address@hidden format
address@hidden ifinfo
+
address@hidden
address@hidden @titlefont{Semantic}
address@hidden 4
address@hidden by @value{AUTHOR}
address@hidden titlepage
address@hidden
+
address@hidden semantic{}
address@hidden
address@hidden macro
+
address@hidden keyword{kw}
address@hidden
address@hidden
address@hidden macro
+
address@hidden obsolete{old,new}
address@hidden 1
address@hidden:
address@hidden introduced in @semantic{} version 2.0 supercedes
address@hidden which is now obsolete.
address@hidden macro
+
address@hidden
*************************************************************************
address@hidden @ Document
address@hidden
*************************************************************************
address@hidden
+
address@hidden top
address@hidden @value{TITLE}
+
address@hidden is a suite of Emacs libraries and utilities for parsing
+source code. At its core is a lexical analyzer and two parser
+generators (@code{bovinator} and @code{wisent}) written in Emacs Lisp.
address@hidden provides a variety of tools for making use of the parser
+output, including user commands for code navigation and completion, as
+well as enhancements for imenu, speedbar, whichfunc, eldoc,
+hippie-expand, and several other parts of Emacs.
+
+To send bug reports, or participate in discussions about semantic,
+use the mailing list cedet-semantic@@sourceforge.net via the URL:
address@hidden://lists.sourceforge.net/lists/listinfo/cedet-semantic}
+
address@hidden
address@hidden
address@hidden ifnottex
+
address@hidden
+* Introduction::
+* Using Semantic::
+* Semantic Internals::
+* Glossary::
+* GNU Free Documentation License::
+* Index::
address@hidden menu
+
address@hidden Introduction
address@hidden Introduction
+
+This chapter gives an overview of @semantic{} and its goals.
+
+Ordinarily, Emacs uses regular expressions (and syntax tables) to
+analyze source code for purposes such as syntax highlighting. This
+approach, though simple and efficient, has its limitations: roughly
+speaking, it only ``guesses'' the meaning of each piece of source code
+in the context of the programming language, instead of rigorously
+``understanding'' it.
+
address@hidden provides a new infrastructure to analyze source code using
address@hidden instead of regular expressions. It contains two
+built-in parser generators (an @acronym{LL} generator named
address@hidden and an @acronym{LALR} generator named @code{Wisent},
+both written in Emacs Lisp), and parsers for several common
+programming languages. It can also make use of @dfn{external
+parsers}---programs such as GNU Global and GNU IDUtils.
+
address@hidden provides a uniform, language-independent @acronym{API} for
+accessing the parser output. This output can be used by other Emacs
+Lisp programs to implement ``syntax-aware'' behavior. @semantic{}
+itself includes several such utilities, including user-level Emacs
+commands for navigating, searching, and completing source code.
+
+The following diagram illustrates the structure of the @semantic{}
+package:
+
address@hidden @strong
address@hidden Please Note:
+The words in all-capital are those that @semantic{} itself provides.
+Others are current or future languages or applications that are not
+distributed along with @semantic{}.
address@hidden table
+
address@hidden
+ Applications
+ and
+ Utilities
+ -------
+ / \
+ +---------------+ +--------+ +--------+
+ C --->| C PARSER |--->| | | |
+ +---------------+ | | | |
+ +---------------+ | COMMON | | COMMON |<--- SPEEDBAR
+ Java --->| JAVA PARSER |--->| PARSE | | |
+ +---------------+ | TREE | | PARSE |<--- SEMANTICDB
+ +---------------+ | FORMAT | | API |<--- ecb
+ Scheme --->| SCHEME PARSER |--->| | | |
+ +---------------+ | | | |
+ +---------------+ | | | |
+ Texinfo --->| TEXI. PARSER |--->| | | |
+ +---------------+ | | | |
+
+ ... ... ... ...
+
+ +---------------+ | | | |<--- app. 1
+ Lang. A --->| A Parser |--->| | | |
+ +---------------+ | | | |<--- app. 2
+ +---------------+ | | | |
+ Lang. B --->| B Parser |--->| | | |<--- app. 3
+ +---------------+ | | | |
+
+ ... ... ... ... ...
+
+ +---------------+ | | | |
+ Lang. Y --->| Y Parser |--->| | | |<--- app. ?
+ +---------------+ | | | |
+ +---------------+ | | | |<--- app. ?
+ Lang. Z --->| Z Parser |--->| | | |
+ +---------------+ +--------+ +--------+
address@hidden example
+
address@hidden
+* Semantic Components::
address@hidden menu
+
address@hidden Semantic Components
address@hidden Semantic Components
+
+In this section, we provide a more detailed description of the major
+components of @semantic{}, and how they interact with one another.
+
+The first step in parsing a source code file is to break it up into
+its fundamental components. This step is called lexical analysis:
+
address@hidden
+ syntax table, keywords list, and options
+ |
+ |
+ v
+ input file ----> Lexer ----> token stream
address@hidden example
+
address@hidden
+The output of the lexical analyzer is a list of tokens that make up
+the file. The next step is the actual parsing, shown below:
+
address@hidden
+ parser tables
+ |
+ v
+ token stream ---> Parser ----> parse tree
address@hidden example
+
address@hidden
+The end result, the parse tree, is @semantic{}'s internal
+representation of the language grammar. @semantic{} provides an
address@hidden for Emacs Lisp programs to access the parse tree.
+
+Parsing large files can take several seconds or more. By default,
address@hidden automatically caches parse trees by saving them in your
address@hidden directory. When you revisit a previously-parsed file,
+the parse tree is automatically reloaded from this cache, to save
+time. @xref{SemanticDB}.
+
address@hidden Using Semantic
address@hidden Using Semantic
+
address@hidden sem-user.texi
+
address@hidden Semantic Internals
address@hidden Semantic Internals
+
+This chapter provides an overview of the internals of @semantic{}.
+This information would not be needed by neither application developers
+nor grammar developers.
+
+It would be useful mostly for the hackers who would like to learn
+more about how @semantic{} works.
+
address@hidden
+* Parser code :: Code used for the parsers
+* Tag handling :: Code used for manipulating tags
+* Semanticdb internals :: Code used in the semantic database
+* Analyzer :: Code used in the code analyzer
+* Tools :: Code used in user tools.
+* Tests :: Code used for testing.
address@hidden menu
+
address@hidden Parser code
address@hidden Parser code
+
address@hidden parsing code is spread across a range of files.
+
address@hidden @file
address@hidden semantic.el
+The core infrastructure sets up buffers for parsing, and has all the
+core parsing routines. Most parsing routines are overloadable, so the
+actual implementation may be somewhere else.
+
address@hidden semantic-edit.el
+Incremental reparse based on user edits.
+
address@hidden semantic-grammar.el
address@hidden semantic-grammar.wy
+Parser for the different grammar languages, and a major mode for
+editing grammars in Emacs.
+
address@hidden semantic-lex.el
+Infrastructure for implementing lexical analyzers. Provides macros
+for creating individual analyzers for specific features, and a way to
+combine them together.
+
address@hidden semantic-lex-spp.el
+Infrastructure for a lexical symbolic preprocessor. This was written
+to implement the C preprocessor, but could be used for other lexical
+preprocessors.
+
address@hidden bovine/bovine-grammar.el
address@hidden bovine/bovine-grammar-macros.el
address@hidden bovine/semantic-bovine.el
+The ``bovine'' grammar. This is the first grammar mode written for
address@hidden and is useful for simple creating simple parsers.
+
address@hidden wisent/wisent.el
address@hidden wisent/bison-wisent.el
address@hidden wisent/semantic-wisent.el
address@hidden wisent/semantic-debug-grammar.el
+A port of bison to Emacs. This infrastructure lets you create LALR
+based parsers for @semantic{}.
+
address@hidden semantic-ast.el
+Manage Abstract Syntax Trees for parsers.
+
address@hidden semantic-debug.el
+Infrastructure for debugging grammars.
+
address@hidden semantic-util.el
+Various utilities for manipulating tags, such as describing the tag
+under point, adding labels, and the all important
address@hidden
+
address@hidden table
+
address@hidden Tag handling
address@hidden Tag handling
+
+A tag represents an individual item found in a buffer, such as a
+function or variable. Tag handling is handled in several source
+files.
+
address@hidden @file
address@hidden semantic-tag.el
+Basic tag creation, queries, cloning, binding, and unbinding.
+
address@hidden semantic-tag-write.el
+Write a tag or tag list to a stream. These routines are used by
address@hidden when saving a list of tags.
+
address@hidden semantic-tag-file.el
+Files associated with tags. Goto-tag, file for include, and file for
+a prototype.
+
address@hidden semantic-tag-ls.el
+Language dependant features of a tag, such as parent calculation, slot
+protection, and other states like abstract, virtual, static, and leaf.
+
address@hidden semantic-dep.el
+Include file handling. Contains the include path concepts, and
+routines for looking up file names in the include path.
+
address@hidden semantic-format.el
+Convert a tag into a nicely formatted and colored string. Use
address@hidden to test different output
+options.
+
address@hidden semantic-find.el
+Find tags matching different conditions in a tag table.
+These routines are used by @file{semanticdb-find.el} once the database
+has been converted into a simpler tag table.
+
address@hidden semantic-sort.el
+Sorting lists of tags in different ways. Includes sorting a plain
+list of tags forward or backward. Includes binning tags based on
+attributes (bucketize), and tag adoption for multiple references to
+the same thing.
+
address@hidden semantic-doc.el
+Capture documentation comments from near a tag.
+
address@hidden table
+
address@hidden Semanticdb internals
address@hidden Semanticdb internals
+
address@hidden complexity is certainly an issue. It is a rather
+hairy problem to try and solve.
+
address@hidden @file
address@hidden semanticdb.el
+Defines a @dfn{database} and a @dfn{table} base class. You can
+instantiate these classes, and use them, but they are not persistent.
+
+This file also provides support for @code{semanticdb-minor-mode},
+which automatically associates files with tables in databases so that
+tags are @emph{saved} while a buffer is not in memory.
+
+The database and tables both also provide applicate cache information,
+and cache flushing system. The semanticdb search routines use caches
+to save datastructures that are complex to calculate.
+
+Lastly, it provides the concept of @dfn{project root}. It is a system
+by which a file can be associated with the root of a project, so if
+you have a tree of directories and source files, it can find the root,
+and allow a tag-search to span all available databases in that
+directory hierarchy.
+
address@hidden semanticdb-file.el
+Provides a subclass of the basic table so that it can be saved to
+disk. Implements all the code needed to unbind/rebind tags to a
+buffer and writing them to a file.
+
address@hidden semanticdb-el.el
+Implements a special kind of @dfn{system} database that uses Emacs
+internals to perform queries.
+
address@hidden semanticdb-ebrowse.el
+Implements a system database that uses Ebrowse to parse files into a
+table that can be queried for tag names. Successful tag hits during a
+find causes @semantic{} to pick up and parse the reference files to
+get the full details.
+
address@hidden semanticdb-find.el
+Infrastructure for searching groups @semantic{} databases, and dealing
+with the search results format.
+
address@hidden semanticdb-ref.el
+Tracks crossreferences. Cross references are needed when buffer is
+reparsed, and must alert other tables that any dependant caches may
+need to be flushed. References are in the form of include files.
+
address@hidden table
+
address@hidden Analyzer
address@hidden Analyzer
+
+The @semantic{} analyzer is a complex engine which has been broken
+down across several modules. When the @semantic{} analyzer fails,
+start with @code{semantic-analyze-debug-assist}, then dive into some
+of these files.
+
address@hidden @file
address@hidden semantic-analyze.el
+The core analyzer for defining the @dfn{current context}. The
+current context is an object that contains references to aspects of
+the local context including the current prefix, and a tag list
+defining what the prefix means.
+
address@hidden semantic-analyze-complete.el
+Provides @code{semantic-analyze-possible-completions}.
+
address@hidden semantic-analyze-debug.el
+The analyzer debugger. Useful when attempting to get everything
+configured.
+
address@hidden semantic-analyze-fcn.el
+Various support functions needed by the analyzer.
+
address@hidden semantic-ctxt.el
+Local context parser. Contains overloadable functions used to move
+around through different scopes, get local variables, and collect the
+current prefix used when doing completion.
+
address@hidden semantic-scope.el
+Calculate @dfn{scope} for a location in a buffer. The scope includes
+local variables, and tag lists in scope for various reasons, such as
+C++ using statements.
+
address@hidden semanticdb-typecache.el
+The typecache is part of @code{semanticdb}, but is used primarilly by
+the analyzer to look up datatypes and complex names. The typecache is
+bound across source files and builds a master lookup table for data
+type names.
+
address@hidden semantic-ia.el
+Interactive Analyzer functions. Simple routines that do completion or
+lookups based on the results from the Analyzer. These routines are
+meant as examples for application writers, but are quite useful as
+they are.
+
address@hidden semantic-ia-sb.el
+Speedbar support for the analyzer, displaying context info, and
+completion lists.
+
address@hidden table
+
address@hidden Tools
address@hidden Tools
+
+These files contain various tools a user can use.
+
address@hidden @file
address@hidden semantic-idle.el
+Idle scheduler for @semantic{}. Manages reparsing buffers after
+edits, and large work tasks in idle time. Includes modes for showing
+summary help and pop-up completion.
+
address@hidden senator.el
+The @semantic{} navigator. Provides many ways to move through a
+buffer based on the active tag table.
+
address@hidden semantic-decorate.el
+A minor mode for decorating tags based on details from the parser.
+Includes overlines for functions, or coloring class fields based on
+protection.
+
address@hidden semantic-decorate-include.el
+A decoration mode for include files, which assists users in setting up
+parsing for their includes.
+
address@hidden semantic-complete.el
+Advanced completion prompts for reading tag names in the minibuffer, or
+inline in a buffer.
+
address@hidden semantic-imenu.el
+Imenu support for using @semantic{} tags in imenu.
+
address@hidden semantic-mru-bookmark.el
+Automatic bookmarking based on tags. Jump to locations you've been
+before based on tag name.
+
address@hidden semantic-sb.el
+Support for @semantic{} tag usage in Speedbar.
+
address@hidden semantic-util-modes.el
+A bunch of small minor-modes that exposes aspects of the semantic
+parser state. Includes @code{semantic-stickyfunc-mode}.
+
address@hidden document.el
address@hidden document-vars.el
+Create an update comments for tags.
+
address@hidden semantic-adebug.el
+Extensions of @file{data-debug.el} for @semantic{}.
+
address@hidden semantic-chart.el
+Draw some charts from stats generated from parsing.
+
+
address@hidden semantic-elp.el
+Profiler for helping to optimize the @semantic{} analyzer.
+
+
address@hidden table
+
address@hidden Tests
address@hidden Tests
+
address@hidden @file
+
address@hidden semantic-utest.el
+Basic testing of parsing and incremental parsing for most supported
+languages.
+
address@hidden semantic-ia-utest.el
+Test the semantic analyzer's ability to provide smart completions.
+
address@hidden semantic-utest-c.el
+Tests for the C parser's lexical pre-processor.
+
address@hidden semantic-regtest.el
+Regression tests from the older Semantic 1.x API.
+
address@hidden table
+
address@hidden Glossary
address@hidden Glossary
+
address@hidden @keyword
address@hidden BNF
+In semantic 1.4, a BNF file represented ``Bovine Normal Form'', the
+grammar file used for the 1.4 parser generator. This was a play on
+Backus-Naur Form which proved too confusing.
+
address@hidden bovinate
+A verb representing what happens when a bovine parser parses a file.
+
address@hidden bovine lambda
+In a bovine, or LL parser, the bovine lambda is a function to execute
+when a specific set of match rules has succeeded in matching text from
+the buffer.
+
address@hidden bovine parser
+A parser using the bovine parser generator. It is an LL parser
+suitible for small simple languages.
+
address@hidden context
+
address@hidden LALR
+
address@hidden lexer
+A program which converts text into a stream of tokens by analyzing
+them lexically. Lexers will commonly create strings, symbols,
+keywords and punctuation, and strip whitespaces and comments.
+
address@hidden LL
+
address@hidden nonterminal
+A nonterminal symbol or simply a nonterminal stands for a class of
+syntactically equivalent groupings. A nonterminal symbol name is used
+in writing grammar rules.
+
address@hidden overloadable
+Some functions are defined via @code{define-overload}.
+These can be overloaded via ....
+
address@hidden parser
+A program that converts @b{tokens} to @b{tags}.
+
address@hidden tag
+A tag is a representation of some entity in a language file, such as a
+function, variable, or include statement. In semantic, the word tag is
+used the same way it is used for the etags or ctags tools.
+
+A tag is usually bound to a buffer region via overlay, or it just
+specifies character locations in a file.
+
address@hidden token
+A single atomic item returned from a lexer. It represents some set
+of characters found in a buffer.
+
address@hidden token stream
+The output of the lexer as well as the input to the parser.
+
address@hidden wisent parser
+A parser using the wisent parser generator. It is a port of bison to
+Emacs Lisp. It is an LALR parser suitable for complex languages.
address@hidden table
+
+
address@hidden GNU Free Documentation License
address@hidden GNU Free Documentation License
address@hidden doclicense.texi
+
address@hidden Index
address@hidden Index
address@hidden cp
+
address@hidden
address@hidden
address@hidden
address@hidden iftex
+
address@hidden
+
address@hidden Following comments are for the benefit of ispell.
+
address@hidden LocalWords: alist API APIs arg argc args argv asis assoc
autoload Wisent
address@hidden LocalWords: backquote bnf bovinate bovinates LALR
address@hidden LocalWords: bovinating bovination bovinator bucketize
address@hidden LocalWords: cb cdr charquote checkcache cindex CLOS
address@hidden LocalWords: concat concocting const constantness ctxt Decl
defcustom
address@hidden LocalWords: deffn deffnx defun defvar destructor's dfn diff dir
address@hidden LocalWords: doc docstring EDE EIEIO elisp emacsman emph enum
address@hidden LocalWords: eq Exp EXPANDFULL expresssion fn foo func funcall
address@hidden LocalWords: ia ids iff ifinfo imenu imenus init int isearch
itemx java kbd
address@hidden LocalWords: keymap keywordtable lang languagemode lexer lexing
Ludlam
address@hidden LocalWords: menubar metaparent metaparents min minibuffer Misc
mode's
address@hidden LocalWords: multitable NAvigaTOR noindent nomedian nonterm
noselect
address@hidden LocalWords: nosnarf obarray OLE OO outputfile paren parsetable
POINT's
address@hidden LocalWords: popup positionalonly positiononly positionormarker
pre
address@hidden LocalWords: printf printindex Programmatically pt punctuations
quotemode
address@hidden LocalWords: ref regex regexp Regexps reparse resetfile samp sb
address@hidden LocalWords: scopestart SEmantic semanticdb setfilename setq
address@hidden LocalWords: settitle setupfunction sexp sp SPC speedbar
speedbar's
address@hidden LocalWords: streamorbuffer struct subalist submenu submenus
address@hidden LocalWords: subsubsection sw sym texi texinfo titlefont titlepage
address@hidden LocalWords: tok TOKEN's toplevel typemodifiers uml unset untar
address@hidden LocalWords: uref usedb var vskip xref yak
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [Emacs-diffs] emacs/doc/misc ChangeLog Makefile.in ede.texi s...,
Chong Yidong <=