123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373 |
- (require 'syntax)
- (eval-when-compile (require 'cl))
- (defgroup font-lock '((jit-lock custom-group))
- "Font Lock mode text highlighting package."
- :link '(custom-manual :tag "Emacs Manual" "(emacs)Font Lock")
- :link '(custom-manual :tag "Elisp Manual" "(elisp)Font Lock Mode")
- :group 'faces)
- (defgroup font-lock-faces nil
- "Faces for highlighting text."
- :prefix "font-lock-"
- :group 'font-lock)
- (defgroup font-lock-extra-types nil
- "Extra mode-specific type names for highlighting declarations."
- :group 'font-lock)
- (defcustom font-lock-maximum-size 256000
- "Maximum buffer size for unsupported buffer fontification.
- When `font-lock-support-mode' is nil, only buffers smaller than
- this are fontified. This variable has no effect if a Font Lock
- support mode (usually `jit-lock-mode') is enabled.
- If nil, means size is irrelevant.
- If a list, each element should be a cons pair of the form (MAJOR-MODE . SIZE),
- where MAJOR-MODE is a symbol or t (meaning the default). For example:
- ((c-mode . 256000) (c++-mode . 256000) (rmail-mode . 1048576))
- means that the maximum size is 250K for buffers in C or C++ modes, one megabyte
- for buffers in Rmail mode, and size is irrelevant otherwise."
- :type '(choice (const :tag "none" nil)
- (integer :tag "size")
- (repeat :menu-tag "mode specific" :tag "mode specific"
- :value ((t . nil))
- (cons :tag "Instance"
- (radio :tag "Mode"
- (const :tag "all" t)
- (symbol :tag "name"))
- (radio :tag "Size"
- (const :tag "none" nil)
- (integer :tag "size")))))
- :group 'font-lock)
- (make-obsolete-variable 'font-lock-maximum-size nil "24.1")
- (defcustom font-lock-maximum-decoration t
- "Maximum decoration level for fontification.
- If nil, use the default decoration (typically the minimum available).
- If t, use the maximum decoration available.
- If a number, use that level of decoration (or if not available the maximum).
- The higher the number, the more decoration is done.
- If a list, each element should be a cons pair of the form (MAJOR-MODE . LEVEL),
- where MAJOR-MODE is a symbol or t (meaning the default). For example:
- ((c-mode . t) (c++-mode . 2) (t . 1))
- means use the maximum decoration available for buffers in C mode, level 2
- decoration for buffers in C++ mode, and level 1 decoration otherwise."
- :type '(choice (const :tag "default" nil)
- (const :tag "maximum" t)
- (integer :tag "level" 1)
- (repeat :menu-tag "mode specific" :tag "mode specific"
- :value ((t . t))
- (cons :tag "Instance"
- (radio :tag "Mode"
- (const :tag "all" t)
- (symbol :tag "name"))
- (radio :tag "Decoration"
- (const :tag "default" nil)
- (const :tag "maximum" t)
- (integer :tag "level" 1)))))
- :group 'font-lock)
- (defcustom font-lock-verbose nil
- "If non-nil, means show status messages for buffer fontification.
- If a number, only buffers greater than this size have fontification messages."
- :type '(choice (const :tag "never" nil)
- (other :tag "always" t)
- (integer :tag "size"))
- :group 'font-lock
- :version "24.1")
- (defvar font-lock-comment-face 'font-lock-comment-face
- "Face name to use for comments.")
- (defvar font-lock-comment-delimiter-face 'font-lock-comment-delimiter-face
- "Face name to use for comment delimiters.")
- (defvar font-lock-string-face 'font-lock-string-face
- "Face name to use for strings.")
- (defvar font-lock-doc-face 'font-lock-doc-face
- "Face name to use for documentation.")
- (defvar font-lock-keyword-face 'font-lock-keyword-face
- "Face name to use for keywords.")
- (defvar font-lock-builtin-face 'font-lock-builtin-face
- "Face name to use for builtins.")
- (defvar font-lock-function-name-face 'font-lock-function-name-face
- "Face name to use for function names.")
- (defvar font-lock-variable-name-face 'font-lock-variable-name-face
- "Face name to use for variable names.")
- (defvar font-lock-type-face 'font-lock-type-face
- "Face name to use for type and class names.")
- (defvar font-lock-constant-face 'font-lock-constant-face
- "Face name to use for constant and label names.")
- (defvar font-lock-warning-face 'font-lock-warning-face
- "Face name to use for things that should stand out.")
- (defvar font-lock-negation-char-face 'font-lock-negation-char-face
- "Face name to use for easy to overlook negation.
- This can be an \"!\" or the \"n\" in \"ifndef\".")
- (defvar font-lock-preprocessor-face 'font-lock-preprocessor-face
- "Face name to use for preprocessor directives.")
- (defvar font-lock-reference-face 'font-lock-constant-face)
- (make-obsolete-variable 'font-lock-reference-face 'font-lock-constant-face "20.3")
- (defvar font-lock-keywords nil
- "A list of the keywords to highlight.
- There are two kinds of values: user-level, and compiled.
- A user-level keywords list is what a major mode or the user would
- set up. Normally the list would come from `font-lock-defaults'.
- through selection of a fontification level and evaluation of any
- contained expressions. You can also alter it by calling
- `font-lock-add-keywords' or `font-lock-remove-keywords' with MODE = nil.
- Each element in a user-level keywords list should have one of these forms:
- MATCHER
- (MATCHER . SUBEXP)
- (MATCHER . FACENAME)
- (MATCHER . HIGHLIGHT)
- (MATCHER HIGHLIGHT ...)
- (eval . FORM)
- where MATCHER can be either the regexp to search for, or the function name to
- call to make the search (called with one argument, the limit of the search;
- it should return non-nil, move point, and set `match-data' appropriately if
- it succeeds; like `re-search-forward' would).
- MATCHER regexps can be generated via the function `regexp-opt'.
- FORM is an expression, whose value should be a keyword element, evaluated when
- the keyword is (first) used in a buffer. This feature can be used to provide a
- keyword that can only be generated when Font Lock mode is actually turned on.
- HIGHLIGHT should be either MATCH-HIGHLIGHT or MATCH-ANCHORED.
- For highlighting single items, for example each instance of the word \"foo\",
- typically only MATCH-HIGHLIGHT is required.
- However, if an item or (typically) items are to be highlighted following the
- instance of another item (the anchor), for example each instance of the
- word \"bar\" following the word \"anchor\" then MATCH-ANCHORED may be required.
- MATCH-HIGHLIGHT should be of the form:
- (SUBEXP FACENAME [OVERRIDE [LAXMATCH]])
- SUBEXP is the number of the subexpression of MATCHER to be highlighted.
- FACENAME is an expression whose value is the face name to use.
- Instead of a face, FACENAME can evaluate to a property list
- of the form (face FACE PROP1 VAL1 PROP2 VAL2 ...)
- in which case all the listed text-properties will be set rather than
- just FACE. In such a case, you will most likely want to put those
- properties in `font-lock-extra-managed-props' or to override
- `font-lock-unfontify-region-function'.
- OVERRIDE and LAXMATCH are flags. If OVERRIDE is t, existing fontification can
- be overwritten. If `keep', only parts not already fontified are highlighted.
- If `prepend' or `append', existing fontification is merged with the new, in
- which the new or existing fontification, respectively, takes precedence.
- If LAXMATCH is non-nil, that means don't signal an error if there is
- no match for SUBEXP in MATCHER.
- For example, an element of the form highlights (if not already highlighted):
- \"\\\\\\=<foo\\\\\\=>\" discrete occurrences of \"foo\" in the value of the
- variable `font-lock-keyword-face'.
- (\"fu\\\\(bar\\\\)\" . 1) substring \"bar\" within all occurrences of \"fubar\" in
- the value of `font-lock-keyword-face'.
- (\"fubar\" . fubar-face) Occurrences of \"fubar\" in the value of `fubar-face'.
- (\"foo\\\\|bar\" 0 foo-bar-face t)
- occurrences of either \"foo\" or \"bar\" in the value
- of `foo-bar-face', even if already highlighted.
- (fubar-match 1 fubar-face)
- the first subexpression within all occurrences of
- whatever the function `fubar-match' finds and matches
- in the value of `fubar-face'.
- MATCH-ANCHORED should be of the form:
- (MATCHER PRE-MATCH-FORM POST-MATCH-FORM MATCH-HIGHLIGHT ...)
- where MATCHER is a regexp to search for or the function name to call to make
- the search, as for MATCH-HIGHLIGHT above, but with one exception; see below.
- PRE-MATCH-FORM and POST-MATCH-FORM are evaluated before the first, and after
- the last, instance MATCH-ANCHORED's MATCHER is used. Therefore they can be
- used to initialize before, and cleanup after, MATCHER is used. Typically,
- PRE-MATCH-FORM is used to move to some position relative to the original
- MATCHER, before starting with MATCH-ANCHORED's MATCHER. POST-MATCH-FORM might
- be used to move back, before resuming with MATCH-ANCHORED's parent's MATCHER.
- For example, an element of the form highlights (if not already highlighted):
- (\"\\\\\\=<anchor\\\\\\=>\" (0 anchor-face) (\"\\\\\\=<item\\\\\\=>\" nil nil (0 item-face)))
- discrete occurrences of \"anchor\" in the value of `anchor-face', and subsequent
- discrete occurrences of \"item\" (on the same line) in the value of `item-face'.
- (Here PRE-MATCH-FORM and POST-MATCH-FORM are nil. Therefore \"item\" is
- initially searched for starting from the end of the match of \"anchor\", and
- searching for subsequent instances of \"anchor\" resumes from where searching
- for \"item\" concluded.)
- The above-mentioned exception is as follows. The limit of the MATCHER search
- defaults to the end of the line after PRE-MATCH-FORM is evaluated.
- However, if PRE-MATCH-FORM returns a position greater than the position after
- PRE-MATCH-FORM is evaluated, that position is used as the limit of the search.
- It is generally a bad idea to return a position greater than the end of the
- line, i.e., cause the MATCHER search to span lines.
- These regular expressions can match text which spans lines, although
- it is better to avoid it if possible since updating them while editing
- text is slower, and it is not guaranteed to be always correct when using
- support modes like jit-lock or lazy-lock.
- This variable is set by major modes via the variable `font-lock-defaults'.
- Be careful when composing regexps for this list; a poorly written pattern can
- dramatically slow things down!
- A compiled keywords list starts with t. It is produced internal
- by `font-lock-compile-keywords' from a user-level keywords list.
- Its second element is the user-level keywords list that was
- compiled. The remaining elements have the same form as
- user-level keywords, but normally their values have been
- optimized.")
- (defvar font-lock-keywords-alist nil
- "Alist of additional `font-lock-keywords' elements for major modes.
- Each element has the form (MODE KEYWORDS . HOW).
- `font-lock-set-defaults' adds the elements in the list KEYWORDS to
- `font-lock-keywords' when Font Lock is turned on in major mode MODE.
- If HOW is nil, KEYWORDS are added at the beginning of
- `font-lock-keywords'. If it is `set', they are used to replace the
- value of `font-lock-keywords'. If HOW is any other non-nil value,
- they are added at the end.
- This is normally set via `font-lock-add-keywords' and
- `font-lock-remove-keywords'.")
- (put 'font-lock-keywords-alist 'risky-local-variable t)
- (defvar font-lock-removed-keywords-alist nil
- "Alist of `font-lock-keywords' elements to be removed for major modes.
- Each element has the form (MODE . KEYWORDS). `font-lock-set-defaults'
- removes the elements in the list KEYWORDS from `font-lock-keywords'
- when Font Lock is turned on in major mode MODE.
- This is normally set via `font-lock-add-keywords' and
- `font-lock-remove-keywords'.")
- (defvar font-lock-keywords-only nil
- "*Non-nil means Font Lock should not fontify comments or strings.
- This is normally set via `font-lock-defaults'.")
- (defvar font-lock-keywords-case-fold-search nil
- "*Non-nil means the patterns in `font-lock-keywords' are case-insensitive.
- This is set via the function `font-lock-set-defaults', based on
- the CASE-FOLD argument of `font-lock-defaults'.")
- (make-variable-buffer-local 'font-lock-keywords-case-fold-search)
- (defvar font-lock-syntactically-fontified 0
- "Point up to which `font-lock-syntactic-keywords' has been applied.
- If nil, this is ignored, in which case the syntactic fontification may
- sometimes be slightly incorrect.")
- (make-variable-buffer-local 'font-lock-syntactically-fontified)
- (defvar font-lock-syntactic-face-function
- (lambda (state)
- (if (nth 3 state) font-lock-string-face font-lock-comment-face))
- "Function to determine which face to use when fontifying syntactically.
- The function is called with a single parameter (the state as returned by
- `parse-partial-sexp' at the beginning of the region to highlight) and
- should return a face. This is normally set via `font-lock-defaults'.")
- (defvar font-lock-syntactic-keywords nil
- "A list of the syntactic keywords to put syntax properties on.
- The value can be the list itself, or the name of a function or variable
- whose value is the list.
- See `font-lock-keywords' for a description of the form of this list;
- only the differences are stated here. MATCH-HIGHLIGHT should be of the form:
- (SUBEXP SYNTAX OVERRIDE LAXMATCH)
- where SYNTAX can be a string (as taken by `modify-syntax-entry'), a syntax
- table, a cons cell (as returned by `string-to-syntax') or an expression whose
- value is such a form. OVERRIDE cannot be `prepend' or `append'.
- Here are two examples of elements of `font-lock-syntactic-keywords'
- and what they do:
- (\"\\\\$\\\\(#\\\\)\" 1 \".\")
- gives a hash character punctuation syntax (\".\") when following a
- dollar-sign character. Hash characters in other contexts will still
- follow whatever the syntax table says about the hash character.
- (\"\\\\('\\\\).\\\\('\\\\)\"
- (1 \"\\\"\")
- (2 \"\\\"\"))
- gives a pair single-quotes, which surround a single character, a SYNTAX of
- \"\\\"\" (meaning string quote syntax). Single-quote characters in other
- contexts will not be affected.
- This is normally set via `font-lock-defaults'.")
- (make-obsolete-variable 'font-lock-syntactic-keywords
- 'syntax-propertize-function "24.1")
- (defvar font-lock-syntax-table nil
- "Non-nil means use this syntax table for fontifying.
- If this is nil, the major mode's syntax table is used.
- This is normally set via `font-lock-defaults'.")
- (defvar font-lock-beginning-of-syntax-function nil
- "*Non-nil means use this function to move back outside all constructs.
- When called with no args it should move point backward to a place which
- is not in a string or comment and not within any bracket-pairs (or else,
- a place such that any bracket-pairs outside it can be ignored for Emacs
- syntax analysis and fontification).
- If this is nil, Font Lock uses `syntax-begin-function' to move back
- outside of any comment, string, or sexp. This variable is semi-obsolete;
- we recommend setting `syntax-begin-function' instead.
- This is normally set via `font-lock-defaults'.")
- (make-obsolete-variable 'font-lock-beginning-of-syntax-function
- 'syntax-begin-function "23.3" 'set)
- (defvar font-lock-mark-block-function nil
- "*Non-nil means use this function to mark a block of text.
- When called with no args it should leave point at the beginning of any
- enclosing textual block and mark at the end.
- This is normally set via `font-lock-defaults'.")
- (defvar font-lock-fontify-buffer-function 'font-lock-default-fontify-buffer
- "Function to use for fontifying the buffer.
- This is normally set via `font-lock-defaults'.")
- (defvar font-lock-unfontify-buffer-function 'font-lock-default-unfontify-buffer
- "Function to use for unfontifying the buffer.
- This is used when turning off Font Lock mode.
- This is normally set via `font-lock-defaults'.")
- (defvar font-lock-fontify-region-function 'font-lock-default-fontify-region
- "Function to use for fontifying a region.
- It should take two args, the beginning and end of the region, and an optional
- third arg VERBOSE. If VERBOSE is non-nil, the function should print status
- messages. This is normally set via `font-lock-defaults'.")
- (defvar font-lock-unfontify-region-function 'font-lock-default-unfontify-region
- "Function to use for unfontifying a region.
- It should take two args, the beginning and end of the region.
- This is normally set via `font-lock-defaults'.")
- (defvar font-lock-inhibit-thing-lock nil
- "List of Font Lock mode related modes that should not be turned on.
- Currently, valid mode names are `fast-lock-mode', `jit-lock-mode' and
- `lazy-lock-mode'. This is normally set via `font-lock-defaults'.")
- (defvar font-lock-multiline nil
- "Whether font-lock should cater to multiline keywords.
- If nil, don't try to handle multiline patterns.
- If t, always handle multiline patterns.
- If `undecided', don't try to handle multiline patterns until you see one.
- Major/minor modes can set this variable if they know which option applies.")
- (defvar font-lock-fontified nil)
- (eval-when-compile
-
-
- (require 'cl)
-
-
-
- (defmacro save-buffer-state (&rest body)
- "Bind variables according to VARLIST and eval BODY restoring buffer state."
- (declare (indent 0) (debug t))
- `(let ((inhibit-point-motion-hooks t))
- (with-silent-modifications
- ,@body)))
-
-
- (defvar font-lock-face-attributes))
- (defun font-lock-specified-p (mode)
- "Return non-nil if the current buffer is ready for fontification.
- The MODE argument, if non-nil, means Font Lock mode is about to
- be enabled."
- (or font-lock-defaults
- (and (boundp 'font-lock-keywords)
- font-lock-keywords)
- (and mode
- (boundp 'font-lock-set-defaults)
- font-lock-set-defaults
- font-lock-major-mode
- (not (eq font-lock-major-mode major-mode)))))
- (defun font-lock-initial-fontify ()
-
-
- (when (and font-lock-mode
- (font-lock-specified-p t))
- (let ((max-size (font-lock-value-in-major-mode font-lock-maximum-size)))
- (cond (font-lock-fontified
- nil)
- ((or (null max-size) (> max-size (buffer-size)))
- (font-lock-fontify-buffer))
- (font-lock-verbose
- (message "Fontifying %s...buffer size greater than font-lock-maximum-size"
- (buffer-name)))))))
- (defun font-lock-mode-internal (arg)
-
- (when arg
- (add-hook 'after-change-functions 'font-lock-after-change-function t t)
- (font-lock-set-defaults)
- (font-lock-turn-on-thing-lock))
-
- (unless font-lock-mode
- (remove-hook 'after-change-functions 'font-lock-after-change-function t)
- (font-lock-unfontify-buffer)
- (font-lock-turn-off-thing-lock)))
- (defun font-lock-add-keywords (mode keywords &optional how)
- "Add highlighting KEYWORDS for MODE.
- MODE should be a symbol, the major mode command name, such as `c-mode'
- or nil. If nil, highlighting keywords are added for the current buffer.
- KEYWORDS should be a list; see the variable `font-lock-keywords'.
- By default they are added at the beginning of the current highlighting list.
- If optional argument HOW is `set', they are used to replace the current
- highlighting list. If HOW is any other non-nil value, they are added at the
- end of the current highlighting list.
- For example:
- (font-lock-add-keywords 'c-mode
- '((\"\\\\\\=<\\\\(FIXME\\\\):\" 1 font-lock-warning-face prepend)
- (\"\\\\\\=<\\\\(and\\\\|or\\\\|not\\\\)\\\\\\=>\" . font-lock-keyword-face)))
- adds two fontification patterns for C mode, to fontify `FIXME:' words, even in
- comments, and to fontify `and', `or' and `not' words as keywords.
- The above procedure will only add the keywords for C mode, not
- for modes derived from C mode. To add them for derived modes too,
- pass nil for MODE and add the call to c-mode-hook.
- For example:
- (add-hook 'c-mode-hook
- (lambda ()
- (font-lock-add-keywords nil
- '((\"\\\\\\=<\\\\(FIXME\\\\):\" 1 font-lock-warning-face prepend)
- (\"\\\\\\=<\\\\(and\\\\|or\\\\|not\\\\)\\\\\\=>\" .
- font-lock-keyword-face)))))
- The above procedure may fail to add keywords to derived modes if
- some involved major mode does not follow the standard conventions.
- File a bug report if this happens, so the major mode can be corrected.
- Note that some modes have specialized support for additional patterns, e.g.,
- see the variables `c-font-lock-extra-types', `c++-font-lock-extra-types',
- `objc-font-lock-extra-types' and `java-font-lock-extra-types'."
- (cond (mode
-
-
- (let ((spec (cons keywords how)) cell)
- (if (setq cell (assq mode font-lock-keywords-alist))
- (if (eq how 'set)
- (setcdr cell (list spec))
- (setcdr cell (append (cdr cell) (list spec))))
- (push (list mode spec) font-lock-keywords-alist)))
-
-
- (font-lock-update-removed-keyword-alist mode keywords how))
- (t
- (when (and font-lock-mode
- (not (or font-lock-keywords font-lock-defaults)))
-
-
-
- (font-lock-mode -1)
- (set (make-local-variable 'font-lock-defaults) '(nil t))
- (font-lock-mode 1))
-
-
-
- (font-lock-set-defaults)
- (let ((was-compiled (eq (car font-lock-keywords) t)))
-
- (if was-compiled
- (setq font-lock-keywords (cadr font-lock-keywords)))
-
- (if (eq how 'set)
- (setq font-lock-keywords keywords)
- (font-lock-remove-keywords nil keywords)
- (let ((old (if (eq (car-safe font-lock-keywords) t)
- (cdr font-lock-keywords)
- font-lock-keywords)))
- (setq font-lock-keywords (if how
- (append old keywords)
- (append keywords old)))))
-
- (if was-compiled
- (setq font-lock-keywords
- (font-lock-compile-keywords font-lock-keywords)))))))
- (defun font-lock-update-removed-keyword-alist (mode keywords how)
- "Update `font-lock-removed-keywords-alist' when adding new KEYWORDS to MODE."
-
-
-
-
-
-
- (let ((cell (assq mode font-lock-removed-keywords-alist)))
- (if cell
- (if (eq how 'set)
-
-
- (setq font-lock-removed-keywords-alist
- (delq cell font-lock-removed-keywords-alist))
-
- (dolist (kword keywords)
- (setcdr cell (delete kword (cdr cell))))
-
- (if (null (cdr cell))
- (setq font-lock-removed-keywords-alist
- (delq cell font-lock-removed-keywords-alist)))))))
- (defun font-lock-remove-keywords (mode keywords)
- "Remove highlighting KEYWORDS for MODE.
- MODE should be a symbol, the major mode command name, such as `c-mode'
- or nil. If nil, highlighting keywords are removed for the current buffer.
- To make the removal apply to modes derived from MODE as well,
- pass nil for MODE and add the call to MODE-hook. This may fail
- for some derived modes if some involved major mode does not
- follow the standard conventions. File a bug report if this
- happens, so the major mode can be corrected."
- (cond (mode
-
- (dolist (keyword keywords)
- (let ((top-cell (assq mode font-lock-keywords-alist)))
-
-
- (when top-cell
- (dolist (keyword-list-how-pair (cdr top-cell))
-
-
-
- (setcar keyword-list-how-pair
- (delete keyword (car keyword-list-how-pair))))
-
-
-
-
- (let ((cell top-cell))
- (while (cdr cell)
- (if (and (null (car (car (cdr cell))))
- (not (eq (cdr (car (cdr cell))) 'set)))
- (setcdr cell (cdr (cdr cell)))
- (setq cell (cdr cell)))))
-
-
- (if (null (cdr top-cell))
- (setq font-lock-keywords-alist
- (delq top-cell font-lock-keywords-alist))))
-
- (let ((cell (assq mode font-lock-removed-keywords-alist)))
- (if cell
- (unless (member keyword (cdr cell))
- (nconc cell (list keyword)))
- (push (cons mode (list keyword))
- font-lock-removed-keywords-alist))))))
- (t
-
- (font-lock-set-defaults)
- (let ((was-compiled (eq (car font-lock-keywords) t)))
-
- (if was-compiled
- (setq font-lock-keywords (cadr font-lock-keywords)))
-
- (setq font-lock-keywords (copy-sequence font-lock-keywords))
- (dolist (keyword keywords)
- (setq font-lock-keywords
- (delete keyword font-lock-keywords)))
-
- (if was-compiled
- (setq font-lock-keywords
- (font-lock-compile-keywords font-lock-keywords)))))))
- (defcustom font-lock-support-mode 'jit-lock-mode
- "Support mode for Font Lock mode.
- Support modes speed up Font Lock mode by being choosy about when fontification
- occurs. The default support mode, Just-in-time Lock mode (symbol
- `jit-lock-mode'), is recommended.
- Other, older support modes are Fast Lock mode (symbol `fast-lock-mode') and
- Lazy Lock mode (symbol `lazy-lock-mode'). See those modes for more info.
- However, they are no longer recommended, as Just-in-time Lock mode is better.
- If nil, means support for Font Lock mode is never performed.
- If a symbol, use that support mode.
- If a list, each element should be of the form (MAJOR-MODE . SUPPORT-MODE),
- where MAJOR-MODE is a symbol or t (meaning the default). For example:
- ((c-mode . fast-lock-mode) (c++-mode . fast-lock-mode) (t . lazy-lock-mode))
- means that Fast Lock mode is used to support Font Lock mode for buffers in C or
- C++ modes, and Lazy Lock mode is used to support Font Lock mode otherwise.
- The value of this variable is used when Font Lock mode is turned on."
- :type '(choice (const :tag "none" nil)
- (const :tag "fast lock" fast-lock-mode)
- (const :tag "lazy lock" lazy-lock-mode)
- (const :tag "jit lock" jit-lock-mode)
- (repeat :menu-tag "mode specific" :tag "mode specific"
- :value ((t . jit-lock-mode))
- (cons :tag "Instance"
- (radio :tag "Mode"
- (const :tag "all" t)
- (symbol :tag "name"))
- (radio :tag "Support"
- (const :tag "none" nil)
- (const :tag "fast lock" fast-lock-mode)
- (const :tag "lazy lock" lazy-lock-mode)
- (const :tag "JIT lock" jit-lock-mode)))
- ))
- :version "21.1"
- :group 'font-lock)
- (defvar fast-lock-mode)
- (defvar lazy-lock-mode)
- (defvar jit-lock-mode)
- (declare-function fast-lock-after-fontify-buffer "fast-lock")
- (declare-function fast-lock-after-unfontify-buffer "fast-lock")
- (declare-function fast-lock-mode "fast-lock")
- (declare-function lazy-lock-after-fontify-buffer "lazy-lock")
- (declare-function lazy-lock-after-unfontify-buffer "lazy-lock")
- (declare-function lazy-lock-mode "lazy-lock")
- (defun font-lock-turn-on-thing-lock ()
- (case (font-lock-value-in-major-mode font-lock-support-mode)
- (fast-lock-mode (fast-lock-mode t))
- (lazy-lock-mode (lazy-lock-mode t))
- (jit-lock-mode
-
- (remove-hook 'after-change-functions
- 'font-lock-after-change-function t)
- (set (make-local-variable 'font-lock-fontify-buffer-function)
- 'jit-lock-refontify)
-
- (set (make-local-variable 'font-lock-fontified) t)
-
- (jit-lock-register 'font-lock-fontify-region
- (not font-lock-keywords-only))
-
- (add-hook 'jit-lock-after-change-extend-region-functions
- 'font-lock-extend-jit-lock-region-after-change
- nil t))))
- (defun font-lock-turn-off-thing-lock ()
- (cond ((bound-and-true-p fast-lock-mode)
- (fast-lock-mode -1))
- ((bound-and-true-p jit-lock-mode)
- (jit-lock-unregister 'font-lock-fontify-region)
-
- (kill-local-variable 'font-lock-fontify-buffer-function))
- ((bound-and-true-p lazy-lock-mode)
- (lazy-lock-mode -1))))
- (defun font-lock-after-fontify-buffer ()
- (cond ((bound-and-true-p fast-lock-mode)
- (fast-lock-after-fontify-buffer))
-
-
-
- ((bound-and-true-p lazy-lock-mode)
- (lazy-lock-after-fontify-buffer))))
- (defun font-lock-after-unfontify-buffer ()
- (cond ((bound-and-true-p fast-lock-mode)
- (fast-lock-after-unfontify-buffer))
-
-
-
-
-
-
-
-
- ((bound-and-true-p lazy-lock-mode)
- (lazy-lock-after-unfontify-buffer))))
- (defvar font-lock-extend-after-change-region-function nil
- "A function that determines the region to refontify after a change.
- This variable is either nil, or is a function that determines the
- region to refontify after a change.
- It is usually set by the major mode via `font-lock-defaults'.
- Font-lock calls this function after each buffer change.
- The function is given three parameters, the standard BEG, END, and OLD-LEN
- from `after-change-functions'. It should return either a cons of the beginning
- and end buffer positions \(in that order) of the region to refontify, or nil
- \(which directs the caller to fontify a default region).
- This function should preserve the match-data.
- The region it returns may start or end in the middle of a line.")
- (make-variable-buffer-local 'font-lock-extend-after-change-region-function)
- (defun font-lock-fontify-buffer ()
- "Fontify the current buffer the way the function `font-lock-mode' would."
- (interactive)
- (font-lock-set-defaults)
- (let ((font-lock-verbose (or font-lock-verbose
- (called-interactively-p 'interactive))))
- (funcall font-lock-fontify-buffer-function)))
- (defun font-lock-unfontify-buffer ()
- (funcall font-lock-unfontify-buffer-function))
- (defun font-lock-fontify-region (beg end &optional loudly)
- "Fontify the text between BEG and END.
- If LOUDLY is non-nil, print status messages while fontifying.
- This works by calling `font-lock-fontify-region-function'."
- (font-lock-set-defaults)
- (funcall font-lock-fontify-region-function beg end loudly))
- (defun font-lock-unfontify-region (beg end)
- "Unfontify the text between BEG and END.
- This works by calling `font-lock-unfontify-region-function'."
- (save-buffer-state
- (funcall font-lock-unfontify-region-function beg end)))
- (defun font-lock-default-fontify-buffer ()
- "Fontify the whole buffer using `font-lock-fontify-region-function'."
- (let ((verbose (if (numberp font-lock-verbose)
- (> (buffer-size) font-lock-verbose)
- font-lock-verbose)))
- (with-temp-message
- (when verbose
- (format "Fontifying %s..." (buffer-name)))
-
- (save-restriction
- (widen)
- (condition-case nil
- (save-excursion
- (save-match-data
- (font-lock-fontify-region (point-min) (point-max) verbose)
- (font-lock-after-fontify-buffer)
- (setq font-lock-fontified t)))
-
- (quit (font-lock-unfontify-buffer)))))))
- (defun font-lock-default-unfontify-buffer ()
- "Unfontify the whole buffer using `font-lock-unfontify-region-function'."
-
- (save-restriction
- (widen)
- (font-lock-unfontify-region (point-min) (point-max))
- (font-lock-after-unfontify-buffer)
- (setq font-lock-fontified nil)))
- (defvar font-lock-dont-widen nil
- "If non-nil, font-lock will work on the non-widened buffer.
- Useful for things like RMAIL and Info where the whole buffer is not
- a very meaningful entity to highlight.")
- (defvar font-lock-beg) (defvar font-lock-end)
- (defvar font-lock-extend-region-functions
- '(font-lock-extend-region-wholelines
-
-
-
-
-
-
- font-lock-extend-region-multiline)
- "Special hook run just before proceeding to fontify a region.
- This is used to allow major modes to help font-lock find safe buffer positions
- as beginning and end of the fontified region. Its most common use is to solve
- the problem of /identification/ of multiline elements by providing a function
- that tries to find such elements and move the boundaries such that they do
- not fall in the middle of one.
- Each function is called with no argument; it is expected to adjust the
- dynamically bound variables `font-lock-beg' and `font-lock-end'; and return
- non-nil if it did make such an adjustment.
- These functions are run in turn repeatedly until they all return nil.
- Put first the functions more likely to cause a change and cheaper to compute.")
- (make-variable-buffer-local 'font-lock-extend-region-functions)
- (defun font-lock-extend-region-multiline ()
- "Move fontification boundaries away from any `font-lock-multiline' property."
- (let ((changed nil))
- (when (and (> font-lock-beg (point-min))
- (get-text-property (1- font-lock-beg) 'font-lock-multiline))
- (setq changed t)
- (setq font-lock-beg (or (previous-single-property-change
- font-lock-beg 'font-lock-multiline)
- (point-min))))
-
- (when (get-text-property font-lock-end 'font-lock-multiline)
- (setq changed t)
- (setq font-lock-end (or (text-property-any font-lock-end (point-max)
- 'font-lock-multiline nil)
- (point-max))))
- changed))
- (defun font-lock-extend-region-wholelines ()
- "Move fontification boundaries to beginning of lines."
- (let ((changed nil))
- (goto-char font-lock-beg)
- (unless (bolp)
- (setq changed t font-lock-beg (line-beginning-position)))
- (goto-char font-lock-end)
- (unless (bolp)
- (unless (eq font-lock-end
- (setq font-lock-end (line-beginning-position 2)))
- (setq changed t)))
- changed))
- (defun font-lock-default-fontify-region (beg end loudly)
- "Fontify the text between BEG and END.
- If LOUDLY is non-nil, print status messages while fontifying.
- This function is the default `font-lock-fontify-region-function'."
- (save-buffer-state
-
- (with-syntax-table (or font-lock-syntax-table (syntax-table))
- (save-restriction
- (unless font-lock-dont-widen (widen))
-
-
- (let ((funs font-lock-extend-region-functions)
- (font-lock-beg beg)
- (font-lock-end end))
- (while funs
- (setq funs (if (or (not (funcall (car funs)))
- (eq funs font-lock-extend-region-functions))
- (cdr funs)
-
-
-
-
- font-lock-extend-region-functions)))
- (setq beg font-lock-beg end font-lock-end))
-
- (font-lock-unfontify-region beg end)
- (when (and font-lock-syntactic-keywords
- (null syntax-propertize-function))
-
- (let ((start beg))
- (when (< font-lock-syntactically-fontified start)
- (setq start (max font-lock-syntactically-fontified (point-min)))
- (setq font-lock-syntactically-fontified end))
- (font-lock-fontify-syntactic-keywords-region start end)))
- (unless font-lock-keywords-only
- (font-lock-fontify-syntactically-region beg end loudly))
- (font-lock-fontify-keywords-region beg end loudly)))))
- (defvar font-lock-extra-managed-props nil
- "Additional text properties managed by font-lock.
- This is used by `font-lock-default-unfontify-region' to decide
- what properties to clear before refontifying a region.")
- (defun font-lock-default-unfontify-region (beg end)
- "Unfontify the text between BEG and END.
- This function is the default `font-lock-unfontify-region-function'."
- (remove-list-of-text-properties
- beg end (append
- font-lock-extra-managed-props
- (if font-lock-syntactic-keywords
- '(syntax-table face font-lock-multiline)
- '(face font-lock-multiline)))))
- (defun font-lock-after-change-function (beg end old-len)
- (save-excursion
- (let ((inhibit-point-motion-hooks t)
- (inhibit-quit t)
- (region (if font-lock-extend-after-change-region-function
- (funcall font-lock-extend-after-change-region-function
- beg end old-len))))
- (save-match-data
- (if region
-
- (setq beg (car region) end (cdr region))
-
-
-
-
-
-
- (unless (eq end (point-max))
-
-
-
-
- (setq end (1+ end))))
- (font-lock-fontify-region beg end)))))
- (defvar jit-lock-start) (defvar jit-lock-end)
- (defun font-lock-extend-jit-lock-region-after-change (beg end old-len)
- "Function meant for `jit-lock-after-change-extend-region-functions'.
- This function does 2 things:
- - extend the region so that it not only includes the part that was modified
- but also the surrounding text whose highlighting may change as a consequence.
- - anticipate (part of) the region extension that will happen later in
- `font-lock-default-fontify-region', in order to avoid the need for
- double-redisplay in `jit-lock-fontify-now'."
- (save-excursion
-
- (let ((region (if font-lock-extend-after-change-region-function
- (funcall font-lock-extend-after-change-region-function
- beg end old-len))))
- (if region
- (setq beg (min jit-lock-start (car region))
- end (max jit-lock-end (cdr region))))
-
-
-
-
-
-
-
-
-
-
-
-
- (when (and (> beg (point-min))
- (get-text-property (1- beg) 'font-lock-multiline))
- (setq beg (or (previous-single-property-change
- beg 'font-lock-multiline)
- (point-min))))
- (when (< end (point-max))
- (setq end
- (if (get-text-property end 'font-lock-multiline)
- (or (text-property-any end (point-max)
- 'font-lock-multiline nil)
- (point-max))
-
-
-
-
- (1+ end))))
-
-
-
-
-
-
- (when (memq 'font-lock-extend-region-wholelines
- font-lock-extend-region-functions)
- (goto-char beg)
- (setq jit-lock-start (min jit-lock-start (line-beginning-position)))
- (goto-char end)
- (setq jit-lock-end
- (max jit-lock-end
- (if (bolp) (point) (line-beginning-position 2))))))))
- (defun font-lock-fontify-block (&optional arg)
- "Fontify some lines the way `font-lock-fontify-buffer' would.
- The lines could be a function or paragraph, or a specified number of lines.
- If ARG is given, fontify that many lines before and after point, or 16 lines if
- no ARG is given and `font-lock-mark-block-function' is nil.
- If `font-lock-mark-block-function' non-nil and no ARG is given, it is used to
- delimit the region to fontify."
- (interactive "P")
- (let ((inhibit-point-motion-hooks t) font-lock-beginning-of-syntax-function
- deactivate-mark)
-
- (if (not font-lock-mode) (font-lock-set-defaults))
- (save-excursion
- (save-match-data
- (condition-case error-data
- (if (or arg (not font-lock-mark-block-function))
- (let ((lines (if arg (prefix-numeric-value arg) 16)))
- (font-lock-fontify-region
- (save-excursion (forward-line (- lines)) (point))
- (save-excursion (forward-line lines) (point))))
- (funcall font-lock-mark-block-function)
- (font-lock-fontify-region (point) (mark)))
- ((error quit) (message "Fontifying block...%s" error-data)))))))
- (defun font-lock-prepend-text-property (start end prop value &optional object)
- "Prepend to one property of the text from START to END.
- Arguments PROP and VALUE specify the property and value to prepend to the value
- already in place. The resulting property values are always lists.
- Optional argument OBJECT is the string or buffer containing the text."
- (let ((val (if (listp value) value (list value))) next prev)
- (while (/= start end)
- (setq next (next-single-property-change start prop object end)
- prev (get-text-property start prop object))
-
- (and (memq prop '(face font-lock-face))
- (listp prev)
- (or (keywordp (car prev))
- (memq (car prev) '(foreground-color background-color)))
- (setq prev (list prev)))
- (put-text-property start next prop
- (append val (if (listp prev) prev (list prev)))
- object)
- (setq start next))))
- (defun font-lock-append-text-property (start end prop value &optional object)
- "Append to one property of the text from START to END.
- Arguments PROP and VALUE specify the property and value to append to the value
- already in place. The resulting property values are always lists.
- Optional argument OBJECT is the string or buffer containing the text."
- (let ((val (if (listp value) value (list value))) next prev)
- (while (/= start end)
- (setq next (next-single-property-change start prop object end)
- prev (get-text-property start prop object))
-
- (and (memq prop '(face font-lock-face))
- (listp prev)
- (or (keywordp (car prev))
- (memq (car prev) '(foreground-color background-color)))
- (setq prev (list prev)))
- (put-text-property start next prop
- (append (if (listp prev) prev (list prev)) val)
- object)
- (setq start next))))
- (defun font-lock-fillin-text-property (start end prop value &optional object)
- "Fill in one property of the text from START to END.
- Arguments PROP and VALUE specify the property and value to put where none are
- already in place. Therefore existing property values are not overwritten.
- Optional argument OBJECT is the string or buffer containing the text."
- (let ((start (text-property-any start end prop nil object)) next)
- (while start
- (setq next (next-single-property-change start prop object end))
- (put-text-property start next prop value object)
- (setq start (text-property-any next end prop nil object)))))
- (defun font-lock-apply-syntactic-highlight (highlight)
- "Apply HIGHLIGHT following a match.
- HIGHLIGHT should be of the form MATCH-HIGHLIGHT,
- see `font-lock-syntactic-keywords'."
- (let* ((match (nth 0 highlight))
- (start (match-beginning match)) (end (match-end match))
- (value (nth 1 highlight))
- (override (nth 2 highlight)))
- (if (not start)
-
- (or (nth 3 highlight)
- (error "No match %d in highlight %S" match highlight))
- (when (and (consp value) (not (numberp (car value))))
- (setq value (eval value)))
- (when (stringp value) (setq value (string-to-syntax value)))
-
-
-
- (syntax-ppss-after-change-function start)
- (cond
- ((not override)
-
- (or (text-property-not-all start end 'syntax-table nil)
- (put-text-property start end 'syntax-table value)))
- ((eq override t)
-
- (put-text-property start end 'syntax-table value))
- ((eq override 'keep)
-
- (font-lock-fillin-text-property start end 'syntax-table value))))))
- (defun font-lock-fontify-syntactic-anchored-keywords (keywords limit)
- "Fontify according to KEYWORDS until LIMIT.
- KEYWORDS should be of the form MATCH-ANCHORED, see `font-lock-keywords',
- LIMIT can be modified by the value of its PRE-MATCH-FORM."
- (let ((matcher (nth 0 keywords)) (lowdarks (nthcdr 3 keywords)) highlights
-
- (pre-match-value (eval (nth 1 keywords))))
-
- (if (and (numberp pre-match-value) (> pre-match-value (point)))
- (setq limit pre-match-value)
- (setq limit (line-end-position)))
- (save-match-data
-
- (while (if (stringp matcher)
- (re-search-forward matcher limit t)
- (funcall matcher limit))
-
- (setq highlights lowdarks)
- (while highlights
- (font-lock-apply-syntactic-highlight (car highlights))
- (setq highlights (cdr highlights)))))
-
- (eval (nth 2 keywords))))
- (defun font-lock-fontify-syntactic-keywords-region (start end)
- "Fontify according to `font-lock-syntactic-keywords' between START and END.
- START should be at the beginning of a line."
- (unless parse-sexp-lookup-properties
-
-
- (set (make-local-variable 'parse-sexp-lookup-properties) t))
-
- (when (symbolp font-lock-syntactic-keywords)
- (setq font-lock-syntactic-keywords (font-lock-eval-keywords
- font-lock-syntactic-keywords)))
-
- (unless (eq (car font-lock-syntactic-keywords) t)
- (setq font-lock-syntactic-keywords (font-lock-compile-keywords
- font-lock-syntactic-keywords
- t)))
-
- (let ((case-fold-search font-lock-keywords-case-fold-search)
- (keywords (cddr font-lock-syntactic-keywords))
- keyword matcher highlights)
- (while keywords
-
- (setq keyword (car keywords) matcher (car keyword))
- (goto-char start)
- (while (and (< (point) end)
- (if (stringp matcher)
- (re-search-forward matcher end t)
- (funcall matcher end)))
-
-
- (setq highlights (cdr keyword))
- (while highlights
- (if (numberp (car (car highlights)))
- (font-lock-apply-syntactic-highlight (car highlights))
- (font-lock-fontify-syntactic-anchored-keywords (car highlights)
- end))
- (setq highlights (cdr highlights))))
- (setq keywords (cdr keywords)))))
- (defvar font-lock-comment-start-skip nil
- "If non-nil, Font Lock mode uses this instead of `comment-start-skip'.")
- (defvar font-lock-comment-end-skip nil
- "If non-nil, Font Lock mode uses this instead of `comment-end'.")
- (defun font-lock-fontify-syntactically-region (start end &optional loudly)
- "Put proper face on each string and comment between START and END.
- START should be at the beginning of a line."
- (syntax-propertize end)
- (let ((-end-regexp
- (or font-lock-comment-end-skip
- (regexp-quote
- (replace-regexp-in-string "^ *" "" comment-end))))
-
- (state (syntax-ppss start))
- face beg)
- (if loudly (message "Fontifying %s... (syntactically...)" (buffer-name)))
-
-
- (while
- (progn
- (when (or (nth 3 state) (nth 4 state))
- (setq face (funcall font-lock-syntactic-face-function state))
- (setq beg (max (nth 8 state) start))
- (setq state (parse-partial-sexp (point) end nil nil state
- 'syntax-table))
- (when face (put-text-property beg (point) 'face face))
- (when (and (eq face 'font-lock-comment-face)
- (or font-lock-comment-start-skip
- comment-start-skip))
-
-
- (save-excursion
- (goto-char beg)
- (if (looking-at (or font-lock-comment-start-skip
- comment-start-skip))
- (put-text-property beg (match-end 0) 'face
- font-lock-comment-delimiter-face)))
- (if (looking-back comment-end-regexp (point-at-bol) t)
- (put-text-property (match-beginning 0) (point) 'face
- font-lock-comment-delimiter-face))))
- (< (point) end))
- (setq state (parse-partial-sexp (point) end nil nil state
- 'syntax-table)))))
- (defsubst font-lock-apply-highlight (highlight)
- "Apply HIGHLIGHT following a match.
- HIGHLIGHT should be of the form MATCH-HIGHLIGHT, see `font-lock-keywords'."
- (let* ((match (nth 0 highlight))
- (start (match-beginning match)) (end (match-end match))
- (override (nth 2 highlight)))
- (if (not start)
-
- (or (nth 3 highlight)
- (error "No match %d in highlight %S" match highlight))
- (let ((val (eval (nth 1 highlight))))
- (when (eq (car-safe val) 'face)
- (add-text-properties start end (cddr val))
- (setq val (cadr val)))
- (cond
- ((not (or val (eq override t)))
-
-
-
-
- nil)
- ((not override)
-
- (or (text-property-not-all start end 'face nil)
- (put-text-property start end 'face val)))
- ((eq override t)
-
- (put-text-property start end 'face val))
- ((eq override 'prepend)
-
- (font-lock-prepend-text-property start end 'face val))
- ((eq override 'append)
-
- (font-lock-append-text-property start end 'face val))
- ((eq override 'keep)
-
- (font-lock-fillin-text-property start end 'face val)))))))
- (defsubst font-lock-fontify-anchored-keywords (keywords limit)
- "Fontify according to KEYWORDS until LIMIT.
- KEYWORDS should be of the form MATCH-ANCHORED, see `font-lock-keywords',
- LIMIT can be modified by the value of its PRE-MATCH-FORM."
- (let ((matcher (nth 0 keywords)) (lowdarks (nthcdr 3 keywords)) highlights
- (lead-start (match-beginning 0))
-
- (pre-match-value (eval (nth 1 keywords))))
-
- (if (not (and (numberp pre-match-value) (> pre-match-value (point))))
- (setq limit (line-end-position))
- (setq limit pre-match-value)
- (when (and font-lock-multiline (>= limit (line-beginning-position 2)))
-
-
- (put-text-property (if (= limit (line-beginning-position 2))
- (1- limit)
- (min lead-start (point)))
- limit
- 'font-lock-multiline t)))
- (save-match-data
-
- (while (and (< (point) limit)
- (if (stringp matcher)
- (re-search-forward matcher limit t)
- (funcall matcher limit)))
-
- (setq highlights lowdarks)
- (while highlights
- (font-lock-apply-highlight (car highlights))
- (setq highlights (cdr highlights)))))
-
- (eval (nth 2 keywords))))
- (defun font-lock-fontify-keywords-region (start end &optional loudly)
- "Fontify according to `font-lock-keywords' between START and END.
- START should be at the beginning of a line.
- LOUDLY, if non-nil, allows progress-meter bar."
- (unless (eq (car font-lock-keywords) t)
- (setq font-lock-keywords
- (font-lock-compile-keywords font-lock-keywords)))
- (let ((case-fold-search font-lock-keywords-case-fold-search)
- (keywords (cddr font-lock-keywords))
- (bufname (buffer-name)) (count 0)
- (pos (make-marker))
- keyword matcher highlights)
-
-
- (while keywords
- (if loudly (message "Fontifying %s... (regexps..%s)" bufname
- (make-string (incf count) ?.)))
-
-
- (setq keyword (car keywords) matcher (car keyword))
- (goto-char start)
- (while (and (< (point) end)
- (if (stringp matcher)
- (re-search-forward matcher end t)
- (funcall matcher end))
-
-
- (or (> (point) (match-beginning 0))
- (progn (forward-char 1) t)))
- (when (and font-lock-multiline
- (>= (point)
- (save-excursion (goto-char (match-beginning 0))
- (forward-line 1) (point))))
-
-
- (put-text-property (if (= (point)
- (save-excursion
- (goto-char (match-beginning 0))
- (forward-line 1) (point)))
- (1- (point))
- (match-beginning 0))
- (point)
- 'font-lock-multiline t))
-
-
- (setq highlights (cdr keyword))
- (while highlights
- (if (numberp (car (car highlights)))
- (font-lock-apply-highlight (car highlights))
- (set-marker pos (point))
- (font-lock-fontify-anchored-keywords (car highlights) end)
-
-
- (if (< (point) pos) (goto-char pos)))
- (setq highlights (cdr highlights))))
- (setq keywords (cdr keywords)))
- (set-marker pos nil)))
- (defun font-lock-compile-keywords (keywords &optional syntactic-keywords)
- "Compile KEYWORDS into the form (t KEYWORDS COMPILED...)
- Here each COMPILED is of the form (MATCHER HIGHLIGHT ...) as shown in the
- `font-lock-keywords' doc string.
- If SYNTACTIC-KEYWORDS is non-nil, it means these keywords are used for
- `font-lock-syntactic-keywords' rather than for `font-lock-keywords'."
- (if (not font-lock-set-defaults)
-
-
-
-
-
- (error "Font-lock trying to use keywords before setting them up"))
- (if (eq (car-safe keywords) t)
- keywords
- (setq keywords
- (cons t (cons keywords
- (mapcar 'font-lock-compile-keyword keywords))))
- (if (and (not syntactic-keywords)
- (let ((beg-function
- (or font-lock-beginning-of-syntax-function
- syntax-begin-function)))
- (or (eq beg-function 'beginning-of-defun)
- (get beg-function 'font-lock-syntax-paren-check)))
- (not beginning-of-defun-function))
-
-
- (nconc keywords
- `((,(if defun-prompt-regexp
- (concat "^\\(?:" defun-prompt-regexp "\\)?\\s(")
- "^\\s(")
- (0
- (if (memq (get-text-property (match-beginning 0) 'face)
- '(font-lock-string-face font-lock-doc-face
- font-lock-comment-face))
- (list 'face font-lock-warning-face
- 'help-echo "Looks like a toplevel defun: escape the parenthesis"))
- prepend)))))
- keywords))
- (defun font-lock-compile-keyword (keyword)
- (cond ((nlistp keyword)
- (list keyword '(0 font-lock-keyword-face)))
- ((eq (car keyword) 'eval)
- (font-lock-compile-keyword (eval (cdr keyword))))
- ((eq (car-safe (cdr keyword)) 'quote)
-
- (if (symbolp (nth 2 keyword))
- (list (car keyword) (list 0 (cdr keyword)))
- (font-lock-compile-keyword (cons (car keyword) (nth 2 keyword)))))
- ((numberp (cdr keyword))
- (list (car keyword) (list (cdr keyword) 'font-lock-keyword-face)))
- ((symbolp (cdr keyword))
- (list (car keyword) (list 0 (cdr keyword))))
- ((nlistp (nth 1 keyword))
- (list (car keyword) (cdr keyword)))
- (t
- keyword)))
- (defun font-lock-eval-keywords (keywords)
- "Evaluate KEYWORDS if a function (funcall) or variable (eval) name."
- (if (listp keywords)
- keywords
- (font-lock-eval-keywords (if (fboundp keywords)
- (funcall keywords)
- (eval keywords)))))
- (defun font-lock-value-in-major-mode (alist)
- "Return value in ALIST for `major-mode', or ALIST if it is not an alist.
- Structure is ((MAJOR-MODE . VALUE) ...) where MAJOR-MODE may be t."
- (if (consp alist)
- (cdr (or (assq major-mode alist) (assq t alist)))
- alist))
- (defun font-lock-choose-keywords (keywords level)
- "Return LEVELth element of KEYWORDS.
- A LEVEL of nil is equal to a LEVEL of 0, a LEVEL of t is equal to
- \(1- (length KEYWORDS))."
- (cond ((not (and (listp keywords) (symbolp (car keywords))))
- keywords)
- ((numberp level)
- (or (nth level keywords) (car (last keywords))))
- ((eq level t)
- (car (last keywords)))
- (t
- (car keywords))))
- (defvar font-lock-set-defaults nil)
- (defun font-lock-refresh-defaults ()
- "Restart fontification in current buffer after recomputing from defaults.
- Recompute fontification variables using `font-lock-defaults' and
- `font-lock-maximum-decoration'. Then restart fontification.
- Use this function when you have changed any of the above
- variables directly.
- Note: This function will erase modifications done by
- `font-lock-add-keywords' or `font-lock-remove-keywords', but will
- preserve `hi-lock-mode' highlighting patterns."
- (font-lock-mode -1)
- (kill-local-variable 'font-lock-set-defaults)
- (font-lock-mode 1))
- (defvar font-lock-major-mode nil
- "Major mode for which the font-lock settings have been setup.")
- (make-variable-buffer-local 'font-lock-major-mode)
- (defun font-lock-set-defaults ()
- "Set fontification defaults appropriately for this mode.
- Sets various variables using `font-lock-defaults' and
- `font-lock-maximum-decoration'."
-
- (unless (and font-lock-set-defaults
- (eq font-lock-major-mode major-mode))
- (setq font-lock-major-mode major-mode)
- (set (make-local-variable 'font-lock-set-defaults) t)
- (make-local-variable 'font-lock-fontified)
- (make-local-variable 'font-lock-multiline)
- (let* ((defaults font-lock-defaults)
- (keywords
- (font-lock-choose-keywords (nth 0 defaults)
- (font-lock-value-in-major-mode font-lock-maximum-decoration)))
- (local (cdr (assq major-mode font-lock-keywords-alist)))
- (removed-keywords
- (cdr-safe (assq major-mode font-lock-removed-keywords-alist))))
- (set (make-local-variable 'font-lock-defaults) defaults)
-
- (if (nth 1 defaults)
- (set (make-local-variable 'font-lock-keywords-only) t)
- (kill-local-variable 'font-lock-keywords-only))
-
- (if (nth 2 defaults)
- (set (make-local-variable 'font-lock-keywords-case-fold-search) t)
- (kill-local-variable 'font-lock-keywords-case-fold-search))
-
- (if (null (nth 3 defaults))
- (kill-local-variable 'font-lock-syntax-table)
- (set (make-local-variable 'font-lock-syntax-table)
- (copy-syntax-table (syntax-table)))
- (dolist (selem (nth 3 defaults))
-
- (let ((syntax (cdr selem)))
- (dolist (char (if (numberp (car selem))
- (list (car selem))
- (mapcar 'identity (car selem))))
- (modify-syntax-entry char syntax font-lock-syntax-table)))))
-
- (if (nth 4 defaults)
- (set (make-local-variable 'font-lock-beginning-of-syntax-function)
- (nth 4 defaults))
- (kill-local-variable 'font-lock-beginning-of-syntax-function))
-
- (dolist (x (nthcdr 5 defaults))
- (set (make-local-variable (car x)) (cdr x)))
-
-
-
- (set (make-local-variable 'font-lock-keywords)
- (font-lock-eval-keywords keywords))
-
- (while local
- (font-lock-add-keywords nil (car (car local)) (cdr (car local)))
- (setq local (cdr local)))
- (when removed-keywords
- (font-lock-remove-keywords nil removed-keywords))
-
- (unless (eq (car font-lock-keywords) t)
- (setq font-lock-keywords
- (font-lock-compile-keywords font-lock-keywords))))))
- (defface font-lock-comment-face
- '((((class grayscale) (background light))
- (:foreground "DimGray" :weight bold :slant italic))
- (((class grayscale) (background dark))
- (:foreground "LightGray" :weight bold :slant italic))
- (((class color) (min-colors 88) (background light))
- (:foreground "Firebrick"))
- (((class color) (min-colors 88) (background dark))
- (:foreground "chocolate1"))
- (((class color) (min-colors 16) (background light))
- (:foreground "red"))
- (((class color) (min-colors 16) (background dark))
- (:foreground "red1"))
- (((class color) (min-colors 8) (background light))
- (:foreground "red"))
- (((class color) (min-colors 8) (background dark))
- (:foreground "yellow"))
- (t (:weight bold :slant italic)))
- "Font Lock mode face used to highlight comments."
- :group 'font-lock-faces)
- (defface font-lock-comment-delimiter-face
- '((default :inherit font-lock-comment-face))
- "Font Lock mode face used to highlight comment delimiters."
- :group 'font-lock-faces)
- (defface font-lock-string-face
- '((((class grayscale) (background light)) (:foreground "DimGray" :slant italic))
- (((class grayscale) (background dark)) (:foreground "LightGray" :slant italic))
- (((class color) (min-colors 88) (background light)) (:foreground "VioletRed4"))
- (((class color) (min-colors 88) (background dark)) (:foreground "LightSalmon"))
- (((class color) (min-colors 16) (background light)) (:foreground "RosyBrown"))
- (((class color) (min-colors 16) (background dark)) (:foreground "LightSalmon"))
- (((class color) (min-colors 8)) (:foreground "green"))
- (t (:slant italic)))
- "Font Lock mode face used to highlight strings."
- :group 'font-lock-faces)
- (defface font-lock-doc-face
- '((t :inherit font-lock-string-face))
- "Font Lock mode face used to highlight documentation."
- :group 'font-lock-faces)
- (defface font-lock-keyword-face
- '((((class grayscale) (background light)) (:foreground "LightGray" :weight bold))
- (((class grayscale) (background dark)) (:foreground "DimGray" :weight bold))
- (((class color) (min-colors 88) (background light)) (:foreground "Purple"))
- (((class color) (min-colors 88) (background dark)) (:foreground "Cyan1"))
- (((class color) (min-colors 16) (background light)) (:foreground "Purple"))
- (((class color) (min-colors 16) (background dark)) (:foreground "Cyan"))
- (((class color) (min-colors 8)) (:foreground "cyan" :weight bold))
- (t (:weight bold)))
- "Font Lock mode face used to highlight keywords."
- :group 'font-lock-faces)
- (defface font-lock-builtin-face
- '((((class grayscale) (background light)) (:foreground "LightGray" :weight bold))
- (((class grayscale) (background dark)) (:foreground "DimGray" :weight bold))
- (((class color) (min-colors 88) (background light)) (:foreground "dark slate blue"))
- (((class color) (min-colors 88) (background dark)) (:foreground "LightSteelBlue"))
- (((class color) (min-colors 16) (background light)) (:foreground "Orchid"))
- (((class color) (min-colors 16) (background dark)) (:foreground "LightSteelBlue"))
- (((class color) (min-colors 8)) (:foreground "blue" :weight bold))
- (t (:weight bold)))
- "Font Lock mode face used to highlight builtins."
- :group 'font-lock-faces)
- (defface font-lock-function-name-face
- '((((class color) (min-colors 88) (background light)) (:foreground "Blue1"))
- (((class color) (min-colors 88) (background dark)) (:foreground "LightSkyBlue"))
- (((class color) (min-colors 16) (background light)) (:foreground "Blue"))
- (((class color) (min-colors 16) (background dark)) (:foreground "LightSkyBlue"))
- (((class color) (min-colors 8)) (:foreground "blue" :weight bold))
- (t (:inverse-video t :weight bold)))
- "Font Lock mode face used to highlight function names."
- :group 'font-lock-faces)
- (defface font-lock-variable-name-face
- '((((class grayscale) (background light))
- (:foreground "Gray90" :weight bold :slant italic))
- (((class grayscale) (background dark))
- (:foreground "DimGray" :weight bold :slant italic))
- (((class color) (min-colors 88) (background light)) (:foreground "sienna"))
- (((class color) (min-colors 88) (background dark)) (:foreground "LightGoldenrod"))
- (((class color) (min-colors 16) (background light)) (:foreground "DarkGoldenrod"))
- (((class color) (min-colors 16) (background dark)) (:foreground "LightGoldenrod"))
- (((class color) (min-colors 8)) (:foreground "yellow" :weight light))
- (t (:weight bold :slant italic)))
- "Font Lock mode face used to highlight variable names."
- :group 'font-lock-faces)
- (defface font-lock-type-face
- '((((class grayscale) (background light)) (:foreground "Gray90" :weight bold))
- (((class grayscale) (background dark)) (:foreground "DimGray" :weight bold))
- (((class color) (min-colors 88) (background light)) (:foreground "ForestGreen"))
- (((class color) (min-colors 88) (background dark)) (:foreground "PaleGreen"))
- (((class color) (min-colors 16) (background light)) (:foreground "ForestGreen"))
- (((class color) (min-colors 16) (background dark)) (:foreground "PaleGreen"))
- (((class color) (min-colors 8)) (:foreground "green"))
- (t (:weight bold :underline t)))
- "Font Lock mode face used to highlight type and classes."
- :group 'font-lock-faces)
- (defface font-lock-constant-face
- '((((class grayscale) (background light))
- (:foreground "LightGray" :weight bold :underline t))
- (((class grayscale) (background dark))
- (:foreground "Gray50" :weight bold :underline t))
- (((class color) (min-colors 88) (background light)) (:foreground "dark cyan"))
- (((class color) (min-colors 88) (background dark)) (:foreground "Aquamarine"))
- (((class color) (min-colors 16) (background light)) (:foreground "CadetBlue"))
- (((class color) (min-colors 16) (background dark)) (:foreground "Aquamarine"))
- (((class color) (min-colors 8)) (:foreground "magenta"))
- (t (:weight bold :underline t)))
- "Font Lock mode face used to highlight constants and labels."
- :group 'font-lock-faces)
- (defface font-lock-warning-face
- '((t :inherit error))
- "Font Lock mode face used to highlight warnings."
- :group 'font-lock-faces)
- (defface font-lock-negation-char-face
- '((t nil))
- "Font Lock mode face used to highlight easy to overlook negation."
- :group 'font-lock-faces)
- (defface font-lock-preprocessor-face
- '((t :inherit font-lock-builtin-face))
- "Font Lock mode face used to highlight preprocessor directives."
- :group 'font-lock-faces)
- (defface font-lock-regexp-grouping-backslash
- '((t :inherit bold))
- "Font Lock mode face for backslashes in Lisp regexp grouping constructs."
- :group 'font-lock-faces)
- (defface font-lock-regexp-grouping-construct
- '((t :inherit bold))
- "Font Lock mode face used to highlight grouping constructs in Lisp regexps."
- :group 'font-lock-faces)
- (defun font-lock-match-c-style-declaration-item-and-skip-to-next (limit)
- "Match, and move over, any declaration/definition item after point.
- Matches after point, but ignores leading whitespace and `*' characters.
- Does not move further than LIMIT.
- The expected syntax of a declaration/definition item is `word' (preceded by
- optional whitespace and `*' characters and proceeded by optional whitespace)
- optionally followed by a `('. Everything following the item (but belonging to
- it) is expected to be skip-able by `scan-sexps', and items are expected to be
- separated with a `,' and to be terminated with a `;'.
- Thus the regexp matches after point: word (
- ^^^^ ^
- Where the match subexpressions are: 1 2
- The item is delimited by (match-beginning 1) and (match-end 1).
- If (match-beginning 2) is non-nil, the item is followed by a `('.
- This function could be MATCHER in a MATCH-ANCHORED `font-lock-keywords' item."
- (when (looking-at "[ \n\t*]*\\(\\sw+\\)[ \t\n]*\\(((?\\)?")
- (when (and (match-end 2) (> (- (match-end 2) (match-beginning 2)) 1))
-
-
-
- (let ((pos (point)))
- (skip-chars-backward " \t\n")
- (skip-syntax-backward "w")
- (unless (looking-at "\\(\\sw+\\)[ \t\n]*\\sw+[ \t\n]*\\(((?\\)?")
-
-
- (goto-char pos)
- (looking-at "[ \n\t*]*\\(\\sw+\\)[ \t\n]*\\(((?\\)?"))))
- (save-match-data
- (condition-case nil
- (save-restriction
-
- (narrow-to-region (point-min) limit)
- (goto-char (match-end 1))
-
- (while (not (looking-at "[ \t\n]*\\(\\(,\\)\\|;\\|\\'\\)"))
- (goto-char (or (scan-sexps (point) 1) (point-max))))
- (if (match-end 2)
- (goto-char (match-end 2))))
- (error t)))))
- (defconst cpp-font-lock-keywords-source-directives
- "define\\|e\\(?:l\\(?:if\\|se\\)\\|ndif\\|rror\\)\\|file\\|i\\(?:f\\(?:n?def\\)?\\|mport\\|nclude\\)\\|line\\|pragma\\|undef\\|warning"
- "Regular expression used in `cpp-font-lock-keywords'.")
- (defconst cpp-font-lock-keywords-source-depth 0
- "An integer representing regular expression depth of `cpp-font-lock-keywords-source-directives'.
- Used in `cpp-font-lock-keywords'.")
- (defconst cpp-font-lock-keywords
- (let* ((directives cpp-font-lock-keywords-source-directives)
- (directives-depth cpp-font-lock-keywords-source-depth))
- (list
-
-
- '("^#[ \t]*\\(?:error\\|warning\\)[ \t]+\\(.+\\)" 1 font-lock-warning-face prepend)
-
-
- '("^#[ \t]*\\(?:import\\|include\\)[ \t]*\\(<[^>\"\n]*>?\\)"
- 1 font-lock-string-face prepend)
-
-
- '("^#[ \t]*define[ \t]+\\([[:alpha:]_][[:alnum:]_$]*\\)("
- (1 font-lock-function-name-face prepend)
-
-
- ((lambda (limit)
- (re-search-forward
- "\\(?:\\([[:alpha:]_][[:alnum:]_]*\\)[,]?\\)"
- (or (save-excursion (re-search-forward ")" limit t))
- limit)
- t))
- nil nil (1 font-lock-variable-name-face prepend)))
-
-
- '("^#[ \t]*\\(?:elif\\|if\\)\\>"
- ("\\<\\(defined\\)\\>[ \t]*(?\\([[:alpha:]_][[:alnum:]_]*\\)?" nil nil
- (1 font-lock-builtin-face prepend) (2 font-lock-variable-name-face prepend t)))
-
-
- (list
- (concat "^\\(#[ \t]*\\(?:" directives
- "\\)\\)\\>[ \t!]*\\([[:alpha:]_][[:alnum:]_]*\\)?")
- '(1 font-lock-preprocessor-face prepend)
- (list (+ 2 directives-depth)
- 'font-lock-variable-name-face nil t))))
- "Font lock keywords for C preprocessor directives.
- `c-mode', `c++-mode' and `objc-mode' have their own font lock keywords
- for C preprocessor directives. This definition is for the other modes
- in which C preprocessor directives are used. e.g. `asm-mode' and
- `ld-script-mode'.")
- (defconst lisp-font-lock-keywords-1
- (eval-when-compile
- `(
- (,(concat "(\\(def\\("
-
- "\\(advice\\|alias\\|generic\\|macro\\*?\\|method\\|"
- "setf\\|subst\\*?\\|un\\*?\\|"
- "ine-\\(condition\\|"
- "\\(?:derived\\|\\(?:global\\(?:ized\\)?-\\)?minor\\|generic\\)-mode\\|"
- "method-combination\\|setf-expander\\|skeleton\\|widget\\|"
- "function\\|\\(compiler\\|modify\\|symbol\\)-macro\\)\\)\\|"
-
- "\\(const\\(ant\\)?\\|custom\\|varalias\\|face\\|parameter\\|var\\)\\|"
-
- "\\(class\\|group\\|theme\\|package\\|struct\\|type\\)"
- "\\)\\)\\>"
-
- "[ \t'\(]*"
- "\\(setf[ \t]+\\sw+\\|\\sw+\\)?")
- (1 font-lock-keyword-face)
- (9 (cond ((match-beginning 3) font-lock-function-name-face)
- ((match-beginning 6) font-lock-variable-name-face)
- (t font-lock-type-face))
- nil t))
-
-
- ("^;;;###\\([-a-z]*autoload\\)" 1 font-lock-warning-face prepend)
-
- ("\\[\\(\\^\\)" 1 font-lock-negation-char-face prepend)))
- "Subdued level highlighting for Lisp modes.")
- (defconst lisp-font-lock-keywords-2
- (append lisp-font-lock-keywords-1
- (eval-when-compile
- `(
- (,(concat
- "(" (regexp-opt
- '("cond" "if" "while" "while-no-input" "let" "let*" "letrec"
- "prog" "progn" "progv" "prog1" "prog2" "prog*"
- "inline" "lambda" "save-restriction" "save-excursion"
- "save-selected-window" "save-window-excursion"
- "save-match-data" "save-current-buffer"
- "combine-after-change-calls" "unwind-protect"
- "condition-case" "condition-case-unless-debug"
- "track-mouse" "eval-after-load" "eval-and-compile"
- "eval-when-compile" "eval-when" "eval-next-after-load"
- "with-case-table" "with-category-table"
- "with-current-buffer" "with-demoted-errors"
- "with-electric-help"
- "with-local-quit" "with-no-warnings"
- "with-output-to-string" "with-output-to-temp-buffer"
- "with-selected-window" "with-selected-frame"
- "with-silent-modifications" "with-syntax-table"
- "with-temp-buffer" "with-temp-file" "with-temp-message"
- "with-timeout" "with-timeout-handler" "with-wrapper-hook") t)
- "\\>")
- . 1)
-
- (,(concat
- "(" (regexp-opt
- '("when" "unless" "case" "ecase" "typecase" "etypecase"
- "ccase" "ctypecase" "handler-case" "handler-bind"
- "restart-bind" "restart-case" "in-package"
- "break" "ignore-errors"
- "loop" "do" "do*" "dotimes" "dolist" "the" "locally"
- "proclaim" "declaim" "declare" "symbol-macrolet" "letf"
- "lexical-let" "lexical-let*" "flet" "labels" "compiler-let"
- "destructuring-bind" "macrolet" "tagbody" "block" "go"
- "multiple-value-bind" "multiple-value-prog1"
- "return" "return-from"
- "with-accessors" "with-compilation-unit"
- "with-condition-restarts" "with-hash-table-iterator"
- "with-input-from-string" "with-open-file"
- "with-open-stream" "with-output-to-string"
- "with-package-iterator" "with-simple-restart"
- "with-slots" "with-standard-io-syntax") t)
- "\\>")
- . 1)
-
- (,(concat "(\\(catch\\|throw\\|featurep\\|provide\\|require\\)\\>"
- "[ \t']*\\(\\sw+\\)?")
- (1 font-lock-keyword-face)
- (2 font-lock-constant-face nil t))
-
- ("(\\(abort\\|assert\\|warn\\|check-type\\|cerror\\|error\\|signal\\)\\>" 1 font-lock-warning-face)
-
- ("\\\\\\\\\\[\\(\\sw+\\)\\]" 1 font-lock-constant-face prepend)
-
- ("`\\(\\sw\\sw+\\)'" 1 font-lock-constant-face prepend)
-
- ("\\<:\\sw+\\>" 0 font-lock-builtin-face)
-
- ("\\<\\&\\sw+\\>" . font-lock-type-face)
-
- ((lambda (bound)
- (catch 'found
-
-
-
-
- (while (re-search-forward "\\(\\\\\\\\\\)\\(?:\\(\\\\\\\\\\)\\|\\((\\(?:\\?[0-9]*:\\)?\\|[|)]\\)\\)" bound t)
- (unless (match-beginning 2)
- (let ((face (get-text-property (1- (point)) 'face)))
- (when (or (and (listp face)
- (memq 'font-lock-string-face face))
- (eq 'font-lock-string-face face))
- (throw 'found t)))))))
- (1 'font-lock-regexp-grouping-backslash prepend)
- (3 'font-lock-regexp-grouping-construct prepend))
- )))
- "Gaudy level highlighting for Lisp modes.")
- (defvar lisp-font-lock-keywords lisp-font-lock-keywords-1
- "Default expressions to highlight in Lisp modes.")
- (provide 'font-lock)
|