Removed bundled slang

This commit is contained in:
Enrico Weigelt, metux IT service 2009-01-10 21:04:30 +01:00
parent 3410eb3229
commit 4f9185a3ee
42 changed files with 29 additions and 14939 deletions

View File

@ -158,6 +158,10 @@
Changed message type codes on calls to message(), query_dialog(), Changed message type codes on calls to message(), query_dialog(),
close_error_pipe() from numeric IDs to symbols D_ERROR, D_NORMAL close_error_pipe() from numeric IDs to symbols D_ERROR, D_NORMAL
2009-01-07 Enrico Weigelt, metux ITS <weigelt@metux.de>
* removed bundled slang
2008-12-18 Roland Illig <roland.illig@gmx.de> 2008-12-18 Roland Illig <roland.illig@gmx.de>
* doc/mcedit.1: Documented the newly added filename:lineno * doc/mcedit.1: Documented the newly added filename:lineno

14
INSTALL
View File

@ -169,19 +169,11 @@ included one, but you can override this by using the following flag
(please note that since S-Lang is default, it is tested better than (please note that since S-Lang is default, it is tested better than
ncurses): ncurses):
`--with-screen={slang|mcslang|ncurses}' `--with-screen={slang|ncurses}'
Choose the library used to manage interaction with the terminal. Choose the library used to manage interaction with the terminal.
`slang' means S-Lang library already installed on the system, `slang' means S-Lang library already installed on the system,
`mcslang' means S-Lang library included with the sources of `ncurses' means ncurses library already installed on the system.
GNU Midnight Commander, `ncurses' means ncurses library already The installed S-Lang library is used by default if found.
installed on the system. The installed S-Lang library is used
by default if found, otherwise the included S-Lang library is
used.
`--with-termcap'
If the included S-Lang library is used, this option forces it to
use the termcap database, as opposed to the default terminfo
database.
On systems that require unusual options for compilation or linking that On systems that require unusual options for compilation or linking that
the package's `configure' script does not know about, you can give the package's `configure' script does not know about, you can give

View File

@ -24,14 +24,11 @@ The most often needed options to configure are following:
You can specify an installation prefix other than default by You can specify an installation prefix other than default by
giving `configure' the option `--prefix=PATH'. giving `configure' the option `--prefix=PATH'.
`--with-screen={slang|mcslang|ncurses}' `--with-screen={slang|ncurses}'
Choose the library used to manage interaction with the terminal. Choose the library used to manage interaction with the terminal.
`slang' means S-Lang library already installed on the system, `slang' means S-Lang library already installed on the system,
`mcslang' means S-Lang library included with the sources of `ncurses' means ncurses library already installed on the system.
GNU Midnight Commander, `ncurses' means ncurses library already The installed S-Lang library is used by default if found.
installed on the system. The installed S-Lang library is used
by default if found, otherwise the included S-Lang library is
used.
You may also want to specify CFLAGS for the compiler, even if it finds You may also want to specify CFLAGS for the compiler, even if it finds
itself some defaults by typing e.g. itself some defaults by typing e.g.

View File

@ -2,7 +2,7 @@
AUTOMAKE_OPTIONS = 1.5 AUTOMAKE_OPTIONS = 1.5
SUBDIRS = intl po m4 vfs slang edit src lib doc syntax SUBDIRS = intl po m4 vfs edit src lib doc syntax
EXTRA_DIST = FAQ HACKING INSTALL.FAST MAINTAINERS README.QNX TODO pkginfo.in prototype.in mc.qpg mc.spec EXTRA_DIST = FAQ HACKING INSTALL.FAST MAINTAINERS README.QNX TODO pkginfo.in prototype.in mc.qpg mc.spec

View File

@ -362,7 +362,7 @@ AC_DEFUN([MC_SLANG_TERMCAP], [
]) ])
dnl dnl
dnl Common code for MC_WITH_SLANG and MC_WITH_MCSLANG dnl Common code for MC_WITH_SLANG
dnl dnl
AC_DEFUN([_MC_WITH_XSLANG], [ AC_DEFUN([_MC_WITH_XSLANG], [
screen_type=slang screen_type=slang
@ -373,7 +373,7 @@ AC_DEFUN([_MC_WITH_XSLANG], [
dnl dnl
dnl Check if the system S-Lang library can be used. dnl Check if the system S-Lang library can be used.
dnl If not, and $1 is "strict", exit, otherwise fall back to mcslang. dnl If not, and $1 is "strict", exit.
dnl dnl
AC_DEFUN([MC_WITH_SLANG], [ AC_DEFUN([MC_WITH_SLANG], [
with_screen=slang with_screen=slang
@ -383,7 +383,7 @@ AC_DEFUN([MC_WITH_SLANG], [
AC_CHECK_HEADERS([slang.h slang/slang.h], AC_CHECK_HEADERS([slang.h slang/slang.h],
[slang_h_found=yes; break]) [slang_h_found=yes; break])
if test -z "$slang_h_found"; then if test -z "$slang_h_found"; then
with_screen=mcslang AC_MSG_ERROR([Slang header not found])
fi fi
dnl Check if termcap is needed. dnl Check if termcap is needed.
@ -395,78 +395,23 @@ AC_DEFUN([MC_WITH_SLANG], [
dnl Check the library dnl Check the library
if test x$with_screen = xslang; then if test x$with_screen = xslang; then
AC_CHECK_LIB([slang], [SLang_init_tty], [MCLIBS="$MCLIBS -lslang"], AC_CHECK_LIB([slang], [SLang_init_tty], [MCLIBS="$MCLIBS -lslang"],
[with_screen=mcslang], ["$MCLIBS"]) AC_MSG_ERROR([Slang library not found]), ["$MCLIBS"])
fi fi
dnl Unless external S-Lang was requested, reject S-Lang with UTF-8 hacks dnl Unless external S-Lang was requested, reject S-Lang with UTF-8 hacks
if test x$with_screen = xslang; then if test x$with_screen = xslang; then
: AC_CHECK_LIB(
m4_if([$1], strict, , [slang],
[AC_CHECK_LIB([slang], [SLsmg_write_nwchars], [SLsmg_write_nwchars],
[AC_MSG_WARN([Rejecting S-Lang with UTF-8 support, \ [AC_MSG_ERROR([Rejecting S-Lang with UTF-8 support, it's not fully supported yet])])
it's not fully supported yet])
with_screen=mcslang])])
fi fi
if test x$with_screen = xslang; then if test x$with_screen = xslang; then
AC_DEFINE(HAVE_SYSTEM_SLANG, 1,
[Define to use S-Lang library installed on the system])
MC_SLANG_PRIVATE MC_SLANG_PRIVATE
screen_type=slang screen_type=slang
screen_msg="S-Lang library (installed on the system)" screen_msg="S-Lang library (installed on the system)"
else else
m4_if([$1], strict,
[if test $with_screen != slang; then
AC_MSG_ERROR([S-Lang library not found]) AC_MSG_ERROR([S-Lang library not found])
fi],
[MC_WITH_MCSLANG]
)
fi
_MC_WITH_XSLANG
])
dnl
dnl Use the included S-Lang library.
dnl
AC_DEFUN([MC_WITH_MCSLANG], [
screen_type=mcslang
screen_msg="Included S-Lang library (mcslang)"
dnl Type checks from S-Lang sources
AC_CHECK_SIZEOF(short, 2)
AC_CHECK_SIZEOF(int, 4)
AC_CHECK_SIZEOF(long, 4)
AC_CHECK_SIZEOF(float, 4)
AC_CHECK_SIZEOF(double, 8)
AC_TYPE_OFF_T
AC_CHECK_SIZEOF(off_t)
AC_CHECK_TYPES(long long)
AC_CHECK_SIZEOF(long long)
AC_CHECK_FUNCS(atexit on_exit)
# Search for terminfo database.
use_terminfo=
if test x"$with_termcap" != xyes; then
if test x"$with_termcap" = xno; then
use_terminfo=yes
fi
if test -n "$TERMINFO" && test -r "$TERMINFO/v/vt100"; then
use_terminfo=yes
fi
for dir in "/usr/share/terminfo" "/usr/lib/terminfo" \
"/usr/share/lib/terminfo" "/etc/terminfo" \
"/usr/local/lib/terminfo" "$HOME/.terminfo"; do
if test -r "$dir/v/vt100"; then
use_terminfo=yes
fi
done
fi
# If there is no terminfo, use termcap
if test -z "$use_terminfo"; then
MC_USE_TERMCAP
fi fi
_MC_WITH_XSLANG _MC_WITH_XSLANG

View File

@ -182,12 +182,6 @@ AC_CHECK_FUNCS([\
tcgetattr tcsetattr truncate \ tcgetattr tcsetattr truncate \
]) ])
dnl S-Lang needs all four functions to be defined to use POSIX signal API
AC_CHECK_FUNCS([sigaction sigemptyset sigprocmask sigaddset], , [slang_signals=no])
if test x$slang_signals != xno; then
AC_DEFINE(SLANG_POSIX_SIGNALS, 1, [Define to use POSIX signal API in S-Lang])
fi
dnl dnl
dnl getpt is a GNU Extension (glibc 2.1.x) dnl getpt is a GNU Extension (glibc 2.1.x)
dnl dnl
@ -452,19 +446,16 @@ subshell="$result"
dnl dnl
dnl Select the screen library. mcslang is the included S-Lang library. dnl Select the screen library.
dnl dnl
AC_ARG_WITH(screen, AC_ARG_WITH(screen,
[ --with-screen=LIB Compile with screen library: slang, mcslang or [ --with-screen=LIB Compile with screen library: slang or
ncurses [[slang if found, else mcslang]]]) ncurses [[slang if found]]])
case x$with_screen in case x$with_screen in
xslang) xslang)
MC_WITH_SLANG(strict) MC_WITH_SLANG(strict)
;; ;;
xmcslang)
MC_WITH_MCSLANG
;;
xncurses) xncurses)
MC_WITH_NCURSES MC_WITH_NCURSES
;; ;;
@ -477,18 +468,6 @@ x)
esac esac
dnl
dnl Force using termcap. This option is processed in MC_WITH_MCSLANG.
dnl Report an error if this option is not applicable.
dnl
AC_ARG_WITH(termcap,
[ --with-termcap Try using termcap database [[only if no terminfo]]],
[if test x$with_screen != xmcslang; then
AC_MSG_ERROR([Option `--with-termcap' only works with `--with-screen=mcslang'])
fi
])
dnl dnl
dnl Internal editor support. dnl Internal editor support.
dnl dnl
@ -572,7 +551,6 @@ AM_CONDITIONAL(USE_VFS_NET, [test x"$use_net_code" = xtrue])
AM_CONDITIONAL(USE_UNDEL_FS, [test -n "$use_undelfs"]) AM_CONDITIONAL(USE_UNDEL_FS, [test -n "$use_undelfs"])
AM_CONDITIONAL(USE_SAMBA_FS, [test -n "$use_smbfs"]) AM_CONDITIONAL(USE_SAMBA_FS, [test -n "$use_smbfs"])
AM_CONDITIONAL(USE_MCFS, [test -n "$use_mcfs"]) AM_CONDITIONAL(USE_MCFS, [test -n "$use_mcfs"])
AM_CONDITIONAL(INCLUDED_SLANG, [test "x$with_screen" = xmcslang])
AM_CONDITIONAL(CHARSET, [test -n "$have_charset"]) AM_CONDITIONAL(CHARSET, [test -n "$have_charset"])
AM_CONDITIONAL(CONS_SAVER, [test -n "$cons_saver"]) AM_CONDITIONAL(CONS_SAVER, [test -n "$cons_saver"])
@ -587,7 +565,6 @@ vfs/Makefile
vfs/extfs/Makefile vfs/extfs/Makefile
lib/Makefile lib/Makefile
src/Makefile src/Makefile
slang/Makefile
edit/Makefile edit/Makefile
syntax/Makefile syntax/Makefile
m4/Makefile m4/Makefile

View File

@ -49,7 +49,7 @@ mc_cflags=""
mc_ldflags="" mc_ldflags=""
mc_tests="plain glib12 charset no_charset vfs no_vfs mcfs no_mcfs samba "\ mc_tests="plain glib12 charset no_charset vfs no_vfs mcfs no_mcfs samba "\
"no_samba ext2undel no_ext2undel slang mcslang ncurses maintainer "\ "no_samba ext2undel no_ext2undel slang ncurses maintainer "\
"no_maintainer i18n no_i18n no_features all_features" "no_maintainer i18n no_i18n no_features all_features"
do_clean_basedir=no do_clean_basedir=no
@ -443,12 +443,6 @@ test_slang() {
confbuild confbuild
} }
test_mcslang() {
testname="mcslang"
configure_args="--with-screen=mcslang"
confbuild
}
test_ncurses() { test_ncurses() {
testname="ncurses" testname="ncurses"
configure_args="--with-screen=ncurses" configure_args="--with-screen=ncurses"

View File

@ -48,7 +48,7 @@
# The list of tests that will be run. # The list of tests that will be run.
#mc_tests="plain glib12 charset no_charset vfs no_vfs mcfs no_mcfs samba "\ #mc_tests="plain glib12 charset no_charset vfs no_vfs mcfs no_mcfs samba "\
#"no_samba ext2undel no_ext2undel slang mcslang ncurses maintainer "\ #"no_samba ext2undel no_ext2undel slang ncurses maintainer "\
#"no_maintainer i18n no_i18n no_features all_features" #"no_maintainer i18n no_i18n no_features all_features"
# This cleans mc_basedir and all its subdirectories. Any directories outside # This cleans mc_basedir and all its subdirectories. Any directories outside

View File

@ -78,7 +78,7 @@ mkdir "$RPM_SRC_DIR/RPMS"
mkdir "$RPM_SRC_DIR/RPMS/i386" mkdir "$RPM_SRC_DIR/RPMS/i386"
mkdir "$RPM_SRC_DIR/SPECS" mkdir "$RPM_SRC_DIR/SPECS"
$RPMBUILD -tb --define="_topdir $RPM_SRC_DIR" \ $RPMBUILD -tb --define="_topdir $RPM_SRC_DIR" \
--define="_with_included_slang 1" "$MCTARBALL" "$MCTARBALL"
MC_RPM_VERSION=`echo $MCVERSION | sed s/-//g` MC_RPM_VERSION=`echo $MCVERSION | sed s/-//g`
MC_RPM=$RPM_SRC_DIR/RPMS/i386/mc-$MC_RPM_VERSION-1.i386.rpm MC_RPM=$RPM_SRC_DIR/RPMS/i386/mc-$MC_RPM_VERSION-1.i386.rpm
if test ! -f $MC_RPM; then if test ! -f $MC_RPM; then

View File

@ -40,7 +40,7 @@ echo "Checking the default configuration"
distcheck 1 distcheck 1
echo "Checking the configuration with maximal code coverage" echo "Checking the configuration with maximal code coverage"
distcheck 2 with_screen=mcslang enable_charset=yes with_samba=yes \ distcheck 2 enable_charset=yes with_samba=yes \
with_mcfs=yes with_included_gettext=yes with_glib12=yes with_mcfs=yes with_included_gettext=yes with_glib12=yes
echo "Checking the configuration with minimal code coverage" echo "Checking the configuration with minimal code coverage"
@ -54,7 +54,7 @@ distcheck 4 enable_largefile=no enable_nls=no with_vfs=no \
with_screen=ncurses with_screen=ncurses
echo "Checking the configuration with experimental and rarely used options" echo "Checking the configuration with experimental and rarely used options"
distcheck 5 with_screen=mcslang with_termcap=yes \ distcheck 5 with_termcap=yes \
with_mmap=no with_subshell=optional enable_netcode=no with_mmap=no with_subshell=optional enable_netcode=no
RPMBUILD=/usr/bin/rpmbuild RPMBUILD=/usr/bin/rpmbuild

View File

@ -1,7 +1,6 @@
# Conditional build (replace "#" with "%" to enable): # Conditional build (replace "#" with "%" to enable):
# #
#define _with_ncurses 1 # use ncurses #define _with_ncurses 1 # use ncurses
#define _with_included_slang 1 # use included S-Lang library
#define _with_charset 1 # enable code for charset conversion #define _with_charset 1 # enable code for charset conversion
#define _with_samba 1 # enable SMB/CIFS virtual file system #define _with_samba 1 # enable SMB/CIFS virtual file system
#define _with_ext2undel 1 # compile with ext2 undelete code #define _with_ext2undel 1 # compile with ext2 undelete code
@ -26,7 +25,7 @@ BuildRoot: /var/tmp/mc-%{PACKAGE_VERSION}-root
# Names of those packages are distribution specific # Names of those packages are distribution specific
#BuildRequires: glib-devel #BuildRequires: glib-devel
#%{!?_with_included_slang:%{!?_with_ncurses:BuildRequires: slang-devel}} #%{!?_with_ncurses:BuildRequires: slang-devel}
#%{?_with_ncurses:BuildRequires: ncurses-devel} #%{?_with_ncurses:BuildRequires: ncurses-devel}
%description %description
@ -46,7 +45,6 @@ CFLAGS="$RPM_OPT_FLAGS" LDFLAGS="-s" ./configure \
--prefix=%{_prefix} \ --prefix=%{_prefix} \
--mandir=%{_mandir} \ --mandir=%{_mandir} \
%{?_with_ncurses: --with-screen=ncurses} \ %{?_with_ncurses: --with-screen=ncurses} \
%{?_with_included_slang: --with-screen=mcslang} \
%{?_with_charset: --enable-charset} \ %{?_with_charset: --enable-charset} \
%{?_with_samba: --with-samba} \ %{?_with_samba: --with-samba} \
%{?_with_ext2undel: --with-ext2undel} \ %{?_with_ext2undel: --with-ext2undel} \

4
slang/.gitignore vendored
View File

@ -1,4 +0,0 @@
.deps
Makefile
Makefile.in
slang.h

View File

@ -1,287 +0,0 @@
2006-02-20 Pavel Tsekov <ptsekov@gmx.net>
* slmisc.c: Import SLmake_string() and SLmake_nstring().
2006-02-15 Leonard den Ottolander <leonard den ottolander nl>
* slcommon.c: Patch to slang-2.0.6 leaving local patches intact.
* sldisply.c: Likewise.
* slerr.c: Likewise.
* slgetkey.c: Likewise.
* slmisc.c: Likewise.
* slsignal.c: Likewise.
* slsmg.c: Likewise.
* slstring.c: Likewise.
* sltermin.c: Likewise.
* slutty.c: Likewise.
* include/_slang.h: Likewise.
* include/slang.h: Likewise.
2006-02-01 Vladimir Nadvorknik <nadvornik@suse.cz>
* slcommon.c (utf8_enable_function): Use '==' instead of '=' for
comparison. Reported by David Binderman.
2006-01-18 Pavel Shirshov <me@pavelsh.pp.ru>
* include/slang.h: comment out declaration of SLmemset(), SLmemchr(),
SLmemcpy(), SLmemcmp(), SLmalloc(), SLfree(), SLrealloc().
* slcommon.c: comment out definitions of SLmalloc(), SLfree(),
SLrealloc().
* include/jdmacros.h: Fully rewritten to use glib rather than S-Lang
replacements.
* slmisc.c: Remove SLang_Version variable.
2006-01-14 Pavel Shirshov <me@pavelsh.pp.ru>
* sldisply.c (SLtt_initialize): Fix typo. Change Is_Bg_BGR
to Is_Fg_BGR. (SLtt_goto_rc): Disable cursor movement optimizations
for qansi-m consoles. Needed on QNX Neutrino. (SLtt_initialize): Init
QANSI_Console variable. (SLtt_erase_line): Use tt_write() instead
tt_write_string(). (SLtt_cls): Use tt_write() instead tt_write_string().
(SLtt_tgetstr): Fix warning.
* slmisc.c: Trimmed down for use in GNU Midnight Commander.
* sltermin.c (_pSLtt_tigetent): Avoid strncpy, home_ti is 1K long and
obody really needs it whole cleared. Fix possible off-by-one error.
* include/slang.h: Define __unix__ if __MACH__, __NetBSD__, _AIX is
defined.
2005-11-28 Pavel Roskin <proski@gnu.org>
* slvideo.c: Remove, it's only used by the obsolete PC port.
* slw32tty.c: Likewise.
* Makefile.am: Adjust for the above.
2005-11-17 Leonard den Ottolander <leonard den ottolander nl>
* Makefile.am: Reinstate ChangeLog.
2005-11-16 Roland Illig <roland.illig@gmx.de>
* slcommon.c (_pSLsecure_issetugid): Made the #ifdef more
readable.
2005-11-15 Leonard den Ottolander <leonard den ottolander nl>
* slcommon.c (_pSLsecure_issetugid): Remove dependency on glibc
private integer __libc_enable_secure.
2005-11-10 Leonard den Ottolander <leonard den ottolander nl>
* *: Upgrade slang to 2.0.5.
2005-07-30 Roland Illig <roland.illig@gmx.de>
* include/slang.h: Define __unix__ if __MACH__ is defined.
2005-03-19 Pavel S. Shirshov <me@pavelsh.pp.ru>
* sldisply.c (SLtt_initialize): Fix typo. Change Is_Bg_BGR,
not Is_Fg_BGR.
2005-02-10 Roland Illig <roland.illig@gmx.de>
* include/slang.h: Define __unix__ if __NetBSD__ is defined.
2004-11-29 Pavel S. Shirshov <me@pavelsh.pp.ru>
* Makefile.am: Use AM_CPPFLAGS for path to mc-slang includes.
* slmisc.c (SLang_Version): Declare const. Use SLANG_VERSION for version
number.
* include/slang.h (SLang_Version): Declare const.
2004-11-09 Andrew V. Samoilov <sav@bcs.zp.ua>
* sldisply.c (SLtt_delete_nlines): Add boundary check.
(forward_cursor): Remove unneeded boundary check.
(tt_write): Remove unneeded cast.
2004-11-09 Pavel S. Shirshov <me@pavelsh.pp.ru>
* include/slang.h (SLang_Version): Delete const qualifier for
compatibility with system slang library.
* slmisc.c: Likewise.
* sldisply.c (tt_sprintf): Import last changes from libslang-current.
Add code to check for a buffer overflow.
(tt_printf): Likewise.
(forward_cursor): Likewise.
From: John E. Davis <davis@space.mit.edu>
2004-11-08 Andrew V. Samoilov <sav@bcs.zp.ua>
* include/slang.h (SLang_Version): Declare const.
* slmisc.c: Add SLang_Version.
2004-11-01 Pavel S. Shirshov <me@pavelsh.pp.ru>
* README: Imported slang-1.4.9.
* sldisply.c: Likewise.
* slerr.c: Likewise.
* slgetkey.c: Likewise.
* slmisc.c: Likewise.
* slsignal.c: Likewise.
* slsmg.c: Likewise.
* sltermin.c: Likewise.
* slutty.c: Likewise.
* slvideo.c: Likewise.
* slw32tty.c: Likewise.
* include/_slang.h: Likewise.
* include/jdmacros.h: Likewise.
* include/sl-feat.h: Likewise.
* include/slang.h: Likewise.
* include/slinclud.h: Likewise.
* include/sllimits.h: Likewise.
2004-10-27 Nerijus Baliunas <nerijus@users.sourceforge.net>
* include/slang.h: Define __unix__ if _AIX is defined.
Needed on AIX.
2004-10-14 Andrew V. Samoilov <sav@bcs.zp.ua>
* sldisply.c (tt_sprintf): Add missed break.
* sldisply.c (SLtt_erase_line): Use tt_write() instead
tt_write_string().
2004-09-26 Mike Gorchak <mike@malva.ua>
* sldisplay.c (SLtt_goto_rc): Disable cursor movement optimizations
for qansi-m consoles. Needed on QNX Neutrino.
(SLtt_initialize): Init QANSI_Console variable.
2004-09-24 Roland Illig <roland.illig@gmx.de>
* slsignal.c (SLsystem): Replaced NULL with (char *) NULL in
call to execl.
From patches from the OpenBSD ports collection.
2004-09-04 Pavel S. Shirshov <me@pavelsh.pp.ru>
* sltermin.c (_SLtt_tigetent): Avoid strncpy, home_ti is 1K long and
nobody really needs it whole cleared
2004-08-31 Pavel S. Shirshov <me@pavelsh.pp.ru>
* include/slang.h: Revert last changes - it breaks compiling
* sldisply.c: Likewise.
* slerr.c: Likewise.
* slsmg.c: Likewise.
* sltermin.c: Likewise.
2004-08-29 Roland Illig <roland.illig@gmx.de>
* slang.h: Added const qualifier to some of the SLang functions.
2003-09-26 Andrew V. Samoilov <sav@bcs.zp.ua>
* sldisply.c (RGB_to_BGR): Make const.
* slsignal.c (SLsystem): Commented out.
2003-09-11 Andrew V. Samoilov <sav@bcs.zp.ua>
* slerr.c (SLang_doerror): Fix possible off-by-one error.
* sltermin.c (_SLtt_tigetent): Likewise.
2002-11-28 Pavel Roskin <proski@gnu.org>
* sldisply.c: Fix for the previous patch. Only swap colors if
setf and setb are not empty.
Reported by Andras Barthazi <andras@barthazi.hu>
2002-10-25 Pavel Roskin <proski@gnu.org>
* sldisply.c: Patch to swap blue and red colors for setf/setb
capabilities. Needed on QNX Neutrino.
Reported by Pavel Shirshov <me@pavelsh.pp.ru>
2002-10-07 Pavel Roskin <proski@gnu.org>
* include/jdmacros.h: Define SLMEMSET and SLMEMCPY
unconditionally, use macros with arguments.
* include/_slang.h: Make it clear which parts are disabled
for compatibility with glib.
* include/slinclud.h: Include malloc.h only if STDC_HEADERS is
not defined.
2002-10-07 Andrew V. Samoilov <sav@bcs.zp.ua>
* sldisply.c (Color_Def_Type): Make const.
* slsmg.c (Fake_Alt_Char_Pairs): Likewise.
* sltermin.c (Tgetstr_Map_Type): Likewise.
* slutty.c (Baud_Rate_Type): Likewise.
2002-10-07 Pavel Roskin <proski@gnu.org>
Update to S-Lang 1.4.5. Move include files to "include"
directory to avoid the need to rename slang.h.
* Makefile.am: Adjust file list. Add "-Iinclude" to the
compiler flags.
* include/jdmacros.h: Rewrite to use glib.
* slmisc.c: Trim to include only needed functions.
2002-09-18 Andrew V. Samoilov <sav@bcs.zp.ua>
* slerr.c (SLang_doerror): Use error parameter. Eliminate
err[] array.
2002-08-21 Pavel Roskin <proski@gnu.org>
* slsmg.c (Fake_Alt_Char_Pairs): Update from slang-1.4.5. This
fixes the MC logo in the help screen.
2002-01-21 Pavel Roskin <proski@gnu.org>
* slvideo.c: Include _slang.h, not slang.h.
* slos2tty.c: Remove since OS/2 is no longer supported.
* Makefile.am (EXTRASRC): Remove slos2tty.c.
2001-12-21 Pavel Roskin <proski@gnu.org>
* _slang.h: Include slang-mc.h.
* slang-mc.h: Add protection against using with system installed
S-Lang library.
* sl*.c: Only include _slang.h, but not slang.h to avoid making
symlinks.
2001-09-04 Pavel Roskin <proski@gnu.org>
* Makefile.am (AM_CFLAGS): Remove CFLAGS, don't use substituted
values directly.
2001-08-26 Pavel Roskin <proski@gnu.org>
* Makefile.am: Don't install libmcslang.a.
* Makefile.am (AM_CPPFLAGS): Remove, it's not needed.
2001-08-25 Pavel Roskin <proski@gnu.org>
* Makefile.in: Converted to ...
* Makefile.am: ... this.
2001-02-22 Pavel Roskin <proski@gnu.org>
* _slang.h: Include glib.h.
Tue Apr 13 07:07:36 1999 Norbert Warmuth <nwarmuth@privat.circular.de>
* slutty.c (SLsys_getkey): handle EOF on stdin (return
SLANG_GETKEY_ERROR on EOF instead of returning garbage)
* Makefile.in (clean): remove the symbolic link slang.h on the
distclean target and not on the clean target.
Sun Feb 14 01:05:42 1999 Norbert Warmuth <nwarmuth@privat.circular.de>
* sldisply.c (SLtt_get_terminfo): use g_snprintf instead of
sprintf
* slsmg.c (SLsmg_printf): ditto
* sltermin.c (SLtt_tigetent): ditto

View File

@ -1,38 +0,0 @@
AM_CFLAGS = $(GLIB_CFLAGS)
AM_CPPFLAGS = -I$(srcdir)/include
if INCLUDED_SLANG
noinst_LIBRARIES = libmcslang.a
else
noinst_LIBRARIES =
endif
SLANG_INCLUDES = \
include/_slang.h \
include/jdmacros.h \
include/sl-feat.h \
include/slang.h \
include/slinclud.h \
include/sllimits.h \
include/sllower.h \
include/slupper.h \
include/slwcwidth.h
libmcslang_a_SOURCES = \
slcommon.c \
sldisply.c \
slerr.c \
slgetkey.c \
sllower.c \
slmisc.c \
slsignal.c \
slsmg.c \
slstring.c \
sltermin.c \
slupper.c \
slutf8.c \
slutty.c \
slwcwidth.c \
$(SLANG_INCLUDES)
EXTRA_DIST = ChangeLog README

View File

@ -1,11 +0,0 @@
This is the S-Lang library, version 2.0.5. It has been radically
stripped down to remove functions that are either unused by the Midnight
Commander or already provided by the glib library. The complete
distribution can be downloaded from:
http://www.s-lang.org/
The sources in this directory are only used if you don't have the S-Lang
library installed on your system or if you request to use these sources
by specifying the option `--with-screen=mcslang' to the `configure'
script.

File diff suppressed because it is too large Load Diff

View File

@ -1,15 +0,0 @@
/* Fully rewritten to use glib rather than S-Lang replacements */
#ifndef _JD_MACROS_H_
#define _JD_MACROS_H_
#include <glib.h>
#define SLMEMSET(x,y,z) memset(x,y,z)
#define SLMEMCPY(x,y,z) memcpy(x,y,z)
#define SLfree(x) g_free(x)
#define SLmalloc(x) g_malloc(x)
#define SLrealloc(x,y) g_realloc(x,y)
#define SLvsnprintf g_vsnprintf
#endif /* _JD_MACROS_H_ */

View File

@ -1,74 +0,0 @@
/* Setting this to one permits strings with embedded color changing commands.
* This is experimental.
*/
#define SLSMG_HAS_EMBEDDED_ESCAPE 1
/* Setting this to 1 enables automatic support for associative arrays.
* If this is set to 0, an application must explicitly enable associative
* array support via SLang_init_slassoc.
*/
#define SLANG_HAS_ASSOC_ARRAYS 1
#define SLANG_HAS_COMPLEX 1
#define SLANG_HAS_FLOAT 1
/* This is the old space-speed trade off. To reduce memory usage and code
* size, set this to zero.
*/
/* #define SLANG_OPTIMIZE_FOR_SPEED 0 */
#define SLANG_OPTIMIZE_FOR_SPEED 2
#define SLANG_USE_INLINE_CODE 1
/* Add extra information for tracking down errors. */
#define SLANG_HAS_DEBUG_CODE 1
/* Experimental: Support for examining call frames */
#define SLANG_HAS_DEBUGGER_SUPPORT 1
/* Allow optimizations based upon the __tmp operator. */
#define SLANG_USE_TMP_OPTIMIZATION 1
/* Setting this to one will map 8 bit vtxxx terminals to 7 bit. Terminals
* such as the vt320 can be set up to output the two-character escape sequence
* encoded as 'ESC [' as single character. Setting this variable to 1 will
* insert code to map such characters to the 7 bit equivalent.
* This affects just input characters in the range 128-160 on non PC
* systems.
*/
#if defined(VMS) || defined(AMIGA)
# define SLANG_MAP_VTXXX_8BIT 1
#else
# define SLANG_MAP_VTXXX_8BIT 0
#endif
/* Add support for color terminals that cannot do background color erases
* Such terminals are poorly designed and are slowly disappearing but they
* are still quite common. For example, screen is one of them!
*
* This is experimental. In particular, it is not known to work if
* KANJI suupport is enabled.
*/
#if !defined(IBMPC_SYSTEM)
# define SLTT_HAS_NON_BCE_SUPPORT 1
#else
# define SLTT_HAS_NON_BCE_SUPPORT 0
#endif
/* If you want slang to assume that an xterm always has the background color
* erase feature, then set this to 1. Otherwise, it will check the terminfo
* database. This may or may not be a good idea since most good color xterms
* support bce but many terminfo systems do not support it.
*/
#define SLTT_XTERM_ALWAYS_BCE 0
/* Set this to 1 to enable Kanji support. See above comment. */
#define SLANG_HAS_KANJI_SUPPORT 0
#define SLANG_HAS_SIGNALS 1
/* Enable this if you want beginning-of-statement and end-of-statement
* callbacks. This allows the creation of profilers, stack-checkers, etc.
* SLANG_HAS_DEBUG_CODE must be enabled for this to work.
*/
#define SLANG_HAS_BOSEOS SLANG_HAS_DEBUG_CODE

View File

@ -1,31 +0,0 @@
#ifndef _SLANG_INCLUDE_H_
#define _SLANG_INCLUDE_H_
#define SLANG_SOURCE_ 1
#include "config.h"
#include "sl-feat.h"
#include <stdio.h>
#include <string.h>
#if defined(__QNX__) && defined(__WATCOMC__)
# include <unix.h>
#endif
#ifdef HAVE_STDLIB_H
# include <stdlib.h>
#endif
#ifdef HAVE_UNISTD_H
# include <unistd.h>
#endif
#ifdef HAVE_MALLOC_H
# include <malloc.h>
#endif
#ifdef HAVE_MEMORY_H
# include <memory.h>
#endif
#endif /* _SLANG_INCLUDE_H_ */

View File

@ -1,96 +0,0 @@
/* sllimits.h */
/*
Copyright (C) 2004, 2005 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#define USE_NEW_HASH_CODE 1
#define SLSTRING_HASH_TABLE_SIZE 10007
#if 0
/* slstring.c: Size of the hash table used for strings (prime numbers) */
#ifdef __MSDOS_16BIT__
# define SLSTRING_HASH_TABLE_SIZE 601
#else
# define SLSTRING_HASH_TABLE_SIZE 6007 /* 2909 */
#endif
#endif
/* slang.c: maximum size of run time stack */
#ifdef __MSDOS_16BIT__
# define SLANG_MAX_STACK_LEN 500
#else
# define SLANG_MAX_STACK_LEN 2500
#endif
/* slang.c: This sets the size on the depth of function calls */
#ifdef __MSDOS_16BIT__
# define SLANG_MAX_RECURSIVE_DEPTH 50
#else
# define SLANG_MAX_RECURSIVE_DEPTH 2500
#endif
/* slang.c: Size of the stack used for local variables */
#ifdef __MSDOS_16BIT__
# define SLANG_MAX_LOCAL_STACK 200
#else
# define SLANG_MAX_LOCAL_STACK 4096
#endif
/* slang.c: The size of the hash table used for local and global objects.
* These should be prime numbers.
*/
#if USE_NEW_HASH_CODE
# define SLGLOBALS_HASH_TABLE_SIZE 2048
# define SLLOCALS_HASH_TABLE_SIZE 64
# define SLSTATIC_HASH_TABLE_SIZE 64
#else
# define SLGLOBALS_HASH_TABLE_SIZE 2909
# define SLLOCALS_HASH_TABLE_SIZE 73
# define SLSTATIC_HASH_TABLE_SIZE 73
#endif
/* Size of the keyboard buffer use by the ungetkey routines */
#ifdef __MSDOS_16BIT__
# define SL_MAX_INPUT_BUFFER_LEN 40
#else
# define SL_MAX_INPUT_BUFFER_LEN 1024
#endif
/* Maximum number of nested switch statements */
#define SLANG_MAX_NESTED_SWITCH 10
/* Size of the block stack (used in byte-compiling) */
#define SLANG_MAX_BLOCK_STACK_LEN 50
/* slfile.c: Max number of open file pointers */
#ifdef __MSDOS_16BIT__
# define SL_MAX_FILES 32
#else
# define SL_MAX_FILES 256
#endif
#if !defined(__MSDOS_16BIT__)
# define SLTT_MAX_SCREEN_COLS 512
# define SLTT_MAX_SCREEN_ROWS 512
#else
# define SLTT_MAX_SCREEN_ROWS 64
# define SLTT_MAX_SCREEN_COLS 75
#endif

View File

@ -1,460 +0,0 @@
/* This file was automatically created by ./mktables */
#define SL_TOLOWER_MAX_CHAR 0x10480ul
#define SL_TOLOWER_LOOKUP(x) \
(((unsigned)(x)>=SL_TOLOWER_MAX_CHAR)?0:(_pSLwc_Tolower_Table[(unsigned)(x)>>7][(unsigned)(x)&0x7F]))
extern const short *_pSLwc_Tolower_Table[521];
#ifdef DEFINE_PSLWC_TOLOWER_TABLE
static const short Table_00[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_01[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 32, 32, 32, 32, 32, 32, 32,
/*0x48-0x4F*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x50-0x57*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x58-0x5F*/ 32, 32, 32, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_02[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x48-0x4F*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x50-0x57*/ 32, 32, 32, 32, 32, 32, 32, 0,
/*0x58-0x5F*/ 32, 32, 32, 32, 32, 32, 32, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_03[128] =
{
/*0x00-0x07*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x08-0x0F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x10-0x17*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x18-0x1F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x20-0x27*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x28-0x2F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x30-0x37*/ -199, 0, 1, 0, 1, 0, 1, 0,
/*0x38-0x3F*/ 0, 1, 0, 1, 0, 1, 0, 1,
/*0x40-0x47*/ 0, 1, 0, 1, 0, 1, 0, 1,
/*0x48-0x4F*/ 0, 0, 1, 0, 1, 0, 1, 0,
/*0x50-0x57*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x58-0x5F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x78-0x7F*/ -121, 1, 0, 1, 0, 1, 0, 0
};
static const short Table_04[128] =
{
/*0x00-0x07*/ 0, 210, 1, 0, 1, 0, 206, 1,
/*0x08-0x0F*/ 0, 205, 205, 1, 0, 0, 79, 202,
/*0x10-0x17*/ 203, 1, 0, 205, 207, 0, 211, 209,
/*0x18-0x1F*/ 1, 0, 0, 0, 211, 213, 0, 214,
/*0x20-0x27*/ 1, 0, 1, 0, 1, 0, 218, 1,
/*0x28-0x2F*/ 0, 218, 0, 0, 1, 0, 218, 1,
/*0x30-0x37*/ 0, 217, 217, 1, 0, 1, 0, 219,
/*0x38-0x3F*/ 1, 0, 0, 0, 1, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 2, 1, 0, 2,
/*0x48-0x4F*/ 1, 0, 2, 1, 0, 1, 0, 1,
/*0x50-0x57*/ 0, 1, 0, 1, 0, 1, 0, 1,
/*0x58-0x5F*/ 0, 1, 0, 1, 0, 0, 1, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 0, 2, 1, 0, 1, 0, -97, -56,
/*0x78-0x7F*/ 1, 0, 1, 0, 1, 0, 1, 0
};
static const short Table_05[128] =
{
/*0x00-0x07*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x08-0x0F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x10-0x17*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x18-0x1F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x20-0x27*/ -130, 0, 1, 0, 1, 0, 1, 0,
/*0x28-0x2F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x30-0x37*/ 1, 0, 1, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_06[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 38, 0,
/*0x08-0x0F*/ 37, 37, 37, 0, 64, 0, 63, 63,
/*0x10-0x17*/ 0, 32, 32, 32, 32, 32, 32, 32,
/*0x18-0x1F*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x20-0x27*/ 32, 32, 0, 32, 32, 32, 32, 32,
/*0x28-0x2F*/ 32, 32, 32, 32, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 0, 0, 0, 0, -60, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_07[128] =
{
/*0x00-0x07*/ 80, 80, 80, 80, 80, 80, 80, 80,
/*0x08-0x0F*/ 80, 80, 80, 80, 80, 80, 80, 80,
/*0x10-0x17*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x18-0x1F*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x20-0x27*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x28-0x2F*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x78-0x7F*/ 1, 0, 1, 0, 1, 0, 1, 0
};
static const short Table_08[128] =
{
/*0x00-0x07*/ 1, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 1, 0, 1, 0, 1, 0,
/*0x10-0x17*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x18-0x1F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x20-0x27*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x28-0x2F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x30-0x37*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x38-0x3F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x40-0x47*/ 0, 1, 0, 1, 0, 1, 0, 1,
/*0x48-0x4F*/ 0, 1, 0, 1, 0, 1, 0, 0,
/*0x50-0x57*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x58-0x5F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 1, 0, 1, 0, 1, 0, 0, 0,
/*0x78-0x7F*/ 1, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_09[128] =
{
/*0x00-0x07*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x08-0x0F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 48, 48, 48, 48, 48, 48, 48,
/*0x38-0x3F*/ 48, 48, 48, 48, 48, 48, 48, 48,
/*0x40-0x47*/ 48, 48, 48, 48, 48, 48, 48, 48,
/*0x48-0x4F*/ 48, 48, 48, 48, 48, 48, 48, 48,
/*0x50-0x57*/ 48, 48, 48, 48, 48, 48, 48, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_10[128] =
{
/*0x00-0x07*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x08-0x0F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x10-0x17*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x18-0x1F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x20-0x27*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x28-0x2F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x30-0x37*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x38-0x3F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x40-0x47*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x48-0x4F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x50-0x57*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x58-0x5F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x78-0x7F*/ 1, 0, 1, 0, 1, 0, 1, 0
};
static const short Table_11[128] =
{
/*0x00-0x07*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x08-0x0F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x10-0x17*/ 1, 0, 1, 0, 1, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x28-0x2F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x30-0x37*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x38-0x3F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x40-0x47*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x48-0x4F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x50-0x57*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x58-0x5F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x60-0x67*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x68-0x6F*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x70-0x77*/ 1, 0, 1, 0, 1, 0, 1, 0,
/*0x78-0x7F*/ 1, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_12[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ -8, -8, -8, -8, -8, -8, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ -8, -8, -8, -8, -8, -8, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, -8, 0, -8, 0, -8, 0, -8,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_13[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ -8, -8, -8, -8, -8, -8, -8, -8,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ -8, -8, -74, -74, -9, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ -86, -86, -86, -86, -9, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ -8, -8, -100, -100, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ -8, -8, -112, -112, -7, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ -128, -128, -126, -126, -9, 0, 0, 0
};
static const short Table_14[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, -7517, 0,
/*0x28-0x2F*/ 0, 0, -8383, -8262, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 16, 16, 16, 16, 16, 16, 16, 16,
/*0x68-0x6F*/ 16, 16, 16, 16, 16, 16, 16, 16,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_15[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 26, 26,
/*0x38-0x3F*/ 26, 26, 26, 26, 26, 26, 26, 26,
/*0x40-0x47*/ 26, 26, 26, 26, 26, 26, 26, 26,
/*0x48-0x4F*/ 26, 26, 26, 26, 26, 26, 26, 26,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_16[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 32, 32, 32, 32, 32, 32, 32,
/*0x28-0x2F*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x30-0x37*/ 32, 32, 32, 32, 32, 32, 32, 32,
/*0x38-0x3F*/ 32, 32, 32, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_17[128] =
{
/*0x00-0x07*/ 40, 40, 40, 40, 40, 40, 40, 40,
/*0x08-0x0F*/ 40, 40, 40, 40, 40, 40, 40, 40,
/*0x10-0x17*/ 40, 40, 40, 40, 40, 40, 40, 40,
/*0x18-0x1F*/ 40, 40, 40, 40, 40, 40, 40, 40,
/*0x20-0x27*/ 40, 40, 40, 40, 40, 40, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
const short *_pSLwc_Tolower_Table[521] =
{
Table_01, Table_02, Table_03, Table_04, Table_05, Table_00,
Table_00, Table_06, Table_07, Table_08, Table_09, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_10, Table_11, Table_12, Table_13, Table_00, Table_00,
Table_14, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_15, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_16, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_17
};
#endif /* DEFINE_PSLWC_TOLOWER_TABLE */

View File

@ -1,520 +0,0 @@
/* This file was automatically created by ./mktables */
#define SL_TOUPPER_MAX_CHAR 0x10480ul
#define SL_TOUPPER_LOOKUP(x) \
(((unsigned)(x)>=SL_TOUPPER_MAX_CHAR)?0:(_pSLwc_Toupper_Table[(unsigned)(x)>>7][(unsigned)(x)&0x7F]))
extern const short *_pSLwc_Toupper_Table[521];
#ifdef DEFINE_PSLWC_TOUPPER_TABLE
static const short Table_00[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_01[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, -32, -32, -32, -32, -32, -32, -32,
/*0x68-0x6F*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x70-0x77*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x78-0x7F*/ -32, -32, -32, 0, 0, 0, 0, 0
};
static const short Table_02[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 743, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x68-0x6F*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x70-0x77*/ -32, -32, -32, -32, -32, -32, -32, 0,
/*0x78-0x7F*/ -32, -32, -32, -32, -32, -32, -32, 121
};
static const short Table_03[128] =
{
/*0x00-0x07*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x08-0x0F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x10-0x17*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x18-0x1F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x20-0x27*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x28-0x2F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x30-0x37*/ 0, -232, 0, -1, 0, -1, 0, -1,
/*0x38-0x3F*/ 0, 0, -1, 0, -1, 0, -1, 0,
/*0x40-0x47*/ -1, 0, -1, 0, -1, 0, -1, 0,
/*0x48-0x4F*/ -1, 0, 0, -1, 0, -1, 0, -1,
/*0x50-0x57*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x58-0x5F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x78-0x7F*/ 0, 0, -1, 0, -1, 0, -1, -300
};
static const short Table_04[128] =
{
/*0x00-0x07*/ 0, 0, 0, -1, 0, -1, 0, 0,
/*0x08-0x0F*/ -1, 0, 0, 0, -1, 0, 0, 0,
/*0x10-0x17*/ 0, 0, -1, 0, 0, 97, 0, 0,
/*0x18-0x1F*/ 0, -1, 0, 0, 0, 0, 130, 0,
/*0x20-0x27*/ 0, -1, 0, -1, 0, -1, 0, 0,
/*0x28-0x2F*/ -1, 0, 0, 0, 0, -1, 0, 0,
/*0x30-0x37*/ -1, 0, 0, 0, -1, 0, -1, 0,
/*0x38-0x3F*/ 0, -1, 0, 0, 0, -1, 0, 56,
/*0x40-0x47*/ 0, 0, 0, 0, 0, -1, -2, 0,
/*0x48-0x4F*/ -1, -2, 0, -1, -2, 0, -1, 0,
/*0x50-0x57*/ -1, 0, -1, 0, -1, 0, -1, 0,
/*0x58-0x5F*/ -1, 0, -1, 0, -1, -79, 0, -1,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ 0, 0, -1, -2, 0, -1, 0, 0,
/*0x78-0x7F*/ 0, -1, 0, -1, 0, -1, 0, -1
};
static const short Table_05[128] =
{
/*0x00-0x07*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x08-0x0F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x10-0x17*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x18-0x1F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x20-0x27*/ 0, 0, 0, -1, 0, -1, 0, -1,
/*0x28-0x2F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x30-0x37*/ 0, -1, 0, -1, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, -210, -206, 0, -205, -205,
/*0x58-0x5F*/ 0, -202, 0, -203, 0, 0, 0, 0,
/*0x60-0x67*/ -205, 0, 0, -207, 0, 0, 0, 0,
/*0x68-0x6F*/ -209, -211, 0, 0, 0, 0, 0, -211,
/*0x70-0x77*/ 0, 0, -213, 0, 0, -214, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_06[128] =
{
/*0x00-0x07*/ -218, 0, 0, -218, 0, 0, 0, 0,
/*0x08-0x0F*/ -218, 0, -217, -217, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, -219, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_07[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 84, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_08[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, -38, -37, -37, -37,
/*0x30-0x37*/ 0, -32, -32, -32, -32, -32, -32, -32,
/*0x38-0x3F*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x40-0x47*/ -32, -32, -31, -32, -32, -32, -32, -32,
/*0x48-0x4F*/ -32, -32, -32, -32, -64, -63, -63, 0,
/*0x50-0x57*/ -62, -57, 0, 0, 0, -47, -54, 0,
/*0x58-0x5F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ -86, -80, -79, 0, 0, -96, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_09[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x38-0x3F*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x40-0x47*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x48-0x4F*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x50-0x57*/ -80, -80, -80, -80, -80, -80, -80, -80,
/*0x58-0x5F*/ -80, -80, -80, -80, -80, -80, -80, -80,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x78-0x7F*/ 0, -1, 0, -1, 0, -1, 0, -1
};
static const short Table_10[128] =
{
/*0x00-0x07*/ 0, -1, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, -1, 0, -1, 0, -1,
/*0x10-0x17*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x18-0x1F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x20-0x27*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x28-0x2F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x30-0x37*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x38-0x3F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x40-0x47*/ 0, 0, -1, 0, -1, 0, -1, 0,
/*0x48-0x4F*/ -1, 0, -1, 0, -1, 0, -1, 0,
/*0x50-0x57*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x58-0x5F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ 0, -1, 0, -1, 0, -1, 0, 0,
/*0x78-0x7F*/ 0, -1, 0, 0, 0, 0, 0, 0
};
static const short Table_11[128] =
{
/*0x00-0x07*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x08-0x0F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, -48, -48, -48, -48, -48, -48, -48,
/*0x68-0x6F*/ -48, -48, -48, -48, -48, -48, -48, -48,
/*0x70-0x77*/ -48, -48, -48, -48, -48, -48, -48, -48,
/*0x78-0x7F*/ -48, -48, -48, -48, -48, -48, -48, -48
};
static const short Table_12[128] =
{
/*0x00-0x07*/ -48, -48, -48, -48, -48, -48, -48, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_13[128] =
{
/*0x00-0x07*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x08-0x0F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x10-0x17*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x18-0x1F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x20-0x27*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x28-0x2F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x30-0x37*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x38-0x3F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x40-0x47*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x48-0x4F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x50-0x57*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x58-0x5F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x78-0x7F*/ 0, -1, 0, -1, 0, -1, 0, -1
};
static const short Table_14[128] =
{
/*0x00-0x07*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x08-0x0F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x10-0x17*/ 0, -1, 0, -1, 0, -1, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, -59, 0, 0, 0, 0,
/*0x20-0x27*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x28-0x2F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x30-0x37*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x38-0x3F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x40-0x47*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x48-0x4F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x50-0x57*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x58-0x5F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x60-0x67*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x68-0x6F*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x70-0x77*/ 0, -1, 0, -1, 0, -1, 0, -1,
/*0x78-0x7F*/ 0, -1, 0, 0, 0, 0, 0, 0
};
static const short Table_15[128] =
{
/*0x00-0x07*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 8, 8, 8, 8, 8, 8, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 8, 8, 8, 8, 8, 8, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 8, 0, 8, 0, 8, 0, 8,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 74, 74, 86, 86, 86, 86, 100, 100,
/*0x78-0x7F*/ 128, 128, 112, 112, 126, 126, 0, 0
};
static const short Table_16[128] =
{
/*0x00-0x07*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 8, 8, 8, 8, 8, 8, 8, 8,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 8, 8, 0, 9, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, -7205, 0,
/*0x40-0x47*/ 0, 0, 0, 9, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 8, 8, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 8, 8, 0, 0, 0, 7, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 9, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_17[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ -16, -16, -16, -16, -16, -16, -16, -16,
/*0x78-0x7F*/ -16, -16, -16, -16, -16, -16, -16, -16
};
static const short Table_18[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x48-0x4F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x50-0x57*/ -26, -26, -26, -26, -26, -26, -26, -26,
/*0x58-0x5F*/ -26, -26, -26, -26, -26, -26, -26, -26,
/*0x60-0x67*/ -26, -26, -26, -26, -26, -26, -26, -26,
/*0x68-0x6F*/ -26, -26, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_19[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x30-0x37*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x38-0x3F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x40-0x47*/ 0, -32, -32, -32, -32, -32, -32, -32,
/*0x48-0x4F*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x50-0x57*/ -32, -32, -32, -32, -32, -32, -32, -32,
/*0x58-0x5F*/ -32, -32, -32, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
static const short Table_20[128] =
{
/*0x00-0x07*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x08-0x0F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x10-0x17*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x18-0x1F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x20-0x27*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x28-0x2F*/ -40, -40, -40, -40, -40, -40, -40, -40,
/*0x30-0x37*/ -40, -40, -40, -40, -40, -40, -40, -40,
/*0x38-0x3F*/ -40, -40, -40, -40, -40, -40, -40, -40,
/*0x40-0x47*/ -40, -40, -40, -40, -40, -40, -40, -40,
/*0x48-0x4F*/ -40, -40, -40, -40, -40, -40, 0, 0,
/*0x50-0x57*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x58-0x5F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x60-0x67*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x68-0x6F*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x70-0x77*/ 0, 0, 0, 0, 0, 0, 0, 0,
/*0x78-0x7F*/ 0, 0, 0, 0, 0, 0, 0, 0
};
const short *_pSLwc_Toupper_Table[521] =
{
Table_01, Table_02, Table_03, Table_04, Table_05, Table_06,
Table_07, Table_08, Table_09, Table_10, Table_11, Table_12,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_13, Table_14, Table_15, Table_16, Table_00, Table_00,
Table_17, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_18, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_19, Table_00, Table_00, Table_00, Table_00, Table_00,
Table_00, Table_00, Table_00, Table_00, Table_20
};
#endif /* DEFINE_PSLWC_TOUPPER_TABLE */

File diff suppressed because it is too large Load Diff

View File

@ -1,322 +0,0 @@
/* This file contains library-wide symbols that are always needed when one
* links to the library.
*/
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#define _GNU_SOURCE
#include "slinclud.h"
#include "slang.h"
#include "_slang.h"
#ifdef HAVE_LOCALE_H
# include <locale.h>
#endif
#ifdef HAVE_LANGINFO_H
# include <langinfo.h>
#endif
#define DEBUG_MALLOC 0
#if DEBUG_MALLOC
# define SLREALLOC_FUN SLdebug_realloc
# define SLMALLOC_FUN SLdebug_malloc
# define SLFREE_FUN SLdebug_free
#else
# define SLREALLOC_FUN SLREALLOC
# define SLMALLOC_FUN SLMALLOC
# define SLFREE_FUN SLFREE
#endif
int SLang_Version = SLANG_VERSION;
char *SLang_Version_String = SLANG_VERSION_STRING;
int _pSLinterp_UTF8_Mode = 0;
int _pSLtt_UTF8_Mode = 0;
int _pSLutf8_mode = 0;
#ifndef HAVE_LOCALE_H
# define setlocale(x,y) (NULL)
# define LC_ALL 0
#endif
int SLutf8_is_utf8_mode (void)
{
return _pSLutf8_mode;
}
int SLinterp_utf8_enable (int mode)
{
if (mode == -1)
mode = _pSLutf8_mode;
return _pSLinterp_UTF8_Mode = mode;
}
int SLinterp_is_utf8_mode (void)
{
return _pSLinterp_UTF8_Mode;
}
static int utf8_enable (int mode)
{
char *locale;
if (mode != -1)
return (mode != 0);
(void) setlocale (LC_ALL, "");
#ifdef HAVE_NL_LANGINFO_CODESET
locale = nl_langinfo (CODESET);
if ((locale != NULL) && (*locale))
{
if ((0 == strcmp (locale, "UTF-8"))
|| (0 == strcmp (locale, "utf-8"))
|| (0 == strcmp (locale, "utf8"))
|| (0 == strcmp (locale, "UTF8")))
return 1;
return 0;
}
#endif
locale = setlocale (LC_ALL, "");
if (((locale == NULL) || (*locale == 0))
&& ((NULL == (locale = getenv ("LC_ALL"))) || (*locale == 0))
&& ((NULL == (locale = getenv ("LC_CTYPE"))) || (*locale == 0))
&& ((NULL == (locale = getenv ("LANG"))) || (*locale == 0)))
return 0;
/* setlocale man page says the return value is something like:
* language[_territory][.codeset][@modifier][+special][,...
* Here, we want the codeset, if present.
*/
while (*locale && (*locale != '.') && (*locale != '@')
&& (*locale != '+') && (*locale != ','))
locale++;
if (*locale == '.')
{
locale++;
if (0 == strncmp (locale, "UTF-8", 5))
locale += 5;
else if (0 == strncmp (locale, "utf8", 4))
locale += 4;
else
return 0;
if ((*locale == 0) || (*locale == '@')
|| (*locale == '+') || (*locale == ','))
return 1;
}
return 0;
}
/* Returns the value of _pSLutf8_mode */
int SLutf8_enable (int mode)
{
mode = utf8_enable (mode);
_pSLutf8_mode = mode;
_pSLtt_UTF8_Mode = mode;
_pSLinterp_UTF8_Mode = mode;
return mode;
}
#ifndef MIDNIGHT_COMMANDER_CODE
char *SLmalloc (unsigned int len)
{
char *p;
p = (char *) SLMALLOC_FUN (len);
if (p == NULL)
SLang_set_error (SL_MALLOC_ERROR);
return p;
}
void SLfree (char *p)
{
if (p != NULL) SLFREE_FUN (p);
}
char *SLrealloc (char *p, unsigned int len)
{
if (len == 0)
{
SLfree (p);
return NULL;
}
if (p == NULL) p = SLmalloc (len);
else
{
p = (char *)SLREALLOC_FUN (p, len);
if (p == NULL)
SLang_set_error (SL_MALLOC_ERROR);
}
return p;
}
#endif /* !MIDNIGHT_COMMANDER_CODE */
char *SLcalloc (unsigned int nelems, unsigned int len)
{
char *p;
len = nelems * len;
p = SLmalloc (len);
if (p != NULL) memset (p, 0, len);
return p;
}
#if 0 /* was: !defined(HAVE_ISSETUGID) && defined(__GLIBC__) && (__GLIBC__ >= 2) */
extern int __libc_enable_secure;
# define HAVE___LIBC_ENABLE_SECURE 1
#endif
int _pSLsecure_issetugid (void)
{
#ifdef HAVE_ISSETUGID
return (1 == issetugid ());
#else
# if defined HAVE___LIBC_ENABLE_SECURE && 0
return __libc_enable_secure;
# else
# if defined(HAVE_GETUID) && defined(HAVE_GETEUID) && defined(HAVE_GETGID) && defined(HAVE_GETEUID)
static int enable_secure;
if (enable_secure == 0)
{
if ((getuid () != geteuid ())
|| (getgid () != getegid ()))
enable_secure = 1;
else
enable_secure = -1;
}
return (enable_secure == 1);
# else
return 0;
# endif
# endif
#endif
}
/* Like getenv, except if running as setuid or setgid, returns NULL */
char *_pSLsecure_getenv (char *s)
{
if (_pSLsecure_issetugid ())
return NULL;
return getenv (s);
}
typedef struct Interrupt_Hook_Type
{
int (*func)(VOID_STAR);
VOID_STAR client_data;
struct Interrupt_Hook_Type *next;
}
Interrupt_Hook_Type;
static Interrupt_Hook_Type *Interrupt_Hooks = NULL;
static Interrupt_Hook_Type *
find_interrupt_hook (int (*func)(VOID_STAR), VOID_STAR cd,
Interrupt_Hook_Type **prevp)
{
Interrupt_Hook_Type *h = Interrupt_Hooks;
Interrupt_Hook_Type *prev = NULL;
while (h != NULL)
{
if ((h->func == func) && (h->client_data == cd))
{
if (prevp != NULL)
*prevp = prev;
return h;
}
h = h->next;
}
return NULL;
}
int SLang_add_interrupt_hook (int (*func)(VOID_STAR), VOID_STAR cd)
{
Interrupt_Hook_Type *h;
if (NULL != find_interrupt_hook (func, cd, NULL))
return 0;
if (NULL == (h = (Interrupt_Hook_Type *)SLmalloc (sizeof (Interrupt_Hook_Type))))
return -1;
h->func = func;
h->client_data = cd;
h->next = Interrupt_Hooks;
Interrupt_Hooks = h;
return 0;
}
void SLang_remove_interrupt_hook (int (*func)(VOID_STAR), VOID_STAR cd)
{
Interrupt_Hook_Type *h, *hprev;
if (NULL == (h = find_interrupt_hook (func, cd, &hprev)))
return;
if (hprev == NULL)
Interrupt_Hooks = h->next;
else
hprev->next = h->next;
SLfree ((char *) h);
}
int SLang_handle_interrupt (void)
{
Interrupt_Hook_Type *h;
int status = 0;
h = Interrupt_Hooks;
while (h != NULL)
{
if (-1 == (*h->func)(h->client_data))
status = -1;
h = h->next;
}
return status;
}
#if defined(__WIN32__) && defined(SLANG_DLL)
# include <windows.h>
BOOL WINAPI DllMain(HANDLE hInstance,DWORD dwReason,LPVOID lpParam)
{
return 1;
}
#endif

File diff suppressed because it is too large Load Diff

View File

@ -1,766 +0,0 @@
/* error handling common to all routines. */
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#include "slinclud.h"
#include "slang.h"
#include "_slang.h"
void (*_pSLinterpreter_Error_Hook) (int);
void (*SLang_VMessage_Hook) (char *, va_list);
void (*SLang_Error_Hook)(char *);
void (*SLang_Exit_Error_Hook)(char *, va_list);
void (*SLang_Dump_Routine)(char *);
volatile int _pSLang_Error = 0;
volatile int SLKeyBoard_Quit = 0;
typedef struct _Exception_Type Exception_Type;
struct _Exception_Type
{
int error_code;
char *name;
char *description;
Exception_Type *subclasses;
Exception_Type *next;
Exception_Type *parent;
};
static Exception_Type *Exception_Root;
static Exception_Type Exception_Root_Buf =
{
-1, "AnyError", "All Errors", NULL, NULL, NULL
};
/* Built-in error codes */
/* These values should correspond to the values produced by _pSLerr_init.
* Some apps may not use the interpreter, and as such _pSLerr_init will not
* get called.
*/
int SL_Any_Error = -1;
int SL_Unknown_Error = 6;
int SL_Internal_Error = 5;
int SL_OS_Error = 1;
int SL_Malloc_Error = 2;
int SL_Import_Error = 7;
int SL_RunTime_Error = 3;
int SL_InvalidParm_Error = 4;
int SL_TypeMismatch_Error = 8;
int SL_UserBreak_Error = 9;
int SL_Stack_Error = 10;
int SL_StackOverflow_Error = 12;
int SL_StackUnderflow_Error = 11;
int SL_ReadOnly_Error = 13;
int SL_VariableUninitialized_Error = 14;
int SL_NumArgs_Error = 15;
int SL_Index_Error = 16;
int SL_Usage_Error = 17;
int SL_Application_Error = 18;
int SL_NotImplemented_Error = 19;
int SL_LimitExceeded_Error = 20;
int SL_Forbidden_Error = 21;
int SL_Math_Error = 22;
int SL_DivideByZero_Error = 23;
int SL_ArithOverflow_Error = 24;
int SL_ArithUnderflow_Error = 25;
int SL_Domain_Error = 26;
int SL_IO_Error = 27;
int SL_Write_Error = 28;
int SL_Read_Error = 29;
int SL_Open_Error = 30;
int SL_Data_Error = 31;
int SL_Unicode_Error = 32;
int SL_InvalidUTF8_Error = 33;
int SL_Namespace_Error = 34;
int SL_Parse_Error = 35;
int SL_Syntax_Error = 36;
int SL_DuplicateDefinition_Error = 37;
int SL_UndefinedName_Error = 38;
typedef struct
{
int *errcode_ptr;
char *name;
char *description;
int *base_class_ptr;
}
BuiltIn_Exception_Table_Type;
static SLCONST BuiltIn_Exception_Table_Type BuiltIn_Exception_Table[] =
{
/* Define MallocError and InvalidParmError ASAP */
{&SL_OS_Error, "OSError", "OS Error", &SL_Any_Error},
{&SL_Malloc_Error, "MallocError", "Not enough memory", &SL_OS_Error},
{&SL_RunTime_Error, "RunTimeError", "Run-Time Error", &SL_Any_Error},
{&SL_InvalidParm_Error, "InvalidParmError", "Invalid Parameter", &SL_RunTime_Error},
{&SL_Internal_Error, "InternalError", "Internal Error", &SL_Any_Error},
{&SL_Unknown_Error, "UnknownError", "Unknown Error", &SL_Any_Error},
/* Rest of OSErrors */
{&SL_Import_Error, "ImportError", "Import Error", &SL_OS_Error},
/* Rest of RunTimeErrors */
{&SL_TypeMismatch_Error, "TypeMismatchError", "Type Mismatch", &SL_RunTime_Error},
{&SL_UserBreak_Error, "UserBreakError", "User Break", &SL_RunTime_Error},
{&SL_Stack_Error, "StackError", "Stack Error", &SL_RunTime_Error},
{&SL_StackUnderflow_Error, "StackUnderflowError", "Stack Underflow Error", &SL_Stack_Error},
{&SL_StackOverflow_Error, "StackOverflowError", "Stack Overflow Error", &SL_Stack_Error},
{&SL_ReadOnly_Error, "ReadOnlyError", "Read-Only Error", &SL_RunTime_Error},
{&SL_VariableUninitialized_Error, "VariableUninitializedError", "Variable Uninitialized Error", &SL_RunTime_Error},
{&SL_NumArgs_Error, "NumArgsError", "Invalid Number of Arguments", &SL_RunTime_Error},
{&SL_Index_Error, "IndexError", "Invalid Index", &SL_RunTime_Error},
{&SL_Usage_Error, "UsageError", "Illegal Usage", &SL_RunTime_Error},
{&SL_Application_Error, "ApplicationError", "Application Error", &SL_RunTime_Error},
{&SL_NotImplemented_Error, "NotImplementedError", "Not Implemented", &SL_RunTime_Error},
{&SL_LimitExceeded_Error, "LimitExceededError", "Limit Exceeded", &SL_RunTime_Error},
{&SL_Forbidden_Error, "ForbiddenError", "Operation Forbidden", &SL_RunTime_Error},
{&SL_Math_Error, "MathError", "Math Error", &SL_RunTime_Error},
{&SL_DivideByZero_Error, "DivideByZeroError", "Divide by Zero", &SL_Math_Error},
{&SL_ArithOverflow_Error, "ArithOverflowError", "Arithmetic Overflow", &SL_Math_Error},
{&SL_ArithUnderflow_Error, "ArithUnderflowError", "Arithmetic Underflow", &SL_Math_Error},
{&SL_Domain_Error, "DomainError", "Domain Error", &SL_Math_Error},
{&SL_IO_Error, "IOError", "I/O Error", &SL_RunTime_Error},
{&SL_Write_Error, "WriteError", "Write failed", &SL_IO_Error},
{&SL_Read_Error, "ReadError", "Read failed", &SL_IO_Error},
{&SL_Open_Error, "OpenError", "Open failed", &SL_IO_Error},
{&SL_Data_Error, "DataError", "Data Error", &SL_RunTime_Error},
{&SL_Unicode_Error, "UnicodeError", "Unicode Error", &SL_RunTime_Error},
{&SL_InvalidUTF8_Error, "UTF8Error", "Invalid UTF8", &SL_Unicode_Error},
{&SL_Namespace_Error, "NamespaceError", "Namespace Error", &SL_RunTime_Error},
/* Parse Errors */
{&SL_Parse_Error, "ParseError", "Parse Error", &SL_Any_Error},
{&SL_Syntax_Error, "SyntaxError", "Syntax Error", &SL_Parse_Error},
{&SL_DuplicateDefinition_Error, "DuplicateDefinitionError", "Duplicate Definition", &SL_Parse_Error},
{&SL_UndefinedName_Error, "UndefinedNameError", "Undefined Name", &SL_Parse_Error},
{NULL, NULL, NULL, NULL}
};
static Exception_Type *find_exception (Exception_Type *root, int error_code)
{
Exception_Type *e;
while (root != NULL)
{
if (error_code == root->error_code)
return root;
if (root->subclasses != NULL)
{
e = find_exception (root->subclasses, error_code);
if (e != NULL)
return e;
}
root = root->next;
}
return root;
}
static int is_exception_ancestor (int a, int b)
{
Exception_Type *e;
if (a == b)
return 1;
if (NULL == (e = find_exception (Exception_Root, a)))
return 0;
while (e->parent != NULL)
{
e = e->parent;
if (e->error_code == b)
return 1;
}
return 0;
}
int SLerr_exception_eqs (int a, int b)
{
if (is_exception_ancestor (a, b))
return 1;
return 0;
}
static void free_this_exception (Exception_Type *e)
{
if (e == NULL)
return;
if (e->name != NULL)
SLang_free_slstring (e->name);
if (e->description != NULL)
SLang_free_slstring (e->description);
SLfree ((char *)e);
}
static int Next_Exception_Code;
/* The whole point of this nonsense involving the _pSLerr_New_Exception_Hook
* is to provide a mechanism to avoid linking in the interpreter for apps
* that just want the other facilities.
*/
int (*_pSLerr_New_Exception_Hook)(char *name, char *desc, int error_code);
int _pSLerr_init_interp_exceptions (void)
{
SLCONST BuiltIn_Exception_Table_Type *b;
Exception_Type *e;
if (_pSLerr_New_Exception_Hook == NULL)
return 0;
e = &Exception_Root_Buf;
if (-1 == (*_pSLerr_New_Exception_Hook)(e->name, e->description, e->error_code))
return -1;
b = BuiltIn_Exception_Table;
while (b->errcode_ptr != NULL)
{
if (-1 == (*_pSLerr_New_Exception_Hook)(b->name, b->description, *b->errcode_ptr))
return -1;
b++;
}
return 0;
}
int SLerr_new_exception (int baseclass, char *name, char *descript)
{
Exception_Type *base;
Exception_Type *e;
if (-1 == _pSLerr_init ())
return -1;
base = find_exception (Exception_Root, baseclass);
if (base == NULL)
{
SLang_verror (SL_InvalidParm_Error,
"Base class for new exception not found");
return -1;
}
e = (Exception_Type *) SLcalloc (1, sizeof (Exception_Type));
if (e == NULL)
return -1;
if ((NULL == (e->name = SLang_create_slstring (name)))
|| (NULL == (e->description = SLang_create_slstring (descript))))
{
free_this_exception (e);
return -1;
}
e->error_code = Next_Exception_Code;
if ((_pSLerr_New_Exception_Hook != NULL)
&& (-1 == (*_pSLerr_New_Exception_Hook) (e->name, e->description, e->error_code)))
{
free_this_exception (e);
return -1;
}
e->parent = base;
e->next = base->subclasses;
base->subclasses = e;
Next_Exception_Code++;
return e->error_code;
}
static int init_exceptions (void)
{
SLCONST BuiltIn_Exception_Table_Type *b;
if (Exception_Root != NULL)
return 0;
Exception_Root = &Exception_Root_Buf;
Next_Exception_Code = 1;
b = BuiltIn_Exception_Table;
while (b->errcode_ptr != NULL)
{
int err_code;
err_code = SLerr_new_exception (*b->base_class_ptr, b->name, b->description);
if (err_code == -1)
return -1;
*b->errcode_ptr = err_code;
b++;
}
return 0;
}
static void free_exceptions (Exception_Type *root)
{
while (root != NULL)
{
Exception_Type *next;
if (root->subclasses != NULL)
free_exceptions (root->subclasses);
next = root->next;
free_this_exception (root);
root = next;
}
}
static void deinit_exceptions (void)
{
Exception_Type *root = Exception_Root;
if (root != NULL)
free_exceptions (root->subclasses);
Exception_Root = NULL;
Next_Exception_Code = 0;
}
char *SLerr_strerror (int err_code)
{
Exception_Type *e;
if (err_code == 0)
err_code = _pSLang_Error;
if (-1 == _pSLerr_init ())
return "Unable to initialize SLerr module";
if (NULL == (e = find_exception (Exception_Root, err_code)))
return "Invalid/Unknown Error Code";
return e->description;
}
/* Error Queue Functions
* SLang_verror (int errcode, fmt, args)
* Add an error message to the queue.
* SLerr_delete_queue ()
* Removes messages from the error queue
* SLerr_print_queue ()
* Prints all messages from the queue, deletes the queue
*/
typedef struct _Error_Message_Type
{
char *msg; /* SLstring, may be NULL */
int msg_type;
#define _SLERR_MSG_ERROR 1
#define _SLERR_MSG_WARNING 2
#define _SLERR_MSG_TRACEBACK 4
struct _Error_Message_Type *next;
}
Error_Message_Type;
typedef struct
{
Error_Message_Type *head;
Error_Message_Type *tail;
}
Error_Queue_Type;
static Error_Queue_Type *Default_Error_Queue;
static void free_error_msg (Error_Message_Type *m)
{
if (m == NULL)
return;
if (m->msg != NULL)
SLang_free_slstring (m->msg);
SLfree ((char *)m);
}
static Error_Message_Type *allocate_error_msg (char *msg, int msg_type)
{
Error_Message_Type *m;
if (NULL == (m = (Error_Message_Type*) SLcalloc (1, sizeof (Error_Message_Type))))
return NULL;
if ((NULL != msg) && (NULL == (m->msg = SLang_create_slstring (msg))))
{
free_error_msg (m);
return NULL;
}
m->msg_type = msg_type;
return m;
}
static void free_queued_messages (Error_Queue_Type *q)
{
Error_Message_Type *m;
if (q == NULL)
return;
m = q->head;
while (m != NULL)
{
Error_Message_Type *m1 = m->next;
free_error_msg (m);
m = m1;
}
q->head = NULL;
q->tail = NULL;
}
static void delete_msg_queue (Error_Queue_Type *q)
{
if (q == NULL)
return;
free_queued_messages (q);
SLfree ((char *)q);
}
static Error_Queue_Type *create_msg_queue (void)
{
Error_Queue_Type *q;
if (NULL == (q = (Error_Queue_Type *)SLcalloc (1, sizeof(Error_Queue_Type))))
return NULL;
return q;
}
static int queue_message (Error_Queue_Type *q, char *msg, int msg_type)
{
Error_Message_Type *m;
if (NULL == (m = allocate_error_msg (msg, msg_type)))
return -1;
if (q->tail != NULL)
q->tail->next = m;
if (q->head == NULL)
q->head = m;
q->tail = m;
return 0;
}
static void print_error (int msg_type, char *err)
{
unsigned int len;
switch (msg_type)
{
case _SLERR_MSG_ERROR:
if (SLang_Error_Hook != NULL)
{
(*SLang_Error_Hook)(err);
return;
}
break;
case _SLERR_MSG_TRACEBACK:
case _SLERR_MSG_WARNING:
if (SLang_Dump_Routine != NULL)
{
(*SLang_Dump_Routine)(err);
return;
}
break;
}
len = strlen (err);
if (len == 0)
return;
fputs (err, stderr);
if ((err[len-1] != '\n')
&& (msg_type != _SLERR_MSG_TRACEBACK))
fputs("\n", stderr);
fflush (stderr);
}
static void print_queue (void)
{
if (-1 == _pSLerr_init ())
print_error (_SLERR_MSG_ERROR, "Unable to initialize SLerr module");
if (_pSLang_Error == 0)
return;
if (Default_Error_Queue != NULL)
{
Error_Queue_Type *q = Default_Error_Queue;
Error_Message_Type *m = q->head;
while (m != NULL)
{
Error_Message_Type *m_next = m->next;
if (m->msg != NULL)
print_error (m->msg_type, m->msg);
m = m_next;
}
free_queued_messages (q);
}
#if 0
if (_pSLang_Error != SL_Usage_Error)
{
print_error (_SLERR_MSG_ERROR, SLerr_strerror (_pSLang_Error));
}
#endif
}
/* This function returns a pointer to the first error message in the queue.
* Make no attempts to free the returned pointer.
*/
char *_pSLerr_get_error_from_queue (void)
{
Error_Queue_Type *q;
Error_Message_Type *m;
unsigned int len;
char *err, *err1, *err_max;
if (NULL == (q = Default_Error_Queue))
return NULL;
len = 0;
m = q->head;
while (m != NULL)
{
if (m->msg_type == _SLERR_MSG_ERROR)
len += 1 + strlen (m->msg);
m = m->next;
}
if (len)
len--; /* last \n not needed */
if (NULL == (err = _pSLallocate_slstring (len)))
return NULL;
err_max = err + len;
err1 = err;
m = q->head;
while (m != NULL)
{
if (m->msg_type == _SLERR_MSG_ERROR)
{
unsigned int dlen = strlen (m->msg);
strcpy (err1, m->msg);
err1 += dlen;
if (err1 != err_max)
*err1++ = '\n';
}
m = m->next;
}
*err1 = 0;
return _pSLcreate_via_alloced_slstring (err, len);
}
void _pSLerr_print_message_queue (void)
{
print_queue ();
}
static volatile int Suspend_Error_Messages = 0;
int _pSLerr_resume_messages (void)
{
if (Suspend_Error_Messages == 0)
return 0;
Suspend_Error_Messages--;
if (Suspend_Error_Messages == 0)
print_queue ();
return 0;
}
int _pSLerr_suspend_messages (void)
{
Suspend_Error_Messages++;
return 0;
}
void _pSLerr_free_queued_messages (void)
{
free_queued_messages (Default_Error_Queue);
}
void SLang_verror (int err_code, char *fmt, ...)
{
va_list ap;
char err [4096];
if (-1 == _pSLerr_init ())
{
print_queue ();
return;
}
if (err_code == 0)
err_code = SL_INTRINSIC_ERROR;
if (_pSLang_Error == 0)
SLang_set_error (err_code);
if (fmt == NULL)
return;
va_start(ap, fmt);
(void) SLvsnprintf (err, sizeof (err), fmt, ap);
va_end(ap);
if (Suspend_Error_Messages)
(void) queue_message (Default_Error_Queue, err, _SLERR_MSG_ERROR);
else
print_error (_SLERR_MSG_ERROR, err);
}
int _pSLerr_traceback_msg (char *fmt, ...)
{
va_list ap;
char msg [4096];
va_start(ap, fmt);
(void) SLvsnprintf (msg, sizeof (msg), fmt, ap);
va_end(ap);
return queue_message (Default_Error_Queue, msg, _SLERR_MSG_TRACEBACK);
}
void SLang_exit_error (char *fmt, ...)
{
va_list ap;
print_queue ();
va_start (ap, fmt);
if (SLang_Exit_Error_Hook != NULL)
{
(*SLang_Exit_Error_Hook) (fmt, ap);
exit (1);
}
if (fmt != NULL)
{
vfprintf (stderr, fmt, ap);
fputs ("\n", stderr);
fflush (stderr);
}
va_end (ap);
exit (1);
}
int SLang_set_error (int error)
{
/* Only allow an error to be cleared (error==0), but not changed
* if there already is an error.
*/
if ((error == 0)
|| (_pSLang_Error == 0))
_pSLang_Error = error;
if (_pSLinterpreter_Error_Hook != NULL)
(*_pSLinterpreter_Error_Hook) (_pSLang_Error);
return 0;
}
int SLang_get_error (void)
{
return _pSLang_Error;
}
void SLang_vmessage (char *fmt, ...)
{
va_list ap;
if (fmt == NULL)
return;
va_start (ap, fmt);
if (SLang_VMessage_Hook != NULL)
(*SLang_VMessage_Hook) (fmt, ap);
else
{
vfprintf (stdout, fmt, ap);
fputs ("\n", stdout);
}
va_end (ap);
}
/* This routine does not queue messages. It is used for tracing, etc. */
void _pSLerr_dump_msg (char *fmt, ...)
{
char buf[1024];
va_list ap;
va_start (ap, fmt);
if (SLang_Dump_Routine != NULL)
{
(void) SLvsnprintf (buf, sizeof (buf), fmt, ap);
(*SLang_Dump_Routine) (buf);
}
else
{
vfprintf (stderr, fmt, ap);
fflush (stderr);
}
va_end (ap);
}
int _pSLerr_init (void)
{
if (Default_Error_Queue == NULL)
{
Suspend_Error_Messages = 0;
if (NULL == (Default_Error_Queue = create_msg_queue ()))
return -1;
}
if (-1 == init_exceptions ())
return -1;
return 0;
}
void _pSLerr_deinit (void)
{
deinit_exceptions ();
delete_msg_queue (Default_Error_Queue);
Suspend_Error_Messages = 0;
Default_Error_Queue = NULL;
}

View File

@ -1,320 +0,0 @@
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#include "slinclud.h"
#include "slang.h"
#include "_slang.h"
unsigned int SLang_Input_Buffer_Len = 0;
unsigned char SLang_Input_Buffer [SL_MAX_INPUT_BUFFER_LEN];
int SLang_Abort_Char = 7;
int SLang_Ignore_User_Abort = 0;
/* This has the effect of mapping all characters in the range 128-169 to
* ESC [ something
*/
unsigned int SLang_getkey (void)
{
unsigned int imax;
unsigned int ch;
if (SLang_Input_Buffer_Len)
{
ch = (unsigned int) *SLang_Input_Buffer;
SLang_Input_Buffer_Len--;
imax = SLang_Input_Buffer_Len;
SLMEMCPY ((char *) SLang_Input_Buffer,
(char *) (SLang_Input_Buffer + 1), imax);
}
else if (SLANG_GETKEY_ERROR == (ch = _pSLsys_getkey ())) return ch;
#if SLANG_MAP_VTXXX_8BIT
# if !defined(IBMPC_SYSTEM)
if (ch & 0x80)
{
unsigned char i;
i = (unsigned char) (ch & 0x7F);
if (i < ' ')
{
i += 64;
SLang_ungetkey (i);
ch = 27;
}
}
# endif
#endif
return(ch);
}
int SLang_ungetkey_string (unsigned char *s, unsigned int n)
{
register unsigned char *bmax, *b, *b1;
if (SLang_Input_Buffer_Len + n + 3 > SL_MAX_INPUT_BUFFER_LEN)
return -1;
b = SLang_Input_Buffer;
bmax = (b - 1) + SLang_Input_Buffer_Len;
b1 = bmax + n;
while (bmax >= b) *b1-- = *bmax--;
bmax = b + n;
while (b < bmax) *b++ = *s++;
SLang_Input_Buffer_Len += n;
return 0;
}
int SLang_buffer_keystring (unsigned char *s, unsigned int n)
{
if (n + SLang_Input_Buffer_Len + 3 > SL_MAX_INPUT_BUFFER_LEN) return -1;
SLMEMCPY ((char *) SLang_Input_Buffer + SLang_Input_Buffer_Len,
(char *) s, n);
SLang_Input_Buffer_Len += n;
return 0;
}
int SLang_ungetkey (unsigned char ch)
{
return SLang_ungetkey_string(&ch, 1);
}
int SLang_input_pending (int tsecs)
{
int n;
unsigned char c;
if (SLang_Input_Buffer_Len) return (int) SLang_Input_Buffer_Len;
n = _pSLsys_input_pending (tsecs);
if (n <= 0) return 0;
c = (unsigned char) SLang_getkey ();
SLang_ungetkey_string (&c, 1);
return n;
}
void SLang_flush_input (void)
{
int quit = SLKeyBoard_Quit;
SLang_Input_Buffer_Len = 0;
SLKeyBoard_Quit = 0;
while (_pSLsys_input_pending (0) > 0)
{
(void) _pSLsys_getkey ();
/* Set this to 0 because _pSLsys_getkey may stuff keyboard buffer if
* key sends key sequence (OS/2, DOS, maybe VMS).
*/
SLang_Input_Buffer_Len = 0;
}
SLKeyBoard_Quit = quit;
}
#ifdef IBMPC_SYSTEM
static int Map_To_ANSI;
int SLgetkey_map_to_ansi (int enable)
{
Map_To_ANSI = enable;
return 0;
}
static int convert_scancode (unsigned int scan,
unsigned int shift,
int getkey,
unsigned int *ret_key)
{
unsigned char buf[16];
unsigned char *b;
unsigned char end;
int is_arrow;
shift &= (_pSLTT_KEY_ALT|_pSLTT_KEY_SHIFT|_pSLTT_KEY_CTRL);
b = buf;
if (_pSLTT_KEY_ALT == shift)
{
shift = 0;
*b++ = 27;
}
*b++ = 27;
*b++ = '[';
is_arrow = 0;
end = '~';
if (shift)
{
if (shift == _pSLTT_KEY_CTRL)
end = '^';
else if (shift == _pSLTT_KEY_SHIFT)
end = '$';
else shift = 0;
}
/* These mappings correspond to what rxvt produces under Linux */
switch (scan & 0xFF)
{
default:
return -1;
case 0x47: /* home */
*b++ = '1';
break;
case 0x48: /* up */
end = 'A';
is_arrow = 1;
break;
case 0x49: /* PgUp */
*b++ = '5';
break;
case 0x4B: /* Left */
end = 'D';
is_arrow = 1;
break;
case 0x4D: /* Right */
end = 'C';
is_arrow = 1;
break;
case 0x4F: /* End */
*b++ = '4';
break;
case 0x50: /* Down */
end = 'B';
is_arrow = 1;
break;
case 0x51: /* PgDn */
*b++ = '6';
break;
case 0x52: /* Insert */
*b++ = '2';
break;
case 0x53: /* Delete */
*b++ = '3';
break;
case ';': /* F1 */
*b++ = '1';
*b++ = '1';
break;
case '<': /* F2 */
*b++ = '1';
*b++ = '2';
break;
case '=': /* F3 */
*b++ = '1';
*b++ = '3';
break;
case '>': /* F4 */
*b++ = '1';
*b++ = '4';
break;
case '?': /* F5 */
*b++ = '1';
*b++ = '5';
break;
case '@': /* F6 */
*b++ = '1';
*b++ = '7';
break;
case 'A': /* F7 */
*b++ = '1';
*b++ = '8';
break;
case 'B': /* F8 */
*b++ = '1';
*b++ = '9';
break;
case 'C': /* F9 */
*b++ = '2';
*b++ = '0';
break;
case 'D': /* F10 */
*b++ = '2';
*b++ = '1';
break;
case 0x57: /* F11 */
*b++ = '2';
*b++ = '3';
break;
case 0x58: /* F12 */
*b++ = '2';
*b++ = '4';
break;
}
if (is_arrow && shift)
{
if (shift == _pSLTT_KEY_CTRL)
end &= 0x1F;
else
end |= 0x20;
}
*b++ = end;
if (getkey)
{
(void) SLang_buffer_keystring (buf + 1, (unsigned int) (b - (buf + 1)));
*ret_key = buf[0];
return 0;
}
(void) SLang_buffer_keystring (buf, (unsigned int) (b - buf));
return 0;
}
unsigned int _pSLpc_convert_scancode (unsigned int scan,
unsigned int shift,
int getkey)
{
unsigned char buf[16];
if (Map_To_ANSI)
{
if (0 == convert_scancode (scan, shift, getkey, &scan))
return scan;
}
if (getkey)
{
buf[0] = scan & 0xFF;
SLang_buffer_keystring (buf, 1);
return (scan >> 8) & 0xFF;
}
buf[0] = (scan >> 8) & 0xFF;
buf[1] = scan & 0xFF;
(void) SLang_buffer_keystring (buf, 2);
return 0;
}
#endif

View File

@ -1,17 +0,0 @@
#include "slinclud.h"
#include <ctype.h>
#include "slang.h"
#include "_slang.h"
#define DEFINE_PSLWC_TOLOWER_TABLE
#include "sllower.h"
#define MODE_VARIABLE _pSLinterp_UTF8_Mode
SLwchar_Type SLwchar_tolower (SLwchar_Type ch)
{
if (MODE_VARIABLE)
return ch + SL_TOLOWER_LOOKUP(ch);
return tolower(ch);
}

View File

@ -1,162 +0,0 @@
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
Trimmed down for use in GNU Midnight Commander.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#define _GNU_SOURCE
#include "slinclud.h"
#include <ctype.h>
#include "slang.h"
#include "_slang.h"
char *SLmake_string(char *str)
{
return SLmake_nstring(str, strlen (str));
}
char *SLmake_nstring (char *str, unsigned int n)
{
char *ptr;
if (NULL == (ptr = SLmalloc(n + 1)))
{
return NULL;
}
SLMEMCPY (ptr, str, n);
ptr[n] = 0;
return(ptr);
}
/*
* This function assumes that the initial \ char has been removed.
*/
char *_pSLexpand_escaped_char(char *p, SLwchar_Type *ch, int *isunicodep)
{
int i = 0;
SLwchar_Type max = 0;
SLwchar_Type num, base = 0;
SLwchar_Type ch1;
int isunicode;
int needs_brace;
ch1 = *p++;
isunicode = 0;
needs_brace = 0;
switch (ch1)
{
default: num = ch1; break;
case 'n': num = '\n'; break;
case 't': num = '\t'; break;
case 'v': num = '\v'; break;
case 'b': num = '\b'; break;
case 'r': num = '\r'; break;
case 'f': num = '\f'; break;
case 'E': case 'e': num = 27; break;
case 'a': num = 7;
break;
/* octal */
case '0': case '1': case '2': case '3':
case '4': case '5': case '6': case '7':
max = '7';
base = 8; i = 2; num = ch1 - '0';
break;
case 'd': /* decimal -- S-Lang extension */
base = 10;
i = 3;
max = '9';
num = 0;
break;
case 'u':
isunicode = 1;
/* drop */
case 'x': /* hex */
base = 16;
max = '9';
i = 2;
num = 0;
if (*p == '{')
{
p++;
i = 0;
while (p[i] && (p[i] != '}'))
i++;
if (p[i] != '}')
{
SLang_verror (SL_SYNTAX_ERROR, "Escaped character missing closing }.");
return NULL;
}
/* The meaning of \x{...} is mode dependent. If in UTF-8 mode, then
* \x{...} always generates a unicode character. Otherwise, the
* meaning of \x{...} depends upon the number of characters enclosed
* by the brace. If there are less than 3, then assume no unicode.
* If greater than or equal to 3, then assume unicode.
*/
if (isunicode == 0) /* \x... */
isunicode = _pSLinterp_UTF8_Mode || (i > 2);
needs_brace = 1;
}
break;
}
while (i)
{
ch1 = *p;
i--;
if ((ch1 <= max) && (ch1 >= '0'))
{
num = base * num + (ch1 - '0');
}
else if (base == 16)
{
ch1 |= 0x20;
if ((ch1 < 'a') || ((ch1 > 'f'))) break;
num = base * num + 10 + (ch1 - 'a');
}
else break;
p++;
}
if (needs_brace)
{
if (*p != '}')
{
SLang_verror (SL_SYNTAX_ERROR, "Malformed escaped character.");
return NULL;
}
p++;
}
if (isunicodep != NULL)
*isunicodep = isunicode;
*ch = num;
return p;
}

View File

@ -1,351 +0,0 @@
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#include "slinclud.h"
#include <signal.h>
#ifdef HAVE_SYS_TYPES_H
# include <sys/types.h>
#endif
#ifdef HAVE_SYS_WAIT_H
# include <sys/wait.h>
#endif
#include <errno.h>
#include "slang.h"
#include "_slang.h"
/* Do not trust these environments */
#if defined(__MINGW32__) || defined(AMIGA)
# ifdef SLANG_POSIX_SIGNALS
# undef SLANG_POSIX_SIGNALS
# endif
#endif
/* This function will cause system calls to be restarted after signal if possible */
SLSig_Fun_Type *SLsignal (int sig, SLSig_Fun_Type *f)
{
#if defined(SLANG_POSIX_SIGNALS)
struct sigaction old_sa, new_sa;
# ifdef SIGALRM
/* We want system calls to be interrupted by SIGALRM. */
if (sig == SIGALRM) return SLsignal_intr (sig, f);
# endif
sigemptyset (&new_sa.sa_mask);
new_sa.sa_handler = f;
new_sa.sa_flags = 0;
# ifdef SA_RESTART
new_sa.sa_flags |= SA_RESTART;
# endif
if (-1 == sigaction (sig, &new_sa, &old_sa))
return (SLSig_Fun_Type *) SIG_ERR;
return old_sa.sa_handler;
#else
/* Not POSIX. */
return signal (sig, f);
#endif
}
/* This function will NOT cause system calls to be restarted after
* signal if possible
*/
SLSig_Fun_Type *SLsignal_intr (int sig, SLSig_Fun_Type *f)
{
#ifdef SLANG_POSIX_SIGNALS
struct sigaction old_sa, new_sa;
sigemptyset (&new_sa.sa_mask);
new_sa.sa_handler = f;
new_sa.sa_flags = 0;
# ifdef SA_INTERRUPT
new_sa.sa_flags |= SA_INTERRUPT;
# endif
if (-1 == sigaction (sig, &new_sa, &old_sa))
return (SLSig_Fun_Type *) SIG_ERR;
return old_sa.sa_handler;
#else
/* Not POSIX. */
return signal (sig, f);
#endif
}
/* We are primarily interested in blocking signals that would cause the
* application to reset the tty. These include suspend signals and
* possibly interrupt signals.
*/
#ifdef SLANG_POSIX_SIGNALS
static sigset_t Old_Signal_Mask;
#endif
static volatile unsigned int Blocked_Depth;
int SLsig_block_signals (void)
{
#ifdef SLANG_POSIX_SIGNALS
sigset_t new_mask;
#endif
Blocked_Depth++;
if (Blocked_Depth != 1)
{
return 0;
}
#ifdef SLANG_POSIX_SIGNALS
sigemptyset (&new_mask);
# ifdef SIGQUIT
sigaddset (&new_mask, SIGQUIT);
# endif
# ifdef SIGTSTP
sigaddset (&new_mask, SIGTSTP);
# endif
# ifdef SIGINT
sigaddset (&new_mask, SIGINT);
# endif
# ifdef SIGTTIN
sigaddset (&new_mask, SIGTTIN);
# endif
# ifdef SIGTTOU
sigaddset (&new_mask, SIGTTOU);
# endif
# ifdef SIGWINCH
sigaddset (&new_mask, SIGWINCH);
# endif
(void) sigprocmask (SIG_BLOCK, &new_mask, &Old_Signal_Mask);
return 0;
#else
/* Not implemented. */
return -1;
#endif
}
int SLsig_unblock_signals (void)
{
if (Blocked_Depth == 0)
return -1;
Blocked_Depth--;
if (Blocked_Depth != 0)
return 0;
#ifdef SLANG_POSIX_SIGNALS
(void) sigprocmask (SIG_SETMASK, &Old_Signal_Mask, NULL);
return 0;
#else
return -1;
#endif
}
#ifdef MSWINDOWS
int SLsystem (char *cmd)
{
SLang_verror (SL_NOT_IMPLEMENTED, "system not implemented");
return -1;
}
#else
int SLsystem (char *cmd)
{
#ifdef SLANG_POSIX_SIGNALS
pid_t pid;
int status;
struct sigaction ignore;
# ifdef SIGINT
struct sigaction save_intr;
# endif
# ifdef SIGQUIT
struct sigaction save_quit;
# endif
# ifdef SIGCHLD
sigset_t child_mask, save_mask;
# endif
if (cmd == NULL) return 1;
ignore.sa_handler = SIG_IGN;
sigemptyset (&ignore.sa_mask);
ignore.sa_flags = 0;
# ifdef SIGINT
if (-1 == sigaction (SIGINT, &ignore, &save_intr))
return -1;
# endif
# ifdef SIGQUIT
if (-1 == sigaction (SIGQUIT, &ignore, &save_quit))
{
(void) sigaction (SIGINT, &save_intr, NULL);
return -1;
}
# endif
# ifdef SIGCHLD
sigemptyset (&child_mask);
sigaddset (&child_mask, SIGCHLD);
if (-1 == sigprocmask (SIG_BLOCK, &child_mask, &save_mask))
{
# ifdef SIGINT
(void) sigaction (SIGINT, &save_intr, NULL);
# endif
# ifdef SIGQUIT
(void) sigaction (SIGQUIT, &save_quit, NULL);
# endif
return -1;
}
# endif
pid = fork();
if (pid == -1)
status = -1;
else if (pid == 0)
{
/* Child */
# ifdef SIGINT
(void) sigaction (SIGINT, &save_intr, NULL);
# endif
# ifdef SIGQUIT
(void) sigaction (SIGQUIT, &save_quit, NULL);
# endif
# ifdef SIGCHLD
(void) sigprocmask (SIG_SETMASK, &save_mask, NULL);
# endif
execl ("/bin/sh", "sh", "-c", cmd, NULL);
_exit (127);
}
else
{
/* parent */
while (-1 == waitpid (pid, &status, 0))
{
# ifdef EINTR
if (errno == EINTR)
continue;
# endif
# ifdef ERESTARTSYS
if (errno == ERESTARTSYS)
continue;
# endif
status = -1;
break;
}
}
# ifdef SIGINT
if (-1 == sigaction (SIGINT, &save_intr, NULL))
status = -1;
# endif
# ifdef SIGQUIT
if (-1 == sigaction (SIGQUIT, &save_quit, NULL))
status = -1;
# endif
# ifdef SIGCHLD
if (-1 == sigprocmask (SIG_SETMASK, &save_mask, NULL))
status = -1;
# endif
return status;
#else /* No POSIX Signals */
# ifdef SIGINT
void (*sint)(int);
# endif
# ifdef SIGQUIT
void (*squit)(int);
# endif
int status;
# ifdef SIGQUIT
squit = SLsignal (SIGQUIT, SIG_IGN);
# endif
# ifdef SIGINT
sint = SLsignal (SIGINT, SIG_IGN);
# endif
status = system (cmd);
# ifdef SIGINT
SLsignal (SIGINT, sint);
# endif
# ifdef SIGQUIT
SLsignal (SIGQUIT, squit);
# endif
return status;
#endif /* POSIX_SIGNALS */
}
#endif
#if 0
#include <windows.h>
static int msw_system (char *cmd)
{
STARTUPINFO startup_info;
PROCESS_INFORMATION process_info;
int status;
if (cmd == NULL) return -1;
memset ((char *) &startup_info, 0, sizeof (STARTUPINFO));
startup_info.cb = sizeof(STARTUPINFO);
startup_info.dwFlags = STARTF_USESHOWWINDOW;
startup_info.wShowWindow = SW_SHOWDEFAULT;
if (FALSE == CreateProcess (NULL,
cmd,
NULL,
NULL,
FALSE,
NORMAL_PRIORITY_CLASS|CREATE_NEW_CONSOLE,
NULL,
NULL,
&startup_info,
&process_info))
{
SLang_verror (0, "%s: CreateProcess failed.", cmd);
return -1;
}
status = -1;
if (0xFFFFFFFFUL != WaitForSingleObject (process_info.hProcess, INFINITE))
{
DWORD exit_code;
if (TRUE == GetExitCodeProcess (process_info.hProcess, &exit_code))
status = (int) exit_code;
}
CloseHandle (process_info.hThread);
CloseHandle (process_info.hProcess);
return status;
}
#endif

File diff suppressed because it is too large Load Diff

View File

@ -1,692 +0,0 @@
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#include "slinclud.h"
#include "slang.h"
#include "_slang.h"
typedef struct _pSLstring_Type
{
struct _pSLstring_Type *next;
unsigned int ref_count;
unsigned long hash;
unsigned int len;
char bytes [1];
}
SLstring_Type;
#define MAP_HASH_TO_INDEX(hash) ((hash) % SLSTRING_HASH_TABLE_SIZE)
static SLstring_Type *String_Hash_Table [SLSTRING_HASH_TABLE_SIZE];
static char Single_Char_Strings [256 * 2];
#if SLANG_OPTIMIZE_FOR_SPEED
#define MAX_FREE_STORE_LEN 32
static SLstring_Type *SLS_Free_Store [MAX_FREE_STORE_LEN];
# define NUM_CACHED_STRINGS 601
typedef struct
{
SLstring_Type *sls;
char *str;
}
Cached_String_Type;
static char *Deleted_String = "*deleted*";
static Cached_String_Type Cached_Strings [NUM_CACHED_STRINGS];
#define GET_CACHED_STRING(s) \
(Cached_Strings + (unsigned int)(((unsigned long) (s)) % NUM_CACHED_STRINGS))
_INLINE_
static void cache_string (SLstring_Type *sls)
{
Cached_String_Type *cs;
cs = GET_CACHED_STRING(sls->bytes);
cs->str = sls->bytes;
cs->sls = sls;
}
_INLINE_
static void uncache_string (char *s)
{
Cached_String_Type *cs;
cs = GET_CACHED_STRING(s);
if (cs->str == s)
{
cs->sls = NULL;
cs->str = Deleted_String;
}
}
#endif
#if USE_NEW_HASH_CODE
/* This hash algorithm comes from:
*
* Bob Jenkins, 1996. bob_jenkins@burtleburtle.net.
* You may use this code any way you wish, private, educational, or commercial. It's free.
* See http://burtleburtle.net/bob/hash/evahash.html
*/
typedef unsigned long uint32;
#define mix(a,b,c) \
{ \
a -= b; a -= c; a ^= (c>>13); \
b -= c; b -= a; b ^= (a<<8); \
c -= a; c -= b; c ^= (b>>13); \
a -= b; a -= c; a ^= (c>>12); \
b -= c; b -= a; b ^= (a<<16); \
c -= a; c -= b; c ^= (b>>5); \
a -= b; a -= c; a ^= (c>>3); \
b -= c; b -= a; b ^= (a<<10); \
c -= a; c -= b; c ^= (b>>15); \
}
_INLINE_
unsigned long _pSLstring_hash (unsigned char *s, unsigned char *smax)
{
register uint32 a,b,c;
unsigned int length = (unsigned int)(smax - s);
unsigned int len = length;
a = b = 0x9e3779b9; /* the golden ratio; an arbitrary value */
c = 0;
/*---------------------------------------- handle most of the key */
while (len >= 12)
{
a += (s[0] +((uint32)s[1]<<8) +((uint32)s[2]<<16) +((uint32)s[3]<<24));
b += (s[4] +((uint32)s[5]<<8) +((uint32)s[6]<<16) +((uint32)s[7]<<24));
c += (s[8] +((uint32)s[9]<<8) +((uint32)s[10]<<16)+((uint32)s[11]<<24));
mix(a,b,c);
s += 12; len -= 12;
}
/*------------------------------------- handle the last 11 bytes */
c += length;
switch(len) /* all the case statements fall through */
{
case 11: c+=((uint32)s[10]<<24);
case 10: c+=((uint32)s[9]<<16);
case 9 : c+=((uint32)s[8]<<8);
/* the first byte of c is reserved for the length */
case 8 : b+=((uint32)s[7]<<24);
case 7 : b+=((uint32)s[6]<<16);
case 6 : b+=((uint32)s[5]<<8);
case 5 : b+=s[4];
case 4 : a+=((uint32)s[3]<<24);
case 3 : a+=((uint32)s[2]<<16);
case 2 : a+=((uint32)s[1]<<8);
case 1 : a+=s[0];
/* case 0: nothing left to add */
}
mix(a,b,c);
/*-------------------------------------------- report the result */
return (unsigned long) c;
}
#else
_INLINE_
unsigned long _pSLstring_hash (unsigned char *s, unsigned char *smax)
{
register unsigned long h = 0;
register unsigned long sum = 0;
unsigned char *smax4;
smax4 = smax - 4;
while (s < smax4)
{
sum += s[0];
h = sum + (h << 1);
sum += s[1];
h = sum + (h << 1);
sum += s[2];
h = sum + (h << 1);
sum += s[3];
h = sum + (h << 1);
s += 4;
}
while (s < smax)
{
sum += *s++;
h ^= sum + (h << 3); /* slightly different */
}
return h;
}
#endif
unsigned long _pSLcompute_string_hash (char *s)
{
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
cs = GET_CACHED_STRING(s);
if (cs->str == s)
return cs->sls->hash;
#endif
return _pSLstring_hash ((unsigned char *) s, (unsigned char *) s + strlen (s));
}
_INLINE_
/* This routine works with any (long) string */
static SLstring_Type *find_string (char *s, unsigned int len, unsigned long hash)
{
SLstring_Type *sls;
sls = String_Hash_Table [(unsigned int) MAP_HASH_TO_INDEX(hash)];
if (sls == NULL)
return NULL;
do
{
/* Note that we need to actually make sure that bytes[len] == 0.
* In this case, it is not enough to just compare pointers. In fact,
* this is called from create_nstring, etc... It is unlikely that the
* pointer is a slstring
*/
if ((sls->hash == hash)
&& (sls->len == len)
&& (0 == strncmp (s, sls->bytes, len)))
break;
sls = sls->next;
}
while (sls != NULL);
return sls;
}
_INLINE_
static SLstring_Type *find_slstring (char *s, unsigned long hash)
{
SLstring_Type *sls;
sls = String_Hash_Table [MAP_HASH_TO_INDEX(hash)];
while (sls != NULL)
{
if (s == sls->bytes)
return sls;
sls = sls->next;
}
return sls;
}
_INLINE_
static SLstring_Type *allocate_sls (unsigned int len)
{
SLstring_Type *sls;
#if SLANG_OPTIMIZE_FOR_SPEED
if ((len < MAX_FREE_STORE_LEN)
&& (NULL != (sls = SLS_Free_Store [len])))
{
SLS_Free_Store[len] = NULL;
return sls;
}
#endif
/* FIXME: use structure padding */
sls = (SLstring_Type *) SLmalloc (len + sizeof (SLstring_Type));
if (sls != NULL)
sls->len = len;
return sls;
}
_INLINE_
static void free_sls (SLstring_Type *sls)
{
#if SLANG_OPTIMIZE_FOR_SPEED
unsigned int len = sls->len;
if ((len < MAX_FREE_STORE_LEN)
&& (SLS_Free_Store[len] == NULL))
{
SLS_Free_Store [len] = sls;
return;
}
#endif
SLfree ((char *)sls);
}
_INLINE_
static char *create_long_string (char *s, unsigned int len, unsigned long hash)
{
SLstring_Type *sls;
sls = find_string (s, len, hash);
if (sls != NULL)
{
sls->ref_count++;
#if SLANG_OPTIMIZE_FOR_SPEED
cache_string (sls);
#endif
return sls->bytes;
}
sls = allocate_sls (len);
if (sls == NULL)
return NULL;
strncpy (sls->bytes, s, len);
sls->bytes[len] = 0;
sls->ref_count = 1;
sls->hash = hash;
#if SLANG_OPTIMIZE_FOR_SPEED
cache_string (sls);
#endif
hash = MAP_HASH_TO_INDEX(hash);
sls->next = String_Hash_Table [(unsigned int)hash];
String_Hash_Table [(unsigned int)hash] = sls;
return sls->bytes;
}
_INLINE_
static char *create_short_string (char *s, unsigned int len)
{
char ch;
/* Note: if len is 0, then it does not matter what *s is. This is
* important for SLang_create_nslstring.
*/
if (len) ch = *s; else ch = 0;
len = 2 * (unsigned int) ((unsigned char) ch);
Single_Char_Strings [len] = ch;
Single_Char_Strings [len + 1] = 0;
return Single_Char_Strings + len;
}
/* s cannot be NULL */
_INLINE_
static SLstr_Type *create_nstring (char *s, unsigned int len, unsigned long *hash_ptr)
{
unsigned long hash;
if (len < 2)
return create_short_string (s, len);
hash = _pSLstring_hash ((unsigned char *) s, (unsigned char *) (s + len));
*hash_ptr = hash;
return create_long_string (s, len, hash);
}
SLstr_Type *SLang_create_nslstring (char *s, unsigned int len)
{
unsigned long hash;
if (s == NULL)
return NULL;
return create_nstring (s, len, &hash);
}
char *_pSLstring_make_hashed_string (char *s, unsigned int len, unsigned long *hashptr)
{
unsigned long hash;
if (s == NULL) return NULL;
hash = _pSLstring_hash ((unsigned char *) s, (unsigned char *) s + len);
*hashptr = hash;
if (len < 2)
return create_short_string (s, len);
return create_long_string (s, len, hash);
}
char *_pSLstring_dup_hashed_string (char *s, unsigned long hash)
{
unsigned int len;
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
if (s == NULL) return NULL;
if (s[0] == 0)
return create_short_string (s, 0);
if (s[1] == 0)
return create_short_string (s, 1);
cs = GET_CACHED_STRING(s);
if (cs->str == s)
{
cs->sls->ref_count += 1;
return s;
}
#else
if (s == NULL) return NULL;
#endif
len = strlen (s);
#if !SLANG_OPTIMIZE_FOR_SPEED
if (len < 2) return create_short_string (s, len);
#endif
return create_long_string (s, len, hash);
}
/* This function requires an slstring!!! */
char *_pSLstring_dup_slstring (char *s)
{
SLstring_Type *sls;
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
#endif
if (s == NULL)
return s;
#if SLANG_OPTIMIZE_FOR_SPEED
cs = GET_CACHED_STRING(s);
if (cs->str == s)
{
cs->sls->ref_count += 1;
return s;
}
#endif
if ((s[0] == 0) || (s[1] == 0))
return s;
sls = (SLstring_Type *) (s - offsetof(SLstring_Type,bytes[0]));
sls->ref_count++;
#if SLANG_OPTIMIZE_FOR_SPEED
cache_string (sls);
#endif
return s;
}
static void free_sls_string (SLstring_Type *sls)
{
SLstring_Type *sls1, *prev;
unsigned long hash = sls->hash;
hash = MAP_HASH_TO_INDEX(hash);
sls1 = String_Hash_Table [(unsigned int) hash];
prev = NULL;
/* This should not fail. */
while (sls1 != sls)
{
prev = sls1;
sls1 = sls1->next;
}
if (prev != NULL)
prev->next = sls->next;
else
String_Hash_Table [(unsigned int) hash] = sls->next;
free_sls (sls);
}
_INLINE_
static void free_long_string (char *s, unsigned long hash)
{
SLstring_Type *sls;
if (NULL == (sls = find_slstring (s, hash)))
{
SLang_verror (SL_APPLICATION_ERROR, "invalid attempt to free string:%s", s);
return;
}
sls->ref_count--;
if (sls->ref_count != 0)
{
#if SLANG_OPTIMIZE_FOR_SPEED
/* cache_string (sls, len, hash); */
#endif
return;
}
#if SLANG_OPTIMIZE_FOR_SPEED
uncache_string (s);
#endif
free_sls_string (sls);
}
/* This routine may be passed NULL-- it is not an error. */
void SLang_free_slstring (char *s)
{
unsigned long hash;
unsigned int len;
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
#endif
if (s == NULL) return;
#if SLANG_OPTIMIZE_FOR_SPEED
cs = GET_CACHED_STRING(s);
if (cs->str == s)
{
SLstring_Type *sls = cs->sls;
if (sls->ref_count <= 1)
{
#if SLANG_OPTIMIZE_FOR_SPEED
cs->sls = NULL;
cs->str = Deleted_String;
#endif
free_sls_string (sls);
}
else
sls->ref_count -= 1;
return;
}
#endif
if ((len = strlen (s)) < 2)
return;
hash = _pSLstring_hash ((unsigned char *)s, (unsigned char *) s + len);
free_long_string (s, hash);
}
char *SLang_create_slstring (char *s)
{
unsigned long hash;
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
#endif
if (s == NULL) return NULL;
#if SLANG_OPTIMIZE_FOR_SPEED
cs = GET_CACHED_STRING(s);
if (cs->str == s)
{
cs->sls->ref_count += 1;
return s;
}
#endif
return create_nstring (s, strlen (s), &hash);
}
void _pSLfree_hashed_string (char *s, unsigned int len, unsigned long hash)
{
if ((s == NULL) || (len < 2)) return;
free_long_string (s, hash);
}
char *_pSLallocate_slstring (unsigned int len)
{
SLstring_Type *sls = allocate_sls (len);
if (sls == NULL)
return NULL;
sls->hash = 0;
return sls->bytes;
}
void _pSLunallocate_slstring (char *s, unsigned int len)
{
SLstring_Type *sls;
(void) len;
if (s == NULL)
return;
sls = (SLstring_Type *) (s - offsetof(SLstring_Type,bytes[0]));
free_sls (sls);
}
char *_pSLcreate_via_alloced_slstring (char *s, unsigned int len)
{
unsigned long hash;
SLstring_Type *sls;
if (s == NULL)
return NULL;
if (len < 2)
{
char *s1 = create_short_string (s, len);
_pSLunallocate_slstring (s, len);
return s1;
}
/* s is not going to be in the cache because when it was malloced, its
* value was unknown. This simplifies the coding.
*/
hash = _pSLstring_hash ((unsigned char *)s, (unsigned char *)s + len);
sls = find_string (s, len, hash);
if (sls != NULL)
{
sls->ref_count++;
_pSLunallocate_slstring (s, len);
s = sls->bytes;
#if SLANG_OPTIMIZE_FOR_SPEED
cache_string (sls);
#endif
return s;
}
sls = (SLstring_Type *) (s - offsetof(SLstring_Type,bytes[0]));
sls->ref_count = 1;
sls->hash = hash;
#if SLANG_OPTIMIZE_FOR_SPEED
cache_string (sls);
#endif
hash = MAP_HASH_TO_INDEX(hash);
sls->next = String_Hash_Table [(unsigned int)hash];
String_Hash_Table [(unsigned int)hash] = sls;
return s;
}
/* Note, a and b may be ordinary strings. The result is an slstring */
char *SLang_concat_slstrings (char *a, char *b)
{
unsigned int lena, len;
char *c;
lena = strlen (a);
len = lena + strlen (b);
c = _pSLallocate_slstring (len);
if (c == NULL)
return NULL;
strcpy (c, a);
strcpy (c + lena, b);
return _pSLcreate_via_alloced_slstring (c, len);
}
/* This routine is assumed to work even if s is not an slstring */
unsigned int _pSLstring_bytelen (SLstr_Type *s)
{
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
cs = GET_CACHED_STRING(s);
if (cs->str == s)
return cs->sls->len;
#endif
return strlen (s);
}
/* The caller must ensure that this is an slstring */
void _pSLang_free_slstring (SLstr_Type *s)
{
#if SLANG_OPTIMIZE_FOR_SPEED
Cached_String_Type *cs;
#endif
SLstring_Type *sls;
if (s == NULL) return;
#if SLANG_OPTIMIZE_FOR_SPEED
cs = GET_CACHED_STRING(s);
if (cs->str == s)
{
sls = cs->sls;
if (sls->ref_count <= 1)
{
#if SLANG_OPTIMIZE_FOR_SPEED
cs->sls = NULL;
cs->str = Deleted_String;
#endif
free_sls_string (sls);
}
else
sls->ref_count -= 1;
return;
}
#endif
if ((s[0] == 0) || (s[1] == 0))
return;
sls = (SLstring_Type *) (s - offsetof(SLstring_Type,bytes[0]));
if (sls->ref_count > 1)
{
sls->ref_count--;
return;
}
free_long_string (s, sls->hash);
}
/* An SLstring is required */
unsigned long _pSLstring_get_hash (SLstr_Type *s)
{
SLstring_Type *sls;
if (s[0] == 0)
return _pSLstring_hash ((unsigned char*)s, (unsigned char *)s);
if (s[1] == 0)
return _pSLstring_hash ((unsigned char *)s, (unsigned char *)s+1);
sls = (SLstring_Type *) (s - offsetof(SLstring_Type,bytes[0]));
return sls->hash;
}

File diff suppressed because it is too large Load Diff

View File

@ -1,18 +0,0 @@
#include "slinclud.h"
#include <ctype.h>
#include "slang.h"
#include "_slang.h"
#define DEFINE_PSLWC_TOUPPER_TABLE
#include "slupper.h"
#define MODE_VARIABLE _pSLinterp_UTF8_Mode
SLwchar_Type SLwchar_toupper (SLwchar_Type ch)
{
if (MODE_VARIABLE)
return ch + SL_TOUPPER_LOOKUP(ch);
return toupper (ch);
}

View File

@ -1,841 +0,0 @@
#include "slinclud.h"
#include <string.h>
#include "slang.h"
#include "_slang.h"
static unsigned char Len_Map[256] =
{
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* - 31 */
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* - 63 */
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* - 95 */
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* - 127 */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* - 159 */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* - 191 */
2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2, /* - 223 */
3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,6,6,1,1 /* - 255 */
};
/*
* Also note that the code positions U+D800 to U+DFFF (UTF-16 surrogates)
* as well as U+FFFE and U+FFFF must not occur in normal UTF-8 or UCS-4
* data. UTF-8 decoders should treat them like malformed or overlong
* sequences for safety reasons.
*/
#define IS_ILLEGAL_UNICODE(w) \
(((w >= 0xD800) && (w <= 0xDFFF)) || (w == 0xFFFE) || (w == 0xFFFF))
_INLINE_
static int is_invalid_or_overlong_utf8 (SLuchar_Type *u, unsigned int len)
{
unsigned int i;
unsigned char ch, ch1;
/* Check for invalid sequences */
for (i = 1; i < len; i++)
{
if ((u[i] & 0xC0) != 0x80)
return 1;
}
/* Illegal (overlong) sequences */
/* 1100000x (10xxxxxx) */
/* 11100000 100xxxxx (10xxxxxx) */
/* 11110000 1000xxxx (10xxxxxx 10xxxxxx) */
/* 11111000 10000xxx (10xxxxxx 10xxxxxx 10xxxxxx) */
/* 11111100 100000xx (10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx) */
ch = *u;
if ((ch == 0xC0) || (ch == 0xC1))
return 1;
ch1 = u[1];
if (((ch1 & ch) == 0x80)
&& ((ch == 0xE0)
|| (ch == 0xF0)
|| (ch == 0xF8)
|| (ch == 0xFC)))
return 1;
if (len == 3)
{
/* D800 is encoded as 0xED 0xA0 0x80 and DFFF as 0xED 0xBF 0xBF */
if ((ch == 0xED)
&& ((ch1 >= 0xA0) && (ch1 <= 0xBF))
&& (u[2] >= 0x80) && (u[2] <= 0xBF))
return 1;
/* Now FFFE and FFFF */
if ((ch == 0xEF)
&& (ch1 == 0xBF)
&& ((u[2] == 0xBE) || (u[2] == 0xBF)))
return 1;
}
return 0;
}
/* This function assumes that the necessary checks have been made to ensure
* a valid UTF-8 encoded character is present.
*/
_INLINE_
static SLwchar_Type fast_utf8_decode (SLuchar_Type *u, unsigned int len)
{
static unsigned char masks[7] =
{
0, 0, 0x1F, 0xF, 0x7, 0x3, 0x1
};
SLuchar_Type *umax;
SLwchar_Type w;
w = (*u & masks[len]);
umax = u + len;
u++;
while (u < umax)
{
w = (w << 6)| (u[0] & 0x3F);
u++;
}
return w;
}
unsigned char *SLutf8_skip_char (unsigned char *s, unsigned char *smax)
{
unsigned int len;
if (s >= smax)
return s;
len = Len_Map[*s];
if (len <= 1)
return s+1;
if (s + len > smax)
return s+1;
if (is_invalid_or_overlong_utf8 (s, len))
return s + 1;
return s + len;
}
SLuchar_Type *SLutf8_skip_chars (SLuchar_Type *s, SLuchar_Type *smax,
unsigned int num, unsigned int *dnum,
int ignore_combining)
{
unsigned int n;
n = 0;
while ((n < num) && (s < smax))
{
unsigned int len = Len_Map[*s];
if (len <= 1)
{
n++;
s++;
continue;
}
if (s + len > smax)
{
s++;
n++;
continue;
}
if (is_invalid_or_overlong_utf8 (s, len))
{
s++;
n++;
continue;
}
if (ignore_combining)
{
SLwchar_Type w = fast_utf8_decode (s, len);
if (0 != SLwchar_wcwidth (w))
n++;
s += len;
continue;
}
n++;
s += len;
}
if (ignore_combining)
{
while (s < smax)
{
SLwchar_Type w;
unsigned int nconsumed;
if (NULL == SLutf8_decode (s, smax, &w, &nconsumed))
break;
if (0 != SLwchar_wcwidth (w))
break;
s += nconsumed;
}
}
if (dnum != NULL)
*dnum = n;
return s;
}
SLuchar_Type *SLutf8_bskip_chars (SLuchar_Type *smin, SLuchar_Type *s,
unsigned int num, unsigned int *dnum,
int ignore_combining)
{
unsigned int n;
SLuchar_Type *smax = s;
n = 0;
while ((n < num) && (s > smin))
{
unsigned char ch;
unsigned int dn;
s--;
ch = *s;
if (ch < 0x80)
{
n++;
smax = s;
continue;
}
dn = 0;
while ((s != smin)
&& (Len_Map[ch] == 0)
&& (dn < SLUTF8_MAX_MBLEN))
{
s--;
ch = *s;
dn++;
}
if (ch <= 0xBF)
{
/* Invalid sequence */
n++;
smax--;
s = smax;
continue;
}
if (ch > 0xBF)
{
SLwchar_Type w;
SLuchar_Type *s1;
if ((NULL == (s1 = SLutf8_decode (s, smax, &w, NULL)))
|| (s1 != smax))
{
/* This means we backed up over an invalid sequence */
dn = (unsigned int) (smax - s);
n++;
smax--;
s = smax;
continue;
}
if ((ignore_combining == 0)
|| (0 != SLwchar_wcwidth (w)))
n++;
smax = s;
}
}
if (dnum != NULL)
*dnum = n;
return s;
}
SLuchar_Type *SLutf8_bskip_char (SLuchar_Type *smin, SLuchar_Type *s)
{
if (s > smin)
{
unsigned int dn;
s--;
if (*s >= 0x80)
s = SLutf8_bskip_chars (smin, s+1, 1, &dn, 0);
}
return s;
}
/* This function counts the number of wide characters in a UTF-8 encoded
* string. Each byte in an invalid sequence is counted as a single character.
* If the string contains illegal values, the bytes making up the character is
* counted as 1 character.
*/
unsigned int SLutf8_strlen (SLuchar_Type *s, int ignore_combining)
{
unsigned int count, len;
if (s == NULL)
return 0;
len = strlen ((char *)s);
(void) SLutf8_skip_chars (s, s + len, len, &count, ignore_combining);
return count;
}
/*
* This function returns NULL if the input does not correspond to a valid
* UTF-8 sequence, otherwise, it returns the position of the next character
* in the sequence.
*/
unsigned char *SLutf8_decode (unsigned char *u, unsigned char *umax,
SLwchar_Type *wp, unsigned int *nconsumedp)
{
unsigned int len;
unsigned char ch;
SLwchar_Type w;
if (u >= umax)
{
*wp = 0;
if (nconsumedp != NULL)
*nconsumedp = 0;
return NULL;
}
*wp = ch = *u;
if (ch < 0x80)
{
if (nconsumedp != NULL) *nconsumedp = 1;
return u+1;
}
len = Len_Map[ch];
if (len < 2)
{
/* should not happen--- code here for completeness */
if (nconsumedp != NULL) *nconsumedp = 1;
return NULL;
}
if (u + len > umax)
{
if (nconsumedp != NULL) *nconsumedp = 1; /* (unsigned int) (umax - u); */
return NULL;
}
if (is_invalid_or_overlong_utf8 (u, len))
{
if (nconsumedp != NULL)
*nconsumedp = 1;
return NULL;
}
if (nconsumedp != NULL)
*nconsumedp = len;
*wp = w = fast_utf8_decode (u, len);
if (IS_ILLEGAL_UNICODE(w))
return NULL;
return u + len;
}
/* Encode the wide character returning a pointer to the end of the
* utf8 of the encoded multi-byte character. This function will also encode
* illegal unicode values. It returns NULL if buflen is too small.
* Otherwise, it returns a pointer at the end of the last encoded byte.
* It does not null terminate the encoded string.
*/
SLuchar_Type *SLutf8_encode (SLwchar_Type w, SLuchar_Type *u, unsigned int ulen)
{
SLuchar_Type *umax = u + ulen;
/* U-00000000 - U-0000007F: 0xxxxxxx */
if (w <= 0x7F)
{
if (u >= umax)
return NULL;
*u++ = (unsigned char) w;
return u;
}
/* U-00000080 - U-000007FF: 110xxxxx 10xxxxxx */
if (w <= 0x7FF)
{
if ((u + 1) >= umax)
return NULL;
*u++ = (w >> 6) | 0xC0;
*u++ = (w & 0x3F) | 0x80;
return u;
}
/* First bad character starts at 0xD800 */
/* Allow illegal values to be encoded */
/*
*if (IS_ILLEGAL_UNICODE(w))
* return NULL;
*/
/* U-00000800 - U-0000FFFF: 1110xxxx 10xxxxxx 10xxxxxx */
if (w <= 0xFFFF)
{
if (u+2 >= umax)
return NULL;
*u++ = (w >> 12 ) | 0xE0;
goto finish_2;
}
/* U-00010000 - U-001FFFFF: 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx */
if (w <= 0x1FFFFF)
{
if (u+3 >= umax)
return NULL;
*u++ = (w >> 18) | 0xF0;
goto finish_3;
}
/* U-00200000 - U-03FFFFFF: 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx */
if (w <= 0x3FFFFFF)
{
if (u+4 >= umax)
return NULL;
*u++ = (w >> 24) | 0xF8;
goto finish_4;
}
/* U-04000000 - U-7FFFFFFF: 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx */
if (w <= 0x7FFFFFFF)
{
if (u+5 >= umax)
return NULL;
*u++ = (w >> 30) | 0xFC;
goto finish_5;
}
/* unreached?? */
return NULL;
finish_5: *u++ = ((w >> 24) & 0x3F)|0x80;
finish_4: *u++ = ((w >> 18) & 0x3F)|0x80;
finish_3: *u++ = ((w >> 12) & 0x3F)|0x80;
finish_2: *u++ = ((w >> 6) & 0x3F)|0x80;
*u++ = (w & 0x3F)|0x80;
return u;
}
/* Like SLutf8_encode, but null terminates the result.
* At least SLUTF8_MAX_MBLEN+1 bytes assumed.
*/
SLuchar_Type *SLutf8_encode_null_terminate (SLwchar_Type w, SLuchar_Type *u)
{
SLuchar_Type *p;
p = SLutf8_encode (w, u, SLUTF8_MAX_MBLEN);
if (p != NULL)
*p = 0;
return p;
}
#if 0
int SLutf8_decode_bytes (SLuchar_Type *u, SLuchar_Type *umax,
unsigned char *b, unsigned int *np)
{
unsigned char *bmax;
bmax = b;
while (u < umax)
{
SLwchar_Type w;
if (0 == (*u & 0x80))
{
*bmax++ = *u++;
continue;
}
if (NULL == (u = SLutf8_decode (u, umax, &w, NULL)))
return -1; /* FIXME: HANDLE ERROR */
if (w > 0xFF)
{
#if 0
sprintf (bmax, "<U+%04X>", w);
bmax += strlen (bmax);
continue;
#endif
/* FIXME: HANDLE ERROR */
w = w & 0xFF;
}
*bmax++ = w;
}
*np = bmax - b;
*bmax = 0;
return 0;
}
/* UTF-8 Encode the bytes between b and bmax storing the results in the
* buffer defined by u and umax, returning the position following the
* last encoded character. Upon return, *np is set to the number of bytes
* sucessfully encoded.
*/
SLuchar_Type *SLutf8_encode_bytes (unsigned char *b, unsigned char *bmax,
SLuchar_Type *u, unsigned int ulen,
unsigned int *np)
{
unsigned char *bstart = b;
SLuchar_Type *umax = u + ulen;
while (b < bmax)
{
SLuchar_Type *u1;
if (0 == (*b & 0x80))
{
if (u >= umax)
break;
*u++ = *b++;
continue;
}
if (NULL == (u1 = SLutf8_encode (*b, u, umax - u)))
break;
u = u1;
b++;
}
*np = b - bstart;
if (u < umax)
*u = 0;
return u;
}
#endif
static SLuchar_Type *xform_utf8 (SLuchar_Type *u, SLuchar_Type *umax,
SLwchar_Type (*fun)(SLwchar_Type))
{
SLuchar_Type *buf, *p;
unsigned int malloced_len, len;
if (umax < u)
return NULL;
len = 0;
p = buf = NULL;
malloced_len = 0;
while (1)
{
SLwchar_Type w;
SLuchar_Type *u1;
unsigned int nconsumed;
if (malloced_len <= len + SLUTF8_MAX_MBLEN)
{
SLuchar_Type *newbuf;
malloced_len += 1 + (umax - u) + SLUTF8_MAX_MBLEN;
newbuf = (SLuchar_Type *)SLrealloc ((char *)buf, malloced_len);
if (newbuf == NULL)
{
SLfree ((char *)buf);
return NULL;
}
buf = newbuf;
p = buf + len;
}
if (u >= umax)
{
*p = 0;
p = (SLuchar_Type *) SLang_create_nslstring ((char *)buf, len);
SLfree ((char *)buf);
return p;
}
if (NULL == (u1 = SLutf8_decode (u, umax, &w, &nconsumed)))
{
/* Invalid sequence */
memcpy ((char *) p, u, nconsumed);
p += nconsumed;
len += nconsumed;
u1 = u + nconsumed;
}
else
{
SLuchar_Type *p1;
p1 = SLutf8_encode ((*fun)(w), p, malloced_len);
if (p1 == NULL)
{
SLfree ((char *)buf);
SLang_verror (SL_INTERNAL_ERROR, "SLutf8_encode returned NULL");
return NULL;
}
len += p1 - p;
p = p1;
}
u = u1;
}
}
/* Returned an uppercased version of an UTF-8 encoded string. Illegal or
* invalid sequences will be returned as-is. This function returns
* an SLstring.
*/
SLuchar_Type *SLutf8_strup (SLuchar_Type *u, SLuchar_Type *umax)
{
return xform_utf8 (u, umax, SLwchar_toupper);
}
/* Returned an lowercased version of an UTF-8 encoded string. Illegal or
* invalid sequences will be returned as-is. This function returns
* an SLstring.
*/
SLuchar_Type *SLutf8_strlo (SLuchar_Type *u, SLuchar_Type *umax)
{
return xform_utf8 (u, umax, SLwchar_tolower);
}
int SLutf8_compare (SLuchar_Type *a, SLuchar_Type *amax,
SLuchar_Type *b, SLuchar_Type *bmax,
unsigned int nchars,
int cs)
{
while (nchars && (a < amax) && (b < bmax))
{
SLwchar_Type cha, chb;
unsigned int na, nb;
int aok, bok;
if (*a < 0x80)
{
cha = (SLwchar_Type) *a++;
aok = 1;
}
else
{
aok = (NULL != SLutf8_decode (a, amax, &cha, &na));
a += na;
}
if (*b < 0x80)
{
chb = (SLwchar_Type) *b++;
bok = 1;
}
else
{
bok = (NULL != SLutf8_decode (b, bmax, &chb, &nb));
b += nb;
}
nchars--;
if (aok && bok)
{
if (cs == 0)
{
cha = SLwchar_toupper (cha);
chb = SLwchar_toupper (chb);
}
}
else if (aok)
return 1;
else if (bok)
return -1;
if (cha == chb)
continue;
if (cha > chb)
return 1;
return -1;
}
if (nchars == 0)
return 0;
if ((a >= amax) && (b >= bmax))
return 0;
if (b >= bmax)
return 1;
return -1;
}
/* Returns an SLstring */
SLstr_Type *SLutf8_subst_wchar (SLuchar_Type *u, SLuchar_Type *umax,
SLwchar_Type wch, unsigned int pos,
int ignore_combining)
{
SLuchar_Type *a, *a1, *b;
unsigned int dpos;
SLuchar_Type buf[SLUTF8_MAX_MBLEN+1];
SLstr_Type *c;
unsigned int n1, n2, n3, len;
a = SLutf8_skip_chars (u, umax, pos, &dpos, ignore_combining);
if ((dpos != pos) || (a == umax))
{
SLang_verror (SL_INDEX_ERROR, "Specified character position is invalid for string");
return NULL;
}
a1 = SLutf8_skip_chars (a, umax, 1, NULL, ignore_combining);
b = SLutf8_encode (wch, buf, SLUTF8_MAX_MBLEN);
if (b == NULL)
{
SLang_verror (SL_UNICODE_ERROR, "Unable to encode wchar 0x%lX", (unsigned long)wch);
return NULL;
}
n1 = (a-u);
n2 = (b-buf);
n3 = (umax-a1);
len = n1 + n2 + n3;
c = _pSLallocate_slstring (len);
if (c == NULL)
return NULL;
memcpy (c, (char *)u, n1);
memcpy (c+n1, (char *)buf, n2);
memcpy (c+n1+n2, (char *)a1, n3);
c[len] = 0;
/* No need to worry about this failing-- it frees its argument */
return _pSLcreate_via_alloced_slstring (c, len);
}
/* utf8 buffer assumed to be at least SLUTF8_MAX_MBLEN+1 bytes. Result will be
* null terminated. Returns position of NEXT character.
* Analogous to: *p++
*/
SLuchar_Type *SLutf8_extract_utf8_char (SLuchar_Type *u,
SLuchar_Type *umax,
SLuchar_Type *utf8)
{
SLuchar_Type *u1;
u1 = SLutf8_skip_char (u, umax);
memcpy ((char *)utf8, u, u1-u);
utf8[u1-u] = 0;
return u1;
}
/* These routines depend upon the value of the _pSLinterp_UTF8_Mode variable.
* They also generate slang errors upon error.
*/
SLuchar_Type *_pSLinterp_decode_wchar (SLuchar_Type *u,
SLuchar_Type *umax,
SLwchar_Type *chp)
{
if (_pSLinterp_UTF8_Mode == 0)
{
if (u < umax)
*chp = (SLwchar_Type) *u++;
return u;
}
if (NULL == (u = SLutf8_decode (u, umax, chp, NULL)))
SLang_verror (SL_INVALID_UTF8, "Invalid UTF-8 encoded string");
return u;
}
/* At least SLUTF8_MAX_MBLEN+1 bytes assumed-- null terminates result.
* Upon success, it returns a pointer to the _end_ of the encoded character
*/
SLuchar_Type *_pSLinterp_encode_wchar (SLwchar_Type wch, SLuchar_Type *u, unsigned int *encoded_len)
{
SLuchar_Type *u1;
if (_pSLinterp_UTF8_Mode == 0)
{
*encoded_len = 1;
*u++ = (SLuchar_Type) wch;
*u++ = 0;
return u;
}
if (NULL == (u1 = SLutf8_encode_null_terminate (wch, u)))
{
SLang_verror (SL_UNICODE_ERROR, "Unable to encode character 0x%lX", (unsigned long)wch);
return NULL;
}
*encoded_len = (unsigned int) (u1 - u);
return u1;
}
#ifdef REGRESSION
int main (int argc, char **argv)
{
unsigned char *s, *smax;
char **t;
char *ok_tests [] =
{
"퟿",
"",
"�",
"ô<EFBFBD>¿¿",
"ô<EFBFBD>€€",
NULL
};
char *long_tests [] =
{
"À¯",
"à€¯",
"ð€€¯",
"ø€€€¯",
"ü€€€€¯",
NULL
};
t = long_tests;
while ((s = (unsigned char *) *t++) != NULL)
{
smax = s + strlen ((char *)s);
while (s < smax)
{
SLwchar_Type w;
if (NULL == (s = SLutf8_to_wc (s, smax, &w)))
{
fprintf (stderr, "SLutf8_to_wc failed\n");
break;
}
if (w == 0)
break;
fprintf (stdout, " 0x%X", w);
}
fprintf (stdout, "\n");
}
return 0;
}
#endif

View File

@ -1,618 +0,0 @@
/* slutty.c --- Unix Low level terminal (tty) functions for S-Lang */
/*
Copyright (C) 2004, 2005, 2006 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library 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 library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
#include "slinclud.h"
#include <signal.h>
/* sequent support thanks to Kenneth Lorber <keni@oasys.dt.navy.mil> */
/* SYSV (SYSV ISC R3.2 v3.0) provided by iain.lea@erlm.siemens.de */
#if defined (_AIX) && !defined (_ALL_SOURCE)
# define _ALL_SOURCE /* so NBBY is defined in <sys/types.h> */
#endif
#include <sys/time.h>
#include <sys/types.h>
#ifdef SYSV
# include <fcntl.h>
# ifndef CRAY
# include <sys/termio.h>
# include <sys/stream.h>
# include <sys/ptem.h>
# include <sys/tty.h>
# endif
#endif
#ifdef __BEOS__
/* Prototype for select */
# include <net/socket.h>
#endif
#include <sys/file.h>
#ifndef sun
# include <sys/ioctl.h>
#endif
#ifdef __QNX__
# include <sys/select.h>
#endif
#include <sys/stat.h>
#include <errno.h>
#if defined (_AIX) && !defined (FD_SET)
# include <sys/select.h> /* for FD_ISSET, FD_SET, FD_ZERO */
#endif
#ifndef O_RDWR
# include <fcntl.h>
#endif
#include "slang.h"
#include "_slang.h"
int SLang_TT_Read_FD = -1;
int SLang_TT_Baud_Rate;
#ifdef HAVE_TERMIOS_H
# if !defined(HAVE_TCGETATTR) || !defined(HAVE_TCSETATTR)
# undef HAVE_TERMIOS_H
# endif
#endif
#ifndef HAVE_TERMIOS_H
# if !defined(CBREAK) && defined(sun)
# ifndef BSD_COMP
# define BSD_COMP 1
# endif
# include <sys/ioctl.h>
# endif
typedef struct
{
struct tchars t;
struct ltchars lt;
struct sgttyb s;
}
TTY_Termio_Type;
#else
# include <termios.h>
typedef struct termios TTY_Termio_Type;
#endif
static TTY_Termio_Type Old_TTY;
#ifdef HAVE_TERMIOS_H
typedef SLCONST struct
{
unsigned int key;
unsigned int value;
} Baud_Rate_Type;
static Baud_Rate_Type Baud_Rates [] =
{
#ifdef B0
{B0, 0},
#endif
#ifdef B50
{B50, 50},
#endif
#ifdef B75
{B75, 75},
#endif
#ifdef B110
{B110, 110},
#endif
#ifdef B134
{B134, 134},
#endif
#ifdef B150
{B150, 150},
#endif
#ifdef B200
{B200, 200},
#endif
#ifdef B300
{B300, 300},
#endif
#ifdef B600
{B600, 600},
#endif
#ifdef B1200
{B1200, 1200},
#endif
#ifdef B1800
{B1800, 1800},
#endif
#ifdef B2400
{B2400, 2400},
#endif
#ifdef B4800
{B4800, 4800},
#endif
#ifdef B9600
{B9600, 9600},
#endif
#ifdef B19200
{B19200, 19200},
#endif
#ifdef B38400
{B38400, 38400},
#endif
#ifdef B57600
{B57600, 57600},
#endif
#ifdef B115200
{B115200, 115200},
#endif
#ifdef B230400
{B230400, 230400},
#endif
{0, 0}
};
static void
set_baud_rate (TTY_Termio_Type *tty)
{
#ifdef HAVE_CFGETOSPEED
unsigned int speed;
Baud_Rate_Type *b, *bmax;
if (SLang_TT_Baud_Rate)
return; /* already set */
speed = (unsigned int) cfgetospeed (tty);
b = Baud_Rates;
bmax = b + (sizeof (Baud_Rates)/sizeof(Baud_Rates[0]));
while (b < bmax)
{
if (b->key == speed)
{
SLang_TT_Baud_Rate = b->value;
return;
}
b++;
}
#else
(void) tty;
#endif
}
#endif /* HAVE_TERMIOS_H */
#ifdef HAVE_TERMIOS_H
# define GET_TERMIOS(fd, x) tcgetattr(fd, x)
# define SET_TERMIOS(fd, x) tcsetattr(fd, TCSADRAIN, x)
#else
# ifdef TCGETS
# define GET_TERMIOS(fd, x) ioctl(fd, TCGETS, x)
# define SET_TERMIOS(fd, x) ioctl(fd, TCSETS, x)
# else
# define X(x,m) &(((TTY_Termio_Type *)(x))->m)
# define GET_TERMIOS(fd, x) \
((ioctl(fd, TIOCGETC, X(x,t)) || \
ioctl(fd, TIOCGLTC, X(x,lt)) || \
ioctl(fd, TIOCGETP, X(x,s))) ? -1 : 0)
# define SET_TERMIOS(fd, x) \
((ioctl(fd, TIOCSETC, X(x,t)) ||\
ioctl(fd, TIOCSLTC, X(x,lt)) || \
ioctl(fd, TIOCSETP, X(x,s))) ? -1 : 0)
# endif
#endif
static int TTY_Inited = 0;
static int TTY_Open = 0;
#ifdef ultrix /* Ultrix gets _POSIX_VDISABLE wrong! */
# define NULL_VALUE -1
#else
# ifdef _POSIX_VDISABLE
# define NULL_VALUE _POSIX_VDISABLE
# else
# define NULL_VALUE 255
# endif
#endif
int SLang_init_tty (int abort_char, int no_flow_control, int opost)
{
TTY_Termio_Type newtty;
SLsig_block_signals ();
if (TTY_Inited)
{
SLsig_unblock_signals ();
return 0;
}
TTY_Open = 0;
if ((SLang_TT_Read_FD == -1)
|| (1 != isatty (SLang_TT_Read_FD)))
{
#ifdef O_RDWR
# if !defined(__BEOS__) && !defined(__APPLE__)
/* I have been told that BEOS will HANG if passed /dev/tty */
if ((SLang_TT_Read_FD = open("/dev/tty", O_RDWR)) >= 0)
{
TTY_Open = 1;
}
# endif
#endif
if (TTY_Open == 0)
{
SLang_TT_Read_FD = fileno (stderr);
if (1 != isatty (SLang_TT_Read_FD))
{
SLang_TT_Read_FD = fileno (stdin);
if (1 != isatty (SLang_TT_Read_FD))
{
fprintf (stderr, "Failed to open terminal.");
return -1;
}
}
}
}
SLang_Abort_Char = abort_char;
/* Some systems may not permit signals to be blocked. As a result, the
* return code must be checked.
*/
while (-1 == GET_TERMIOS(SLang_TT_Read_FD, &Old_TTY))
{
if (errno != EINTR)
{
SLsig_unblock_signals ();
return -1;
}
}
while (-1 == GET_TERMIOS(SLang_TT_Read_FD, &newtty))
{
if (errno != EINTR)
{
SLsig_unblock_signals ();
return -1;
}
}
#ifndef HAVE_TERMIOS_H
(void) opost;
(void) no_flow_control;
newtty.s.sg_flags &= ~(ECHO);
newtty.s.sg_flags &= ~(CRMOD);
/* if (Flow_Control == 0) newtty.s.sg_flags &= ~IXON; */
newtty.t.t_eofc = 1;
if (abort_char == -1) SLang_Abort_Char = newtty.t.t_intrc;
newtty.t.t_intrc = SLang_Abort_Char; /* ^G */
newtty.t.t_quitc = 255;
newtty.lt.t_suspc = 255; /* to ignore ^Z */
newtty.lt.t_dsuspc = 255; /* to ignore ^Y */
newtty.lt.t_lnextc = 255;
newtty.s.sg_flags |= CBREAK; /* do I want cbreak or raw????? */
#else
/* get baud rate */
newtty.c_iflag &= ~(ECHO | INLCR | ICRNL);
#ifdef ISTRIP
/* newtty.c_iflag &= ~ISTRIP; */
#endif
if (opost == 0) newtty.c_oflag &= ~OPOST;
set_baud_rate (&newtty);
if (no_flow_control) newtty.c_iflag &= ~IXON; else newtty.c_iflag |= IXON;
newtty.c_cc[VEOF] = 1;
newtty.c_cc[VMIN] = 1;
newtty.c_cc[VTIME] = 0;
newtty.c_lflag = ISIG | NOFLSH;
if (abort_char == -1) SLang_Abort_Char = newtty.c_cc[VINTR];
newtty.c_cc[VINTR] = SLang_Abort_Char; /* ^G */
newtty.c_cc[VQUIT] = NULL_VALUE;
newtty.c_cc[VSUSP] = NULL_VALUE; /* to ignore ^Z */
#ifdef VDSUSP
newtty.c_cc[VDSUSP] = NULL_VALUE; /* to ignore ^Y */
#endif
#ifdef VLNEXT
newtty.c_cc[VLNEXT] = NULL_VALUE; /* to ignore ^V ? */
#endif
#ifdef VSWTCH
newtty.c_cc[VSWTCH] = NULL_VALUE; /* to ignore who knows what */
#endif
#endif /* NOT HAVE_TERMIOS_H */
while (-1 == SET_TERMIOS(SLang_TT_Read_FD, &newtty))
{
if (errno != EINTR)
{
SLsig_unblock_signals ();
return -1;
}
}
TTY_Inited = 1;
SLsig_unblock_signals ();
return 0;
}
void SLtty_set_suspend_state (int mode)
{
TTY_Termio_Type newtty;
SLsig_block_signals ();
if (TTY_Inited == 0)
{
SLsig_unblock_signals ();
return;
}
while ((-1 == GET_TERMIOS (SLang_TT_Read_FD, &newtty))
&& (errno == EINTR))
;
#ifndef HAVE_TERMIOS_H
/* I do not know if all systems define the t_dsuspc field */
if (mode == 0)
{
newtty.lt.t_suspc = 255;
newtty.lt.t_dsuspc = 255;
}
else
{
newtty.lt.t_suspc = Old_TTY.lt.t_suspc;
newtty.lt.t_dsuspc = Old_TTY.lt.t_dsuspc;
}
#else
if (mode == 0)
{
newtty.c_cc[VSUSP] = NULL_VALUE;
#ifdef VDSUSP
newtty.c_cc[VDSUSP] = NULL_VALUE;
#endif
}
else
{
newtty.c_cc[VSUSP] = Old_TTY.c_cc[VSUSP];
#ifdef VDSUSP
newtty.c_cc[VDSUSP] = Old_TTY.c_cc[VDSUSP];
#endif
}
#endif
while ((-1 == SET_TERMIOS (SLang_TT_Read_FD, &newtty))
&& (errno == EINTR))
;
SLsig_unblock_signals ();
}
void SLang_reset_tty (void)
{
SLsig_block_signals ();
if (TTY_Inited == 0)
{
SLsig_unblock_signals ();
return;
}
while ((-1 == SET_TERMIOS(SLang_TT_Read_FD, &Old_TTY))
&& (errno == EINTR))
;
if (TTY_Open)
{
while ((-1 == close (SLang_TT_Read_FD))
&& (errno == EINTR))
;
TTY_Open = 0;
SLang_TT_Read_FD = -1;
}
TTY_Inited = 0;
SLsig_unblock_signals ();
}
static void default_sigint (int sig)
{
sig = errno; /* use parameter */
SLKeyBoard_Quit = 1;
if (SLang_Ignore_User_Abort == 0) SLang_set_error (SL_USER_BREAK);
SLsignal_intr (SIGINT, default_sigint);
errno = sig;
}
int SLang_set_abort_signal (void (*hand)(int))
{
int save_errno = errno;
SLSig_Fun_Type *f;
if (hand == NULL) hand = default_sigint;
f = SLsignal_intr (SIGINT, hand);
errno = save_errno;
if (f == (SLSig_Fun_Type *) SIG_ERR)
return -1;
return 0;
}
#ifndef FD_SET
#define FD_SET(fd, tthis) *(tthis) = 1 << (fd)
#define FD_ZERO(tthis) *(tthis) = 0
#define FD_ISSET(fd, tthis) (*(tthis) & (1 << fd))
typedef int fd_set;
#endif
static fd_set Read_FD_Set;
/* HACK: If > 0, use 1/10 seconds. If < 0, use 1/1000 seconds */
int _pSLsys_input_pending(int tsecs)
{
struct timeval wait;
long usecs, secs;
if ((TTY_Inited == 0)
|| (SLang_TT_Read_FD < 0))
{
errno = EBADF;
return -1;
}
if (tsecs >= 0)
{
secs = tsecs / 10;
usecs = (tsecs % 10) * 100000;
}
else
{
tsecs = -tsecs;
secs = tsecs / 1000;
usecs = (tsecs % 1000) * 1000;
}
wait.tv_sec = secs;
wait.tv_usec = usecs;
FD_ZERO(&Read_FD_Set);
FD_SET(SLang_TT_Read_FD, &Read_FD_Set);
return select(SLang_TT_Read_FD + 1, &Read_FD_Set, NULL, NULL, &wait);
}
int (*SLang_getkey_intr_hook) (void);
static int handle_interrupt (void)
{
if (SLang_getkey_intr_hook != NULL)
{
int save_tty_fd = SLang_TT_Read_FD;
if (-1 == (*SLang_getkey_intr_hook) ())
return -1;
if (save_tty_fd != SLang_TT_Read_FD)
return -1;
}
return 0;
}
unsigned int _pSLsys_getkey (void)
{
unsigned char c;
if (TTY_Inited == 0)
{
int ic = fgetc (stdin);
if (ic == EOF) return SLANG_GETKEY_ERROR;
return (unsigned int) ic;
}
while (1)
{
int ret;
if (SLKeyBoard_Quit)
return SLang_Abort_Char;
if (0 == (ret = _pSLsys_input_pending (100)))
continue;
if (ret != -1)
break;
if (SLKeyBoard_Quit)
return SLang_Abort_Char;
if (errno == EINTR)
{
if (-1 == handle_interrupt ())
return SLANG_GETKEY_ERROR;
continue;
}
break; /* let read handle it */
}
while (1)
{
int status = read(SLang_TT_Read_FD, (char *) &c, 1);
if (status > 0)
break;
if (status == 0)
{
/* We are at the end of a file. Let application handle it. */
return SLANG_GETKEY_ERROR;
}
if (errno == EINTR)
{
if (-1 == handle_interrupt ())
return SLANG_GETKEY_ERROR;
if (SLKeyBoard_Quit)
return SLang_Abort_Char;
continue;
}
#ifdef EAGAIN
if (errno == EAGAIN)
{
sleep (1);
continue;
}
#endif
#ifdef EWOULDBLOCK
if (errno == EWOULDBLOCK)
{
sleep (1);
continue;
}
#endif
#ifdef EIO
if (errno == EIO)
{
SLang_verror (SL_Read_Error, "_pSLsys_getkey: EIO error");
}
#endif
return SLANG_GETKEY_ERROR;
}
return((unsigned int) c);
}

View File

@ -1,15 +0,0 @@
#include "slinclud.h"
#include <ctype.h>
#include "slang.h"
#include "_slang.h"
#define DEFINE_PSLWC_WIDTH_TABLE
#include "slwcwidth.h"
int SLwchar_wcwidth (SLwchar_Type ch)
{
int w;
SL_WIDTH_ALOOKUP(w,ch);
return w;
}

View File

@ -22,10 +22,6 @@ cons_saver_SOURCES = cons.saver.c
man2hlp_SOURCES = man2hlp.c glibcompat.c man2hlp_SOURCES = man2hlp.c glibcompat.c
if INCLUDED_SLANG
SLANGLIB = ../slang/libmcslang.a
endif
if USE_EDIT if USE_EDIT
EDITLIB = ../edit/libedit.a EDITLIB = ../edit/libedit.a
endif endif

View File

@ -2033,10 +2033,6 @@ handle_args (int argc, char *argv[])
poptGetContext ("mc", argc, argv, argument_table, poptGetContext ("mc", argc, argv, argument_table,
POPT_CONTEXT_NO_EXEC); POPT_CONTEXT_NO_EXEC);
#ifdef USE_TERMCAP
SLtt_Try_Termcap = 1;
#endif
while ((c = poptGetNextOpt (ctx)) > 0) { while ((c = poptGetNextOpt (ctx)) > 0) {
process_args (ctx, c, poptGetOptArg (ctx)); process_args (ctx, c, poptGetOptArg (ctx));
} }

View File

@ -1,15 +1,11 @@
#ifndef MC_MYSLANG_H #ifndef MC_MYSLANG_H
#define MC_MYSLANG_H #define MC_MYSLANG_H
#ifndef HAVE_SYSTEM_SLANG
# include "../slang/include/slang.h"
#else
#ifdef HAVE_SLANG_SLANG_H #ifdef HAVE_SLANG_SLANG_H
# include <slang/slang.h> # include <slang/slang.h>
#else #else
# include <slang.h> # include <slang.h>
#endif /* HAVE_SLANG_SLANG_H */ #endif /* HAVE_SLANG_SLANG_H */
#endif
enum { enum {
KEY_BACKSPACE = 400, KEY_BACKSPACE = 400,

View File

@ -56,13 +56,6 @@
# endif # endif
#endif #endif
/* Taken from S-Lang's sldisply.c file */
#ifndef USE_TERMCAP
# define tgetstr(a,b) SLtt_tgetstr (a)
#else
extern char *tgetstr(char *, char **);
#endif
#ifndef SA_RESTART #ifndef SA_RESTART
# define SA_RESTART 0 # define SA_RESTART 0
#endif #endif

View File

@ -58,19 +58,11 @@ static const char *const features[] = {
#ifdef HAVE_SLANG #ifdef HAVE_SLANG
# ifdef HAVE_SYSTEM_SLANG
N_("Using system-installed S-Lang library"), N_("Using system-installed S-Lang library"),
# else
N_("Using included S-Lang library"),
# endif
" ", " ",
#ifdef USE_TERMCAP
N_("with termcap database"),
#else
N_("with terminfo database"), N_("with terminfo database"),
#endif
#elif defined(USE_NCURSES) #elif defined(USE_NCURSES)
N_("Using the ncurses library"), N_("Using the ncurses library"),