From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: =?ISO-8859-1?Q?R=FCdiger?= Sonderfeld Newsgroups: gmane.emacs.devel Subject: [PATCH 1/2] progmodes/vhdl-mode.el: Backported changes from 3.33. Date: Wed, 23 May 2012 14:53:29 +0200 Message-ID: <11841062.XUGkREX5ia@descartes> NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable X-Trace: dough.gmane.org 1337777658 22588 80.91.229.3 (23 May 2012 12:54:18 GMT) X-Complaints-To: usenet@dough.gmane.org NNTP-Posting-Date: Wed, 23 May 2012 12:54:18 +0000 (UTC) To: emacs-devel@gnu.org Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Wed May 23 14:54:14 2012 Return-path: Envelope-to: ged-emacs-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1SXB4u-00021I-CQ for ged-emacs-devel@m.gmane.org; Wed, 23 May 2012 14:54:13 +0200 Original-Received: from localhost ([::1]:50935 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SXB4t-00048E-Sd for ged-emacs-devel@m.gmane.org; Wed, 23 May 2012 08:54:11 -0400 Original-Received: from eggs.gnu.org ([208.118.235.92]:45733) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SXB4b-0003uO-Ql for emacs-devel@gnu.org; Wed, 23 May 2012 08:54:07 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1SXB4Q-0006tz-Mb for emacs-devel@gnu.org; Wed, 23 May 2012 08:53:53 -0400 Original-Received: from ptmx.org ([178.63.28.110]:38093) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SXB4P-0006td-TR for emacs-devel@gnu.org; Wed, 23 May 2012 08:53:42 -0400 Original-Received: from localhost (localhost [127.0.0.1]) by ptmx.org (Postfix) with ESMTP id A510B21DD8; Wed, 23 May 2012 14:53:40 +0200 (CEST) X-Virus-Scanned: Debian amavisd-new at ptmx.org Original-Received: from ptmx.org ([127.0.0.1]) by localhost (ptmx.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id xlh3iavXcy5B; Wed, 23 May 2012 14:53:30 +0200 (CEST) Original-Received: from descartes.localnet (chello080108246092.7.14.vie.surfer.at [80.108.246.92]) by ptmx.org (Postfix) with ESMTPSA id C5DA91FF90; Wed, 23 May 2012 14:53:29 +0200 (CEST) User-Agent: KMail/4.8.2 (Linux/3.2.0-24-generic; KDE/4.8.2; x86_64; ; ) X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.6 (newer, 3) X-Received-From: 178.63.28.110 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.devel:150616 Archived-At: See http://www.iis.ee.ethz.ch/~zimmi/emacs/vhdl-mode.html#release-notes-3.3= 3 Among the changes are * Support for ghdl (free vhdl compiler). Now default * Add/update support for VHDL-AMS packages. * Update to VHDL'02 standard ... I tried to be very careful not to overwrite any non-upstream changes that were made to vhdl-mode. Signed-off-by: R=C3=BCdiger Sonderfeld --- lisp/progmodes/vhdl-mode.el | 1303=20 +++++++++++++++++++++++++++++-------------- 1 file changed, 893 insertions(+), 410 deletions(-) diff --git a/lisp/progmodes/vhdl-mode.el b/lisp/progmodes/vhdl-mode.el index 9b7ee5d..27215de 100644 --- a/lisp/progmodes/vhdl-mode.el +++ b/lisp/progmodes/vhdl-mode.el @@ -13,10 +13,10 @@ ;; filed in the Emacs bug reporting system against this file, a copy ;; of the bug report be sent to the maintainer's email address. =20 -(defconst vhdl-version "3.33.6" +(defconst vhdl-version "3.33.28" "VHDL Mode version number.") =20 -(defconst vhdl-time-stamp "2005-08-30" +(defconst vhdl-time-stamp "2010-09-22" "VHDL Mode time stamp for last update.") =20 ;; This file is part of GNU Emacs. @@ -72,13 +72,13 @@ ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; ;; Emacs Versions =20 -;; supported: GNU Emacs 20.X/21.X/22.X, XEmacs 20.X/21.X -;; tested on: GNU Emacs 20.4, XEmacs 21.1 (marginally) +;; supported: GNU Emacs 20.X/21.X/22.X,23.X, XEmacs 20.X/21.X +;; tested on: GNU Emacs 20.4/21.3/22.1,23.X, XEmacs 21.1 (marginally) =20 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; ;; Installation =20 -;; Prerequisites: GNU Emacs 20.X/21.X/22.X, XEmacs 20.X/21.X. +;; Prerequisites: GNU Emacs 20.X/21.X/22.X/23.X, XEmacs 20.X/21.X. =20 ;; Put `vhdl-mode.el' into the `site-lisp' directory of your Emacs=20 installation ;; or into an arbitrary directory that is added to the load path by th= e @@ -93,7 +93,7 @@ =20 ;; Add the following lines to the `site-start.el' file in the `site-li= sp' ;; directory of your Emacs installation or to your Emacs start-up file= =20 `.emacs' -;; (not required in Emacs 20.X): +;; (not required in Emacs 20 and higher): =20 ;; (autoload 'vhdl-mode "vhdl-mode" "VHDL Mode" t) ;; (setq auto-mode-alist (cons '("\\.vhdl?\\'" . vhdl-mode) auto-mod= e- alist)) @@ -184,7 +184,7 @@ Examples: \".*\" \"\" inserts empty string") =20 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; -;; User variables +;; User variables (customization options) =20 (defgroup vhdl nil "Customizations for VHDL Mode." @@ -197,6 +197,21 @@ Examples: "Customizations for modes." :group 'vhdl) =20 +(defcustom vhdl-electric-mode t + "Non-nil enables electrification (automatic template generation). +If nil, template generators can still be invoked through key bindings = and +menu. Is indicated in the modeline by \"/e\" after the mode name and = can be +toggled by `\\[vhdl-electric-mode]'." + :type 'boolean + :group 'vhdl-mode) + +(defcustom vhdl-stutter-mode t + "Non-nil enables stuttering. +Is indicated in the modeline by \"/s\" after the mode name and can be = toggled +by `\\[vhdl-stutter-mode]'." + :type 'boolean + :group 'vhdl-mode) + (defcustom vhdl-indent-tabs-mode nil "Non-nil means indentation can insert tabs. Overrides local variable `indent-tabs-mode'." @@ -210,6 +225,17 @@ Overrides local variable `indent-tabs-mode'." =20 (defcustom vhdl-compiler-alist '( + ("ADVance MS" "vacom" "-work \\1" "make" "-f \\1" + nil "valib \\1; vamap \\2 \\1" "./" "work/" "Makefile" "adms" + ("\\s-\\([0-9]+\\):" 0 1 0) ("Compiling file \\(.+\\)" 1) + ("ENTI/\\1.vif" "ARCH/\\1-\\2.vif" "CONF/\\1.vif" + "PACK/\\1.vif" "BODY/\\1.vif" upcase)) + ;; Aldec + ;; COMP96 ERROR COMP96_0078: "Unknown identifier "Addr_Bits"." ""=20 40 30 + ("Aldec" "vcom" "-93 -work \\1" "make" "-f \\1" + nil "vlib \\1; vmap \\2 \\1" "./" "work/" "Makefile" "aldec" + (".+?[ \t]+\\(?:ERROR\\)[^:]+:.+?\\(?:.+\"\\(.+?\\)\"[=20 \t]+\\([0-9]+\\)\\)" 1 2 0) ("" 0) + nil) ;; Cadence Leapfrog: cv -file test.vhd ;; duluth: *E,430 (test.vhd,13): identifier (POSITIV) is not decla= red ("Cadence Leapfrog" "cv" "-work \\1 -file" "make" "-f \\1" @@ -225,6 +251,12 @@ Overrides local variable `indent-tabs-mode'." ("ncvhdl_p: \\*E,\\w+ (\\(.+\\),\\([0-9]+\\)|\\([0-9]+\\)):" 1 2 = 3) (""=20 0) ("\\1/entity/pc.db" "\\2/\\1/pc.db" "\\1/configuration/pc.db" "\\1/package/pc.db" "\\1/body/pc.db" downcase)) + ;; ghdl vhdl: ghdl test.vhd + ("GHDL" "ghdl" "-i --workdir=3D\\1 --ieee=3Dsynopsys -fexplicit " = "make" "-f=20 \\1" + nil "mkdir \\1" "./" "work/" "Makefile" "ghdl" + ("ghdl_p: \\*E,\\w+ (\\(.+\\),\\([0-9]+\\)|\\([0-9]+\\)):" 1 2 3)= ("" 0) + ("\\1/entity" "\\2/\\1" "\\1/configuration" + "\\1/package" "\\1/body" downcase)) ;; Ikos Voyager: analyze test.vhd ;; analyze test.vhd ;; E L4/C5: this library unit is inaccessible @@ -236,10 +268,11 @@ Overrides local variable `indent-tabs-mode'." ;; ModelSim, Model Technology: vcom test.vhd ;; ERROR: test.vhd(14): Unknown identifier: positiv ;; WARNING[2]: test.vhd(85): Possible infinite loop + ;; ** Warning: [4] ../src/emacsvsim.vhd(43): An abstract ... ;; ** Error: adder.vhd(190): Unknown identifier: ctl_numb ("ModelSim" "vcom" "-93 -work \\1" "make" "-f \\1" nil "vlib \\1; vmap \\2 \\1" "./" "work/" "Makefile" "modelsim" - ("\\(ERROR\\|WARNING\\|\\*\\* Error\\|\\*\\* Warning\\)[^:]*: \\(= .+\\) (\\([0-9]+\\)):" 2 3 0) ("" 0) + ("\\(ERROR\\|WARNING\\|\\*\\* Error\\|\\*\\* Warning\\)[^:]*:\\(=20= *\[[0-9]+\]\\)? \\(.+\\)(\\([0-9]+\\)):" 3 4 0) ("" 0) ("\\1/_primary.dat" "\\2/\\1.dat" "\\1/_primary.dat" "\\1/_primary.dat" "\\1/body.dat" downcase)) ;; ProVHDL, Synopsys LEDA: provhdl -w work -f test.vhd @@ -321,6 +354,12 @@ Overrides local variable `indent-tabs-mode'." ("\\*\\*Error: LINE \\([0-9]+\\) \\*\\*\\*" 0 1 0) ("^ *Compiling \"\\(.+\\)\" " 1) nil) + ;; Xilinx XST: + ;; ERROR:HDLParsers:164 - "test.vhd" Line 3. parse error + ("Xilinx XST" "xflow" "" "make" "-f \\1" + nil "mkdir \\1" "./" "work/" "Makefile" "xilinx" + ("^ERROR:HDLParsers:[0-9]+ - \"\\(.+\\)\" Line \\([0-9]+\\)\." 1 = 2 0)=20 ("" 0) + nil) ) "List of available VHDL compilers and their properties. Each list entry specifies the following items for a compiler: @@ -428,7 +467,7 @@ NOTE: Activate new error and file message regexps a= nd=20 reflect the new setting =09 (vhdl-custom-set variable value 'vhdl-update-mode-menu)) :group 'vhdl-compile) =20 -(defcustom vhdl-compiler "ModelSim" +(defcustom vhdl-compiler "GHDL" "Specifies the VHDL compiler to be used for syntax analysis. Select a compiler name from the ones defined in option `vhdl-compiler-= alist'." :type (let ((alist vhdl-compiler-alist) list) @@ -450,6 +489,17 @@ NOTE: Activate the new setting by restarting Emacs= ." :type 'boolean :group 'vhdl-compile) =20 +(defcustom vhdl-makefile-default-targets '("all" "clean" "library") + "List of default target names in Makefiles. +Automatically generated Makefiles include three default targets to com= pile +the entire design, clean the entire design and to create the design li= brary. +This option allows to change the names of these targets to avoid confl= icts +with other user Makefiles." + :type '(list (string :tag "Compile entire design") +=09 (string :tag "Clean entire design ") +=09 (string :tag "Create design library")) + :group 'vhdl-compile) + (defcustom vhdl-makefile-generation-hook nil "Functions to run at the end of Makefile generation. Allows to insert user specific parts into a Makefile. @@ -647,11 +697,11 @@ A project setup file can be obtained by exporting= a=20 project (see menu). :group 'vhdl-port :group 'vhdl-compose) =20 -(defcustom vhdl-standard '(87 nil) +(defcustom vhdl-standard '(93 nil) "VHDL standards used. Basic standard: VHDL'87 : IEEE Std 1076-1987 - VHDL'93 : IEEE Std 1076-1993 + VHDL'93/02 : IEEE Std 1076-1993/2002 Additional standards: VHDL-AMS : IEEE Std 1076.1 (analog-mixed-signal) Math packages: IEEE Std 1076.2 (`math_real', `math_complex') @@ -660,7 +710,7 @@ NOTE: Activate the new setting in a VHDL buffer by = using=20 the menu entry \"Activate Options\"." :type '(list (choice :tag "Basic standard" =09=09 (const :tag "VHDL'87" 87) -=09=09 (const :tag "VHDL'93" 93)) +=09=09 (const :tag "VHDL'93/02" 93)) =09 (set :tag "Additional standards" :indent 2 =09=09 (const :tag "VHDL-AMS" ams) =09=09 (const :tag "Math packages" math))) @@ -730,6 +780,14 @@ This is done when expanded." =09=09 (const :tag "Always" always)) :group 'vhdl-style) =20 +(defcustom vhdl-array-index-record-field-in-sensitivity-list t + "Non-nil means include array indices / record fields in sensitivity = list. +If a signal read in a process is a record field or pointed to by an ar= ray +index, the record field or array index is included with the record nam= e in +the sensitivity list (e.g. \"in1(0)\", \"in2.f0\"). +Otherwise, only the record name is included (e.g. \"in1\", \"in2\")." + :type 'boolean + :group 'vhdl-style) =20 (defgroup vhdl-naming nil "Customizations for naming conventions." @@ -916,7 +974,8 @@ if the header needs to be version controlled. The following keywords for template generation are supported: : replaced by the name of the buffer : replaced by the user name and email address - \(`user-full-name', `mail-host-address', `user-mail-= address') + \(`user-full-name',`mail-host-address', `user-mail- address') + : replaced by the user full name (`user-full-name')=20= : replaced by user login name (`user-login-name') : replaced by contents of option `vhdl-company-name' : replaced by the current date @@ -999,11 +1058,12 @@ NOTE: Activate the new setting in a VHDL buffer = by using=20 the menu entry "Customizations for sequential processes." :group 'vhdl-template) =20 -(defcustom vhdl-reset-kind 'async +(defcustom vhdl-reset-kind 'async "Specifies which kind of reset to use in sequential processes." :type '(choice (const :tag "None" none) =09=09 (const :tag "Synchronous" sync) -=09=09 (const :tag "Asynchronous" async)) +=09=09 (const :tag "Asynchronous" async) +=09=09 (const :tag "Query" query)) :group 'vhdl-sequential-process) =20 (defcustom vhdl-reset-active-high nil @@ -1563,22 +1623,25 @@ NOTE: Activate the new setting in a VHDL buffer= by re- fontifying it (menu :group 'vhdl-highlight) =20 (defcustom vhdl-special-syntax-alist - '(("generic/constant" "\\w+_[cg]" "Gold3" "BurlyWood1") - ("type" "\\w+_t" "ForestGreen" "PaleGreen") - ("variable" "\\w+_v" "Grey50" "Grey80")) + '(("generic/constant" "\\<\\w+_[cg]\\>" "Gold3" "BurlyWood1" nil) + ("type" "\\<\\w+_t\\>" "ForestGreen" "PaleGreen" nil) + ("variable" "\\<\\w+_v\\>" "Grey50" "Grey80" nil)) "List of special syntax to be highlighted. If option `vhdl-highlight-special-words' is non-nil, words with the sp= ecified syntax (as regular expression) are highlighted in the corresponding co= lor. =20 Name : string of words and spaces Regexp : regular expression describing word syntax - (e.g. \"\\\w+_c\" matches word with suffix \"_c\") + (e.g. \"\\\\=3D\<\\\w+_c\\\\=3D\>\" matches word with= suffix=20 \"_c\") + expression must start with \"\\\\=3D\<\" and end with= =20 \"\\\\=3D\>\" + if only whole words should be matched (no substrings)= Color (light): foreground color for light background (matching color examples: Gold3, Grey50, LimeGreen, T= omato, LightSeaGreen, DodgerBlue, Gold, PaleVioletRed) Color (dark) : foreground color for dark background (matching color examples: BurlyWood1, Grey80, Green, = Coral, AquaMarine2, LightSkyBlue1, Yellow, PaleVioletRed1) + In comments : If non-nil, words are also highlighted inside comment= s =20 Can be used for visual support of naming conventions, such as highligh= ting different kinds of signals (e.g. \"Clk50\", \"Rst_n\") or objects (e.g= . @@ -1593,7 +1656,8 @@ NOTE: Activate a changed regexp in a VHDL buffer = by re- fontifying it (menu =09=09 (string :tag "Name ") =09=09 (regexp :tag "Regexp " "\\w+_") =09=09 (string :tag "Color (light)") -=09=09 (string :tag "Color (dark) "))) +=09=09 (string :tag "Color (dark) ") +=09=09 (boolean :tag "In comments "))) :set (lambda (variable value) =09 (vhdl-custom-set variable value 'vhdl-font-lock-init)) :group 'vhdl-highlight) @@ -1794,6 +1858,14 @@ useful in large files where syntax-based indenta= tion=20 gets very slow." :type 'boolean :group 'vhdl-misc) =20 +(defcustom vhdl-indent-comment-like-next-code-line t + "*Non-nil means comment lines are indented like the following code l= ine. +Otherwise, comment lines are indented like the preceding code line. +Indenting comment lines like the following code line gives nicer inden= tation +when comments precede the code that they refer to." + :type 'boolean + :group 'vhdl-misc) + (defcustom vhdl-word-completion-case-sensitive nil "Non-nil means word completion using `TAB' is case sensitive. That is, `TAB' completes words that start with the same letters and ca= se. @@ -1833,6 +1905,7 @@ NOTE: Activate the new setting in a VHDL buffer b= y using=20 the menu entry (custom-add-to-group 'vhdl-related 'paren-showing 'custom-group)) (custom-add-to-group 'vhdl-related 'ps-print 'custom-group) (custom-add-to-group 'vhdl-related 'speedbar 'custom-group) +(custom-add-to-group 'vhdl-related 'comment-style 'custom-variable) (custom-add-to-group 'vhdl-related 'line-number-mode 'custom-variable)= (unless (featurep 'xemacs) (custom-add-to-group 'vhdl-related 'transient-mark-mode 'custom-vari= able)) @@ -1841,6 +1914,15 @@ NOTE: Activate the new setting in a VHDL buffer = by using=20 the menu entry (custom-add-to-group 'vhdl-related 'user-mail-address 'custom-variable= ) =20 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; +;; Hidden user variables + +(defvar vhdl-compile-absolute-path nil + "If non-nil, use absolute instead of relative path for compiled file= s.") + +(defvar vhdl-comment-display-line-char ?- + "Character to use in comment display line.") + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; ;; Internal variables =20 (defvar vhdl-menu-max-size 20 @@ -3270,9 +3352,6 @@ STRING are replaced by `-' and substrings are con= verted=20 to lower case." (list (append =09'("Package") -=09(when (vhdl-standard-p 'math) -=09 '(["math_complex"=09vhdl-template-package-math-complex t] -=09 ["math_real"=09vhdl-template-package-math-real t])) =09'(["numeric_bit"=09vhdl-template-package-numeric-bit t] =09 ["numeric_std"=09vhdl-template-package-numeric-std t] =09 ["std_logic_1164"=09vhdl-template-package-std-logic-1164 t] @@ -3283,8 +3362,22 @@ STRING are replaced by `-' and substrings are co= nverted=20 to lower case." =09 ["std_logic_unsigned"=09vhdl-template-package-std-logic-unsigned = t] =09 ["std_logic_misc"=09vhdl-template-package-std-logic-misc t] =09 ["std_logic_textio"=09vhdl-template-package-std-logic-textio t] -=09 "--" -=09 ["Insert Package..."=09vhdl-template-insert-package +=09 "--") +=09(when (vhdl-standard-p 'ams) +=09 '(["fundamental_constants" vhdl-template-package-fundamental-cons= tants t] +=09 ["material_constants" vhdl-template-package-material-constants = t] +=09 ["energy_systems"=09vhdl-template-package-energy-systems t] +=09 ["electrical_systems" vhdl-template-package-electrical-systems = t] +=09 ["mechanical_systems" vhdl-template-package-mechanical-systems = t] +=09 ["radiant_systems"=09vhdl-template-package-radiant-systems t] +=09 ["thermal_systems"=09vhdl-template-package-thermal-systems t] +=09 ["fluidic_systems"=09vhdl-template-package-fluidic-systems t] +=09 "--")) +=09(when (vhdl-standard-p 'math) +=09 '(["math_complex"=09vhdl-template-package-math-complex t] +=09 ["math_real"=09vhdl-template-package-math-real t] +=09 "--")) +=09'(["Insert Package..."=09vhdl-template-insert-package =09=09=09=09:keys "C-c C-i C-p"]))) '(("Directive" =09 ["translate_on"=09vhdl-template-directive-translate-on t] @@ -3417,6 +3510,7 @@ STRING are replaced by `-' and substrings are con= verted=20 to lower case." ["Buffer"=09=09=09vhdl-beautify-buffer t]) ("Fix" ["Generic/Port Clause"=09vhdl-fix-clause t] + ["Generic/Port Clause Buffer" vhdl-fix-clause t] "--" ["Case Region"=09=09vhdl-fix-case-region (mark)] ["Case Buffer"=09=09vhdl-fix-case-buffer t] @@ -3449,11 +3543,13 @@ STRING are replaced by `-' and substrings are=20= converted to lower case." ("Mode" ["Electric Mode" (progn (customize-set-variable 'vhdl-electric-mode -=09=09=09=09 (not vhdl-electric-mode))) +=09=09=09=09 (not vhdl-electric-mode)) +=09 (vhdl-mode-line-update)) :style toggle :selected vhdl-electric-mode :keys "C-c C-m C-e"]= ["Stutter Mode" (progn (customize-set-variable 'vhdl-stutter-mode -=09=09=09=09 (not vhdl-stutter-mode))) +=09=09=09=09 (not vhdl-stutter-mode)) +=09 (vhdl-mode-line-update)) :style toggle :selected vhdl-stutter-mode :keys "C-c C-m C-s"] ["Indent Tabs Mode" (progn (customize-set-variable 'vhdl-indent-tabs-mode @@ -3515,6 +3611,8 @@ STRING are replaced by `-' and substrings are con= verted=20 to lower case." (customize-set-variable 'vhdl-compile-use-local-error-regexp =09=09=09 (not vhdl-compile-use-local-error-regexp)) :style toggle :selected vhdl-compile-use-local-error-regexp] + ["Makefile Default Targets..." + (customize-option 'vhdl-makefile-default-targets) t] ["Makefile Generation Hook..." (customize-option 'vhdl-makefile-generation-hook) t] ["Default Library Name" (customize-option 'vhdl-default-library)= t] @@ -3527,7 +3625,7 @@ STRING are replaced by `-' and substrings are con= verted=20 to lower case." =09=09=09=09 (list '87 (cadr vhdl-standard))) =09 (vhdl-activate-customizations)) =09:style radio :selected (eq '87 (car vhdl-standard))] - ["VHDL'93" + ["VHDL'93/02" =09(progn (customize-set-variable 'vhdl-standard =09=09=09=09 (list '93 (cadr vhdl-standard))) =09 (vhdl-activate-customizations)) @@ -3580,6 +3678,10 @@ STRING are replaced by `-' and substrings are co= nverted=20 to lower case." ["Always" =09(customize-set-variable 'vhdl-use-direct-instantiation 'always) =09:style radio :selected (eq 'always vhdl-use-direct-instantiation)])= + ["Include Array Index and Record Field in Sensitivity List" + (customize-set-variable 'vhdl-array-index-record-field-in-sensi= tivity- list +=09=09=09 (not vhdl-array-index-record-field-in-sensitivity-list= )) + :style toggle :selected vhdl-array-index-record-field-in-sensit= ivity- list] "--" ["Customize Group..." (customize-group 'vhdl-style) t]) ("Naming" @@ -3676,7 +3778,10 @@ STRING are replaced by `-' and substrings are co= nverted=20 to lower case." =09 :style radio :selected (eq 'sync vhdl-reset-kind)] =09["Asynchronous" =09 (customize-set-variable 'vhdl-reset-kind 'async) -=09 :style radio :selected (eq 'async vhdl-reset-kind)]) +=09 :style radio :selected (eq 'async vhdl-reset-kind)] +=09["Query" +=09 (customize-set-variable 'vhdl-reset-kind 'query) +=09 :style radio :selected (eq 'query vhdl-reset-kind)]) ["Reset is Active High" =09(customize-set-variable 'vhdl-reset-active-high =09=09=09=09(not vhdl-reset-active-high)) @@ -3966,6 +4071,10 @@ STRING are replaced by `-' and substrings are co= nverted=20 to lower case." (customize-set-variable 'vhdl-indent-syntax-based =09=09=09 (not vhdl-indent-syntax-based)) :style toggle :selected vhdl-indent-syntax-based] + ["Indent Comments Like Next Code Line" + (customize-set-variable 'vhdl-indent-comment-like-next-code-lin= e +=09=09=09 (not vhdl-indent-comment-like-next-code-line)) + :style toggle :selected vhdl-indent-comment-like-next-code-line= ] ["Word Completion is Case Sensitive" (customize-set-variable 'vhdl-word-completion-case-sensitive =09=09=09 (not vhdl-word-completion-case-sensitive)) @@ -4009,7 +4118,7 @@ STRING are replaced by `-' and substrings are con= verted=20 to lower case." "^\\s-*\\(\\(\\(impure\\|pure\\)\\s-+\\|\\)function\\| procedure\\)\\s-+\\(\"?\\(\\w\\|\\s_\\)+\"?\\)" 4) ("Instance" - "^\\s-*\\(\\(\\w\\|\\s_\\)+\\s-*:\\(\\s-\\|\n\\)*\\(\\w\\| \\s_\\)+\\)\\(\\s-\\|\n\\)+\\(generic\\|port\\)\\s-+map\\>" + "^\\s-*\\(\\(\\w\\|\\s_\\)+\\s-*:\\(\\s-\\|\n\\)*\\(entity\\s-+\\= (\\w\\| \\s_\\)+\\.\\)?\\(\\w\\|\\s_\\)+\\)\\(\\s-\\|\n\\)+\\(generic\\| port\\)\\s-+map\\>" 1) ("Component" "^\\s-*\\(component\\)\\s-+\\(\\(\\w\\|\\s_\\)+\\)" @@ -4193,8 +4302,10 @@ Usage: with a comment in between. `--CR' comments out code on that line. Re-hitting CR comm= ents out following lines. - `C-c c' comments out a region if not commented out, - uncomments a region if already commented out. + `C-c C-c' comments out a region if not commented out, + uncomments a region if already commented out. Opti= on + `comment-style' defines where the comment character= s + should be placed (beginning of line, indent, etc.).= =20 You are prompted for comments after object definitions (i.e. sig= nals, variables, constants, ports) and after subprogram and process @@ -4215,7 +4326,8 @@ Usage: `TAB' indents a line if at the beginning of the line. The amount = of indentation is specified by option `vhdl-basic-offset'. `C-c C-i = C-l' always indents the current line (is bound to `TAB' if option - `vhdl-intelligent-tab' is nil). + `vhdl-intelligent-tab' is nil). If a region is active, `TAB' inde= nts + the entire region. =20 Indentation can be done for a group of lines (`C-c C-i C-g'), a = region \(`M-C-\\') or the entire buffer (menu). Argument and port lists = are @@ -4229,6 +4341,10 @@ Usage: Syntax-based indentation can be very slow in large files. Optio= n `vhdl-indent-syntax-based' allows to use faster but simpler indent= ation. =20 + Option `vhdl-indent-comment-like-next-code-line' controls whethe= r + comment lines are indented like the preceding or like the followin= g code + line. + =20 ALIGNMENT: The alignment functions align operators, keywords, and inline comm= ents @@ -4357,12 +4473,12 @@ Usage: =20 =20 STRUCTURAL COMPOSITION: - Enables simple structural composition. `C-c C-c C-n' creates a sk= eleton + Enables simple structural composition. `C-c C-m C-n' creates a sk= eleton for a new component. Subcomponents (i.e. component declaration an= d instantiation) can be automatically placed from a previously read = port - \(`C-c C-c C-p') or directly from the hierarchy browser (`P'). Fi= nally, + \(`C-c C-m C-p') or directly from the hierarchy browser (`P'). Fi= nally, all subcomponents can be automatically connected using internal si= gnals - and ports (`C-c C-c C-w') following these rules: + and ports (`C-c C-m C-w') following these rules: - subcomponent actual ports with same name are considered to be connected by a signal (internal signal or port) - signals that are only inputs to subcomponents are considered a= s @@ -4383,25 +4499,25 @@ Usage: =20 Component declarations can be placed in a components package (op= tion `vhdl-use-components-package') which can be automatically generate= d for - an entire directory or project (`C-c C-c M-p'). The VHDL'93 direc= t + an entire directory or project (`C-c C-m M-p'). The VHDL'93 direc= t component instantiation is also supported (option `vhdl-use-direct-instantiation'). =20 -| Configuration declarations can automatically be generated either= from -| the menu (`C-c C-c C-f') (for the architecture the cursor is in) o= r from -| the speedbar menu (for the architecture under the cursor). The -| configurations can optionally be hierarchical (i.e. include all -| component levels of a hierarchical design, option -| `vhdl-compose-configuration-hierarchical') or include subconfigura= tions -| (option `vhdl-compose-configuration-use-subconfiguration'). For -| subcomponents in hierarchical configurations, the most-recently-an= alyzed -| (mra) architecture is selected. If another architecture is desire= d, it -| can be marked as most-recently-analyzed (speedbar menu) before -| generating the configuration. -| -| Note: Configurations of subcomponents (i.e. hierarchical configu= ration -| declarations) are currently not considered when displaying -| configurations in speedbar. + Configuration declarations can automatically be generated either= from + the menu (`C-c C-m C-f') (for the architecture the cursor is in) o= r from + the speedbar menu (for the architecture under the cursor). The + configurations can optionally be hierarchical (i.e. include all + component levels of a hierarchical design, option + `vhdl-compose-configuration-hierarchical') or include subconfigura= tions + (option `vhdl-compose-configuration-use-subconfiguration'). For + subcomponents in hierarchical configurations, the most-recently-an= alyzed + (mra) architecture is selected. If another architecture is desire= d, it + can be marked as most-recently-analyzed (speedbar menu) before + generating the configuration. +=20 + Note: Configurations of subcomponents (i.e. hierarchical configu= ration + declarations) are currently not considered when displaying + configurations in speedbar. =20 See the options group `vhdl-compose' for all relevant user optio= ns. =20 @@ -4433,11 +4549,13 @@ Usage: =20 The Makefile's default target \"all\" compiles the entire design= , the target \"clean\" removes it and the target \"library\" creates the= - library directory if not existent. The Makefile also includes a t= arget - for each primary library unit which allows selective compilation o= f this - unit, its secondary units and its subhierarchy (example: compilati= on of - a design specified by a configuration). User specific parts can b= e - inserted into a Makefile with option `vhdl-makefile-generation-hoo= k'. + library directory if not existent. These target names can be cust= omized + by option `vhdl-makefile-default-targets'. The Makefile also incl= udes a + target for each primary library unit which allows selective compil= ation + of this unit, its secondary units and its subhierarchy (example: + compilation of a design specified by a configuration). User speci= fic + parts can be inserted into a Makefile with option + `vhdl-makefile-generation-hook'. =20 Limitations: - Only library units and dependencies within the current library= are @@ -4483,7 +4601,7 @@ Usage: =20 VHDL STANDARDS: The VHDL standards to be used are specified in option `vhdl-standa= rd'. - Available standards are: VHDL'87/'93, VHDL-AMS, and Math Packages.= + Available standards are: VHDL'87/'93(02), VHDL-AMS, and Math Packa= ges. =20 =20 KEYWORD CASE: @@ -4559,6 +4677,9 @@ Usage: - Out parameters of procedures are considered to be read. Use option `vhdl-entity-file-name' to specify the entity file na= me \(used to obtain the port names). + Use option `vhdl-array-index-record-field-in-sensitivity-list' t= o + specify whether to include array indices and record fields in + sensitivity lists. =20 =20 CODE FIXING: @@ -4632,16 +4753,17 @@ releases. You are kindly invited to participat= e in=20 beta testing. Subscribe to above mailing lists by sending an email to . =20 VHDL Mode is officially distributed at -URL `http://opensource.ethz.ch/emacs/vhdl-mode.html' +http://www.iis.ee.ethz.ch/~zimmi/emacs/vhdl-mode.html where the latest version can be found. =20 =20 Known problems: --------------- =20 -- Indentation bug in simultaneous if- and case-statements (VHDL-AMS). - XEmacs: Incorrect start-up when automatically opening speedbar. - XEmacs: Indentation in XEmacs 21.4 (and higher). +- Indentation incorrect for new 'postponed' VHDL keyword. +- Indentation incorrect for 'protected body' construct. =20 =20 The VHDL Mode Authors @@ -4764,7 +4886,7 @@ Key bindings: ;;; Keywords and standardized words ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; =20 -(defconst vhdl-93-keywords +(defconst vhdl-02-keywords '( "abs" "access" "after" "alias" "all" "and" "architecture" "array" "assert" "attribute" @@ -4779,7 +4901,7 @@ Key bindings: "map" "mod" "nand" "new" "next" "nor" "not" "null" "of" "on" "open" "or" "others" "out" - "package" "port" "postponed" "procedure" "process" "pure" + "package" "port" "postponed" "procedure" "process" "protected" "pu= re" "range" "record" "register" "reject" "rem" "report" "return" "rol" "ror" "select" "severity" "shared" "signal" "sla" "sll" "sra" "srl" "sub= type" @@ -4789,7 +4911,7 @@ Key bindings: "wait" "when" "while" "with" "xnor" "xor" ) - "List of VHDL'93 keywords.") + "List of VHDL'02 keywords.") =20 (defconst vhdl-ams-keywords '( @@ -4822,7 +4944,7 @@ Key bindings: ) "List of Verilog keywords as candidate for additional reserved words= .") =20 -(defconst vhdl-93-types +(defconst vhdl-02-types '( "boolean" "bit" "bit_vector" "character" "severity_level" "integer= " "real" "time" "natural" "positive" "string" "line" "text" "side" @@ -4830,25 +4952,72 @@ Key bindings: "std_logic" "std_logic_vector" "std_ulogic" "std_ulogic_vector" ) - "List of VHDL'93 standardized types.") + "List of VHDL'02 standardized types.") =20 (defconst vhdl-ams-types + ;; standards: IEEE Std 1076.1-2007, IEEE Std 1076.1.1-2004 '( + ;; package `standard' "domain_type" "real_vector" - ;; from `nature_pkg' package - "voltage" "current" "electrical" "position" "velocity" "force" - "mechanical_vf" "mechanical_pf" "rotvel" "torque" "rotational" - "pressure" "flowrate" "fluid" - ) + ;; package `energy_systems' + "energy" "power" "periodicity" "real_across" "real_through" "unspe= cified" + "unspecified_vector" "energy_vector" "power_vector" "periodicity_v= ector" + "real_across_vector" "real_through_vector" + ;; package `electrical_systems' + "voltage" "current" "charge" "resistance" "conductance" "capacitan= ce" + "mmf" "electric_flux" "electric_flux_density" "electric_field_stre= ngth" + "magnetic_flux" "magnetic_flux_density" "magnetic_field_strength" + "inductance" "reluctance" "electrical" "electrical_vector" "magnet= ic" + "magnetic_vector" "voltage_vector" "current_vector" "mmf_vector" + "magnetic_flux_vector" "charge_vector" "resistance_vector" + "conductance_vector" "capacitance_vector" "electric_flux_vector" + "electric_flux_density_vector" "electric_field_strength_vector" + "magnetic_flux_density_vector" "magnetic_field_strength_vector" + "inductance_vector" "reluctance_vector" "ground" + ;; package `mechanical_systems' + "displacement" "force" "velocity" "acceleration" "mass" "stiffness= " + "damping" "momentum" "angle" "torque" "angular_velocity" + "angular_acceleration" "moment_inertia" "angular_momentum" + "angular_stiffness" "angular_damping" "translational" + "translational_vector" "translational_velocity" + "translational_velocity_vector" "rotational" "rotational_vector" + "rotational_velocity" "rotational_velocity_vector" "displacement_v= ector" + "force_vector" "velocity_vector" "force_velocity_vector" "angle_ve= ctor" + "torque_vector" "angular_velocity_vector" "torque_velocity_vector"= + "acceleration_vector" "mass_vector" "stiffness_vector" "damping_ve= ctor" + "momentum_vector" "angular_acceleration_vector" "moment_inertia_ve= ctor" + "angular_momentum_vector" "angular_stiffness_vector" + "angular_damping_vector" "anchor" "translational_v_ref" + "rotational_v_ref" "translational_v" "rotational_v" + ;; package `radiant_systems' + "illuminance" "luminous_flux" "luminous_intensity" "irradiance" "r= adiant" + "radiant_vector" "luminous_intensity_vector" "luminous_flux_vector= " + "illuminance_vector" "irradiance_vector" + ;; package `thermal_systems' + "temperature" "heat_flow" "thermal_capacitance" "thermal_resistanc= e" + "thermal_conductance" "thermal" "thermal_vector" "temperature_vect= or" + "heat_flow_vector" "thermal_capacitance_vector" + "thermal_resistance_vector" "thermal_conductance_vector" + ;; package `fluidic_systems' + "pressure" "vflow_rate" "mass_flow_rate" "volume" "density" "visco= sity" + "fresistance" "fconductance" "fcapacitance" "inertance" "cfresista= nce" + "cfcapacitance" "cfinertance" "cfconductance" "fluidic" "fluidic_v= ector" + "compressible_fluidic" "compressible_fluidic_vector" "pressure_vec= tor" + "vflow_rate_vector" "mass_flow_rate_vector" "volume_vector" + "density_vector" "viscosity_vector" "fresistance_vector" + "fconductance_vector" "fcapacitance_vector" "inertance_vector" + "cfresistance_vector" "cfconductance_vector" "cfcapacitance_vector= " + "cfinertance_vector" + ) "List of VHDL-AMS standardized types.") =20 (defconst vhdl-math-types '( - "complex" "complex_polar" + "complex" "complex_polar" "positive_real" "principal_value"=20 ) "List of Math Packages standardized types.") =20 -(defconst vhdl-93-attributes +(defconst vhdl-02-attributes '( "base" "left" "right" "high" "low" "pos" "val" "succ" "pred" "leftof" "rightof" "range" "reverse_range" @@ -4858,7 +5027,7 @@ Key bindings: "simple_name" "instance_name" "path_name" "foreign" ) - "List of VHDL'93 standardized attributes.") + "List of VHDL'02 standardized attributes.") =20 (defconst vhdl-ams-attributes '( @@ -4869,7 +5038,7 @@ Key bindings: ) "List of VHDL-AMS standardized attributes.") =20 -(defconst vhdl-93-enum-values +(defconst vhdl-02-enum-values '( "true" "false" "note" "warning" "error" "failure" @@ -4878,7 +5047,7 @@ Key bindings: "fs" "ps" "ns" "us" "ms" "sec" "min" "hr" "right" "left" ) - "List of VHDL'93 standardized enumeration values.") + "List of VHDL'02 standardized enumeration values.") =20 (defconst vhdl-ams-enum-values '( @@ -4888,22 +5057,38 @@ Key bindings: ) "List of VHDL-AMS standardized enumeration values.") =20 +(defconst vhdl-ams-constants + ;; standard: IEEE Std 1076.1.1-2004 + '( + ;; package `fundamental_constants' + "phys_q" "phys_eps0" "phys_mu0" "phys_k" "phys_gravity" "phys_ctok= " + "phys_c" "phys_h" "phys_h_over_2_pi" "yocto" "zepto" "atto" "femto= " + "pico" "nano" "micro" "milli" "centi" "deci" "deka" "hecto" "kilo"= "mega" + "giga" "tera" "peta" "exa" "zetta" "yotta" "deca" + ;; package `material_constants' + "phys_eps_si" "phys_eps_sio2" "phys_e_si" "phys_e_sio2" "phys_e_po= ly" + "phys_nu_si" "phys_nu_poly" "phys_rho_poly" "phys_rho_sio2" + "ambient_temperature" "ambient_pressure" "ambient_illuminance" =20= + ) + "List of VHDL-AMS standardized constants.") + (defconst vhdl-math-constants + ;; standard: IEEE Std 1076.2-1996 '( - "math_e" "math_1_over_e" - "math_pi" "math_two_pi" "math_1_over_pi" - "math_half_pi" "math_q_pi" "math_3_half_pi" - "math_log_of_2" "math_log_of_10" "math_log2_of_e" "math_log10_of_e= " - "math_sqrt2" "math_sqrt1_2" "math_sqrt_pi" - "math_deg_to_rad" "math_rad_to_deg" - "cbase_1" "cbase_j" "czero" + "math_1_over_e" "math_1_over_pi" "math_1_over_sqrt_2" "math_2_pi" + "math_3_pi_over_2" "math_cbase_1" "math_cbase_j" "math_czero" + "math_deg_to_rad" "math_e" "math_log10_of_e" "math_log2_of_e" + "math_log_of_10" "math_log_of_2" "math_pi" "math_pi_over_2" + "math_pi_over_3" "math_pi_over_4" "math_rad_to_deg" "math_sqrt_2" + "math_sqrt_pi" ) "List of Math Packages standardized constants.") =20 -(defconst vhdl-93-functions +(defconst vhdl-02-functions '( "now" "resolved" "rising_edge" "falling_edge" - "read" "readline" "write" "writeline" "endfile" + "read" "readline" "hread" "oread" "write" "writeline" "hwrite" "ow= rite" + "endfile" "resize" "is_X" "std_match" "shift_left" "shift_right" "rotate_left" "rotate_right" "to_unsigned" "to_signed" "to_integer" @@ -4913,25 +5098,27 @@ Key bindings: "shl" "shr" "ext" "sxt" "deallocate" ) - "List of VHDL'93 standardized functions.") + "List of VHDL'02 standardized functions.") =20 (defconst vhdl-ams-functions '( + ;; package `standard' "frequency" ) "List of VHDL-AMS standardized functions.") =20 (defconst vhdl-math-functions + ;; standard: IEEE Std 1076.2-1996 '( - "sign" "ceil" "floor" "round" "trunc" "fmax" "fmin" "uniform" - "sqrt" "cbrt" "exp" "log" - "sin" "cos" "tan" "arcsin" "arccos" "arctan" - "sinh" "cosh" "tanh" "arcsinh" "arccosh" "arctanh" - "cmplx" "complex_to_polar" "polar_to_complex" "arg" "conj" + "arccos" "arccosh" "arcsin" "arcsinh" "arctan" "arctanh" "arg" + "cbrt" "ceil" "cmplx" "complex_to_polar" "conj" "cos" "cosh" "exp"= + "floor" "get_principal_value" "log" "log10" "log2" "polar_to_compl= ex" + "realmax" "realmin" "round" "sign" "sin" "sinh" "sqrt" + "tan" "tanh" "trunc" "uniform" ) "List of Math Packages standardized functions.") =20 -(defconst vhdl-93-packages +(defconst vhdl-02-packages '( "std_logic_1164" "numeric_std" "numeric_bit" "standard" "textio" @@ -4939,12 +5126,13 @@ Key bindings: "std_logic_misc" "std_logic_textio" "ieee" "std" "work" ) - "List of VHDL'93 standardized packages and libraries.") + "List of VHDL'02 standardized packages and libraries.") =20 (defconst vhdl-ams-packages '( - ;; from `nature_pkg' package - "nature_pkg" + "fundamental_constants" "material_constants" "energy_systems" + "electrical_systems" "mechanical_systems" "radiant_systems" + "thermal_systems" "fluidic_systems" ) "List of VHDL-AMS standardized packages and libraries.") =20 @@ -4990,6 +5178,9 @@ Key bindings: (defvar vhdl-enum-values-regexp nil "Regexp for VHDL standardized enumeration values.") =20 +(defvar vhdl-constants-regexp nil + "Regexp for VHDL standardized constants.") + (defvar vhdl-functions-regexp nil "Regexp for VHDL standardized functions.") =20 @@ -5002,29 +5193,50 @@ Key bindings: (defvar vhdl-directive-keywords-regexp nil "Regexp for compiler directive keywords.") =20 +(defun vhdl-upcase-list (condition list) + "Upcase all elements in LIST based on CONDITION." + (when condition + (let ((tmp-list list)) + (while tmp-list +=09(setcar tmp-list (upcase (car tmp-list))) +=09(setq tmp-list (cdr tmp-list))))) + list) + (defun vhdl-words-init () "Initialize reserved words." (setq vhdl-keywords -=09(append vhdl-93-keywords -=09=09(when (vhdl-standard-p 'ams) vhdl-ams-keywords))) +=09(vhdl-upcase-list +=09 (and vhdl-highlight-case-sensitive vhdl-upper-case-keywords) +=09 (append vhdl-02-keywords +=09=09 (when (vhdl-standard-p 'ams) vhdl-ams-keywords)))) (setq vhdl-types -=09(append vhdl-93-types -=09=09(when (vhdl-standard-p 'ams) vhdl-ams-types) -=09=09(when (vhdl-standard-p 'math) vhdl-math-types))) +=09(vhdl-upcase-list +=09 (and vhdl-highlight-case-sensitive vhdl-upper-case-types) +=09 (append vhdl-02-types +=09=09 (when (vhdl-standard-p 'ams) vhdl-ams-types) +=09=09 (when (vhdl-standard-p 'math) vhdl-math-types)))) (setq vhdl-attributes -=09(append vhdl-93-attributes -=09=09(when (vhdl-standard-p 'ams) vhdl-ams-attributes))) +=09(vhdl-upcase-list +=09 (and vhdl-highlight-case-sensitive vhdl-upper-case-attributes) +=09 (append vhdl-02-attributes +=09=09 (when (vhdl-standard-p 'ams) vhdl-ams-attributes)))) (setq vhdl-enum-values -=09(append vhdl-93-enum-values -=09=09(when (vhdl-standard-p 'ams) vhdl-ams-enum-values))) +=09(vhdl-upcase-list +=09 (and vhdl-highlight-case-sensitive vhdl-upper-case-enum-values) +=09 (append vhdl-02-enum-values +=09=09 (when (vhdl-standard-p 'ams) vhdl-ams-enum-values)))) (setq vhdl-constants -=09(append (when (vhdl-standard-p 'math) vhdl-math-constants))) +=09(vhdl-upcase-list +=09 (and vhdl-highlight-case-sensitive vhdl-upper-case-constants) +=09 (append (when (vhdl-standard-p 'ams) vhdl-ams-constants) +=09=09 (when (vhdl-standard-p 'math) vhdl-math-constants) +=09=09 '("")))) (setq vhdl-functions -=09(append vhdl-93-functions +=09(append vhdl-02-functions =09=09(when (vhdl-standard-p 'ams) vhdl-ams-functions) =09=09(when (vhdl-standard-p 'math) vhdl-math-functions))) (setq vhdl-packages -=09(append vhdl-93-packages +=09(append vhdl-02-packages =09=09(when (vhdl-standard-p 'ams) vhdl-ams-packages) =09=09(when (vhdl-standard-p 'math) vhdl-math-packages))) (setq vhdl-reserved-words @@ -5039,6 +5251,8 @@ Key bindings: =09(concat "\\<\\(" (regexp-opt vhdl-attributes) "\\)\\>")) (setq vhdl-enum-values-regexp =09(concat "\\<\\(" (regexp-opt vhdl-enum-values) "\\)\\>")) + (setq vhdl-constants-regexp +=09(concat "\\<\\(" (regexp-opt vhdl-constants) "\\)\\>")) (setq vhdl-functions-regexp =09(concat "\\<\\(" (regexp-opt vhdl-functions) "\\)\\>")) (setq vhdl-packages-regexp @@ -5090,7 +5304,7 @@ We cannot use just `word' syntax class since `_' = cannot=20 be in word class. Putting underscore in word class breaks forward word movement behavior that users are familiar with.") =20 -(defconst vhdl-case-header-key "case[( \t\n][^;=3D>]+[) \t\n]is" +(defconst vhdl-case-header-key "case[( \t\n\r\f][^;=3D>]+[) \t\n\r\f]i= s" "Regexp describing a case statement header key.") =20 (defconst vhdl-label-key @@ -5318,6 +5532,17 @@ the offset is simply returned." "Check if point is in a string." (eq (vhdl-in-literal) 'string)) =20 +(defun vhdl-in-quote-p () + "Check if point is in a quote ('x')." + (or (and (> (point) (point-min)) +=09 (< (1+ (point)) (point-max)) +=09 (=3D (char-before (point)) ?\') +=09 (=3D (char-after (1+ (point))) ?\')) + (and (> (1- (point)) (point-min)) +=09 (< (point) (point-max)) +=09 (=3D (char-before (1- (point))) ?\') +=09 (=3D (char-after (point)) ?\')))) + (defun vhdl-in-literal () "Determine if point is in a VHDL literal." (save-excursion @@ -5328,6 +5553,12 @@ the offset is simply returned." ((vhdl-beginning-of-macro) 'pound) (t nil))))) =20 +(defun vhdl-in-extended-identifier-p () + "Determine if point is inside extended identifier (delimited by '\')= ." + (save-match-data + (and (save-excursion (re-search-backward "\\\\" (vhdl-point 'bol) = t)) +=09 (save-excursion (re-search-forward "\\\\" (vhdl-point 'eol) t)))))= + (defun vhdl-forward-comment (&optional direction) "Skip all comments (including whitespace). Skip backwards if DIRECT= ION is negative, skip forward otherwise." @@ -5335,20 +5566,30 @@ negative, skip forward otherwise." (if (and direction (< direction 0)) ;; skip backwards (progn -=09(skip-chars-backward " \t\n") +=09(skip-chars-backward " \t\n\r\f") =09(while (re-search-backward "^[^\"-]*\\(\\(-?\"[^\"]*\"\\|-[^\"-]\\)= [^\"-]*\\)*\\(--\\)" (vhdl-point 'bol) t) =09 (goto-char (match-beginning 3)) -=09 (skip-chars-backward " \t\n"))) +=09 (skip-chars-backward " \t\n\r\f"))) ;; skip forwards - (skip-chars-forward " \t\n") + (skip-chars-forward " \t\n\r\f") (while (looking-at "--.*") (goto-char (match-end 0)) - (skip-chars-forward " \t\n")))) + (skip-chars-forward " \t\n\r\f")))) =20 ;; XEmacs hack: work around buggy `forward-comment' in XEmacs 21.4+ (unless (and (featurep 'xemacs) (string< "21.2" emacs-version)) (defalias 'vhdl-forward-comment 'forward-comment)) =20 +(defun vhdl-back-to-indentation () + "Move point to the first non-whitespace character on this line." + (interactive) + (beginning-of-line 1) + (skip-syntax-forward " " (vhdl-point 'eol))) + +;; XEmacs hack: work around old `back-to-indentation' in XEmacs +(when (featurep 'xemacs) + (defalias 'back-to-indentation 'vhdl-back-to-indentation)) + ;; This is the best we can do in Win-Emacs. (defun vhdl-win-il (&optional lim) "Determine if point is in a VHDL literal." @@ -5513,7 +5754,7 @@ that point, else nil." (and (save-excursion (forward-sexp) - (skip-chars-forward " \t\n") + (skip-chars-forward " \t\n\r\f") (not (looking-at "is\\b[^_]"))) (save-excursion (backward-sexp) @@ -5553,12 +5794,12 @@ corresponding \"begin\" keyword, else return ni= l." =09 "is")))) =20 (defconst vhdl-begin-fwd-re - "\\b\\(is\\|begin\\|block\\|component\\|generate\\|then\\|else\\|loo= p\\| process\\|procedural\\|units\\|record\\|for\\)\\b\\([^_]\\|\\'\\)" + "\\b\\(is\\|begin\\|block\\|component\\|generate\\|then\\|else\\|loo= p\\| process\\|procedural\\(\\s-+body\\)?\\|units\\|use\\|record\\| protected\\(\\s-+body\\)?\\|for\\)\\b\\([^_]\\|\\'\\)" "A regular expression for searching forward that matches all known \"begin\" keywords.") =20 (defconst vhdl-begin-bwd-re - "\\b\\(is\\|begin\\|block\\|component\\|generate\\|then\\|else\\|loo= p\\| process\\|procedural\\|units\\|record\\|for\\)\\b[^_]" + "\\b\\(is\\|begin\\|block\\|component\\|generate\\|then\\|else\\|loo= p\\| process\\|procedural\\(\\s-+body\\)?\\|units\\|use\\|record\\| protected\\(\\s-+body\\)?\\|for\\)\\b[^_]" "A regular expression for searching backward that matches all known \"begin\" keywords.") =20 @@ -5591,21 +5832,21 @@ keyword." =09 (and (/=3D (following-char) ?\;) =09=09(not (looking-at "is\\|begin\\|process\\|procedural\\|block"))))= ) t) - ;; "begin", "then": - ((looking-at "be\\|t") + ;; "begin", "then", "use": + ((looking-at "be\\|t\\|use") t) ;; "else": ((and (looking-at "e") =09 ;; make sure that the "else" isn't inside a =09 ;; conditional signal assignment. =09 (save-excursion -=09 (re-search-backward ";\\|\\bwhen\\b[^_]" lim 'move) +=09 (vhdl-re-search-backward ";\\|\\bwhen\\b[^_]" lim 'move) =09 (or (eq (following-char) ?\;) =09 (eq (point) lim)))) t) ;; "block", "generate", "loop", "process", "procedural", - ;; "units", "record": - ((and (looking-at "bl\\|[glpur]") + ;; "units", "record", "protected body": + ((and (looking-at "block\\|generate\\|loop\\|process\\|procedural\\= | protected\\(\\s-+body\\)?\\|units\\|record") =09 (save-excursion =09 (backward-sexp) =09 (not (looking-at "end\\s-+\\w")))) @@ -5633,7 +5874,7 @@ keyword." (cond ((looking-at "is\\|block\\|generate\\|process\\|procedural") "begin") - ((looking-at "then") + ((looking-at "then\\|use") "") (t "end"))) @@ -5648,6 +5889,9 @@ Assumes that the caller will make sure that we ar= e not=20 in the middle of an identifier that just happens to contain a \"begin\" keyword." (save-excursion (and (looking-at vhdl-begin-fwd-re) +=09 (or (not (looking-at "\\")) +=09 (save-excursion (back-to-indentation) +=09=09=09 (looking-at "\\(\\w+\\s-*:\\s-*\\)?\\<\\(case\\|elsif\\|= if\\)\\>"))) =09 (/=3D (preceding-char) ?_) =09 (not (vhdl-in-literal)) =09 (vhdl-begin-p lim) @@ -5670,8 +5914,8 @@ of an identifier that just happens to contain a \= "begin\"=20 keyword." =09=09=09 (vhdl-beginning-of-statement-1 lim) =09=09=09 (vhdl-backward-skip-label lim) =09=09=09 (vhdl-first-word (point))))))) -=09 ;; "component", "units", "record": -=09 ((looking-at "[cur]") +=09 ;; "component", "units", "record", "protected body": +=09 ((looking-at "component\\|units\\|protected\\(\\s-+body\\)?\\|rec= ord") =09 ;; The first end found will close the block =09 (vector "end" nil)) =09 ;; "block", "process", "procedural": @@ -5683,8 +5927,8 @@ of an identifier that just happens to contain a \= "begin\"=20 keyword." =09=09=09 (vhdl-backward-skip-label lim) =09=09=09 (vhdl-first-word (point)))))) =09 ;; "then": -=09 ((looking-at "t") -=09 (vector "elsif\\|else\\|end\\s-+if" +=09 ((looking-at "t\\|use") +=09 (vector "elsif\\|else\\|end\\s-+\\(if\\|use\\)" =09=09 (and (vhdl-last-word (point)) =09=09=09(or (vhdl-first-word (point)) =09=09=09 (save-excursion @@ -5730,25 +5974,25 @@ of an identifier that just happens to contain a= n=20 \"end\" keyword." =09 (vhdl-end-p lim)) =09 (if (looking-at "el") =09 ;; "else", "elsif": -=09 (vector "if\\|elsif" (vhdl-first-word (point)) "then" nil) +=09 (vector "if\\|elsif" (vhdl-first-word (point)) "then\\|use" n= il) =09 ;; "end ...": =09 (setq pos (point)) =09 (forward-sexp) -=09 (skip-chars-forward " \t\n") +=09 (skip-chars-forward " \t\n\r\f") =09 (cond =09 ;; "end if": =09 ((looking-at "if\\b[^_]") =09 (vector "else\\|elsif\\|if" =09=09 (vhdl-first-word pos) -=09=09 "else\\|then" nil)) +=09=09 "else\\|then\\|use" nil)) =09 ;; "end component": =09 ((looking-at "component\\b[^_]") =09 (vector (buffer-substring (match-beginning 1) =09=09=09=09=09(match-end 1)) =09=09 (vhdl-first-word pos) =09=09 nil nil)) -=09 ;; "end units", "end record": -=09 ((looking-at "\\(units\\|record\\)\\b[^_]") +=09 ;; "end units", "end record", "end protected": +=09 ((looking-at "\\(units\\|record\\|protected\\(\\s-+body\\)?\\)= \\b[^_]") =09 (vector (buffer-substring (match-beginning 1) =09=09=09=09=09(match-end 1)) =09=09 (vhdl-first-word pos) @@ -5805,38 +6049,38 @@ of an identifier that just happens to contain a= n=20 \"end\" keyword." (cond ((looking-at "block\\|process\\|procedural") =09 (if (save-excursion =09=09 (forward-sexp) -=09=09 (skip-chars-forward " \t\n") +=09=09 (skip-chars-forward " \t\n\r\f") =09=09 (=3D (following-char) ?\()) =09 (forward-sexp 2) =09 (forward-sexp)) -=09 (when (looking-at "[ \t\n]*is") +=09 (when (looking-at "[ \t\n\r\f]*is") =09 (goto-char (match-end 0))) =09 (point)) =09 ((looking-at "component") =09 (forward-sexp 2) -=09 (when (looking-at "[ \t\n]*is") +=09 (when (looking-at "[ \t\n\r\f]*is") =09 (goto-char (match-end 0))) =09 (point)) =09 ((looking-at "for") =09 (forward-sexp 2) -=09 (skip-chars-forward " \t\n") +=09 (skip-chars-forward " \t\n\r\f") =09 (while (looking-at "[,:(]") =09 (forward-sexp) -=09 (skip-chars-forward " \t\n")) +=09 (skip-chars-forward " \t\n\r\f")) =09 (point)) =09 (t nil) =09 ))) =20 (defconst vhdl-trailer-re - "\\b\\(is\\|then\\|generate\\|loop\\|record\\)\\b[^_]") + "\\b\\(is\\|then\\|generate\\|loop\\|record\\|protected\\(\\s-+body\= \)?\\| use\\)\\b[^_]") =20 (defconst vhdl-statement-fwd-re - "\\b\\(if\\|for\\|while\\)\\b\\([^_]\\|\\'\\)" + "\\b\\(if\\|for\\|while\\|loop\\)\\b\\([^_]\\|\\'\\)" "A regular expression for searching forward that matches all known \"statement\" keywords.") =20 (defconst vhdl-statement-bwd-re - "\\b\\(if\\|for\\|while\\)\\b[^_]" + "\\b\\(if\\|for\\|while\\|loop\\)\\b[^_]" "A regular expression for searching backward that matches all known \"statement\" keywords.") =20 @@ -5852,7 +6096,7 @@ in the middle of an identifier that just happens = to=20 contain a =09 ;; Make sure it's the start of a parameter specification. =09 (save-excursion =09 (forward-sexp 2) -=09 (skip-chars-forward " \t\n") +=09 (skip-chars-forward " \t\n\r\f") =09 (looking-at "in\\b[^_]")) =09 ;; Make sure it's not an "end for". =09 (save-excursion @@ -5871,7 +6115,7 @@ in the middle of an identifier that just happens = to=20 contain a t) )) =20 -(defconst vhdl-case-alternative-re "when[( \t\n][^;=3D>]+=3D>" +(defconst vhdl-case-alternative-re "when[( \t\n\r\f][^;=3D>]+=3D>" "Regexp describing a case statement alternative key.") =20 (defun vhdl-case-alternative-p (&optional lim) @@ -5908,6 +6152,9 @@ contain a \"when\" keyword." =09(cond =09 ;; "begin" keyword: =09 ((and (looking-at vhdl-begin-fwd-re) +=09 (or (not (looking-at "\\")) +=09=09 (save-excursion (back-to-indentation) +=09=09=09=09 (looking-at "\\(\\w+\\s-*:\\s-*\\)?\\<\\(case\\|elsif\\= | if\\)\\>"))) =09 (/=3D (preceding-char) ?_) =09 (vhdl-begin-p lim)) =09 (setq foundp 'begin)) @@ -5931,7 +6178,7 @@ With COUNT, do it that many times." (save-excursion (while (> count 0) =09;; skip whitespace -=09(skip-chars-forward " \t\n") +=09(skip-chars-forward " \t\n\r\f") =09;; Check for an unbalanced "end" keyword =09(if (and (looking-at vhdl-end-fwd-re) =09=09 (/=3D (preceding-char) ?_) @@ -6007,6 +6254,10 @@ searches." =09 nil =09 (backward-sexp) =09 (if (and (looking-at vhdl-begin-fwd-re) +=09=09 (or (not (looking-at "\\")) +=09=09 (save-excursion +=09=09=09 (back-to-indentation) +=09=09=09 (looking-at "\\(\\w+\\s-*:\\s-*\\)?\\<\\(case\\|elsif\\|if\\= )\\>"))) =09=09 (/=3D (preceding-char) ?_) =09=09 (not (vhdl-in-literal)) =09=09 (vhdl-begin-p lim)) @@ -6278,7 +6529,7 @@ search, and an argument indicating an interactive= call." (re-search-forward vhdl-e-o-s-re)) =20 (defconst vhdl-b-o-s-re - (concat ";\\|\(\\|\)\\|\\bwhen\\b[^_]\\|" + (concat ";[^_]\\|\([^_]\\|\)[^_]\\|\\bwhen\\b[^_]\\|" =09 vhdl-begin-bwd-re "\\|" vhdl-statement-bwd-re)) =20 (defun vhdl-beginning-of-statement-1 (&optional lim) @@ -6299,7 +6550,7 @@ statement if already at the beginning of one." (while (and (not donep) =09=09(not (bobp)) =09=09;; look backwards for a statement boundary -=09=09(re-search-backward vhdl-b-o-s-re lim 'move)) +=09=09(progn (forward-char) (re-search-backward vhdl-b-o-s-re lim 'mov= e))) (if (or (=3D (preceding-char) ?_) =09 (vhdl-in-literal)) =09 (backward-char) @@ -6319,13 +6570,17 @@ statement if already at the beginning of one." =09=09 (vhdl-forward-syntactic-ws here) =09=09 (setq donep t)))) =09 ;; If we are looking at a semicolon, then stop -=09 ((eq (following-char) ?\;) +=09 ((and (eq (following-char) ?\;) (not (vhdl-in-quote-p))) =09 (progn =09 (forward-char) =09 (vhdl-forward-syntactic-ws here) =09 (setq donep t))) =09 ;; If we are looking at a "begin", then stop =09 ((and (looking-at vhdl-begin-fwd-re) +=09 (or (not (looking-at "\\")) +=09=09 (save-excursion +=09=09 (back-to-indentation) +=09=09 (looking-at "\\(\\w+\\s-*:\\s-*\\)?\\<\\(case\\|elsif\\|if\= \)\\>"))) =09 (/=3D (preceding-char) ?_) =09 (vhdl-begin-p nil)) =09 ;; If it's a leader "begin", then find the @@ -6576,6 +6831,10 @@ is not moved." =09(setq begin-after-ip (and =09=09=09 (not literal) =09=09=09 (looking-at vhdl-begin-fwd-re) +=09=09=09 (or (not (looking-at "\\")) +=09=09=09=09 (save-excursion +=09=09=09=09 (back-to-indentation) +=09=09=09=09 (looking-at "\\(\\w+\\s-*:\\s-*\\)?\\<\\(case\\|elsif\= \| if\\)\\>"))) =09=09=09 (vhdl-begin-p))) =09(setq end-after-ip (and =09=09=09 (not literal) @@ -6624,7 +6883,8 @@ is not moved." =09 ((progn =09 (vhdl-backward-syntactic-ws lim) =09 (or (bobp) -=09=09 (=3D (preceding-char) ?\;))) +=09=09 (and (=3D (preceding-char) ?\;) +=09=09 (not (vhdl-in-quote-p))))) =09 (vhdl-add-syntax 'statement placeholder)) =09 ;; CASE 2D: we are looking at a top-level statement-cont =09 (t @@ -6662,6 +6922,10 @@ is not moved." =09=09 (save-excursion =09=09 (vhdl-beginning-of-statement-1 containing-sexp) =09=09 (skip-chars-backward " \t(") +=09=09 (while (and (=3D (preceding-char) ?\;) +=09=09=09 (not (vhdl-in-quote-p))) +=09=09 (vhdl-beginning-of-statement-1 containing-sexp) +=09=09 (skip-chars-backward " \t(")) =09=09 (<=3D (point) containing-sexp))) =09 (goto-char containing-sexp) =09 (vhdl-add-syntax 'arglist-cont-nonempty (vhdl-point 'boi))) @@ -6730,7 +6994,7 @@ is not moved." =09=09 (save-excursion =09=09 (goto-char new) =09=09 (eq new (progn (back-to-indentation) (point))))) -=09=09(setq placeholder new))) +=09=09(setq placeholder new)))=09 =09 (vhdl-add-syntax 'statement-cont placeholder) =09 (if begin-after-ip =09 (vhdl-add-syntax 'block-open))) @@ -6891,7 +7155,7 @@ only-lines." (let* ((relpos (cdr langelem)) =09 (assignp (save-excursion =09=09 (goto-char (vhdl-point 'boi)) -=09=09 (and (re-search-forward "\\(<\\|:\\)=3D" +=09=09 (and (re-search-forward "\\(<\\|:\\|=3D\\)=3D" =09=09=09=09=09 (vhdl-point 'eol) t) =09=09=09 (- (point) (vhdl-point 'boi))))) =09 (curcol (progn @@ -6900,7 +7164,7 @@ only-lines." =09 foundp) (while (and (not foundp) =09=09 (< (point) (vhdl-point 'eol))) -=09(re-search-forward "\\(<\\|:\\)=3D\\|(" (vhdl-point 'eol) 'move) +=09(re-search-forward "\\(<\\|:\\|=3D\\)=3D\\|(" (vhdl-point 'eol) 'mo= ve) =09(if (vhdl-in-literal) =09 (forward-char) =09 (if (=3D (preceding-char) ?\() @@ -7001,7 +7265,8 @@ character is a space." (interactive) (if (and (=3D (preceding-char) ? ) (vhdl-in-comment-p)) (indent-new-comment-line) - (when (and (>=3D (preceding-char) ?a) (<=3D (preceding-char) ?z)) + (when (and (>=3D (preceding-char) ?a) (<=3D (preceding-char) ?z) +=09 (not (vhdl-in-comment-p))) (vhdl-fix-case-word -1)) (newline-and-indent))) =20 @@ -7011,6 +7276,7 @@ indentation change." (interactive) (let* ((syntax (and vhdl-indent-syntax-based (vhdl-get-syntactic-con= text))) =09 (pos (- (point-max) (point))) +=09 (is-comment nil) =09 (indent =09 (if syntax =09 ;; indent syntax-based @@ -7018,6 +7284,15 @@ indentation change." =09=09 (>=3D (vhdl-get-offset (car syntax)) comment-column)) =09=09 ;; special case: comments at or right of comment-column =09=09 (vhdl-get-offset (car syntax)) +=09=09;; align comments like following code line +=09=09(when vhdl-indent-comment-like-next-code-line +=09=09 (save-excursion +=09=09 (while (eq (caar syntax) 'comment) +=09=09 (setq is-comment t) +=09=09 (beginning-of-line 2) +=09=09 (setq syntax (vhdl-get-syntactic-context))))) +=09=09(when is-comment +=09=09 (setq syntax (cons (cons 'comment nil) syntax))) =09=09(apply '+ (mapcar 'vhdl-get-offset syntax))) =09 ;; indent like previous nonblank line =09 (save-excursion (beginning-of-line) @@ -7026,10 +7301,13 @@ indentation change." =09 (shift-amt (- indent (current-indentation)))) (and vhdl-echo-syntactic-information-p =09 (message "syntax: %s, indent=3D %d" syntax indent)) - (unless (zerop shift-amt) - (delete-region (vhdl-point 'bol) (vhdl-point 'boi)) - (beginning-of-line) - (indent-to indent)) + (let ((has-formfeed +=09 (save-excursion (beginning-of-line) (looking-at "\\s-*\f")))) + (when (or (not (zerop shift-amt)) has-formfeed) +=09(delete-region (vhdl-point 'bol) (vhdl-point 'boi)) +=09(beginning-of-line) +=09(when has-formfeed (insert "\f")) +=09(indent-to indent))) (if (< (point) (vhdl-point 'boi)) =09(back-to-indentation) ;; If initial point was within line's indentation, position afte= r @@ -7040,7 +7318,7 @@ indentation change." (vhdl-update-progress-info "Indenting" (vhdl-current-line)) shift-amt)) =20 -(defun vhdl-indent-region (beg end column) +(defun vhdl-indent-region (beg end &optional column) "Indent region as VHDL code. Adds progress reporting to `indent-region'." (interactive "r\nP") @@ -7055,7 +7333,7 @@ Adds progress reporting to `indent-region'." "Indent whole buffer as VHDL code. Calls `indent-region' for whole buffer and adds progress reporting." (interactive) - (vhdl-indent-region (point-min) (point-max) nil)) + (vhdl-indent-region (point-min) (point-max))) =20 (defun vhdl-indent-group () "Indent group of lines between empty lines." @@ -7068,7 +7346,7 @@ Calls `indent-region' for whole buffer and adds p= rogress=20 reporting." =09 (if (re-search-forward vhdl-align-group-separate nil t) =09=09 (point-marker) =09=09 (point-max-marker))))) - (vhdl-indent-region beg end nil))) + (vhdl-indent-region beg end))) =20 (defun vhdl-indent-sexp (&optional endpos) "Indent each line of the list starting just after point. @@ -7131,21 +7409,23 @@ ENDPOS is encountered." (defconst vhdl-align-alist '( ;; after some keywords - (vhdl-mode "^\\s-*\\(constant\\|quantity\\|signal\\|subtype\\|term= inal\\| type\\|variable\\)[ \t]" -=09 "^\\s-*\\(constant\\|quantity\\|signal\\|subtype\\|terminal\= \| type\\|variable\\)\\([ \t]+\\)" 2) + (vhdl-mode "^\\s-*\\(across\\|constant\\|quantity\\|signal\\|subty= pe\\| terminal\\|through\\|type\\|variable\\)[ \t]" +=09 "^\\s-*\\(across\\|constant\\|quantity\\|signal\\|subtype\\|= terminal\\|through\\|type\\|variable\\)\\([ \t]+\\)" 2) ;; before ':' (vhdl-mode ":[^=3D]" "\\([ \t]*\\):[^=3D]") ;; after direction specifications (vhdl-mode ":[ \t]*\\(in\\|out\\|inout\\|buffer\\|\\)\\>" =09 ":[ \t]*\\(in\\|out\\|inout\\|buffer\\|\\)\\([ \t]+\\)" 2) ;; before "=3D=3D", ":=3D", "=3D>", and "<=3D" - (vhdl-mode "[<:=3D]=3D" "\\([ \t]*\\)[<:=3D]=3D" 1) ; since "<=3D = ... =3D>" can occur + (vhdl-mode "[<:=3D]=3D" "\\([ \t]*\\)\\??[<:=3D]=3D" 1) ; since "<= =3D ... =3D>" can=20 occur (vhdl-mode "=3D>" "\\([ \t]*\\)=3D>" 1) - (vhdl-mode "[<:=3D]=3D" "\\([ \t]*\\)[<:=3D]=3D" 1) ; since "=3D> = ... <=3D" can occur + (vhdl-mode "[<:=3D]=3D" "\\([ \t]*\\)\\??[<:=3D]=3D" 1) ; since "=3D= > ... <=3D" can=20 occur ;; before some keywords (vhdl-mode "[ \t]after\\>" "[^ \t]\\([ \t]+\\)after\\>" 1) (vhdl-mode "[ \t]when\\>" "[^ \t]\\([ \t]+\\)when\\>" 1) (vhdl-mode "[ \t]else\\>" "[^ \t]\\([ \t]+\\)else\\>" 1) + (vhdl-mode "[ \t]across\\>" "[^ \t]\\([ \t]+\\)across\\>" 1) + (vhdl-mode "[ \t]through\\>" "[^ \t]\\([ \t]+\\)through\\>" 1) ;; before "=3D>" since "when/else ... =3D>" can occur (vhdl-mode "=3D>" "\\([ \t]*\\)=3D>" 1) ) @@ -7195,7 +7475,7 @@ parentheses." =09(forward-list) =09(setq end (point)) =09(goto-char (1+ beg)) -=09(skip-chars-forward " \t\n") +=09(skip-chars-forward " \t\n\r\f") =09(setq beg (point)))) ;; run FUNCTION (if beg @@ -7280,8 +7560,14 @@ the token in MATCH." =09 bol (setq begin (progn (beginning-of-line) (point)))) (while (< bol end) =09(save-excursion -=09 (when (and (re-search-forward match eol t) -=09=09 (not (vhdl-in-literal))) +=09 (when (and (vhdl-re-search-forward match eol t) +=09=09 (save-excursion +=09=09 (goto-char (match-beginning 0)) +=09=09 (forward-char) +=09=09 (and (not (vhdl-in-literal)) +=09=09=09 (not (vhdl-in-quote-p)) +=09=09=09 (not (vhdl-in-extended-identifier-p)))) +=09=09 (not (looking-at "\\s-*$"))) =09 (setq distance (- (match-beginning substr) bol)) =09 (when (> distance max) =09 (setq max distance)))) @@ -7295,8 +7581,16 @@ the token in MATCH." (goto-char (setq bol begin)) (setq eol (point-at-eol)) (while (> lines 0) - =09(when (and (re-search-forward match eol t) -=09=09 (not (vhdl-in-literal))) + =09(when (and (vhdl-re-search-forward match eol t) +=09=09 (save-excursion +=09=09 (goto-char (match-beginning 0)) +=09=09 (forward-char) +=09=09 (and (not (vhdl-in-literal)) +=09=09=09 (not (vhdl-in-quote-p)) +=09=09=09 (not (vhdl-in-extended-identifier-p)))) +=09=09 (not (looking-at "\\s-*$")) +=09=09 (> (match-beginning 0) ; not if at boi +=09=09 (save-excursion (back-to-indentation) (point)))) =09 (setq width (- (match-end substr) (match-beginning substr))) =09 (setq distance (- (match-beginning substr) bol)) =09 (goto-char (match-beginning substr)) @@ -7449,7 +7743,7 @@ the token in MATCH." ;; search for comment start positions and lengths (while (< (point) end) =09 (when (and (not (looking-at "^\\s-*\\(begin\\|end\\)\\>")) -=09=09 (looking-at "^\\(.*[^ \t\n-]+\\)\\s-*\\(--.*\\)$") +=09=09 (looking-at "^\\(.*[^ \t\n\r\f-]+\\)\\s-*\\(--.*\\)$") =09=09 (not (save-excursion (goto-char (match-beginning 2)) =09=09=09=09=09 (vhdl-in-literal)))) =09 (setq start (+ (- (match-end 1) (match-beginning 1)) spacing)) @@ -7474,7 +7768,7 @@ the token in MATCH." (while (< (point) end) =09 (setq cur-start nil) =09 (when (and (not (looking-at "^\\s-*\\(begin\\|end\\)\\>")) -=09=09 (or (and (looking-at "^\\(.*[^ \t\n-]+\\)\\(\\s-*\\)\\(--.*\= \)$") +=09=09 (or (and (looking-at "^\\(.*[^ \t\n\r\f-]+\\)\\(\\s-*\\)\\(-= -.*\\)$") =09=09=09 (not (save-excursion =09=09=09=09 (goto-char (match-beginning 3)) =09=09=09=09 (vhdl-in-literal)))) @@ -7582,32 +7876,35 @@ end of line, do nothing in comments and strings= ." (setq end (point-marker)) ;; have no space before and one space after `,' and ';' (goto-char beg) - (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\)= \\| \\(\\s-*\\([,;]\\)\\)" end t) + (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\|= \\\\[^\\\n]*[\\\n]\\)\\|\\(\\s-*\\([,;]\\)\\)" end t) (if (match-string 1) =09 (goto-char (match-end 1)) -=09(replace-match "\\3 " nil nil nil 3))) +=09(replace-match "\\3 " nil nil nil 2))) ;; have no space after `(' (goto-char beg) - (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\)= \\| \\((\\)\\s-+" end t) + (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\|= \\\\[^\\\n]*[\\\n]\\)\\|\\((\\)\\s-+" end t) (if (match-string 1) =09 (goto-char (match-end 1)) =09(replace-match "\\2"))) ;; have no space before `)' (goto-char beg) - (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\|= ^\\s-+\\)\\|\\s-+\\()\\)" end t) + (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\|= \\\\[^\\\n]*[\\\n]\\|^\\s-+\\)\\|\\s-+\\()\\)" end t) (if (match-string 1) =09 (goto-char (match-end 1)) =09(replace-match "\\2"))) ;; surround operator symbols by one space (goto-char beg) - (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\)= \\| \\(\\([^/:<>=3D]\\)\\(:\\|=3D\\|<\\|>\\|:=3D\\|<=3D\\|>=3D\\|=3D>\\|/=3D= \\)\\([^=3D>]\\| $\\)\\)" end t) - (if (match-string 1) -=09 (goto-char (match-end 1)) + (while (re-search-forward "\\(--.*\n\\|\"[^\"\n]*[\"\n]\\|\'.\'\\|= \\\\[^\\\n]*[\\\n]\\)\\|\\(\\([^/:<>=3D]\\)\\(:\\|\\??=3D\\|\\??<<\\|\\= ??>>\\| \\??<\\|\\??>\\|:=3D\\|\\??<=3D\\|\\??>=3D\\|=3D>\\|\\??/=3D\\|\\?\\?\\= )\\([^=3D>]\\| $\\)\\)" end t) + (if (or (match-string 1) +=09 (<=3D (match-beginning 0) ; not if at boi +=09=09 (save-excursion (back-to-indentation) (point)))) +=09 (goto-char (match-end 0)) =09(replace-match "\\3 \\4 \\5") =09(goto-char (match-end 2)))) ;; eliminate multiple spaces and spaces at end of line (goto-char beg) (while (or (and (looking-at "--.*\n") (re-search-forward "--.*\n" = end t)) +=09 (and (looking-at "--.*") (re-search-forward "--.*" end t)) =09 (and (looking-at "\"") (re-search-forward "\"[^\"\n]*[\"\n]"= end t)) =09 (and (looking-at "\\s-+$") (re-search-forward "\\s-+$" end t= ) =09=09 (progn (replace-match "" nil nil) t)) @@ -7618,6 +7915,7 @@ end of line, do nothing in comments and strings."= =09=09 (progn (replace-match " " nil nil) t)) =09 (and (looking-at "\\s-+") (re-search-forward "\\s-+" end t) =09=09 (progn (replace-match " " nil nil) t)) +=09 (and (looking-at "-") (re-search-forward "-" end t)) ;=09 (re-search-forward "[^ \t-]+" end t)))) =09 (re-search-forward "[^ \t\"-]+" end t)))) (unless no-message (message "Fixing up whitespace...done"))) @@ -7639,7 +7937,7 @@ case fixing to a region. Calls functions `vhdl-i= ndent- buffer', `vhdl-fix-case-buffer'." (interactive "r") (setq end (save-excursion (goto-char end) (point-marker))) - (vhdl-indent-region beg end nil) + (vhdl-indent-region beg end) (let ((vhdl-align-groups t)) (vhdl-align-region beg end)) (vhdl-fix-case-region beg end)) @@ -7720,7 +8018,7 @@ buffer." (vhdl-prepare-search-2 (end-of-line) ;; look whether in process - (if (not (and (re-search-backward "^\\s-*\\(\\w+[ \t\n]*:[ \t\n]*= \\)? \\(process\\|end\\s-+process\\)\\>" nil t) + (if (not (and (re-search-backward "^\\s-*\\(\\w+[ \t\n\r\f]*:[=20= \t\n\r\f]*\\)?\\(process\\|end\\s-+process\\)\\>" nil t) =09=09 (equal (upcase (match-string 2)) "PROCESS") =09=09 (save-excursion (re-search-forward "^\\s-*end\\s-+process\\>"= nil=20 t)))) =09 (error "ERROR: Not within a process") @@ -7735,7 +8033,7 @@ buffer." (vhdl-prepare-search-2 (goto-char (point-min)) (message "Updating sensitivity lists...") - (while (re-search-forward "^\\s-*\\(\\w+[ \t\n]*:[ \t\n]*\\)?proc= ess\\>"=20 nil t) + (while (re-search-forward "^\\s-*\\(\\w+[ \t\n\r\f]*:[=20 \t\n\r\f]*\\)?process\\>" nil t) (goto-char (match-beginning 0)) (condition-case nil (vhdl-update-sensitivity-list) (error "")))= (message "Updating sensitivity lists...done")))) @@ -7744,9 +8042,13 @@ buffer." "Update sensitivity list." (let ((proc-beg (point)) =09 (proc-end (re-search-forward "^\\s-*end\\s-+process\\>" nil t)) -=09 (proc-mid (re-search-backward "^\\s-*begin\\>" nil t)) +=09 (proc-mid (vhdl-re-search-backward +=09=09 "\\(\\(\\\\)\\|^\\s-*process\\>\\)" nil t)) =09 seq-region-list) (cond + ;; error if 'begin' keyword missing + ((not (match-string 2)) +=09(error "ERROR: No 'begin' keyword found")) ;; search for wait statement (no sensitivity list allowed) ((progn (goto-char proc-mid) =09 (vhdl-re-search-forward "\\" proc-end t)) @@ -7780,19 +8082,19 @@ buffer." =09=09;; case expression =09=09((re-search-forward "^\\s-*case\\>" proc-end t) =09=09 (re-search-forward "\\" proc-end t)) -=09=09;; parameter list of procedure call -=09=09((and (re-search-forward "^\\s-*\\w+[ \t\n]*(" proc-end t) +=09=09;; parameter list of procedure call, array index +=09=09((and (re-search-forward "^\\s-*\\(\\w\\|\\.\\)+[ \t\n\r\f]*(" p= roc-end t) =09=09 (1- (point))) =09=09 (progn (backward-char) (forward-sexp) =09=09=09(while (looking-at "(") (forward-sexp)) (point))))) -=09 name read-list sens-list signal-list +=09 name field read-list sens-list signal-list =09 sens-beg sens-end beg end margin) =09 ;; scan for signals in old sensitivity list =09 (goto-char proc-beg) =09 (re-search-forward "\\" proc-mid t) -=09 (if (not (looking-at "[ \t\n]*(")) +=09 (if (not (looking-at "[ \t\n\r\f]*(")) =09 (setq sens-beg (point)) -=09 (setq sens-beg (re-search-forward "\\([ \t\n]*\\)([ \t\n]*" nil= t)) +=09 (setq sens-beg (re-search-forward "\\([ \t\n\r\f]*\\)([ \t\n\r\= f]*" nil=20 t)) =09 (goto-char (match-end 1)) =09 (forward-sexp) =09 (setq sens-end (1- (point))) @@ -7825,15 +8127,17 @@ buffer." =09=09=09=09=09 (< (point) (caar tmp-list))) =09=09=09=09 (setq tmp-list (cdr tmp-list))) =09=09=09=09 (and tmp-list (< (point) (cdar tmp-list)))))) -=09=09(while (vhdl-re-search-forward "[^'\"]\\<\\([a-zA-Z]\\w*\\)\\>[=20= \t\n]*\\('\\(\\w+\\)\\|\\(=3D>\\)\\)?" end t) +=09=09(while (vhdl-re-search-forward "[^'\".]\\<\\([a-zA-Z]\\w*\\)\\(\= \(\\. \\w+\\|[ \t\n\r\f]*([^)]*)\\)*\\)[ \t\n\r\f]*\\('\\(\\w+\\)\\|\\(=3D>\\= )\\)?"=20 end t) =09=09 (setq name (match-string 1)) -=09=09 (when (and (not (match-string 4)) ; not when formal parameter -=09=09=09 (not (and (match-string 3) ; not event attribute -=09=09=09=09 (not (member (downcase (match-string 3)) +=09=09 (when vhdl-array-index-record-field-in-sensitivity-list +=09=09 (setq field (match-string 2))) +=09=09 (when (and (not (match-string 6)) ; not when formal parameter +=09=09=09 (not (and (match-string 5) ; not event attribute +=09=09=09=09 (not (member (downcase (match-string 5)) =09=09=09=09=09=09 '("event" "last_event" "transaction"))))) =09=09=09 (member (downcase name) signal-list)) -=09=09 (unless (member-ignore-case name read-list) -=09=09 (setq read-list (cons name read-list)))) +=09=09 (unless (member-ignore-case (concat name field) read-list) +=09=09 (setq read-list (cons (concat name field) read-list)))) =09=09 (goto-char (match-end 1))))) =09 (setq scan-regions-list (cdr scan-regions-list))) =09 ;; update sensitivity list @@ -7879,17 +8183,17 @@ buffer." =09 (goto-char (point-min)) =09 (if (not (re-search-forward (concat "^entity\\s-+" entity-name "\\= >") nil=20 t)) =09 (error "ERROR: Entity \"%s\" not found:\n --> see option `vh= dl- entity-file-name'" entity-name) -=09 (when (setq beg (re-search-forward -=09=09=09 "^\\s-*port[ \t\n]*(" +=09 (when (setq beg (vhdl-re-search-forward +=09=09=09 "\\" nil t)) t)) =09 (setq end (save-excursion =09=09=09 (backward-char) (forward-sexp) (point))) =09 (vhdl-forward-syntactic-ws) =09 (while (< (point) end) -=09 (when (looking-at "signal[ \t\n]+") +=09 (when (looking-at "signal[ \t\n\r\f]+") =09=09 (goto-char (match-end 0))) -=09 (while (looking-at "\\(\\w+\\)[ \t\n,]+") +=09 (while (looking-at "\\(\\w+\\)[ \t\n\r\f,]+") =09=09 (setq signal-list =09=09 (cons (downcase (match-string 1)) signal-list)) =09=09 (goto-char (match-end 0)) @@ -7908,12 +8212,12 @@ buffer." =09 (when (=3D 0 (nth 0 (parse-partial-sexp beg (point)))) =09 (if (match-string 2) =09=09 ;; scan signal name -=09=09 (while (looking-at "[ \t\n,]+\\(\\w+\\)") +=09=09 (while (looking-at "[ \t\n\r\f,]+\\(\\w+\\)") =09=09 (setq signal-list =09=09=09 (cons (downcase (match-string 1)) signal-list)) =09=09 (goto-char (match-end 0))) =09 ;; scan alias name, check is alias of (declared) signal -=09 (when (and (looking-at "[ \t\n]+\\(\\w+\\)[^;]*\\")) - (when (eq vhdl-reset-kind 'async) + (when (eq reset-kind 'query) +=09(setq reset-kind +=09 (if (eq (vhdl-decision-query +=09=09 "" "(a)synchronous or (s)ynchronous reset?" t) ?a) +=09=09 'async +=09=09'sync))) + (when (eq reset-kind 'async) =09(insert ", ") =09(setq reset (or (and (not (equal "" vhdl-reset-name)) =09=09=09 (progn (insert vhdl-reset-name) vhdl-reset-name)) @@ -9257,7 +9582,7 @@ otherwise." (unless (vhdl-standard-p '87) (vhdl-insert-keyword " IS")) (insert "\n") (vhdl-template-begin-end "PROCESS" label margin) - (when seq (setq reset (vhdl-template-seq-process clock reset))) + (when seq (setq reset (vhdl-template-seq-process clock reset reset= - kind))) (when vhdl-prompt-for-comments (setq final-pos (point-marker)) (vhdl-prepare-search-2 @@ -9589,13 +9914,13 @@ otherwise." =09(in-arglist (vhdl-in-argument-list-p))) (vhdl-prepare-search-2 (if (or (save-excursion -=09 (and (vhdl-re-search-backward -=09=09 "\\" -=09=09 nil t) -=09=09 (not (progn (backward-word 1) (looking-at "\\"))))) +=09 (progn (vhdl-beginning-of-block) +=09=09 (looking-at "\\s-*\\(\\w+\\s-*:\\s-*\\)?\\<\\(\\"))) =09 (save-excursion (backward-word 1) (looking-at "\\"))= ) =09 (vhdl-insert-keyword "VARIABLE ") - (vhdl-insert-keyword "SHARED VARIABLE "))) + (if (vhdl-standard-p '87) +=09 (error "ERROR: Not within sequential block") +=09 (vhdl-insert-keyword "SHARED VARIABLE ")))) (when (vhdl-template-field "names" nil t start (point)) (insert " : ") (when in-arglist (vhdl-template-field "[IN | OUT | INOUT]" " " t= )) @@ -9692,14 +10017,16 @@ otherwise." (concat (if vhdl-clock-rising-edge "rising" "falling") =09 " clock edge"))))) =20 -(defun vhdl-template-seq-process (clock reset) +(defun vhdl-template-seq-process (clock reset reset-kind) "Insert a template for the body of a sequential process." (let ((margin (current-indentation)) =09position) (vhdl-insert-keyword "IF ") - (when (eq vhdl-reset-kind 'async) + (when vhdl-conditions-in-parenthesis (insert "(")) + (when (eq reset-kind 'async) (insert reset " =3D " =09 (if vhdl-reset-active-high vhdl-one-string vhdl-zero-string))= + (when vhdl-conditions-in-parenthesis (insert ")")) (vhdl-insert-keyword " THEN") (vhdl-comment-insert-inline (concat "asynchronous reset (active " @@ -9707,7 +10034,8 @@ otherwise." (insert "\n") (indent-to (+ margin vhdl-basic-offset)) (setq position (point)) (insert "\n") (indent-to margin) - (vhdl-insert-keyword "ELSIF ")) + (vhdl-insert-keyword "ELSIF ") + (when vhdl-conditions-in-parenthesis (insert "("))) (if (eq vhdl-clock-edge-condition 'function) =09(insert (if vhdl-clock-rising-edge "rising" "falling") =09=09"_edge(" clock ")") @@ -9715,17 +10043,20 @@ otherwise." (vhdl-insert-keyword " AND ") (insert clock " =3D " =09 (if vhdl-clock-rising-edge vhdl-one-string vhdl-zero-string))= ) + (when vhdl-conditions-in-parenthesis (insert ")")) (vhdl-insert-keyword " THEN") (vhdl-comment-insert-inline (concat (if vhdl-clock-rising-edge "rising" "falling") " clock ed= ge")) (insert "\n") (indent-to (+ margin vhdl-basic-offset)) - (when (eq vhdl-reset-kind 'sync) + (when (eq reset-kind 'sync) (vhdl-insert-keyword "IF ") + (when vhdl-conditions-in-parenthesis (insert "(")) (setq reset (or (and (not (equal "" vhdl-reset-name)) =09=09=09 (progn (insert vhdl-reset-name) vhdl-reset-name)) =09=09 (vhdl-template-field "reset name") "")) (insert " =3D " =09 (if vhdl-reset-active-high vhdl-one-string vhdl-zero-string))= + (when vhdl-conditions-in-parenthesis (insert ")")) (vhdl-insert-keyword " THEN") (vhdl-comment-insert-inline (concat "synchronous reset (active " @@ -9737,7 +10068,7 @@ otherwise." (insert "\n") (indent-to (+ margin (* 2 vhdl-basic-offset))) (insert "\n") (indent-to (+ margin vhdl-basic-offset)) (vhdl-insert-keyword "END IF;")) - (when (eq vhdl-reset-kind 'none) + (when (eq reset-kind 'none) (setq position (point))) (insert "\n") (indent-to margin) (vhdl-insert-keyword "END IF;") @@ -9761,21 +10092,11 @@ specification, if not already there." =09(insert library ";") =09(when package =09 (insert "\n") -=09 (indent-to margin))) - (when package -=09(vhdl-insert-keyword "USE ") -=09(insert library "." package) -=09(vhdl-insert-keyword ".ALL;"))))) - -(defun vhdl-template-package-math-complex () - "Insert specification of `math_complex' package." - (interactive) - (vhdl-template-standard-package "ieee" "math_complex")) - -(defun vhdl-template-package-math-real () - "Insert specification of `math_real' package." - (interactive) - (vhdl-template-standard-package "ieee" "math_real")) +=09 (indent-to margin)))) + (when package + (vhdl-insert-keyword "USE ") + (insert library "." package) + (vhdl-insert-keyword ".ALL;")))) =20 (defun vhdl-template-package-numeric-bit () "Insert specification of `numeric_bit' package." @@ -9822,6 +10143,56 @@ specification, if not already there." (interactive) (vhdl-template-standard-package "std" "textio")) =20 +(defun vhdl-template-package-fundamental-constants () + "Insert specification of `fundamental_constants' package." + (interactive) + (vhdl-template-standard-package "ieee" "fundamental_constants")) + +(defun vhdl-template-package-material-constants () + "Insert specification of `material_constants' package." + (interactive) + (vhdl-template-standard-package "ieee" "material_constants")) + +(defun vhdl-template-package-energy-systems () + "Insert specification of `energy_systems' package." + (interactive) + (vhdl-template-standard-package "ieee" "energy_systems")) + +(defun vhdl-template-package-electrical-systems () + "Insert specification of `electrical_systems' package." + (interactive) + (vhdl-template-standard-package "ieee" "electrical_systems")) + +(defun vhdl-template-package-mechanical-systems () + "Insert specification of `mechanical_systems' package." + (interactive) + (vhdl-template-standard-package "ieee" "mechanical_systems")) + +(defun vhdl-template-package-radiant-systems () + "Insert specification of `radiant_systems' package." + (interactive) + (vhdl-template-standard-package "ieee" "radiant_systems")) + +(defun vhdl-template-package-thermal-systems () + "Insert specification of `thermal_systems' package." + (interactive) + (vhdl-template-standard-package "ieee" "thermal_systems")) + +(defun vhdl-template-package-fluidic-systems () + "Insert specification of `fluidic_systems' package." + (interactive) + (vhdl-template-standard-package "ieee" "fluidic_systems")) + +(defun vhdl-template-package-math-complex () + "Insert specification of `math_complex' package." + (interactive) + (vhdl-template-standard-package "ieee" "math_complex")) + +(defun vhdl-template-package-math-real () + "Insert specification of `math_real' package." + (interactive) + (vhdl-template-standard-package "ieee" "math_real")) + (defun vhdl-template-directive (directive) "Insert directive." (unless (=3D (current-indentation) (current-column)) @@ -9900,6 +10271,9 @@ specification, if not already there." =09 (insert (user-full-name)) =09 (when user-mail-address (insert " <" user-mail-address ">"))) (goto-char beg) + (while (search-forward "" end t) +=09 (replace-match (user-full-name) t t)) + (goto-char beg) (while (search-forward "" end t) =09 (replace-match (user-login-name) t t)) (goto-char beg) @@ -9915,7 +10289,7 @@ specification, if not already there." (while (search-forward "" end t) =09 (replace-match =09 (concat "VHDL" (cond ((vhdl-standard-p '87) "'87") -=09=09=09 ((vhdl-standard-p '93) "'93")) +=09=09=09 ((vhdl-standard-p '93) "'93/02")) =09=09 (when (vhdl-standard-p 'ams) ", VHDL-AMS") =09=09 (when (vhdl-standard-p 'math) ", Math Packages")) t t)) (goto-char beg) @@ -10021,9 +10395,10 @@ If starting after end-comment-column, start a = new=20 line." "Displays one line of dashes." (interactive) (while (=3D (preceding-char) ?-) (delete-char -2)) + (insert "--") (let* ((col (current-column)) =09 (len (- end-comment-column col))) - (insert-char ?- len))) + (insert-char vhdl-comment-display-line-char len))) =20 (defun vhdl-comment-append-inline () "Append empty inline comment to current line." @@ -10084,7 +10459,7 @@ If starting after end-comment-column, start a n= ew=20 line." (goto-char beg) (beginning-of-line) (setq beg (point)) - (if (looking-at comment-start) + (if (looking-at (concat "\\s-*" comment-start)) =09(comment-region beg end '(4)) (comment-region beg end)))) =20 @@ -10119,7 +10494,7 @@ If starting after end-comment-column, start a n= ew=20 line." (goto-char beg) (beginning-of-line) (while (< (point) end) - (when (looking-at "^.*[^ \t\n-]+\\(\\s-*--.*\\)$") + (when (looking-at "^.*[^ \t\n\r\f-]+\\(\\s-*--.*\\)$") =09(delete-region (match-beginning 1) (match-end 1))) (beginning-of-line 2)))) =20 @@ -10323,9 +10698,9 @@ if in comment and past end-comment-column." =09 (self-insert-command count) =09 (cond ((>=3D (current-column) (+ 2 end-comment-column)) =09=09(backward-char 1) -=09=09(skip-chars-backward "^ \t\n") +=09=09(skip-chars-backward "^ \t\n\r\f") =09=09(indent-new-comment-line) -=09=09(skip-chars-forward "^ \t\n") +=09=09(skip-chars-forward "^ \t\n\r\f") =09=09(forward-char 1)) =09 ((>=3D (current-column) end-comment-column) =09=09(indent-new-comment-line)) @@ -10369,7 +10744,9 @@ with double-quotes is to be inserted. DEFAULT=20= specifies a default string." (vhdl-fix-case-region-1 position (point) vhdl-upper-case-attribu= tes =09=09=09 (concat "'" vhdl-attributes-regexp)) (vhdl-fix-case-region-1 position (point) vhdl-upper-case-enum-va= lues -=09=09=09 vhdl-enum-values-regexp)) +=09=09=09 vhdl-enum-values-regexp) + (vhdl-fix-case-region-1 position (point) vhdl-upper-case-constan= ts +=09=09=09 vhdl-constants-regexp)) (when (or (not (equal string "")) (not optional)) (insert (or follow-string ""))) (if (equal string "") nil string))) @@ -10455,55 +10832,57 @@ else insert tab (used for word completion in = VHDL=20 minibuffer)." (defun vhdl-beginning-of-block () "Move cursor to the beginning of the enclosing block." (let (pos) - (save-excursion - (beginning-of-line) - ;; search backward for block beginning or end - (while (or (while (and (setq pos (re-search-backward "^\\s- *\\(\\(end\\)\\|\\(\\(impure\\|pure\\)[ \t\n]+\\)?\\(function\\| procedure\\)\\|\\(for\\)\\|\\(architecture\\|component\\|configuration\= \| entity\\|package\\|record\\|units\\)\\|\\(\\w+[ \t\n]*:[ \t\n]*\\)? \\(postponed[ \t\n]+\\)?\\(block\\|case\\|for\\|if\\|procedural\\|proce= ss\\| while\\)\\)\\>" nil t)) -=09=09=09 ;; not consider subprogram declarations -=09=09=09 (or (and (match-string 5) -=09=09=09=09 (save-match-data -=09=09=09=09=09(save-excursion -=09=09=09=09=09 (goto-char (match-end 5)) -=09=09=09=09=09 (forward-word 1) -=09=09=09=09=09 (vhdl-forward-syntactic-ws) -=09=09=09=09=09 (when (looking-at "(") -=09=09=09=09=09 (forward-sexp)) -=09=09=09=09=09 (re-search-forward "\\\\|\\(;\\)" nil t)) -=09=09=09=09=09(match-string 1))) -=09=09=09=09 ;; not consider configuration specifications -=09=09=09=09 (and (match-string 6) -=09=09=09=09 (save-match-data -=09=09=09=09=09(save-excursion -=09=09=09=09=09 (vhdl-end-of-block) -=09=09=09=09=09 (beginning-of-line) -=09=09=09=09=09 (not (looking-at "^\\s-*end\\s-+\\(for\\|generate\\| loop\\)\\>")))))))) -=09=09 (match-string 2)) -=09;; skip subblock if block end found -=09(vhdl-beginning-of-block))) + (vhdl-prepare-search-2 + (save-excursion + (beginning-of-line) + ;; search backward for block beginning or end + (while (or (while (and (setq pos (re-search-backward "^\\s- *\\(\\(end\\)\\|\\(\\(impure\\|pure\\)[ \t\n\r\f]+\\)?\\(function\\| procedure\\)\\|\\(for\\)\\|\\(architecture\\|component\\|configuration\= \| entity\\|package\\(\\s-+body\\)?\\|type[ \t\n\r\f]+\\w+[ \t\n\r\f]+is[=20= \t\n\r\f]+\\(record\\|protected\\(\\s-+body\\)?\\)\\|units\\)\\|\\(\\w+= [=20 \t\n\r\f]*:[ \t\n\r\f]*\\)?\\(postponed[ \t\n\r\f]+\\)?\\(block\\|case\= \| for\\|if\\|procedural\\|process\\|while\\|loop\\)\\)\\>" nil t)) +=09=09=09 ;; not consider subprogram declarations +=09=09=09 (or (and (match-string 5) +=09=09=09=09 (save-match-data +=09=09=09=09=09 (save-excursion +=09=09=09=09=09 (goto-char (match-end 5)) +=09=09=09=09=09 (forward-word 1) +=09=09=09=09=09 (vhdl-forward-syntactic-ws) +=09=09=09=09=09 (when (looking-at "(") +=09=09=09=09=09 (forward-sexp)) +=09=09=09=09=09 (re-search-forward "\\\\|\\(;\\)" nil t)) +=09=09=09=09=09 (match-string 1))) +=09=09=09=09 ;; not consider configuration specifications +=09=09=09=09 (and (match-string 6) +=09=09=09=09 (save-match-data +=09=09=09=09=09 (save-excursion +=09=09=09=09=09 (vhdl-end-of-block) +=09=09=09=09=09 (beginning-of-line) +=09=09=09=09=09 (not (looking-at "^\\s-*end\\s-+\\(for\\|generate\\|= loop\\)\\>")))))))) +=09=09 (match-string 2)) +=09 ;; skip subblock if block end found +=09 (vhdl-beginning-of-block)))) (when pos (goto-char pos)))) =20 (defun vhdl-end-of-block () "Move cursor to the end of the enclosing block." (let (pos) - (save-excursion - (end-of-line) - ;; search forward for block beginning or end - (while (or (while (and (setq pos (re-search-forward "^\\s- *\\(\\(end\\)\\|\\(\\(impure\\|pure\\)[ \t\n]+\\)?\\(function\\| procedure\\)\\|\\(for\\)\\|\\(architecture\\|component\\|configuration\= \| entity\\|package\\|record\\|units\\)\\|\\(\\w+[ \t\n]*:[ \t\n]*\\)? \\(postponed[ \t\n]+\\)?\\(block\\|case\\|for\\|if\\|procedural\\|proce= ss\\| while\\)\\)\\>" nil t)) -=09=09=09 ;; not consider subprogram declarations -=09=09=09 (or (and (match-string 5) -=09=09=09=09 (save-match-data -=09=09=09=09=09(save-excursion (re-search-forward "\\\\|\\(;\\)"= nil t)) -=09=09=09=09=09(match-string 1))) -=09=09=09=09 ;; not consider configuration specifications -=09=09=09=09 (and (match-string 6) -=09=09=09=09 (save-match-data -=09=09=09=09=09(save-excursion -=09=09=09=09=09 (vhdl-end-of-block) -=09=09=09=09=09 (beginning-of-line) -=09=09=09=09=09 (not (looking-at "^\\s-*end\\s-+\\(for\\|generate\\| loop\\)\\>")))))))) -=09=09 (not (match-string 2))) -=09;; skip subblock if block beginning found -=09(vhdl-end-of-block))) + (vhdl-prepare-search-2 + (save-excursion + (end-of-line) + ;; search forward for block beginning or end + (while (or (while (and (setq pos (re-search-forward "^\\s- *\\(\\(end\\)\\|\\(\\(impure\\|pure\\)[ \t\n\r\f]+\\)?\\(function\\| procedure\\)\\|\\(for\\)\\|\\(architecture\\|component\\|configuration\= \| entity\\|package\\(\\s-+body\\)?\\|type[ \t\n\r\f]+\\w+[ \t\n\r\f]+is[=20= \t\n\r\f]+\\(record\\|protected\\(\\s-+body\\)?\\)\\|units\\)\\|\\(\\w+= [=20 \t\n\r\f]*:[ \t\n\r\f]*\\)?\\(postponed[ \t\n\r\f]+\\)?\\(block\\|case\= \| for\\|if\\|procedural\\|process\\|while\\|loop\\)\\)\\>" nil t)) +=09=09=09 ;; not consider subprogram declarations +=09=09=09 (or (and (match-string 5) +=09=09=09=09 (save-match-data +=09=09=09=09=09 (save-excursion (re-search-forward "\\\\|\\(;\\)= " nil t)) +=09=09=09=09=09 (match-string 1))) +=09=09=09=09 ;; not consider configuration specifications +=09=09=09=09 (and (match-string 6) +=09=09=09=09 (save-match-data +=09=09=09=09=09 (save-excursion +=09=09=09=09=09 (vhdl-end-of-block) +=09=09=09=09=09 (beginning-of-line) +=09=09=09=09=09 (not (looking-at "^\\s-*end\\s-+\\(for\\|generate\\|= loop\\)\\>")))))))) +=09=09 (not (match-string 2))) +=09 ;; skip subblock if block beginning found +=09 (vhdl-end-of-block)))) (when pos (goto-char pos)))) =20 (defun vhdl-sequential-statement-p () @@ -10518,7 +10897,7 @@ else insert tab (used for word completion in VH= DL=20 minibuffer)." =09=09 (< start (point))) =09 ;; ... a sequential block =09 (progn (vhdl-beginning-of-block) -=09=09 (looking-at "^\\s-*\\(\\(\\w+[ \t\n]+\\)?\\(function\\|proced= ure\\)\\| \\(\\w+[ \t\n]*:[ \t\n]*\\)?\\(\\w+[ \t\n]+\\)?\\(procedural\\| process\\)\\)\\>"))))))) +=09=09 (looking-at "^\\s-*\\(\\(\\w+[ \t\n\r\f]+\\)?\\(function\\| procedure\\)\\|\\(\\w+[ \t\n\r\f]*:[ \t\n\r\f]*\\)?\\(\\w+[ \t\n\r\f]+\= \)? \\(procedural\\|process\\)\\)\\>"))))))) =20 (defun vhdl-in-argument-list-p () "Check if within an argument list." @@ -10542,7 +10921,9 @@ but not if inside a comment or quote." (progn =09(insert " ") =09(unexpand-abbrev) -=09(delete-char -1)) +=09(backward-word 1) +=09(vhdl-case-word 1) +=09(delete-char 1)) (if (not vhdl-electric-mode) =09(progn =09 (insert " ") @@ -10821,7 +11202,10 @@ but not if inside a comment or quote." (defun vhdl-parse-string (string &optional optional) "Check that the text following point matches the regexp in STRING." (if (looking-at string) - (goto-char (match-end 0)) + (progn (goto-char (match-end 0)) +=09 (when (vhdl-in-literal) +=09 (end-of-line)) +=09 (point)) (unless optional (throw 'parse (format "ERROR: Syntax error near line %s, expect= ing=20 \"%s\"" =09=09=09 (vhdl-current-line) string))) @@ -10919,7 +11303,9 @@ reflected in a subsequent paste operation." =09 port-dir (car port-dir-car)) =09(setcar port-dir-car =09=09(cond ((equal port-dir "in") "out") +=09=09 ((equal port-dir "IN") "OUT") =09=09 ((equal port-dir "out") "in") +=09=09 ((equal port-dir "OUT") "IN") =09=09 (t port-dir))) =09(setq port-list (cdr port-list))) (setq vhdl-port-reversed-direction (not vhdl-port-reversed-direc= tion)) @@ -10949,20 +11335,23 @@ reflected in a subsequent paste operation." =09 (message "Reading port of %s \"%s\"..." decl-type name) =09 (vhdl-forward-syntactic-ws) =09 ;; parse generic clause -=09 (when (vhdl-parse-string "generic[ \t\n]*(" t) +=09 (when (vhdl-parse-string "generic[ \t\n\r\f]*(" t) =09 ;; parse group comment and spacing =09 (setq group-comment (vhdl-parse-group-comment)) -=09 (setq end-of-list (vhdl-parse-string ")[ \t\n]*;[ \t\n]*" t)) +=09 (setq end-of-list (vhdl-parse-string ")[ \t\n\r\f]*;[ \t\n\r\f]= *" t)) =09 (while (not end-of-list) =09 ;; parse names (accept extended identifiers) -=09 (vhdl-parse-string "\\(\\w+\\|\\\\[^\\]+\\\\\\)[ \t\n]*") +=09 (vhdl-parse-string "\\(\\\\[^\\]+\\\\\\|\\w+\\)[ \t\n\r\f]*")= =09 (setq names (list (match-string-no-properties 1))) -=09 (while (vhdl-parse-string ",[ \t\n]*\\(\\w+\\)[ \t\n]*" t) +=09 (while (vhdl-parse-string ",[ \t\n\r\f]*\\(\\\\[^\\]+\\\\\\|\= \w+\\)[=20 \t\n\r\f]*" t) =09=09(setq names =09=09 (append names (list (match-string-no-properties 1))))) =09 ;; parse type -=09 (vhdl-parse-string ":[ \t\n]*\\([^():;\n]+\\)") +=09 (vhdl-parse-string ":[ \t\n\r\f]*\\([^():;\n]+\\)") =09 (setq type (match-string-no-properties 1)) +=09 (when (vhdl-in-comment-p) ; if stuck in comment +=09=09(setq type (concat type (and (vhdl-parse-string ".*") +=09=09=09=09=09 (match-string-no-properties 0))))) =09 (setq comment nil) =09 (while (looking-at "(") =09=09(setq type @@ -10980,7 +11369,7 @@ reflected in a subsequent paste operation." =09 (setq type (substring type 0 (match-end 1))) =09 ;; parse initialization expression =09 (setq init nil) -=09 (when (vhdl-parse-string ":=3D[ \t\n]*" t) +=09 (when (vhdl-parse-string ":=3D[ \t\n\r\f]*" t) =09=09(vhdl-parse-string "\\([^();\n]*\\)") =09=09(setq init (match-string-no-properties 1)) =09=09(while (looking-at "(") @@ -11014,28 +11403,31 @@ reflected in a subsequent paste operation." =09 ;; parse group comment and spacing =09 (setq group-comment (vhdl-parse-group-comment)))) =09 ;; parse port clause -=09 (when (vhdl-parse-string "port[ \t\n]*(" t) +=09 (when (vhdl-parse-string "port[ \t\n\r\f]*(" t) =09 ;; parse group comment and spacing =09 (setq group-comment (vhdl-parse-group-comment)) -=09 (setq end-of-list (vhdl-parse-string ")[ \t\n]*;[ \t\n]*" t)) +=09 (setq end-of-list (vhdl-parse-string ")[ \t\n\r\f]*;[ \t\n\r\f]= *" t)) =09 (while (not end-of-list) =09 ;; parse object =09 (setq object -=09=09 (and (vhdl-parse-string "\\<\\(signal\\|quantity\\|terminal\= \)\\>[=20 \t\n]*" t) +=09=09 (and (vhdl-parse-string "\\<\\(signal\\|quantity\\|terminal\= \)\\>[=20 \t\n\r\f]*" t) =09=09=09 (match-string-no-properties 1))) =09 ;; parse names (accept extended identifiers) -=09 (vhdl-parse-string "\\(\\w+\\|\\\\[^\\]+\\\\\\)[ \t\n]*") +=09 (vhdl-parse-string "\\(\\\\[^\\]+\\\\\\|\\w+\\)[ \t\n\r\f]*")= =09 (setq names (list (match-string-no-properties 1))) -=09 (while (vhdl-parse-string ",[ \t\n]*\\(\\w+\\|\\\\[^\\]+\\\\\= \)[=20 \t\n]*" t) +=09 (while (vhdl-parse-string ",[ \t\n\r\f]*\\(\\\\[^\\]+\\\\\\|\= \w+\\)[=20 \t\n\r\f]*" t) =09=09(setq names (append names (list (match-string-no-properties 1)))= )) =09 ;; parse direction -=09 (vhdl-parse-string ":[ \t\n]*") +=09 (vhdl-parse-string ":[ \t\n\r\f]*") =09 (setq direct -=09=09 (and (vhdl-parse-string "\\<\\(in\\|out\\|inout\\|buffer\\| linkage\\)\\>[ \t\n]+" t) +=09=09 (and (vhdl-parse-string "\\<\\(in\\|out\\|inout\\|buffer\\| linkage\\)\\>[ \t\n\r\f]+" t) =09=09=09 (match-string-no-properties 1))) =09 ;; parse type =09 (vhdl-parse-string "\\([^();\n]+\\)") =09 (setq type (match-string-no-properties 1)) +=09 (when (vhdl-in-comment-p) ; if stuck in comment +=09=09(setq type (concat type (and (vhdl-parse-string ".*") +=09=09=09=09=09 (match-string-no-properties 0))))) =09 (setq comment nil) =09 (while (looking-at "(") =09=09(setq type (concat type @@ -11313,7 +11705,7 @@ reflected in a subsequent paste operation." =09 (setq port-list (cdr port-list)) =09 (insert (if port-list "," ");")) =09 ;; paste comment -=09 (when (or vhdl-include-direction-comments +=09 (when (or (and vhdl-include-direction-comments (nth 2 port)) =09=09 vhdl-include-type-comments =09=09 (and vhdl-include-port-comments (nth 4 port))) =09 (vhdl-comment-insert-inline @@ -11454,12 +11846,17 @@ reflected in a subsequent paste operation." =09 ;; paste type =09 (insert " : " (nth 3 port)) =09 ;; paste initialization (inputs only) -=09 (when (and initialize (equal "IN" (upcase (nth 2 port)))) -=09 (insert " :=3D " (if (string-match "(.+)" (nth 3 port)) -=09=09=09 "(others =3D> '0')" "'0'"))) +=09 (when (and initialize (nth 2 port) (equal "IN" (upcase (nth 2 por= t)))) +=09 (insert " :=3D " +=09=09 (cond ((string-match "integer" (nth 3 port)) "0") +=09=09=09 ((string-match "natural" (nth 3 port)) "0") +=09=09=09 ((string-match "positive" (nth 3 port)) "0") +=09=09=09 ((string-match "real" (nth 3 port)) "0.0") +=09=09=09 ((string-match "(.+)" (nth 3 port)) "(others =3D> '0')") +=09=09=09 (t "'0'")))) =09 (insert ";") =09 ;; paste comment -=09 (when (or vhdl-include-direction-comments +=09 (when (or (and vhdl-include-direction-comments (nth 2 port)) =09=09 (and vhdl-include-port-comments (nth 4 port))) =09 (vhdl-comment-insert-inline =09 (concat @@ -11495,8 +11892,14 @@ reflected in a subsequent paste operation." =09 (setq name (car (nth 0 port))) =09 (insert (vhdl-replace-string vhdl-actual-port-name name)) =09 ;; paste initialization -=09 (insert " <=3D " (if (string-match "(.+)" (nth 3 port)) -=09=09=09=09 "(others =3D> '0')" "'0'") ";")) +=09 (insert " <=3D " +=09=09 (cond ((string-match "integer" (nth 3 port)) "0") +=09=09=09 ((string-match "natural" (nth 3 port)) "0") +=09=09=09 ((string-match "positive" (nth 3 port)) "0") +=09=09=09 ((string-match "real" (nth 3 port)) "0.0") +=09=09=09 ((string-match "(.+)" (nth 3 port)) "(others =3D> '0')") +=09=09=09 (t "'0'")) +=09=09 ";")) =09 (setq port-list (cdr port-list)) =09 (when (and port-list =09=09 (equal "IN" (upcase (nth 2 (car port-list))))) @@ -11609,7 +12012,9 @@ reflected in a subsequent paste operation." ;; paste custom declarations (unless (equal "" vhdl-testbench-declarations) =09(insert "\n") -=09(vhdl-insert-string-or-file vhdl-testbench-declarations)) +=09(setq position (point)) +=09(vhdl-insert-string-or-file vhdl-testbench-declarations) +=09(vhdl-indent-region position (point))) (setq position (point)) (insert "\n\n") (vhdl-comment-display-line) (insert "\n") @@ -11638,7 +12043,9 @@ reflected in a subsequent paste operation." ;; paste custom statements (unless (equal "" vhdl-testbench-statements) =09(insert "\n") -=09(vhdl-insert-string-or-file vhdl-testbench-statements)) +=09(setq position (point)) +=09(vhdl-insert-string-or-file vhdl-testbench-statements) +=09(vhdl-indent-region position (point))) (insert "\n") (indent-to vhdl-basic-offset) (unless (eq vhdl-testbench-create-files 'none) @@ -11707,8 +12114,8 @@ reflected in a subsequent paste operation." =09 ;; check if within function declaration =09 (setq pos (point)) =09 (end-of-line) -=09 (when (looking-at "[ \t\n]*\\((\\|;\\|is\\>\\)") (goto-char (matc= h-end=20 0))) -=09 (unless (and (re-search-backward "^\\s-*\\(\\(procedure\\)\\| \\(\\(pure\\|impure\\)\\s-+\\)?function\\)\\s-+\\(\"?\\w+\"?\\)[=20 \t\n]*\\(\\((\\)\\|;\\|is\\>\\)" nil t) +=09 (when (looking-at "[ \t\n\r\f]*\\((\\|;\\|is\\>\\)") (goto-char (= match-end=20 0))) +=09 (unless (and (re-search-backward "^\\s-*\\(\\(procedure\\)\\|\\(\= \(pure\\| impure\\)\\s-+\\)?function\\)\\s-+\\(\"?\\w+\"?\\)[ \t\n\r\f]*\\(\\((\\= )\\|; \\|is\\>\\)" nil t) =09=09 (goto-char (match-end 0)) =09=09 (save-excursion (backward-char) =09=09=09=09 (forward-sexp) @@ -11721,21 +12128,21 @@ reflected in a subsequent paste operation." =09 ;; parse parameter list =09 (setq group-comment (vhdl-parse-group-comment)) =09 (setq end-of-list (or end-of-list -=09=09=09=09(vhdl-parse-string ")[ \t\n]*\\(;\\|\\(is\\|return\\)\\>\\= )" t))) +=09=09=09=09(vhdl-parse-string ")[ \t\n\r\f]*\\(;\\|\\(is\\|return\\)\= \>\\)" t))) =09 (while (not end-of-list) =09 ;; parse object =09 (setq object -=09=09 (and (vhdl-parse-string "\\(constant\\|signal\\|variable\\|fil= e\\| quantity\\|terminal\\)[ \t\n]*" t) +=09=09 (and (vhdl-parse-string "\\(constant\\|signal\\|variable\\|fil= e\\| quantity\\|terminal\\)[ \t\n\r\f]*" t) =09=09=09 (match-string-no-properties 1))) =09 ;; parse names (accept extended identifiers) -=09 (vhdl-parse-string "\\(\\w+\\|\\\\[^\\]+\\\\\\)[ \t\n]*") +=09 (vhdl-parse-string "\\(\\\\[^\\]+\\\\\\|\\w+\\)[ \t\n\r\f]*") =09 (setq names (list (match-string-no-properties 1))) -=09 (while (vhdl-parse-string ",[ \t\n]*\\(\\w+\\|\\\\[^\\]+\\\\\\)= [=20 \t\n]*" t) +=09 (while (vhdl-parse-string ",[ \t\n\r\f]*\\(\\\\[^\\]+\\\\\\|\\w= +\\)[=20 \t\n\r\f]*" t) =09 (setq names (append names (list (match-string-no-properties 1= ))))) =09 ;; parse direction -=09 (vhdl-parse-string ":[ \t\n]*") +=09 (vhdl-parse-string ":[ \t\n\r\f]*") =09 (setq direct -=09=09 (and (vhdl-parse-string "\\(in\\|out\\|inout\\|buffer\\|linkag= e\\)[=20 \t\n]+" t) +=09=09 (and (vhdl-parse-string "\\(in\\|out\\|inout\\|buffer\\|linkag= e\\)[=20 \t\n\r\f]+" t) =09=09 (match-string-no-properties 1))) =09 ;; parse type =09 (vhdl-parse-string "\\([^():;\n]+\\)") @@ -11757,7 +12164,7 @@ reflected in a subsequent paste operation." =09 (setq type (substring type 0 (match-end 1))) =09 ;; parse initialization expression =09 (setq init nil) -=09 (when (vhdl-parse-string ":=3D[ \t\n]*" t) +=09 (when (vhdl-parse-string ":=3D[ \t\n\r\f]*" t) =09 (vhdl-parse-string "\\([^();\n]*\\)") =09 (setq init (match-string-no-properties 1)) =09 (while (looking-at "(") @@ -11787,7 +12194,7 @@ reflected in a subsequent paste operation." =09 (vhdl-parse-string "\\(;\\|\\(is\\|\\(return\\)\\)\\>\\)\\s-*")= =09 ;; parse return type =09 (when (match-string 3) -=09 (vhdl-parse-string "[ \t\n]*\\(.+\\)[ \t\n]*\\(;\\|is\\>\\)\\= s-*") +=09 (vhdl-parse-string "[ \t\n\r\f]*\\(.+\\)[ \t\n\r\f]*\\(;\\| is\\>\\)\\s-*") =09 (setq return-type (match-string-no-properties 1)) =09 (when (and return-type =09=09=09 (string-match "\\(\\s-*--\\s-*\\)\\(.*\\)" return-type)) @@ -12015,17 +12422,15 @@ expressions (e.g. for index ranges of types a= nd=20 signals)." (defalias 'he-list-beg 'vhdl-he-list-beg)) =20 ;; function for expanding abbrevs and dabbrevs -(defun vhdl-expand-abbrev (arg)) -(fset 'vhdl-expand-abbrev (make-hippie-expand-function -=09=09=09 '(try-expand-dabbrev -=09=09=09 try-expand-dabbrev-all-buffers -=09=09=09 vhdl-try-expand-abbrev))) +(defalias 'vhdl-expand-abbrev (make-hippie-expand-function +=09=09=09 '(try-expand-dabbrev +=09=09=09=09 try-expand-dabbrev-all-buffers +=09=09=09=09 vhdl-try-expand-abbrev))) =20 ;; function for expanding parenthesis -(defun vhdl-expand-paren (arg)) -(fset 'vhdl-expand-paren (make-hippie-expand-function -=09=09=09 '(try-expand-list -=09=09=09 try-expand-list-all-buffers))) +(defalias 'vhdl-expand-paren (make-hippie-expand-function +=09=09=09 '(try-expand-list +=09=09=09=09try-expand-list-all-buffers))) =20 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; ;; Case fixing @@ -12049,7 +12454,7 @@ depending on parameter UPPER-CASE." =09=09 (< vhdl-progress-interval =09=09 (- (nth 1 (current-time)) last-update))) =09 (message "Fixing case... (%2d%s)" -=09=09 (+ (* count 25) (/ (* 25 (- (point) beg)) (- end beg))) +=09=09 (+ (* count 20) (/ (* 20 (- (point) beg)) (- end beg))) =09=09 "%") =09 (setq last-update (nth 1 (current-time))))) (goto-char end))))) @@ -12066,6 +12471,8 @@ options vhdl-upper- case-{keywords,types,attributes,enum-values}." beg end vhdl-upper-case-attributes (concat "'" vhdl-attributes-rege= xp) 2) (vhdl-fix-case-region-1 beg end vhdl-upper-case-enum-values vhdl-enum-values-regexp 3) + (vhdl-fix-case-region-1 + beg end vhdl-upper-case-constants vhdl-constants-regexp 4) (when vhdl-progress-interval (message "Fixing case...done"))) =20 (defun vhdl-fix-case-buffer () @@ -12091,6 +12498,9 @@ options vhdl-upper- case-{keywords,types,attributes,enum-values}." (upcase-word 1)) (when (and vhdl-upper-case-enum-values =09=09(looking-at vhdl-enum-values-regexp)) + (upcase-word 1)) + (when (and vhdl-upper-case-constants +=09=09(looking-at vhdl-constants-regexp)) (upcase-word 1))))) =20 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; @@ -12205,6 +12615,9 @@ it works within comments too." (interactive) (let ((no-stats 0) =09(no-code-lines 0) +=09(no-empty-lines 0) +=09(no-comm-lines 0) +=09(no-comments 0) =09(no-lines (count-lines (point-min) (point-max)))) (save-excursion ;; count statements @@ -12218,15 +12631,40 @@ it works within comments too." (while (not (eobp)) =09(unless (looking-at "^\\s-*\\(--.*\\)?$") =09 (setq no-code-lines (1+ no-code-lines))) -=09(beginning-of-line 2))) +=09(beginning-of-line 2)) + ;; count empty lines + (goto-char (point-min)) + (while (and (re-search-forward "^\\s-*$" nil t) +=09=09 (not (eq (point) (point-max)))) +=09(if (match-string 1) +=09 (goto-char (match-end 1)) +=09 (setq no-empty-lines (1+ no-empty-lines)) +=09 (unless (eq (point) (point-max)) +=09 (forward-char)))) + ;; count comment-only lines + (goto-char (point-min)) + (while (re-search-forward "^\\s-*--.*" nil t) +=09(if (match-string 1) +=09 (goto-char (match-end 1)) +=09 (setq no-comm-lines (1+ no-comm-lines)))) + ;; count comments + (goto-char (point-min)) + (while (re-search-forward "--.*" nil t) +=09(if (match-string 1) +=09 (goto-char (match-end 1)) +=09 (setq no-comments (1+ no-comments))))) ;; print results (message "\n\ File statistics: \"%s\"\n\ ---------------------\n\ -# statements : %5d\n\ -# code lines : %5d\n\ -# total lines : %5d\n\ " -=09 (buffer-file-name) no-stats no-code-lines no-lines) +# statements : %5d\n\ +# code lines : %5d\n\ +# empty lines : %5d\n\ +# comment lines : %5d\n\ +# comments : %5d\n\ +# total lines : %5d\n\ " +=09 (buffer-file-name) no-stats no-code-lines no-empty-lines +=09 no-comm-lines no-comments no-lines) (unless vhdl-emacs-21 (vhdl-show-messages)))) =20 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; @@ -12390,18 +12828,18 @@ File statistics: \"%s\"\n\ (concat "\\(^\\)\\s-*\\(" ;; generic/port clause - "\\(generic\\|port\\)[ \t\n]*(\\|" + "\\(generic\\|port\\)[ \t\n\r\f]*(\\|" ;; component "component\\>\\|" ;; component instantiation - "\\(\\w\\|\\s_\\)+[ \t\n]*:[ \t\n]*" - "\\(\\(component\\|configuration\\|entity\\)[ \t\n]+\\)?" - "\\(\\w\\|\\s_\\)+\\([ \t\n]*(\\(\\w\\|\\s_\\)+)\\)?[ \t\n]*" - "\\(generic\\|port\\)[ \t\n]+map[ \t\n]*(\\|" + "\\(\\w\\|\\s_\\)+[ \t\n\r\f]*:[ \t\n\r\f]*" + "\\(\\(component\\|configuration\\|entity\\)[ \t\n\r\f]+\\)?" + "\\(\\w\\|\\s_\\)+\\([ \t\n\r\f]*(\\(\\w\\|\\s_\\)+)\\)?[ \t\n\r\f]= *" + "\\(generic\\|port\\)[ \t\n\r\f]+map[ \t\n\r\f]*(\\|" ;; subprogram "\\(function\\|procedure\\)\\>\\|" ;; process, block - "\\(\\(\\w\\|\\s_\\)+[ \t\n]*:[ \t\n]*\\)?\\(process\\|block\\)\\>\= \|" + "\\(\\(\\w\\|\\s_\\)+[ \t\n\r\f]*:[ \t\n\r\f]*\\)?\\(process\\| block\\)\\>\\|" ;; configuration declaration "configuration\\>" "\\)") @@ -12414,7 +12852,7 @@ File statistics: \"%s\"\n\ (beginning-of-line) (cond ;; generic/port clause - ((looking-at "^\\s-*\\(generic\\|port\\)[ \t\n]*(") + ((looking-at "^\\s-*\\(generic\\|port\\)[ \t\n\r\f]*(") (goto-char (match-end 0)) (backward-char) (forward-sexp)) @@ -12424,16 +12862,16 @@ File statistics: \"%s\"\n\ ;; component instantiation ((looking-at =09(concat -=09 "^\\s-*\\w+\\s-*:[ \t\n]*" -=09 "\\(\\(component\\|configuration\\|entity\\)[ \t\n]+\\)?" -=09 "\\w+\\(\\s-*(\\w+)\\)?[ \t\n]*" -=09 "\\(generic\\|port\\)\\s-+map[ \t\n]*(")) +=09 "^\\s-*\\w+\\s-*:[ \t\n\r\f]*" +=09 "\\(\\(component\\|configuration\\|entity\\)[ \t\n\r\f]+\\)?" +=09 "\\w+\\(\\s-*(\\w+)\\)?[ \t\n\r\f]*" +=09 "\\(generic\\|port\\)\\s-+map[ \t\n\r\f]*(")) (goto-char (match-end 0)) (backward-char) (forward-sexp) (setq pos (point)) (vhdl-forward-syntactic-ws) - (when (looking-at "port\\s-+map[ \t\n]*(") + (when (looking-at "port\\s-+map[ \t\n\r\f]*(") =09 (goto-char (match-end 0)) =09 (backward-char) =09 (forward-sexp) @@ -12585,7 +13023,7 @@ This does highlighting of keywords and standard= =20 identifiers.") ;; highlight labels of common constructs (list (concat - "^\\s-*\\(\\w+\\)\\s-*:[ \t\n]*\\(\\(" + "^\\s-*\\(\\w+\\)\\s-*:[ \t\n\r\f]*\\(\\(" "assert\\|block\\|case\\|exit\\|for\\|if\\|loop\\|next\\|null\\|"= "postponed\\|process\\|" (when (vhdl-standard-p 'ams) "procedural\\|") @@ -12596,14 +13034,14 @@ This does highlighting of keywords and standa= rd=20 identifiers.") ;; highlight label and component name of component instantiations (list (concat - "^\\s-*\\(\\w+\\)\\s-*:[ \t\n]*\\(\\w+\\)" - "\\(\\s-*\\(--[^\n]*\\)?$\\|\\s-+\\(generic\\|port\\)\\s-+map\\>\= \)") + "^\\s-*\\(\\w+\\)\\s-*:[ \t\n\r\f]*\\(\\w+\\)[ \t\n\r\f]*" + "\\(--[^\n]*[ \t\n\r\f]+\\)*\\(generic\\|port\\)\\s-+map\\>") '(1 font-lock-function-name-face) '(2 font-lock-function-name-face= )) =20 ;; highlight label and instantiated unit of component instantiation= s (list (concat - "^\\s-*\\(\\w+\\)\\s-*:[ \t\n]*" + "^\\s-*\\(\\w+\\)\\s-*:[ \t\n\r\f]*" "\\(component\\|configuration\\|entity\\)\\s-+" "\\(\\w+\\)\\(\\.\\(\\w+\\)\\)?\\(\\s-*(\\(\\w+\\))\\)?") '(1 font-lock-function-name-face) '(3 font-lock-function-name-face= ) @@ -12638,7 +13076,7 @@ This does highlighting of keywords and standard= =20 identifiers.") (list (concat "^\\s-*for\\s-+\\(\\w+\\(,\\s-*\\w+\\)*\\)\\>\\s-*" - "\\(:[ \t\n]*\\(\\w+\\)\\|[^i \t]\\)") + "\\(:[ \t\n\r\f]*\\(\\w+\\)\\|[^i \t]\\)") '(1 font-lock-function-name-face) '(4 font-lock-function-name-face= nil=20 t)) =20 ;; highlight names in library clauses @@ -12662,8 +13100,8 @@ This does highlighting of keywords and standard= =20 identifiers.") ;; highlight type/nature name in (sub)type/(sub)nature declarations= (list (concat - "^\\s-*\\(sub\\)?\\(nature\\|type\\)\\s-+\\(\\w+\\)") - 3 'font-lock-type-face) + "^\\s-*\\(\\(sub\\)?\\(nature\\|type\\)\\|end\\s-+\\(record\\| protected\\)\\)\\s-+\\(\\w+\\)") + 5 'font-lock-type-face) =20 ;; highlight signal/variable/constant declaration names (list "\\(:[^=3D]\\)" @@ -12867,6 +13305,7 @@ This does background highlighting of translate-= off=20 regions.") =09 (list vhdl-functions-regexp 1 'vhdl-font-lock-function-face) =09 (list vhdl-packages-regexp 1 'vhdl-font-lock-function-face) =09 (list vhdl-enum-values-regexp 1 'vhdl-font-lock-enumvalue-face) +=09 (list vhdl-constants-regexp 1 'font-lock-constant-face) =09 (list vhdl-keywords-regexp 1 'font-lock-keyword-face))) ;; highlight words with special syntax. (setq vhdl-font-lock-keywords-3 @@ -12875,9 +13314,10 @@ This does background highlighting of translate= -off=20 regions.") =09 (while syntax-alist =09 (setq keywords =09=09 (cons -=09=09 (cons (concat "\\<\\(" (nth 1 (car syntax-alist)) "\\)\\>") +=09=09 (list (concat "\\(" (nth 1 (car syntax-alist)) "\\)") 1 =09=09=09 (vhdl-function-name -=09=09=09 "vhdl-font-lock" (nth 0 (car syntax-alist)) "face")) +=09=09=09 "vhdl-font-lock" (nth 0 (car syntax-alist)) "face") +=09=09=09 (nth 4 (car syntax-alist))) =09=09 keywords)) =09 (setq syntax-alist (cdr syntax-alist))) =09 keywords)) @@ -13066,7 +13506,7 @@ hierarchy otherwise.") (when (re-search-backward "^[ \t]*\\(architecture\\|configuratio= n\\| entity\\|package\\)\\>" nil t) =09(while (and (re-search-backward "^[ \t]*\\(end\\|use\\)\\>" nil t) =09=09 (equal "USE" (upcase (match-string 1)))) -=09 (when (looking-at "^[ \t]*use[ \t\n]*\\(\\w+\\)\\.\\(\\w+\\)\\.\\= w+") +=09 (when (looking-at "^[ \t]*use[ \t\n\r\f]*\\(\\w+\\)\\.\\(\\w+\\)\= \.\\w+") =09 (setq lib-alist (cons (cons (match-string-no-properties 1) =09=09=09=09=09(vhdl-match-string-downcase 2)) =09=09=09=09 lib-alist)))))) @@ -13140,7 +13580,7 @@ hierarchy otherwise.") =09=09=09 (setq big-files t)) =09=09;; scan for entities =09=09(goto-char (point-min)) -=09=09(while (re-search-forward "^[ \t]*entity[ \t\n]+\\(\\w+\\)[ \t\n= ]+is\\>"=20 nil t) +=09=09(while (re-search-forward "^[ \t]*entity[ \t\n\r\f]+\\(\\w+\\)[=20= \t\n\r\f]+is\\>" nil t) =09=09 (let* ((ent-name (match-string-no-properties 1)) =09=09=09 (ent-key (downcase ent-name)) =09=09=09 (ent-entry (aget ent-alist ent-key t)) @@ -13157,7 +13597,7 @@ hierarchy otherwise.") =09=09=09=09 lib-alist))))) =09=09;; scan for architectures =09=09(goto-char (point-min)) -=09=09(while (re-search-forward "^[ \t]*architecture[ \t\n]+\\(\\w+\\)= [=20 \t\n]+of[ \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t) +=09=09(while (re-search-forward "^[ \t]*architecture[ \t\n\r\f]+\\(\\w= +\\)[=20 \t\n\r\f]+of[ \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t) =09=09 (let* ((arch-name (match-string-no-properties 1)) =09=09=09 (arch-key (downcase arch-name)) =09=09=09 (ent-name (match-string-no-properties 2)) @@ -13183,7 +13623,7 @@ hierarchy otherwise.") =09=09=09=09 arch-key (nth 5 ent-entry)))))) =09=09;; scan for configurations =09=09(goto-char (point-min)) -=09=09(while (re-search-forward "^[ \t]*configuration[ \t\n]+\\(\\w+\\= )[=20 \t\n]+of[ \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t) +=09=09(while (re-search-forward "^[ \t]*configuration[ \t\n\r\f]+\\(\\= w+\\)[=20 \t\n\r\f]+of[ \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t) =09=09 (let* ((conf-name (match-string-no-properties 1)) =09=09=09 (conf-key (downcase conf-name)) =09=09=09 (conf-entry (aget conf-alist conf-key t)) @@ -13195,7 +13635,7 @@ hierarchy otherwise.") =09=09=09 arch-key comp-conf-list inst-key-list =09=09=09 inst-comp-key inst-ent-key inst-arch-key =09=09=09 inst-conf-key inst-lib-key) -=09=09 (when (vhdl-re-search-forward "\\" nil t) +=09=09(while (re-search-forward "^[ \t]*package[ \t\n\r\f]+\\(body[=20= \t\n\r\f]+\\)?\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t) =09=09 (let* ((pack-name (match-string-no-properties 2)) =09=09=09 (pack-key (downcase pack-name)) =09=09=09 (is-body (match-string-no-properties 1)) @@ -13250,7 +13690,7 @@ hierarchy otherwise.") =09=09 ;; scan for context clauses =09=09 (setq lib-alist (vhdl-scan-context-clause)) =09=09 ;; scan for component and subprogram declarations/bodies -=09=09 (while (re-search-forward "^[ \t]*\\(component\\|function\= \| procedure\\)[ \t\n]+\\(\\w+\\|\".*\"\\)" end-of-unit t) +=09=09 (while (re-search-forward "^[ \t]*\\(component\\|function\= \| procedure\\)[ \t\n\r\f]+\\(\\w+\\|\".*\"\\)" end-of-unit t) =09=09=09(if (equal (upcase (match-string 1)) "COMPONENT") =09=09=09 (setq comp-name (match-string-no-properties 2) =09=09=09=09 comp-alist @@ -13286,7 +13726,7 @@ hierarchy otherwise.") =09=09=09 (setq big-files t)) =09=09;; scan for architectures =09=09(goto-char (point-min)) -=09=09(while (re-search-forward "^[ \t]*architecture[ \t\n]+\\(\\w+\\)= [=20 \t\n]+of[ \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t) +=09=09(while (re-search-forward "^[ \t]*architecture[ \t\n\r\f]+\\(\\w= +\\)[=20 \t\n\r\f]+of[ \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t) =09=09 (let* ((ent-name (match-string-no-properties 2)) =09=09=09 (ent-key (downcase ent-name)) =09=09=09 (arch-name (match-string-no-properties 1)) @@ -13300,12 +13740,12 @@ hierarchy otherwise.") =09=09=09 inst-alist inst-path) =09=09 ;; scan for contained instantiations =09=09 (while (and (re-search-forward -=09=09=09=09 (concat "^[ \t]*\\(\\w+\\)[ \t\n]*:[ \t\n]*\\(" -=09=09=09=09=09 "\\(\\w+\\)[ \t\n]+\\(--[^\n]*\n[ \t\n]*\\)*\\(generic= \\|port\\)[=20 \t\n]+map\\>\\|" -=09=09=09=09=09 "component[ \t\n]+\\(\\w+\\)\\|" -=09=09=09=09=09 "\\(\\(entity\\)\\|configuration\\)[ \t\n]+\\(\\(\\w+\= \)\\.\\)? \\(\\w+\\)\\([ \t\n]*(\\(\\w+\\))\\)?\\|" +=09=09=09=09 (concat "^[ \t]*\\(\\w+\\)[ \t\n\r\f]*:[ \t\n\r\f]*\\(" +=09=09=09=09=09 "\\(\\w+\\)[ \t\n\r\f]+\\(--[^\n]*\n[ \t\n\r\f]*\\)*\\= (generic\\| port\\)[ \t\n\r\f]+map\\>\\|" +=09=09=09=09=09 "component[ \t\n\r\f]+\\(\\w+\\)\\|" +=09=09=09=09=09 "\\(\\(entity\\)\\|configuration\\)[ \t\n\r\f]+\\(\\(\= \w+\\)\\.\\)? \\(\\w+\\)\\([ \t\n\r\f]*(\\(\\w+\\))\\)?\\|" =09=09=09=09=09 "\\(\\(for\\|if\\)\\>[^;:]+\\\\|block\\>\\= )\\)\\|" -=09=09=09=09=09 "\\(^[ \t]*end[ \t\n]+\\(generate\\|block\\)\\>\\)") e= nd-of-unit=20 t) +=09=09=09=09=09 "\\(^[ \t]*end[ \t\n\r\f]+\\(generate\\|block\\)\\>\\)= ") end-of- unit t) =09=09=09=09(or (not limit-hier-inst-no) =09=09=09=09 (<=3D (setq inst-no (1+ inst-no)) =09=09=09=09=09limit-hier-inst-no))) @@ -13349,8 +13789,8 @@ hierarchy otherwise.") =09=09 ;; scan for contained configuration specifications =09=09 (goto-char beg-of-unit) =09=09 (while (re-search-forward -=09=09=09 (concat "^[ \t]*for[ \t\n]+\\(\\w+\\([ \t\n]*,[ \t\n]*\\w= +\\)*\\)[=20 \t\n]*:[ \t\n]*\\(\\w+\\)[ \t\n]+\\(--[^\n]*\n[ \t\n]*\\)*" -=09=09=09=09 "use[ \t\n]+\\(\\(entity\\)\\|configuration\\)[=20 \t\n]+\\(\\(\\w+\\)\\.\\)?\\(\\w+\\)\\([ \t\n]*(\\(\\w+\\))\\)?") end-o= f-unit=20 t) +=09=09=09 (concat "^[ \t]*for[ \t\n\r\f]+\\(\\w+\\([ \t\n\r\f]*,[=20= \t\n\r\f]*\\w+\\)*\\)[ \t\n\r\f]*:[ \t\n\r\f]*\\(\\w+\\)[=20 \t\n\r\f]+\\(--[^\n]*\n[ \t\n\r\f]*\\)*" +=09=09=09=09 "use[ \t\n\r\f]+\\(\\(entity\\)\\|configuration\\)[=20= \t\n\r\f]+\\(\\(\\w+\\)\\.\\)?\\(\\w+\\)\\([ \t\n\r\f]*(\\(\\w+\\))\\)?= ") end- of-unit t) =09=09 (let* ((inst-comp-name (match-string-no-properties 3)) =09=09=09 (inst-ent-key =09=09=09 (and (match-string 6) @@ -13362,7 +13802,7 @@ hierarchy otherwise.") =09=09=09 (inst-lib-key (vhdl-match-string-downcase 8)) =09=09=09 (inst-key-list =09=09=09 (split-string (vhdl-match-string-downcase 1) -=09=09=09=09=09 "[ \t\n]*,[ \t\n]*")) +=09=09=09=09=09 "[ \t\n\r\f]*,[ \t\n\r\f]*")) =09=09=09 (tmp-inst-alist inst-alist) =09=09=09 inst-entry) =09=09=09(while tmp-inst-alist @@ -15347,7 +15787,7 @@ expansion function)." =09 (read-from-minibuffer "architecture name: " =09=09=09=09 nil vhdl-minibuffer-local-map) =09 (vhdl-replace-string vhdl-compose-architecture-name ent-name)))= -=09 ent-file-name arch-file-name ent-buffer arch-buffer project) +=09 ent-file-name arch-file-name ent-buffer arch-buffer project end-po= s) (message "Creating component \"%s(%s)\"..." ent-name arch-name) ;; open entity file (unless (eq vhdl-compose-create-files 'none) @@ -15364,6 +15804,7 @@ expansion function)." ;; insert header (if vhdl-compose-include-header =09(progn (vhdl-template-header) +=09 (setq end-pos (point)) =09 (goto-char (point-max))) (vhdl-comment-display-line) (insert "\n\n")) ;; insert library clause @@ -15390,6 +15831,7 @@ expansion function)." ;; open architecture file (if (not (eq vhdl-compose-create-files 'separate)) =09(insert "\n") + (goto-char (or end-pos (point-min))) (setq ent-buffer (current-buffer)) (setq arch-file-name =09 (concat (vhdl-replace-string vhdl-architecture-file-name @@ -15434,7 +15876,7 @@ expansion function)." (if (and vhdl-compose-include-header (not (equal vhdl-file-footer = ""))) =09(vhdl-template-footer) (vhdl-comment-display-line) (insert "\n")) - (goto-char (point-min)) + (goto-char (or end-pos (point-min))) (setq arch-buffer (current-buffer)) (when ent-buffer (set-buffer ent-buffer) (save-buffer)) (set-buffer arch-buffer) (save-buffer) @@ -15453,8 +15895,8 @@ component instantiation." (error "ERROR: No port has been read") (save-excursion (vhdl-prepare-search-2 - (unless (or (re-search-backward "^architecture[ \t\n]+\\w+[ \t\= n]+of[=20 \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t) -=09=09 (re-search-forward "^architecture[ \t\n]+\\w+[ \t\n]+of[=20 \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t)) + (unless (or (re-search-backward "^architecture[ \t\n\r\f]+\\w+[= =20 \t\n\r\f]+of[ \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t) +=09=09 (re-search-forward "^architecture[ \t\n\r\f]+\\w+[ \t\n\r\f]+= of[=20 \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t)) =09 (error "ERROR: No architecture found")) (let* ((ent-name (match-string 1)) =09 (ent-file-name @@ -15471,13 +15913,13 @@ component instantiation." =09=09=09=09(car vhdl-port-list) "\\>") nil t))) =09 (re-search-forward "^begin\\>" nil) =09 (beginning-of-line) -=09 (skip-chars-backward " \t\n") +=09 (skip-chars-backward " \t\n\r\f") =09 (insert "\n\n") (indent-to vhdl-basic-offset) =09 (vhdl-port-paste-component t)) =09 ;; place component instantiation =09 (re-search-forward "^end\\>" nil) =09 (beginning-of-line) -=09 (skip-chars-backward " \t\n") +=09 (skip-chars-backward " \t\n\r\f") =09 (insert "\n\n") (indent-to vhdl-basic-offset) =09 (vhdl-port-paste-instance nil t t) =09 ;; place use clause for used packages @@ -15486,7 +15928,7 @@ component instantiation." =09 (when (file-exists-p ent-file-name) =09 (find-file ent-file-name)) =09 (goto-char (point-min)) -=09 (unless (re-search-forward (concat "^entity[ \t\n]+" ent-name "[= =20 \t\n]+is\\>") nil t) +=09 (unless (re-search-forward (concat "^entity[ \t\n\r\f]+" ent-nam= e "[=20 \t\n\r\f]+is\\>") nil t) =09 (error "ERROR: Entity not found: \"%s\"" ent-name)) =09 (goto-char (match-beginning 0)) =09 (if (and (save-excursion @@ -15505,8 +15947,8 @@ component instantiation." (interactive) (save-excursion (vhdl-prepare-search-2 - (unless (or (re-search-backward "^architecture[ \t\n]+\\w+[ \t\n]= +of[=20 \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t) -=09=09 (re-search-forward "^architecture[ \t\n]+\\w+[ \t\n]+of[=20 \t\n]+\\(\\w+\\)[ \t\n]+is\\>" nil t)) + (unless (or (re-search-backward "^architecture[ \t\n\r\f]+\\w+[=20= \t\n\r\f]+of[ \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t) +=09=09 (re-search-forward "^architecture[ \t\n\r\f]+\\w+[ \t\n\r\f]+of= [=20 \t\n\r\f]+\\(\\w+\\)[ \t\n\r\f]+is\\>" nil t)) (error "ERROR: No architecture found")) (let* ((ent-name (match-string 1)) =09 (ent-file-name @@ -15532,11 +15974,11 @@ component instantiation." ;; process all instances (goto-char arch-stat-pos) (while (re-search-forward -=09 (concat "^[ \t]*\\(\\w+\\)[ \t\n]*:[ \t\n]*\\(" -=09=09 "\\(component[ \t\n]+\\)?\\(\\w+\\)" -=09=09 "[ \t\n]+\\(--[^\n]*\n[ \t\n]*\\)*\\(\\(generic\\)\\|port= \\)[=20 \t\n]+map\\|" -=09=09 "\\(\\(entity\\)\\|configuration\\)[ \t\n]+\\(\\(\\w+\\)\= \.\\)? \\(\\w+\\)\\([ \t\n]*(\\(\\w+\\))\\)?" -=09=09 "[ \t\n]+\\(--[^\n]*\n[ \t\n]*\\)*\\(\\(generic\\)\\|port= \\)[=20 \t\n]+map\\)[ \t\n]*(") arch-end-pos t) +=09 (concat "^[ \t]*\\(\\w+\\)[ \t\n\r\f]*:[ \t\n\r\f]*\\(" +=09=09 "\\(component[ \t\n\r\f]+\\)?\\(\\w+\\)" +=09=09 "[ \t\n\r\f]+\\(--[^\n]*\n[ \t\n\r\f]*\\)*\\(\\(generic\\= )\\| port\\)[ \t\n\r\f]+map\\|" +=09=09 "\\(\\(entity\\)\\|configuration\\)[ \t\n\r\f]+\\(\\(\\w+= \\)\\.\\)? \\(\\w+\\)\\([ \t\n\r\f]*(\\(\\w+\\))\\)?" +=09=09 "[ \t\n\r\f]+\\(--[^\n]*\n[ \t\n\r\f]*\\)*\\(\\(generic\\= )\\| port\\)[ \t\n\r\f]+map\\)[ \t\n\r\f]*(") arch-end-pos t) =09 (setq inst-name (match-string-no-properties 1) =09 comp-name (match-string-no-properties 4) =09 comp-ent-name (match-string-no-properties 12) @@ -15548,7 +15990,7 @@ component instantiation." =09 (when vhdl-use-components-package pack-file-name) t =09 (save-excursion =09=09(goto-char (point-min)) -=09=09(unless (re-search-forward (concat "^\\s-*component[ \t\n]+" com= p-name=20 "\\>") nil t) +=09=09(unless (re-search-forward (concat "^\\s-*component[ \t\n\r\f]+"= comp-name=20 "\\>") nil t) =09=09 (error "ERROR: Component declaration not found: \"%s\"" comp-= name)) =09=09(vhdl-port-copy))) =09 ;; ... from entity declaration (direct instantiation) @@ -15559,7 +16001,7 @@ component instantiation." =09 comp-ent-file-name t =09 (save-excursion =09 (goto-char (point-min)) -=09 (unless (re-search-forward (concat "^\\s-*entity[ \t\n]+" com= p-ent- name "\\>") nil t) +=09 (unless (re-search-forward (concat "^\\s-*entity[ \t\n\r\f]+"= comp- ent-name "\\>") nil t) =09=09(error "ERROR: Entity declaration not found: \"%s\"" comp-ent-n= ame)) =09 (vhdl-port-copy)))) =09 (vhdl-port-flatten t) @@ -15571,7 +16013,7 @@ component instantiation." =09 (when has-generic =09 ;; process all constants in generic map =09 (vhdl-forward-syntactic-ws) -=09 (while (vhdl-parse-string "\\(\\(\\w+\\)[ \t\n]*=3D>[ \t\n]*\\)?= \\(\\w+\\),?" t) +=09 (while (vhdl-parse-string "\\(\\(\\w+\\)[ \t\n\r\f]*=3D>[ \t\n\r= \f]*\\)? \\(\\w+\\),?" t) =09 (setq constant-name (match-string-no-properties 3)) =09 (setq constant-entry =09=09 (cons constant-name @@ -15589,10 +16031,10 @@ component instantiation." =09 (unless (match-string 1) =09 (setq generic-alist (cdr generic-alist))) =09 (vhdl-forward-syntactic-ws)) -=09 (vhdl-re-search-forward "\\[ \t\n]*\\)? \\(\\w+\\),?" t) +=09 (while (vhdl-parse-string "\\(\\(\\w+\\)[ \t\n\r\f]*=3D>[ \t\n\r\f= ]*\\)? \\(\\w+\\),?" t) =09 (setq signal-name (match-string-no-properties 3)) =09 (setq signal-entry (cons signal-name =09=09=09=09 (if (match-string 1) @@ -15638,7 +16080,7 @@ component instantiation." ;; prepare signal insertion (vhdl-goto-marker arch-decl-pos) (forward-line 1) - (re-search-forward "^\\s-*-- Internal signal declarations[ \t\n= ]*-*\n"=20 arch-stat-pos t) + (re-search-forward "^\\s-*-- Internal signal declarations[ \t\n= \r\f]*- *\n" arch-stat-pos t) (setq signal-pos (point-marker)) (while (progn (vhdl-forward-syntactic-ws) =09=09 (looking-at "signal\\>")) @@ -15649,10 +16091,10 @@ component instantiation." (when (file-exists-p ent-file-name) =09 (find-file ent-file-name)) (goto-char (point-min)) - (unless (re-search-forward (concat "^entity[ \t\n]+" ent-name "= [=20 \t\n]+is\\>") nil t) + (unless (re-search-forward (concat "^entity[ \t\n\r\f]+" ent-na= me "[=20 \t\n\r\f]+is\\>") nil t) =09 (error "ERROR: Entity not found: \"%s\"" ent-name)) ;; prepare generic clause insertion - (unless (and (re-search-forward "\\(^\\s-*generic[ \t\n]*(\\)\\= | ^end\\>" nil t) + (unless (and (re-search-forward "\\(^\\s-*generic[ \t\n\r\f]*(\= \)\\| ^end\\>" nil t) =09=09 (match-string 1)) =09 (goto-char (match-beginning 0)) =09 (indent-to vhdl-basic-offset) @@ -15670,7 +16112,7 @@ component instantiation." (setq generic-beg-pos (point-marker) generic-pos (point-marker)= =09 generic-inst-pos (point-marker) generic-end-pos (point-marker)= ) ;; prepare port clause insertion - (unless (and (re-search-forward "\\(^\\s-*port[ \t\n]*(\\)\\|^e= nd\\>"=20 nil t) + (unless (and (re-search-forward "\\(^\\s-*port[ \t\n\r\f]*(\\)\= \| ^end\\>" nil t) =09=09 (match-string 1)) =09 (goto-char (match-beginning 0)) =09 (indent-to vhdl-basic-offset) @@ -15894,7 +16336,8 @@ current project/directory." (message "Generating components package \"%s\"...done\n File crea= ted:=20 \"%s\"" =09 pack-name pack-file-name))) =20 -(defun vhdl-compose-configuration-architecture (ent-name arch-name ins= t-alist +(defun vhdl-compose-configuration-architecture (ent-name arch-name ent= -alist +=09=09=09=09=09=09=09 conf-alist inst-alist =09=09=09=09=09=09=09 &optional insert-conf) "Generate block configuration for architecture." (let ((margin (current-indentation)) @@ -15970,7 +16413,7 @@ current project/directory." =09=09 (nth 3 ent-entry)) =09 (indent-to (+ margin vhdl-basic-offset)) =09 (vhdl-compose-configuration-architecture -=09 (nth 0 ent-entry) arch-name +=09 (nth 0 ent-entry) arch-name ent-alist conf-alist =09 (nth 3 (aget (nth 3 ent-entry) (downcase arch-name) t)))))) =09;; insert component configuration end =09(indent-to margin) @@ -16052,7 +16495,8 @@ current project/directory." (vhdl-insert-keyword " IS\n") (indent-to vhdl-basic-offset) ;; insert block configuration (for architecture) - (vhdl-compose-configuration-architecture ent-name arch-name inst-= alist t) + (vhdl-compose-configuration-architecture + ent-name arch-name ent-alist conf-alist inst-alist t) (vhdl-insert-keyword "END ") (insert conf-name ";") (when conf-file-name ;; insert footer and save @@ -16072,6 +16516,9 @@ current project/directory." ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;= ;;;;;;;;; ;; (using `compile.el') =20 +(defvar vhdl-compile-post-command "" + "String appended to compile command after file name.") + (defun vhdl-makefile-name () "Return the Makefile name of the current project or the current comp= iler if no project is defined." @@ -16226,9 +16673,11 @@ do not print any file names." =09 (compiler (or (aget vhdl-compiler-alist vhdl-compiler nil) =09=09 (error "ERROR: No such compiler: \"%s\"" vhdl-compiler))= ) =09 (command (nth 0 compiler)) -=09 (file-name (buffer-file-name)) -=09 (options (vhdl-get-compile-options project compiler file-name)) =09 (default-directory (vhdl-compile-directory)) +=09 (file-name (if vhdl-compile-absolute-path +=09=09=09(buffer-file-name) +=09=09 (file-relative-name (buffer-file-name)))) +=09 (options (vhdl-get-compile-options project compiler file-name)) =09 compilation-process-setup-function) (unless (file-directory-p default-directory) (error "ERROR: Compile directory does not exist: \"%s\"" defaul= t- directory)) @@ -16236,14 +16685,18 @@ do not print any file names." (when (string-match " " file-name) (setq file-name (concat "\"" file-name "\""))) ;; print out file name if compiler does not - (setq vhdl-compile-file-name (buffer-file-name)) + (setq vhdl-compile-file-name (if vhdl-compile-absolute-path +=09=09=09=09 (buffer-file-name) +=09=09=09=09 (file-relative-name (buffer-file-name)))) (when (and (=3D 0 (nth 1 (nth 10 compiler))) =09 (=3D 0 (nth 1 (nth 11 compiler)))) (setq compilation-process-setup-function 'vhdl-compile-print-fil= e-name)) ;; run compilation (if options =09(when command -=09 (compile (concat command " " options " " file-name))) +=09 (compile (concat command " " options " " file-name +=09=09=09 (unless (equal vhdl-compile-post-command "") +=09=09=09 (concat " " vhdl-compile-post-command))))) (vhdl-warning "Your project settings tell me not to compile this= =20 file")))) =20 (defvar vhdl-make-target "all" @@ -16551,6 +17004,8 @@ specified by a target." (insert "\n\n# Define compilation command and options\n" =09 "\nCOMPILE =3D " (nth 0 compiler) =09 "\nOPTIONS =3D " (vhdl-get-compile-options project compiler n= il) +=09 (if (equal vhdl-compile-post-command "") "" +=09=09(concat "\nPOST-COMPILE =3D " vhdl-compile-post-command)) =09 "\n") ;; insert library paths (setq library-directory @@ -16580,16 +17035,16 @@ specified by a target." (setq unit-list tmp-list) ;; insert `make all' rule (insert "\n\n\n# Rule for compiling entire design\n" -=09 "\nall :" -=09 " \\\n\t\tlibrary" +=09 "\n" (nth 0 vhdl-makefile-default-targets) " :" +=09 " \\\n\t\t" (nth 2 vhdl-makefile-default-targets) =09 " \\\n\t\t$(ALL_UNITS)\n") ;; insert `make clean' rule (insert "\n\n# Rule for cleaning entire design\n" -=09 "\nclean : " +=09 "\n" (nth 1 vhdl-makefile-default-targets) " : " =09 "\n\t-rm -f $(ALL_UNITS)\n") ;; insert `make library' rule (insert "\n\n# Rule for creating library directory\n" -=09 "\nlibrary :" +=09 "\n" (nth 2 vhdl-makefile-default-targets) " :" =09 " \\\n\t\t$(LIBRARY-" work-library ")\n" =09 "\n$(LIBRARY-" work-library ") :" =09 "\n\t" @@ -16597,6 +17052,11 @@ specified by a target." =09 (cons "\\(.*\\)\n\\(.*\\)" (nth 5 compiler)) =09 (concat "$(LIBRARY-" work-library ")\n" (vhdl-work-library))= ) =09 "\n") + ;; insert '.PHONY' declaration + (insert "\n\n.PHONY : " +=09 (nth 0 vhdl-makefile-default-targets) " " +=09 (nth 1 vhdl-makefile-default-targets) " " +=09 (nth 2 vhdl-makefile-default-targets) "\n") ;; insert rule for each library unit (insert "\n\n# Rules for compiling single library units and thei= r=20 subhierarchy\n") (while prim-list @@ -16611,7 +17071,7 @@ specified by a target." =09(unless (equal unit-key unit-name) =09 (insert " \\\n" unit-name)) =09(insert " :" -=09=09" \\\n\t\tlibrary" +=09=09" \\\n\t\t" (nth 2 vhdl-makefile-default-targets) =09=09" \\\n\t\t$(UNIT-" work-library "-" unit-key ")") =09(while second-list =09 (insert " \\\n\t\t$(UNIT-" work-library "-" (car second-list) ")"= ) @@ -16653,7 +17113,9 @@ specified by a target." =09(if options =09 (insert "\n\t$(COMPILE) " =09=09 (if (eq options 'default) "$(OPTIONS)" options) " " -=09=09 (nth 0 rule) "\n") +=09=09 (nth 0 rule) +=09=09 (if (equal vhdl-compile-post-command "") "" +=09=09 " $(POST-COMPILE)") "\n") =09 (setq tmp-list target-list) =09 (while target-list =09 (insert "\n\t@touch $(UNIT-" work-library "-" (car target-list)= ")" @@ -16712,6 +17174,7 @@ specified by a target." 'vhdl-compiler-alist 'vhdl-compiler 'vhdl-compile-use-local-error-regexp + 'vhdl-makefile-default-targets 'vhdl-makefile-generation-hook 'vhdl-default-library 'vhdl-standard @@ -16722,6 +17185,7 @@ specified by a target." 'vhdl-upper-case-enum-values 'vhdl-upper-case-constants 'vhdl-use-direct-instantiation + 'vhdl-array-index-record-field-in-sensitivity-list 'vhdl-compose-configuration-name 'vhdl-entity-file-name 'vhdl-architecture-file-name @@ -16812,6 +17276,7 @@ specified by a target." 'vhdl-print-customize-faces 'vhdl-intelligent-tab 'vhdl-indent-syntax-based + 'vhdl-indent-comment-like-next-code-line 'vhdl-word-completion-case-sensitive 'vhdl-word-completion-in-minibuffer 'vhdl-underscore-is-part-of-word @@ -16851,6 +17316,17 @@ CONFIGURATION DECLARATION GENERATION: (See documentation (`C-c C-h') in section on STRUCTURAL COMPOSITIO= N.) =20 =20 +Key Bindings +------------ + +For Emacs compliance the following key bindings have been changed: + +- `C-c c' -> `C-c C-c' `vhdl-comment-uncomment-region' +- `C-c f' -> `C-c C-i C-f' `vhdl-fontify-buffer' +- `C-c s' -> `C-c C-i C-s' `vhdl-statistics-buffer' +- `C-c C-c ...' -> `C-c C-m ...' `vhdl-compose-...' + + User Options ------------ =20 @@ -16864,6 +17340,12 @@ User Options Specify whether hierarchical configurations should be created. `vhdl-compose-configuration-use-subconfiguration': (new) Specify whether subconfigurations should be used inside configuratio= ns. +`vhdl-makefile-default-targets': (new) + Customize names of Makefile default targets. +`vhdl-indent-comment-like-next-code-line': (new) + Specify whether comment lines are indented like following code line.= +`vhdl-array-index-record-field-in-sensitivity-list': (new) + Specify whether to include array indices / record fields in sensitiv= ity=20 list. ") =20 =20 @@ -16872,19 +17354,20 @@ User Options Reserved words in VHDL ---------------------- =20 -VHDL'93 (IEEE Std 1076-1993): - `vhdl-93-keywords' : keywords - `vhdl-93-types' : standardized types - `vhdl-93-attributes' : standardized attributes - `vhdl-93-enum-values' : standardized enumeration values - `vhdl-93-functions' : standardized functions - `vhdl-93-packages' : standardized packages and libraries +VHDL'93/02 (IEEE Std 1076-1993/2002): + `vhdl-02-keywords' : keywords + `vhdl-02-types' : standardized types + `vhdl-02-attributes' : standardized attributes + `vhdl-02-enum-values' : standardized enumeration values + `vhdl-02-functions' : standardized functions + `vhdl-02-packages' : standardized packages and libraries =20 -VHDL-AMS (IEEE Std 1076.1): +VHDL-AMS (IEEE Std 1076.1 / 1076.1.1): `vhdl-ams-keywords' : keywords `vhdl-ams-types' : standardized types `vhdl-ams-attributes' : standardized attributes `vhdl-ams-enum-values' : standardized enumeration values + `vhdl-ams-constants' : standardized constants `vhdl-ams-functions' : standardized functions =20 Math Packages (IEEE Std 1076.2): --=20 1.7.10