ACC SHELL
# Style sheet for common shell constructs
# Used by sh, csh, tcsh, zsh
#
# Copyright (c) 1999 Akim Demaille, Miguel Santana
#
#
# This file is part of a2ps.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2, or (at your option)
# any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; see the file COPYING. If not, write to
# the Free Software Foundation, 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
## 0.1 Akim Demaille
# Initial creation
style "Shell" is
written by "Akim Demaille <akim@freefriends.org>"
version is 1.0
requires a2ps 4.13
first alphabet is
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz_-/$."
second alphabet is
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz_/$#."
case sensitive
documentation is
"This style sheet is not meant to be used directly, but rather an as"
"ancestor for shell style sheets."
end documentation
sequences are
"#" Comment,
C-string,
C-char,
# Here documents. I take as a rule, something which starts with
# EO[CHARACTERS IN UPPERCASE] and ends with the same pattern
# (hence not necessarily the same tag, but it seems to be a good
# guess)
/<<[[:blank:]]*\\\\?EO[A-Z]+/ Plain /^EO[A-Z]+/,
# This is a type of here-docs met in shar files
/<<[[:blank:]]*________This_Is_The_END________/ Plain
/^________This_Is_The_END________$/
end sequences
operators are
# Definition of a function
(/^([a-zA-Z_][a-zA-Z0-9_]*)\\(\\)/
\1 Label, "()" Plain),
# Beware of \", \` and \' alone. Lets make general
/\\\\./
end operators
end style
ACC SHELL 2018