plugins/geshi/geshi/verilog.php
author Dan
Fri, 29 May 2009 19:30:59 -0400
changeset 2 9e3258dfae15
child 3 f3e2bbbd2155
permissions -rwxr-xr-x
Updated GeSHi. w00t.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     1
<?php
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     2
/**
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     3
 * verilog.php
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     4
 * -----------
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     5
 * Author: G�nter Dannoritzer <dannoritzer@web.de>
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     6
 * Copyright: (C) 2008 Guenter Dannoritzer
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     7
 * Release Version: 1.0.8.2
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     8
 * Date Started: 2008/05/28
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
     9
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    10
 * Verilog language file for GeSHi.
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    11
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    12
 * CHANGES
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    13
 * -------
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    14
 * 2008/05/29
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    15
 *   -  added regular expression to find numbers of the form 4'b001xz
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    16
 *   -  added regular expression to find values for `timescale command
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    17
 *   -  extended macro keywords
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    18
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    19
 * TODO (updated 2008/05/29)
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    20
 * -------------------------
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    21
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    22
 *************************************************************************************
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    23
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    24
 *     This file is part of GeSHi.
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    25
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    26
 *   GeSHi is free software; you can redistribute it and/or modify
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    27
 *   it under the terms of the GNU General Public License as published by
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    28
 *   the Free Software Foundation; either version 2 of the License, or
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    29
 *   (at your option) any later version.
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    30
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    31
 *   GeSHi is distributed in the hope that it will be useful,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    32
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    33
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    34
 *   GNU General Public License for more details.
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    35
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    36
 *   You should have received a copy of the GNU General Public License
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    37
 *   along with GeSHi; if not, write to the Free Software
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    38
 *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    39
 *
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    40
 ************************************************************************************/
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    41
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    42
$language_data = array (
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    43
    'LANG_NAME' => 'Verilog',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    44
    'COMMENT_SINGLE' => array(1 => '//'),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    45
    'COMMENT_MULTI' => array('/*' => '*/'),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    46
    'COMMENT_REGEXP' => array(1 => '/\/\/(?:\\\\\\\\|\\\\\\n|.)*$/m'),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    47
    'CASE_KEYWORDS' => GESHI_CAPS_NO_CHANGE,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    48
    'QUOTEMARKS' => array('"'),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    49
    'ESCAPE_CHAR' => '\\',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    50
    'KEYWORDS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    51
        // keywords
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    52
        1 => array('always', 'and', 'assign', 'begin', 'buf', 'bufif0', 'bufif1', 'case',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    53
            'casex', 'casez', 'cmos', 'deassign', 'default', 'defparam',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    54
            'disable', 'edge', 'else', 'end', 'endcase', 'endfunction',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    55
            'endmodule', 'endprimitive', 'endspecify', 'endtable', 'endtask',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    56
            'event', 'for', 'force', 'forever', 'function', 'highz0',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    57
            'highz1', 'if', 'ifnone', 'initial', 'inout', 'input', 'integer',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    58
            'join', 'large', 'macromodule', 'medium', 'module', 'nand',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    59
            'negedge', 'nmos', 'nor', 'not', 'notif0', 'notif1', 'or',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    60
            'output', 'parameter', 'pmos', 'posedge', 'primitive', 'pull0',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    61
            'pull1', 'pulldown', 'pullup', 'rcmos', 'real', 'realtime', 'reg',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    62
            'release', 'repeat', 'rnmos', 'rpmos', 'rtran', 'rtranif0',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    63
            'rtranif1', 'scalared', 'small', 'specify', 'specparam',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    64
            'strong0', 'strong1', 'supply0', 'supply1', 'table', 'task',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    65
            'time', 'tran', 'tranif0', 'tranif1', 'tri', 'tri0', 'tri1',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    66
            'triand', 'trior', 'trireg', 'vectored', 'wait', 'wand', 'weak0',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    67
            'weak1', 'while', 'wire', 'wor', 'xnor', 'xor'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    68
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    69
        // system tasks
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    70
        2 => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    71
            '$display', '$monitor',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    72
            '$dumpall', '$dumpfile', '$dumpflush', '$dumplimit', '$dumpoff',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    73
            '$dumpon', '$dumpvars',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    74
            '$fclose', '$fdisplay', '$fopen',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    75
            '$finish', '$fmonitor', '$fstrobe', '$fwrite',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    76
            '$fgetc', '$ungetc', '$fgets', '$fscanf', '$fread', '$ftell',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    77
            '$fseek', '$frewind', '$ferror', '$fflush', '$feof',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    78
            '$random',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    79
            '$readmemb', '$readmemh', '$readmemx',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    80
            '$signed', '$stime', '$stop',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    81
            '$strobe', '$time', '$unsigned', '$write'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    82
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    83
        // macros
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    84
        3 => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    85
            '`default-net', '`define',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    86
            '`celldefine', '`default_nettype', '`else', '`elsif', '`endcelldefine',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    87
            '`endif', '`ifdef', '`ifndef', '`include', '`line', '`nounconnected_drive',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    88
            '`resetall', '`timescale', '`unconnected_drive', '`undef'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    89
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    90
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    91
    'SYMBOLS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    92
        '(', ')', '{', '}', '[', ']', '=', '+', '-', '*', '/', '!', '%',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    93
        '^', '&', '|', '~',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    94
        '?', ':',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    95
        '#', '<<', '<<<',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    96
        '>', '<', '>=', '<=',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    97
        '@', ';', ','
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    98
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
    99
    'CASE_SENSITIVE' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   100
        GESHI_COMMENTS => false,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   101
        1 => false,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   102
        2 => false,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   103
        3 => false
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   104
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   105
    'STYLES' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   106
        'KEYWORDS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   107
            1 => 'color: #A52A2A; font-weight: bold;',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   108
            2 => 'color: #9932CC;',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   109
            3 => 'color: #008800;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   110
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   111
        'COMMENTS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   112
            1 => 'color: #00008B; font-style: italic;',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   113
            'MULTI' => 'color: #00008B; font-style: italic;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   114
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   115
        'ESCAPE_CHAR' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   116
            0 => 'color: #9F79EE'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   117
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   118
        'BRACKETS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   119
            0 => 'color: #9F79EE;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   120
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   121
        'STRINGS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   122
            0 => 'color: #FF00FF;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   123
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   124
        'NUMBERS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   125
            0 => 'color: #ff0055;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   126
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   127
        'METHODS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   128
            1 => 'color: #202020;',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   129
            2 => 'color: #202020;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   130
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   131
        'SYMBOLS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   132
            0 => 'color: #5D478B;'
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   133
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   134
        'REGEXPS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   135
            0 => 'color: #ff0055;',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   136
            1 => 'color: #ff0055;',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   137
            ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   138
        'SCRIPT' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   139
            0 => '',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   140
            1 => '',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   141
            2 => '',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   142
            3 => ''
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   143
            )
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   144
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   145
    'URLS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   146
        1 => '',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   147
        2 => '',
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   148
        3 => ''
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   149
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   150
    'OOLANG' => false,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   151
    'OBJECT_SPLITTERS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   152
        1 => ''
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   153
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   154
    'REGEXPS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   155
        // numbers
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   156
        0 => "\d'[bdh][0-9_a-fA-FxXzZ]+",
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   157
        // time -> 1, 10, or 100; s, ms, us, ns, ps, of fs
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   158
        1 => "1[0]{0,2}[munpf]?s"
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   159
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   160
    'STRICT_MODE_APPLIES' => GESHI_NEVER,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   161
    'SCRIPT_DELIMITERS' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   162
        1 => ''
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   163
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   164
    'HIGHLIGHT_STRICT_BLOCK' => array(
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   165
        0 => true,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   166
        1 => true,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   167
        2 => true,
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   168
        3 => true
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   169
        ),
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   170
    'TAB_WIDTH' => 4
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   171
);
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   172
9e3258dfae15 Updated GeSHi. w00t.
Dan
parents:
diff changeset
   173
?>