D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
home
/
shubmkcj
/
designpitara.com
/
admin
/
ckeditor
/
plugins
/
codesnippetgeshi
/
dev
/
geshi
/
geshi
/
Filename :
vhdl.php
back
Copy
<?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( ) ); ?>