[gtksourceview] Moved contexts out of main context and placed main context to bottom. Moved regexs to top.



commit 92311794113013127ca2c42d14d91b67b0558370
Author: Carnë Draug <carandraug+dev gmail com>
Date:   Wed May 18 17:04:15 2011 +0100

    Moved contexts out of main context and placed main context to bottom. Moved regexs to top.

 data/language-specs/c.lang |  428 +++++++++++++++++++++++---------------------
 1 files changed, 224 insertions(+), 204 deletions(-)
---
diff --git a/data/language-specs/c.lang b/data/language-specs/c.lang
index 823d3c4..4dc6f07 100644
--- a/data/language-specs/c.lang
+++ b/data/language-specs/c.lang
@@ -54,6 +54,17 @@
     </styles>
 
     <definitions>
+        <!--regexs-->
+        <define-regex id="escaped-character" extended="true">
+            \\(                   # leading backslash
+            [\\\"\'nrbtfav\?] |   # escaped character
+            [0-7]{1,3} |          # one, two, or three octal digits
+            x[0-9A-Fa-f]+         # 'x' followed by hex digits
+            )
+        </define-regex>
+        <define-regex id="preproc-start">^\s*#\s*</define-regex>
+
+        <!--contexts NOT used on the main context-->
         <!-- TODO: what about scanf ? -->
         <!-- man 3 printf -->
         <context id="printf" style-ref="printf" extend-parent="false">
@@ -68,237 +79,246 @@
             </match>
         </context>
 
-        <define-regex id="escaped-character" extended="true">
-            \\(                   # leading backslash
-            [\\\"\'nrbtfav\?] |   # escaped character
-            [0-7]{1,3} |          # one, two, or three octal digits
-            x[0-9A-Fa-f]+         # 'x' followed by hex digits
-            )
-        </define-regex>
+        <!--contexts used on the main context-->
+        <!-- Comments -->
+        <context id="comment" style-ref="comment" end-at-line-end="true" class="comment" class-disabled="no-spell-check">
+            <start>//</start>
 
-        <context id="c" class="no-spell-check">
             <include>
+              <context ref="def:in-line-comment"/>
+            </include>
+        </context>
 
-                <!-- gtk-doc -->
-                <context ref="gtk-doc:inline-docs-section"/>
-
-                <!-- Comments -->
-                <context id="comment" style-ref="comment" end-at-line-end="true" class="comment" class-disabled="no-spell-check">
-                    <start>//</start>
-
-                    <include>
-                      <context ref="def:in-line-comment"/>
-                    </include>
-                </context>
-
-                <context id="comment-multiline" style-ref="comment" class="comment" class-disabled="no-spell-check">
-                    <start>/\*</start>
-                    <end>\*/</end>
-                    <include>
-                        <context ref="def:in-comment"/>
-                    </include>
-                </context>
-
-                <context id="close-comment-outside-comment" style-ref="error">
-                    <match>\*/(?!\*)</match>
-                </context>
+        <context id="comment-multiline" style-ref="comment" class="comment" class-disabled="no-spell-check">
+            <start>/\*</start>
+            <end>\*/</end>
+            <include>
+                <context ref="def:in-comment"/>
+            </include>
+        </context>
 
-                <!-- Preprocessor -->
-                <define-regex id="preproc-start">^\s*#\s*</define-regex>
+        <context id="close-comment-outside-comment" style-ref="error">
+            <match>\*/(?!\*)</match>
+        </context>
 
-                <context id="if0-comment" style-ref="comment">
-                    <start>\%{preproc-start}if\b\s*0\b</start>
-                    <end>\%{preproc-start}(endif|else|elif)\b</end>
+        <!-- Preprocessor -->
+        <context id="if0-comment" style-ref="comment">
+            <start>\%{preproc-start}if\b\s*0\b</start>
+            <end>\%{preproc-start}(endif|else|elif)\b</end>
+            <include>
+                <context id="if-in-if0">
+                    <start>\%{preproc-start}if(n?def)?\b</start>
+                    <end>\%{preproc-start}endif\b</end>
                     <include>
-                        <context id="if-in-if0">
-                            <start>\%{preproc-start}if(n?def)?\b</start>
-                            <end>\%{preproc-start}endif\b</end>
-                            <include>
-                                <context ref="if-in-if0"/>
-                                <context ref="def:in-comment"/>
-                            </include>
-                        </context>
+                        <context ref="if-in-if0"/>
                         <context ref="def:in-comment"/>
                     </include>
                 </context>
+                <context ref="def:in-comment"/>
+            </include>
+        </context>
 
-                <context id="include" style-ref="preprocessor">
-                    <match extended="true">
-                            \%{preproc-start}
-                            (include|import)\s*
-                            (".*?"|&lt;.*&gt;)
-                    </match>
-                    <include>
-                        <context id="included-file" sub-pattern="2" style-ref="included-file"/>
-                    </include>
-                </context>
+        <context id="include" style-ref="preprocessor">
+            <match extended="true">
+                    \%{preproc-start}
+                    (include|import)\s*
+                    (".*?"|&lt;.*&gt;)
+            </match>
+            <include>
+                <context id="included-file" sub-pattern="2" style-ref="included-file"/>
+            </include>
+        </context>
 
-                <context id="preprocessor" style-ref="preprocessor" end-at-line-end="true">
-                    <start extended="true">
-                            \%{preproc-start}
-                            (define|undef|error|pragma|ident|if(n?def)?|else|elif|endif|line|warning)
-                            \b
-                    </start>
-                    <include>
-                        <context ref="def:line-continue" ignore-style="true"/>
-                        <context ref="string" ignore-style="true"/>
-                        <context ref="comment"/>
-                        <context ref="comment-multiline"/>
-                    </include>
-                </context>
+        <context id="preprocessor" style-ref="preprocessor" end-at-line-end="true">
+            <start extended="true">
+                    \%{preproc-start}
+                    (define|undef|error|pragma|ident|if(n?def)?|else|elif|endif|line|warning)
+                    \b
+            </start>
+            <include>
+                <context ref="def:line-continue" ignore-style="true"/>
+                <context ref="string" ignore-style="true"/>
+                <context ref="comment"/>
+                <context ref="comment-multiline"/>
+            </include>
+        </context>
 
-                <context id="string" style-ref="string" end-at-line-end="true" class="string" class-disabled="no-spell-check">
-                    <start>L?"</start>
-                    <end>"</end>
-                    <include>
-                        <context ref="printf"/>
-                        <context id="escaped-character" style-ref="escaped-character">
-                            <match>\%{escaped-character}</match>
-                        </context>
-                        <context ref="def:line-continue"/>
-                    </include>
+        <context id="string" style-ref="string" end-at-line-end="true" class="string" class-disabled="no-spell-check">
+            <start>L?"</start>
+            <end>"</end>
+            <include>
+                <context ref="printf"/>
+                <context id="escaped-character" style-ref="escaped-character">
+                    <match>\%{escaped-character}</match>
                 </context>
+                <context ref="def:line-continue"/>
+            </include>
+        </context>
 
-                <context id="char" style-ref="char">
-                    <match>L?'(\%{escaped-character}|.)'</match>
-                </context>
+        <context id="char" style-ref="char">
+            <match>L?'(\%{escaped-character}|.)'</match>
+        </context>
 
-                <!-- http://www.lysator.liu.se/c/ANSI-C-grammar-l.html -->
-                <context id="float" style-ref="floating-point">
-                    <match extended="true">
-                        (?&lt;![\w\.])
-                        ((\.[0-9]+ | [0-9]+\.[0-9]*) ([Ee][+-]?[0-9]*)? |
-                         ([0-9]+[Ee][+-]?[0-9]*))
-                        [fFlL]?
-                        (?![\w\.])
-                    </match>
-                </context>
+        <!-- http://www.lysator.liu.se/c/ANSI-C-grammar-l.html -->
+        <context id="float" style-ref="floating-point">
+            <match extended="true">
+                (?&lt;![\w\.])
+                ((\.[0-9]+ | [0-9]+\.[0-9]*) ([Ee][+-]?[0-9]*)? |
+                 ([0-9]+[Ee][+-]?[0-9]*))
+                [fFlL]?
+                (?![\w\.])
+            </match>
+        </context>
 
-                <context id="hexadecimal" style-ref="hexadecimal">
-                    <match extended="true">
-                        (?&lt;![\w\.])
-                        0[xX][a-fA-F0-9]+[uUlL]*
-                        (?![\w\.])
-                    </match>
-                </context>
+        <context id="hexadecimal" style-ref="hexadecimal">
+            <match extended="true">
+                (?&lt;![\w\.])
+                0[xX][a-fA-F0-9]+[uUlL]*
+                (?![\w\.])
+            </match>
+        </context>
 
-                <context id="octal" style-ref="octal">
-                    <match extended="true">
-                        (?&lt;![\w\.])
-                        0[0-7]+[uUlL]*
-                        (?![\w\.])
-                    </match>
-                </context>
+        <context id="octal" style-ref="octal">
+            <match extended="true">
+                (?&lt;![\w\.])
+                0[0-7]+[uUlL]*
+                (?![\w\.])
+            </match>
+        </context>
 
-                <context id="decimal" style-ref="decimal">
-                    <match extended="true">
-                        (?&lt;![\w\.])
-                        [0-9]+[uUlL]*
-                        (?![\w\.])
-                    </match>
-                </context>
+        <context id="decimal" style-ref="decimal">
+            <match extended="true">
+                (?&lt;![\w\.])
+                [0-9]+[uUlL]*
+                (?![\w\.])
+            </match>
+        </context>
 
-                <!-- Keywords -->
-                <context id="keywords" style-ref="keyword">
-                    <keyword>asm</keyword>
-                    <keyword>break</keyword>
-                    <keyword>case</keyword>
-                    <keyword>continue</keyword>
-                    <keyword>default</keyword>
-                    <keyword>do</keyword>
-                    <keyword>else</keyword>
-                    <keyword>enum</keyword>
-                    <keyword>for</keyword>
-                    <keyword>fortran</keyword>
-                    <keyword>goto</keyword>
-                    <keyword>if</keyword>
-                    <keyword>return</keyword>
-                    <keyword>sizeof</keyword>
-                    <keyword>struct</keyword>
-                    <keyword>switch</keyword>
-                    <keyword>typedef</keyword>
-                    <keyword>union</keyword>
-                    <keyword>while</keyword>
-                </context>
+        <!-- Keywords -->
+        <context id="keywords" style-ref="keyword">
+            <keyword>asm</keyword>
+            <keyword>break</keyword>
+            <keyword>case</keyword>
+            <keyword>continue</keyword>
+            <keyword>default</keyword>
+            <keyword>do</keyword>
+            <keyword>else</keyword>
+            <keyword>enum</keyword>
+            <keyword>for</keyword>
+            <keyword>fortran</keyword>
+            <keyword>goto</keyword>
+            <keyword>if</keyword>
+            <keyword>return</keyword>
+            <keyword>sizeof</keyword>
+            <keyword>struct</keyword>
+            <keyword>switch</keyword>
+            <keyword>typedef</keyword>
+            <keyword>union</keyword>
+            <keyword>while</keyword>
+        </context>
 
-                <context id="types" style-ref="type">
-                    <keyword>_Bool</keyword>
-                    <keyword>_Complex</keyword>
-                    <keyword>_Imaginary</keyword>
-                    <keyword>bool</keyword>
-                    <keyword>char</keyword>
-                    <keyword>double</keyword>
-                    <keyword>float</keyword>
-                    <keyword>int</keyword>
-                    <keyword>long</keyword>
-                    <keyword>short</keyword>
-                    <keyword>signed</keyword>
-                    <keyword>size_t</keyword>
-                    <keyword>unsigned</keyword>
-                    <keyword>void</keyword>
-                </context>
+        <context id="types" style-ref="type">
+            <keyword>_Bool</keyword>
+            <keyword>_Complex</keyword>
+            <keyword>_Imaginary</keyword>
+            <keyword>bool</keyword>
+            <keyword>char</keyword>
+            <keyword>double</keyword>
+            <keyword>float</keyword>
+            <keyword>int</keyword>
+            <keyword>long</keyword>
+            <keyword>short</keyword>
+            <keyword>signed</keyword>
+            <keyword>size_t</keyword>
+            <keyword>unsigned</keyword>
+            <keyword>void</keyword>
+        </context>
 
-                <context id="storage-class" style-ref="storage-class">
-                    <keyword>auto</keyword>
-                    <keyword>const</keyword>
-                    <keyword>extern</keyword>
-                    <keyword>inline</keyword>
-                    <keyword>register</keyword>
-                    <keyword>restrict</keyword>
-                    <keyword>static</keyword>
-                    <keyword>volatile</keyword>
-                </context>
+        <context id="storage-class" style-ref="storage-class">
+            <keyword>auto</keyword>
+            <keyword>const</keyword>
+            <keyword>extern</keyword>
+            <keyword>inline</keyword>
+            <keyword>register</keyword>
+            <keyword>restrict</keyword>
+            <keyword>static</keyword>
+            <keyword>volatile</keyword>
+        </context>
 
-                <!-- C99 booleans -->
-                <context id="boolean" style-ref="boolean">
-                    <keyword>true</keyword>
-                    <keyword>false</keyword>
-                </context>
+        <!-- C99 booleans -->
+        <context id="boolean" style-ref="boolean">
+            <keyword>true</keyword>
+            <keyword>false</keyword>
+        </context>
 
-                <context id="common-defines" style-ref="common-defines">
-                    <keyword>NULL</keyword>
-                    <keyword>MAX</keyword>
-                    <keyword>MIN</keyword>
-                    <keyword>TRUE</keyword>
-                    <keyword>FALSE</keyword>
-                    <keyword>__LINE__</keyword>
-                    <keyword>__DATA__</keyword>
-                    <keyword>__FILE__</keyword>
-                    <keyword>__func__</keyword>
-                    <keyword>__TIME__</keyword>
-                    <keyword>__STDC__</keyword>
-                </context>
+        <context id="common-defines" style-ref="common-defines">
+            <keyword>NULL</keyword>
+            <keyword>MAX</keyword>
+            <keyword>MIN</keyword>
+            <keyword>TRUE</keyword>
+            <keyword>FALSE</keyword>
+            <keyword>__LINE__</keyword>
+            <keyword>__DATA__</keyword>
+            <keyword>__FILE__</keyword>
+            <keyword>__func__</keyword>
+            <keyword>__TIME__</keyword>
+            <keyword>__STDC__</keyword>
+        </context>
 
-                <context id="standard-streams" style-ref="standard-stream">
-                    <keyword>stdin</keyword>
-                    <keyword>stdout</keyword>
-                    <keyword>stderr</keyword>
-                </context>
+        <context id="standard-streams" style-ref="standard-stream">
+            <keyword>stdin</keyword>
+            <keyword>stdout</keyword>
+            <keyword>stderr</keyword>
+        </context>
 
-                <context id="signals" style-ref="signal-name">
-                    <keyword>SIGABRT</keyword>
-                    <keyword>SIGALRM</keyword>
-                    <keyword>SIGCHLD</keyword>
-                    <keyword>SIGCONT</keyword>
-                    <keyword>SIGFPE</keyword>
-                    <keyword>SIGHUP</keyword>
-                    <keyword>SIGILL</keyword>
-                    <keyword>SIGINT</keyword>
-                    <keyword>SIGKILL</keyword>
-                    <keyword>SIGPIPE</keyword>
-                    <keyword>SIGQUIT</keyword>
-                    <keyword>SIGSEGV</keyword>
-                    <keyword>SIGSTOP</keyword>
-                    <keyword>SIGTERM</keyword>
-                    <keyword>SIGTRAP</keyword>
-                    <keyword>SIGTSTP</keyword>
-                    <keyword>SIGTTIN</keyword>
-                    <keyword>SIGTTOU</keyword>
-                    <keyword>SIGUSR1</keyword>
-                    <keyword>SIGUSR2</keyword>
-                </context>
+        <context id="signals" style-ref="signal-name">
+            <keyword>SIGABRT</keyword>
+            <keyword>SIGALRM</keyword>
+            <keyword>SIGCHLD</keyword>
+            <keyword>SIGCONT</keyword>
+            <keyword>SIGFPE</keyword>
+            <keyword>SIGHUP</keyword>
+            <keyword>SIGILL</keyword>
+            <keyword>SIGINT</keyword>
+            <keyword>SIGKILL</keyword>
+            <keyword>SIGPIPE</keyword>
+            <keyword>SIGQUIT</keyword>
+            <keyword>SIGSEGV</keyword>
+            <keyword>SIGSTOP</keyword>
+            <keyword>SIGTERM</keyword>
+            <keyword>SIGTRAP</keyword>
+            <keyword>SIGTSTP</keyword>
+            <keyword>SIGTTIN</keyword>
+            <keyword>SIGTTOU</keyword>
+            <keyword>SIGUSR1</keyword>
+            <keyword>SIGUSR2</keyword>
+        </context>
 
+        <!--Main context-->
+        <context id="c" class="no-spell-check">
+            <include>
+                <context ref="gtk-doc:inline-docs-section"/>
+                <context ref="comment"/>
+                <context ref="comment-multiline"/>
+                <context ref="close-comment-outside-comment"/>
+                <context ref="if0-comment"/>
+                <context ref="include"/>
+                <context ref="preprocessor"/>
+                <context ref="string"/>
+                <context ref="char"/>
+                <context ref="float"/>
+                <context ref="hexadecimal"/>
+                <context ref="octal"/>
+                <context ref="decimal"/>
+                <context ref="keywords"/>
+                <context ref="types"/>
+                <context ref="storage-class"/>
+                <context ref="boolean"/>
+                <context ref="common-defines"/>
+                <context ref="standard-streams"/>
+                <context ref="signals"/>
             </include>
         </context>
+
     </definitions>
 </language>



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]