| 
							- <?php
 - /*************************************************************************************
 -  * vhdl.php
 -  * --------
 -  * Author: Alexander 'E-Razor' Krause (admin@erazor-zone.de)
 -  * Contributors:
 -  *  - Kevin Thibedeau (kevinpt@yahoo.com)
 -  * Copyright: (c) 2005 Alexander Krause
 -  * Release Version: 1.0.8.11
 -  * Date Started: 2005/06/15
 -  *
 -  * VHDL (VHSICADL, very high speed integrated circuit HDL) language file for GeSHi.
 -  *
 -  * CHANGES
 -  * -------
 -  * 2012/4/30 (1.0.8.10)
 -  *  -  Reworked to support new features of VHDL-2008.
 -  *  -    Changes include: multi-line comments, all new keywords, PSL keywords and metacomments,
 -  *  -    based literals, attribute highlighting, preprocessor macros (from PSL), and other small
 -  *  -    improvements.
 -  * 2008/05/23 (1.0.7.22)
 -  *  -  Added description of extra language features (SF#1970248)
 -  *  -  Optimized regexp group 0 somewhat
 -  * 2006/06/15 (1.0.0)
 -  *  -  First Release
 -  *
 -  * TODO
 -  * ----
 -  *
 -  *************************************************************************************
 -  *
 -  *     This file is part of GeSHi.
 -  *
 -  *   GeSHi is free software; you can redistribute it and/or modify
 -  *   it under the terms of the GNU General Public License as published by
 -  *   the Free Software Foundation; either version 2 of the License, or
 -  *   (at your option) any later version.
 -  *
 -  *   GeSHi is distributed in the hope that it will be useful,
 -  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 -  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 -  *   GNU General Public License for more details.
 -  *
 -  *   You should have received a copy of the GNU General Public License
 -  *   along with GeSHi; if not, write to the Free Software
 -  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 -  *
 -  ************************************************************************************/
 - 
 - $language_data = array (
 -     'LANG_NAME' => 'VHDL',
 -     'COMMENT_SINGLE' => array(1 => '--'),
 -     'COMMENT_MULTI' => array('/*' => '*/'),
 -     'COMMENT_REGEXP' => array(
 -         // PSL adds C-preprocessor support
 -         1 => '/(?<=\s)#(?:\\\\\\\\|\\\\\\n|.)*$/m',
 -         // PSL metacomments (single-line only for now)
 -         2 => '/--\s*@?psl(?:.)*?;$/m',
 -         ),
 -     'CASE_KEYWORDS' => GESHI_CAPS_NO_CHANGE,
 -     'QUOTEMARKS' => array('"'),
 -     'ESCAPE_CHAR' => '',
 -     'KEYWORDS' => array(
 -         /*keywords*/
 -         1 => array(
 -             'access','after','alias','all','attribute','architecture','array','begin',
 -             'block','body','buffer','bus','case','case?','component','configuration','constant','context',
 -             'disconnect','downto','else','elsif','end','entity','exit','file','for','force',
 -             'function','generate','generic','group','guarded','if','impure','in',
 -             'inertial','inout','is','label','library','linkage','literal','loop',
 -             'map','new','next','null','of','on','open','others','out','package',
 -             'port','postponed','procedure','process','protected','pure','range','record','register',
 -             'reject','release','report','return','select','severity','shared','signal','subtype',
 -             'then','to','transport','type','unaffected','units','until','use','variable',
 -             'wait','when','while','with'
 -             ),
 -         /*types and standard libs*/
 -         2 => array(
 -             'bit','bit_vector','character','boolean','integer','real','time','delay_length','string',
 -             'severity_level','positive','natural','signed','unsigned','line','text',
 -             'std_logic','std_logic_vector','std_ulogic','std_ulogic_vector',
 -             'sfixed','ufixed','float','float32','float64','float128',
 -             'work','ieee','std_logic_1164','math_real','math_complex','textio',
 -             'numeric_std','numeric_std_signed','numeric_std_unsigned','numeric_bit'
 -             ),
 -         /*operators*/
 -         3 => array(
 -             'abs','and','mod','nor','not','or','rem','rol','ror','sla','sll','sra','srl','xnor','xor'
 -             ),
 -         /*psl*/
 -         4 => array(
 -             'assert','assume','assume_guarantee','clock','const','countones','cover','default',
 -             'endpoint','fairness','fell','forall','inf','inherit','isunknown','onehot','onehot0','property',
 -             'prev','restrict','restrict_guarantee','rose','sequence','stable','strong','union','vmode','vprop','vunit'
 -             ),
 -         /*psl operators*/
 -         5 => array(
 -             'abort','always','before','before!','before!_','before_','eventually!','never',
 -             'next!','next_a','next_a!','next_e','next_e!','next_event','next_event!','next_event_a','next_event_a!',
 -             'next_event_e','next_event_e!','until!','until!_','until_','within'
 -             )
 -         ),
 -     'SYMBOLS' => array(
 -         '[', ']', '(', ')',
 -         ';',':',
 -         '<','>','=','+','-','*','/','&','|','?'
 -     ),
 -     'CASE_SENSITIVE' => array(
 -         GESHI_COMMENTS => false,
 -         1 => false,
 -         2 => false,
 -         3 => false,
 -         4 => false,
 -         5 => false
 -         ),
 -     'STYLES' => array(
 -         'KEYWORDS' => array(
 -             1 => 'color: #000080; font-weight: bold;',
 -             2 => 'color: #0000ff;',
 -             3 => 'color: #000066;',
 -             4 => 'color: #000080; font-weight: bold;',
 -             5 => 'color: #000066;'
 -             ),
 -         'COMMENTS' => array(
 -             1 => 'color: #008000; font-style: italic;',
 -             2 => 'color: #ff0000; font-weight: bold;',
 -             'MULTI' => 'color: #008000; font-style: italic;'
 -             ),
 -         'ESCAPE_CHAR' => array(
 -             0 => 'color: #000099; font-weight: bold;'
 -             ),
 -         'BRACKETS' => array(
 -             0 => 'color: #000066;'
 -             ),
 -         'STRINGS' => array(
 -             0 => 'color: #7f007f;'
 -             ),
 -         'NUMBERS' => array(
 -             0 => 'color: #ff0000;'
 -             ),
 -         'METHODS' => array(
 -             ),
 -         'SYMBOLS' => array(
 -             0 => 'color: #000066;'
 -             ),
 -         'REGEXPS' => array(
 -             0 => 'color: #ff0000;',
 -             //1 => 'color: #ff0000;',
 -             2 => 'color: #ee82ee;'
 -             ),
 -         'SCRIPT' => array(
 -             )
 -         ),
 -     'URLS' => array(
 -         1 => '',
 -         2 => '',
 -         3 => '',
 -         4 => '',
 -         5 => ''
 -         ),
 -     'OOLANG' => false,
 -     'OBJECT_SPLITTERS' => array(
 -         ),
 -     'REGEXPS' => array(
 -         //Based literals, scientific notation, and time units
 -         0 => '(\b\d+#[[:xdigit:]_]+#)|'.
 -             '(\b[\d_]+(\.[\d_]+)?[eE][+\-]?[\d_]+)|'.
 -             '(\b(hr|min|sec|ms|us|ns|ps|fs)\b)',
 -         //Character literals
 -         /* GeSHi won't match this pattern for some reason and QUOTEMARKS
 -          * can't be used because it interferes with attribute parsing */
 -         /*1 => "\b'.'\b",*/
 -         //Attributes
 -         2 => "'\w+(?!')"
 -         ),
 -     'STRICT_MODE_APPLIES' => GESHI_NEVER,
 -     'SCRIPT_DELIMITERS' => array(
 -         ),
 -     'HIGHLIGHT_STRICT_BLOCK' => array(
 -         )
 - );
 - 
 - ?>
 
 
  |