From 4dd00943043d88e31f1e2cedf175dabc20ddb086 Mon Sep 17 00:00:00 2001 From: Helly Guo Date: Sat, 9 Apr 2016 16:10:57 +0800 Subject: [PATCH] =?UTF-8?q?=E5=88=A0=E9=99=A4=E9=99=A4proxy=E5=A4=96?= =?UTF-8?q?=E4=BB=A3=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit On branch devel modified: src/Makefile.inc Untracked files: src/pstdint.h no changes added to commit (use "git add" and/or "git commit -a") On branch devel deleted: Makefile.Solaris Changes not staged for commit: modified: src/Makefile.inc Untracked files: src/tags On branch devel deleted: cfg/0.scenario.txt Untracked files: src/tags no changes added to commit (use "git add" and/or "git commit -a") --- Makefile.Solaris | 36 - Makefile.Solaris-gcc | 37 - Makefile.intl | 33 - Makefile.msvcCE | 35 - Makefile.unix | 59 - Makefile.unix-install | 60 - Makefile.win | 36 - Makefile.winCE | 34 - cfg/0.scenario.txt | 17 - cfg/3proxy.cfg.sample | 201 - cfg/counters.sample | 52 - cfg/sql/3proxy.cfg.sample | 53 - cfg/sql/create.sql | 56 - cfg/sql/report.xls | Bin 57856 -> 0 bytes man/3proxy.8 | 151 - man/3proxy.cfg.3 | 951 --- man/ftppr.8 | 87 - man/icqpr.8 | 80 - man/pop3p.8 | 83 - man/proxy.8 | 78 - man/smtpp.8 | 84 - man/socks.8 | 79 - man/tcppm.8 | 73 - man/udppm.8 | 79 - scripts/3proxy.cfg | 32 - scripts/add3proxyuser.sh | 10 - scripts/install-unix.sh | 21 - scripts/rc.d/proxy.sh | 48 - src/3proxy.c | 561 -- src/Makefile.inc | 126 +- src/auth.c | 1367 ---- src/conf.c | 1708 ----- src/datatypes.c | 817 --- src/dighosts.c | 141 - src/dnspr.c | 211 - src/ftppr.c | 328 - src/icqpr.c | 529 -- src/mycrypt.c | 199 - src/ntlm.c | 88 - src/plugins.c | 142 - src/plugins/FilePlugin/FilePlugin.c | 917 --- src/plugins/FilePlugin/FilePlugin.h | 41 - src/plugins/FilePlugin/Makefile | 1 - src/plugins/FilePlugin/Makefile.inc | 7 - src/plugins/LastFRipper/Makefile | 1 - src/plugins/LastFRipper/Makefile.inc | 7 - src/plugins/LastFRipper/lastFripper.c | 704 -- src/plugins/LastFRipper/lastFripper.h | 66 - src/plugins/LdapPlugin/Makefile.inc | 7 - src/plugins/LdapPlugin/com-unix.sh | 3 - src/plugins/LdapPlugin/com-win32.bat | 4 - src/plugins/LdapPlugin/getldapuser.c | 105 - src/plugins/LdapPlugin/ldapauth.c | 576 -- src/plugins/LdapPlugin/ldapauth.txt | 592 -- src/plugins/PCREPlugin/Makefile | 1 - src/plugins/PCREPlugin/Makefile.inc | 71 - src/plugins/PCREPlugin/config.h | 145 - src/plugins/PCREPlugin/pcre.h | 304 - src/plugins/PCREPlugin/pcre_compile.c | 6145 ----------------- src/plugins/PCREPlugin/pcre_config.c | 128 - src/plugins/PCREPlugin/pcre_dfa_exec.c | 2896 -------- src/plugins/PCREPlugin/pcre_dftables.c | 192 - src/plugins/PCREPlugin/pcre_exec.c | 4938 ------------- src/plugins/PCREPlugin/pcre_fullinfo.c | 165 - src/plugins/PCREPlugin/pcre_get.c | 465 -- src/plugins/PCREPlugin/pcre_globals.c | 63 - src/plugins/PCREPlugin/pcre_info.c | 93 - src/plugins/PCREPlugin/pcre_internal.h | 1118 --- src/plugins/PCREPlugin/pcre_maketables.c | 143 - src/plugins/PCREPlugin/pcre_newline.c | 164 - src/plugins/PCREPlugin/pcre_ord2utf8.c | 85 - src/plugins/PCREPlugin/pcre_plugin.c | 400 -- src/plugins/PCREPlugin/pcre_refcount.c | 82 - src/plugins/PCREPlugin/pcre_study.c | 579 -- src/plugins/PCREPlugin/pcre_tables.c | 318 - src/plugins/PCREPlugin/pcre_try_flipped.c | 137 - src/plugins/PCREPlugin/pcre_ucp_searchfuncs.c | 179 - src/plugins/PCREPlugin/pcre_valid_utf8.c | 162 - src/plugins/PCREPlugin/pcre_version.c | 90 - src/plugins/PCREPlugin/pcre_xclass.c | 148 - src/plugins/PCREPlugin/pcreposix.c | 337 - src/plugins/PCREPlugin/pcreposix.h | 142 - src/plugins/PCREPlugin/ucp.h | 133 - src/plugins/PCREPlugin/ucpinternal.h | 92 - src/plugins/PCREPlugin/ucptable.c | 3068 -------- src/plugins/PCREPlugin/ucptable.h | 3068 -------- src/plugins/PamAuth/Makefile | 1 - src/plugins/PamAuth/Makefile.inc | 7 - src/plugins/PamAuth/PAMAUTH.TXT | 30 - src/plugins/PamAuth/pamauth.c | 140 - src/plugins/SSLPlugin/Makefile | 1 - src/plugins/SSLPlugin/Makefile.inc | 14 - src/plugins/SSLPlugin/my_ssl.c | 474 -- src/plugins/SSLPlugin/my_ssl.h | 43 - src/plugins/SSLPlugin/ssl_plugin.c | 414 -- src/plugins/StringsPlugin/Makefile | 1 - src/plugins/StringsPlugin/Makefile.inc | 7 - src/plugins/StringsPlugin/ReadMe.txt | 63 - src/plugins/StringsPlugin/StringsPlugin.c | 254 - src/plugins/TrafficPlugin/Changelog.txt | 13 - src/plugins/TrafficPlugin/Makefile | 1 - src/plugins/TrafficPlugin/Makefile.inc | 7 - src/plugins/TrafficPlugin/ReadMe.txt | 67 - src/plugins/TrafficPlugin/TrafficPlugin.c | 310 - src/plugins/TransparentPlugin/Makefile | 1 - src/plugins/TransparentPlugin/Makefile.inc | 10 - .../TransparentPlugin/transparent_plugin.c | 110 - src/plugins/WindowsAuthentication/Makefile | 1 - .../WindowsAuthentication/Makefile.inc | 8 - .../WindowsAuthentication.c | 94 - src/plugins/WindowsAuthentication/copying | 31 - src/plugins/utf8tocp1251/Makefile | 1 - src/plugins/utf8tocp1251/Makefile.inc | 8 - src/plugins/utf8tocp1251/utf8tocp1251.c | 88 - src/pop3p.c | 72 - src/smtpp.c | 316 - src/socks.c | 472 -- src/stringtable.c | 80 - src/tcppm.c | 40 - src/udppm.c | 119 - src/webadmin.c | 578 -- 121 files changed, 1 insertion(+), 41739 deletions(-) delete mode 100644 Makefile.Solaris delete mode 100644 Makefile.Solaris-gcc delete mode 100644 Makefile.intl delete mode 100644 Makefile.msvcCE delete mode 100644 Makefile.unix delete mode 100644 Makefile.unix-install delete mode 100644 Makefile.win delete mode 100644 Makefile.winCE delete mode 100644 cfg/0.scenario.txt delete mode 100644 cfg/3proxy.cfg.sample delete mode 100644 cfg/counters.sample delete mode 100644 cfg/sql/3proxy.cfg.sample delete mode 100644 cfg/sql/create.sql delete mode 100644 cfg/sql/report.xls delete mode 100644 man/3proxy.8 delete mode 100644 man/3proxy.cfg.3 delete mode 100644 man/ftppr.8 delete mode 100644 man/icqpr.8 delete mode 100644 man/pop3p.8 delete mode 100644 man/proxy.8 delete mode 100644 man/smtpp.8 delete mode 100644 man/socks.8 delete mode 100644 man/tcppm.8 delete mode 100644 man/udppm.8 delete mode 100644 scripts/3proxy.cfg delete mode 100644 scripts/add3proxyuser.sh delete mode 100644 scripts/install-unix.sh delete mode 100644 scripts/rc.d/proxy.sh delete mode 100644 src/3proxy.c delete mode 100644 src/auth.c delete mode 100644 src/conf.c delete mode 100644 src/datatypes.c delete mode 100644 src/dighosts.c delete mode 100644 src/dnspr.c delete mode 100644 src/ftppr.c delete mode 100644 src/icqpr.c delete mode 100644 src/mycrypt.c delete mode 100644 src/ntlm.c delete mode 100644 src/plugins.c delete mode 100644 src/plugins/FilePlugin/FilePlugin.c delete mode 100644 src/plugins/FilePlugin/FilePlugin.h delete mode 100644 src/plugins/FilePlugin/Makefile delete mode 100644 src/plugins/FilePlugin/Makefile.inc delete mode 100644 src/plugins/LastFRipper/Makefile delete mode 100644 src/plugins/LastFRipper/Makefile.inc delete mode 100644 src/plugins/LastFRipper/lastFripper.c delete mode 100644 src/plugins/LastFRipper/lastFripper.h delete mode 100644 src/plugins/LdapPlugin/Makefile.inc delete mode 100644 src/plugins/LdapPlugin/com-unix.sh delete mode 100644 src/plugins/LdapPlugin/com-win32.bat delete mode 100644 src/plugins/LdapPlugin/getldapuser.c delete mode 100644 src/plugins/LdapPlugin/ldapauth.c delete mode 100644 src/plugins/LdapPlugin/ldapauth.txt delete mode 100644 src/plugins/PCREPlugin/Makefile delete mode 100644 src/plugins/PCREPlugin/Makefile.inc delete mode 100644 src/plugins/PCREPlugin/config.h delete mode 100644 src/plugins/PCREPlugin/pcre.h delete mode 100644 src/plugins/PCREPlugin/pcre_compile.c delete mode 100644 src/plugins/PCREPlugin/pcre_config.c delete mode 100644 src/plugins/PCREPlugin/pcre_dfa_exec.c delete mode 100644 src/plugins/PCREPlugin/pcre_dftables.c delete mode 100644 src/plugins/PCREPlugin/pcre_exec.c delete mode 100644 src/plugins/PCREPlugin/pcre_fullinfo.c delete mode 100644 src/plugins/PCREPlugin/pcre_get.c delete mode 100644 src/plugins/PCREPlugin/pcre_globals.c delete mode 100644 src/plugins/PCREPlugin/pcre_info.c delete mode 100644 src/plugins/PCREPlugin/pcre_internal.h delete mode 100644 src/plugins/PCREPlugin/pcre_maketables.c delete mode 100644 src/plugins/PCREPlugin/pcre_newline.c delete mode 100644 src/plugins/PCREPlugin/pcre_ord2utf8.c delete mode 100644 src/plugins/PCREPlugin/pcre_plugin.c delete mode 100644 src/plugins/PCREPlugin/pcre_refcount.c delete mode 100644 src/plugins/PCREPlugin/pcre_study.c delete mode 100644 src/plugins/PCREPlugin/pcre_tables.c delete mode 100644 src/plugins/PCREPlugin/pcre_try_flipped.c delete mode 100644 src/plugins/PCREPlugin/pcre_ucp_searchfuncs.c delete mode 100644 src/plugins/PCREPlugin/pcre_valid_utf8.c delete mode 100644 src/plugins/PCREPlugin/pcre_version.c delete mode 100644 src/plugins/PCREPlugin/pcre_xclass.c delete mode 100644 src/plugins/PCREPlugin/pcreposix.c delete mode 100644 src/plugins/PCREPlugin/pcreposix.h delete mode 100644 src/plugins/PCREPlugin/ucp.h delete mode 100644 src/plugins/PCREPlugin/ucpinternal.h delete mode 100644 src/plugins/PCREPlugin/ucptable.c delete mode 100644 src/plugins/PCREPlugin/ucptable.h delete mode 100644 src/plugins/PamAuth/Makefile delete mode 100644 src/plugins/PamAuth/Makefile.inc delete mode 100644 src/plugins/PamAuth/PAMAUTH.TXT delete mode 100644 src/plugins/PamAuth/pamauth.c delete mode 100644 src/plugins/SSLPlugin/Makefile delete mode 100644 src/plugins/SSLPlugin/Makefile.inc delete mode 100644 src/plugins/SSLPlugin/my_ssl.c delete mode 100644 src/plugins/SSLPlugin/my_ssl.h delete mode 100644 src/plugins/SSLPlugin/ssl_plugin.c delete mode 100644 src/plugins/StringsPlugin/Makefile delete mode 100644 src/plugins/StringsPlugin/Makefile.inc delete mode 100644 src/plugins/StringsPlugin/ReadMe.txt delete mode 100644 src/plugins/StringsPlugin/StringsPlugin.c delete mode 100644 src/plugins/TrafficPlugin/Changelog.txt delete mode 100644 src/plugins/TrafficPlugin/Makefile delete mode 100644 src/plugins/TrafficPlugin/Makefile.inc delete mode 100644 src/plugins/TrafficPlugin/ReadMe.txt delete mode 100644 src/plugins/TrafficPlugin/TrafficPlugin.c delete mode 100644 src/plugins/TransparentPlugin/Makefile delete mode 100644 src/plugins/TransparentPlugin/Makefile.inc delete mode 100644 src/plugins/TransparentPlugin/transparent_plugin.c delete mode 100644 src/plugins/WindowsAuthentication/Makefile delete mode 100644 src/plugins/WindowsAuthentication/Makefile.inc delete mode 100644 src/plugins/WindowsAuthentication/WindowsAuthentication.c delete mode 100644 src/plugins/WindowsAuthentication/copying delete mode 100644 src/plugins/utf8tocp1251/Makefile delete mode 100644 src/plugins/utf8tocp1251/Makefile.inc delete mode 100644 src/plugins/utf8tocp1251/utf8tocp1251.c delete mode 100644 src/pop3p.c delete mode 100644 src/smtpp.c delete mode 100644 src/socks.c delete mode 100644 src/stringtable.c delete mode 100644 src/tcppm.c delete mode 100644 src/udppm.c delete mode 100644 src/webadmin.c diff --git a/Makefile.Solaris b/Makefile.Solaris deleted file mode 100644 index 290993c..0000000 --- a/Makefile.Solaris +++ /dev/null @@ -1,36 +0,0 @@ -# -# 3 proxy Makefile for Solaris/SunCC -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# remove -DNOODBC from CFLAGS and add -lodbc to LDFLAGS to compile with ODBC -# library support. Add -DSAFESQL for poorely written ODBC library / drivers. - -BUILDDIR = -CC = cc -CFLAGS = -xO3 -c -D_SOLARIS -D_THREAD_SAFE -DGETHOSTBYNAME_R -D_REENTRANT -DNOODBC -DWITH_STD_MALLOC -DFD_SETSIZE=4096 -DWITH_POLL -COUT = -o ./ -LN = cc -LDFLAGS = -xO3 -DCFLAGS = -fpic -DLFLAGS = -shared -DLSUFFICS = .ld.so -LIBS = -lpthread -lsocket -lnsl -lresolv -ldl -LIBSPREFIX = -l -LIBSSUFFIX = -LNOUT = -o ./ -EXESUFFICS = -OBJSUFFICS = .o -DEFINEOPTION = -D -COMPFILES = *~ -REMOVECOMMAND = rm -f -TYPECOMMAND = cat -COMPATLIBS = -MAKEFILE = Makefile.Solaris -PLUGINS = StringsPlugin TrafficPlugin PCREPlugin - -include Makefile.inc - -allplugins: - @list='$(PLUGINS)'; for p in $$list; do cp Makefile Makefile.var plugins/$$p; cd plugins/$$p ; make ; cd ../.. ; done diff --git a/Makefile.Solaris-gcc b/Makefile.Solaris-gcc deleted file mode 100644 index fa9a4cf..0000000 --- a/Makefile.Solaris-gcc +++ /dev/null @@ -1,37 +0,0 @@ -# -# 3 proxy Makefile for Solaris/gcc -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# remove -DNOODBC from CFLAGS and add -lodbc to LDFLAGS to compile with ODBC -# library support. Add -DSAFESQL for poorely written ODBC library / drivers. - - -BUILDDIR = -CC = gcc -CFLAGS = -O3 -c -D_SOLARIS -D_THREAD_SAFE -DGETHOSTBYNAME_R -D_REENTRANT -DNOODBC -DWITH_STD_MALLOC -DFD_SETSIZE=4096 -DWITH_POLL -COUT = -o ./ -LN = gcc -LDFLAGS = -O3 -DCFLAGS = -fpic -DLFLAGS = -shared -DLSUFFICS = .ld.so -LIBS = -lpthread -lsocket -lnsl -lresolv -ldl -LIBSPREFIX = -l -LIBSSUFFIX = -LNOUT = -o ./ -EXESUFFICS = -OBJSUFFICS = .o -DEFINEOPTION = -D -COMPFILES = *~ -REMOVECOMMAND = rm -f -TYPECOMMAND = cat -COMPATLIBS = -MAKEFILE = Makefile.Solaris-gcc -PLUGINS = StringsPlugin TrafficPlugin PCREPlugin - -include Makefile.inc - -allplugins: - @list='$(PLUGINS)'; for p in $$list; do cp Makefile Makefile.var plugins/$$p; cd plugins/$$p ; make ; cd ../.. ; done diff --git a/Makefile.intl b/Makefile.intl deleted file mode 100644 index 56ab7d9..0000000 --- a/Makefile.intl +++ /dev/null @@ -1,33 +0,0 @@ -# -# 3 proxy Makefile for Intel C compiler for Windows (for both make and nmake) -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# Add /DSAFESQL to CFLAGS if you are using poorely written/tested ODBC driver - - -BUILDDIR = ../bin/ -CC = icl -CFLAGS = /nologo /MD /W3 /G6 /GX /O2 /D "WITH_STD_MALLOC" /D "NDEBUG" /D "WIN32" /D "_CONSOLE" /D "_MBCS" /D "_WIN32" /Fp"proxy.pch" /YX /FD /c -COUT = /Fo -LN = xilink -LDFLAGS = /nologo /subsystem:console /incremental:no /machine:I386 -LIBS = ws2_32.lib advapi32.lib odbc32.lib user32.lib -DLFLAGS = /DLL -DLSUFFICS = .dll -LNOUT = /out: -EXESUFFICS = .exe -OBJSUFFICS = .obj -DEFINEOPTION = /D -COMPFILES = *.pch *.idb -REMOVECOMMAND = del 2>NUL -TYPECOMMAND = type -COMPATLIBS = -MAKEFILE = Makefile.intl -PLUGINS = WindowsAuthentication TrafficPlugin PCREPlugin - -include Makefile.inc - -allplugins: - for /D %%i in ($(PLUGINS)) do (copy Makefile Makefile.var plugins\%%i && cd plugins\%%i && nmake && del *.obj *.idb &&cd ..\..) diff --git a/Makefile.msvcCE b/Makefile.msvcCE deleted file mode 100644 index 1e4056c..0000000 --- a/Makefile.msvcCE +++ /dev/null @@ -1,35 +0,0 @@ -# -# 3 proxy Makefile for Microsoft Visual C compiler (for both make and nmake) -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# Add /DSAFESQL to CFLAGS if you are using poorely written/tested ODBC driver - -BUILDDIR = ../bin/ -CC = cl -CFLAGS = /DARM /D "NOODBC" /nologo /MT /W3 /Wp64 /Ox /GS /EHs- /GA /GF /D "MSVC" /D "_WINCE" /D "WITH_STD_MALLOC" /D "NDEBUG" /D "WIN32" /D "_CONSOLE" /D "_MBCS" /D "_WIN32" /Fp"proxy.pch" /FD /c -COUT = /Fo -LN = link -LDFLAGS = /nologo /subsystem:console /incremental:no -DLFLAGS = /DLL -DLSUFFICS = .dll -LIBS = ws2_32.lib advapi32.lib odbc32.lib user32.lib -LIBEXT = .lib -LNOUT = /out: -EXESUFFICS = .exe -OBJSUFFICS = .obj -DEFINEOPTION = /D -COMPFILES = *.pch *.idb -REMOVECOMMAND = del 2>NUL >NUL -TYPECOMMAND = type -COMPATLIBS = -MAKEFILE = Makefile.msvc -PLUGINS = WindowsAuthentication TrafficPlugin StringsPlugin PCREPlugin - - -include Makefile.inc - -allplugins: - for /D %%i in ($(PLUGINS)) do (copy Makefile plugins\%%i && copy Makefile.var plugins\%%i && cd plugins\%%i && nmake && del *.obj *.idb &&cd ..\..) - \ No newline at end of file diff --git a/Makefile.unix b/Makefile.unix deleted file mode 100644 index 37797a5..0000000 --- a/Makefile.unix +++ /dev/null @@ -1,59 +0,0 @@ -# -# 3 proxy Makefile for GCC/Unix -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# remove -DNOODBC from CFLAGS and add -lodbc to LDFLAGS to compile with ODBC -# library support. Add -DSAFESQL for poorely written ODBC library / drivers. - -BUILDDIR = -CC = gcc - -# you may need -L/usr/pkg/lib for older NetBSD versions -CFLAGS = -g -O2 -c -pthread -D_THREAD_SAFE -D_REENTRANT -DNOODBC -DWITH_STD_MALLOC -DFD_SETSIZE=4096 -DWITH_POLL -COUT = -o -LN = gcc -LDFLAGS = -O2 -pthread -# -lpthreads may be reuqired on some platforms instead of -pthreads -# -ldl or -lld may be required for some platforms -DCFLAGS = -fpic -DLFLAGS = -shared -DLSUFFICS = .ld.so -LIBS = -LIBSPREFIX = -l -LIBSSUFFIX = -LNOUT = -o -EXESUFFICS = -OBJSUFFICS = .o -DEFINEOPTION = -D -COMPFILES = *~ -REMOVECOMMAND = rm -f -TYPECOMMAND = cat -COMPATLIBS = -MAKEFILE = Makefile.unix -PLUGINS = StringsPlugin TrafficPlugin PCREPlugin PamAuth - -include Makefile.inc - -install: all - if [ ! -d /usr/local/etc/3proxy/bin ]; then mkdir -p /usr/local/etc/3proxy/bin/; fi - install src/3proxy /usr/local/etc/3proxy/bin/3proxy - install src/mycrypt /usr/local/etc/3proxy/bin/mycrypt - install scripts/rc.d/proxy.sh /usr/local/etc/rc.d/proxy.sh - install scripts/add3proxyuser.sh /usr/local/etc/3proxy/bin/ - if [ -s /usr/local/etc/3proxy/3proxy.cfg ]; then - echo /usr/local/etc/3proxy/3proxy.cfg already exists - else - install scripts/3proxy.cfg /usr/local/etc/3proxy/ - if [ ! -d /var/log/3proxy/ ]; then - mkdir /var/log/3proxy/ - fi - touch /usr/local/etc/3proxy/passwd - touch /usr/local/etc/3proxy/counters - touch /usr/local/etc/3proxy/bandlimiters - echo Run /usr/local/etc/3proxy/bin/add3proxyuser.sh to add \'admin\' user - fi - -allplugins: - @list='$(PLUGINS)'; for p in $$list; do cp Makefile Makefile.var plugins/$$p; cd plugins/$$p ; make ; cd ../.. ; done diff --git a/Makefile.unix-install b/Makefile.unix-install deleted file mode 100644 index 4676dbf..0000000 --- a/Makefile.unix-install +++ /dev/null @@ -1,60 +0,0 @@ -DESTDIR = -prefix = /usr/local -exec_prefix = $(prefix) -man_prefix = $(prefix)/share - -INSTALL = /usr/bin/install -INSTALL_BIN = $(INSTALL) -m 755 -INSTALL_DATA = $(INSTALL) -m 644 -INSTALL_OBJS = src/3proxy \ - src/dighosts \ - src/ftppr \ - src/mycrypt \ - src/pop3p \ - src/proxy \ - src/socks \ - src/tcppm \ - src/udppm \ - scripts/add3proxyuser.sh - -INSTALL_CFG_OBJS = scripts/3proxy.cfg -INSTALL_CFG_DEST = config - -INSTALL_CFG_OBJS2 = passwd counters bandlimiters - -MANDIR1 = $(DESTDIR)$(man_prefix)/man/man1 -MANDIR3 = $(DESTDIR)$(man_prefix)/man/man3 -MANDIR8 = $(DESTDIR)$(man_prefix)/man/man8 -BINDIR = $(DESTDIR)$(exec_prefix)/bin -ETCDIR = $(DESTDIR)$(prefix)/etc/3proxy - -install-bin: - $(INSTALL_BIN) -d $(BINDIR) - $(INSTALL_BIN) -s $(INSTALL_OBJS) $(BINDIR) - -install-etc-dir: - $(INSTALL_BIN) -d $(ETCDIR) - -install-etc-default-config: - if [ -f $(ETCDIR)/$(INSTALL_CFG_DEST) ]; then \ - : ; \ - else \ - $(INSTALL_DATA) $(INSTALL_CFG_OBJS) $(ETCDIR)/$(INSTALL_CFG_DEST) \ - fi - -install-etc: install-etc-dir - for file in $(INSTALL_CFG_OBJS2); \ - do \ - touch $(ETCDIR)/$$file; chmod 0600 $(ETCDIR)/$$file; \ - done; - -install-man: - $(INSTALL_BIN) -d $(MANDIR1) - $(INSTALL_BIN) -d $(MANDIR3) - $(INSTALL_BIN) -d $(MANDIR8) - $(INSTALL_DATA) man/*.1 $(MANDIR1) - $(INSTALL_DATA) man/*.3 $(MANDIR3) - $(INSTALL_DATA) man/*.8 $(MANDIR8) - -install: install-bin install-etc install-man - diff --git a/Makefile.win b/Makefile.win deleted file mode 100644 index 19f6952..0000000 --- a/Makefile.win +++ /dev/null @@ -1,36 +0,0 @@ -# -# 3 proxy Makefile for GCC/windows -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# remove -DNOODBC from CFLAGS and add -lodbc to LDFLAGS to compile with ODBC -# library support - - -BUILDDIR = ../bin/ -CC = gcc -CFLAGS = -O2 -s -c -mthreads -DWITH_STD_MALLOC -DNOIPV6 -COUT = -o -LN = gcc -LDFLAGS = -O2 -s -mthreads -DLFLAGS = -shared -DLSUFFICS = .dll -LIBS = -lws2_32 -lodbc32 -ladvapi32 -LIBSPREFIX = -l -LIBSSUFFIX = -LNOUT = -o -EXESUFFICS = .exe -OBJSUFFICS = .o -DEFINEOPTION = -D -COMPFILES = *.tmp -REMOVECOMMAND = rm -f -TYPECOMMAND = cat -COMPATLIBS = -MAKEFILE = Makefile.win -PLUGINS = utf8tocp1251 WindowsAuthentication TrafficPlugin StringsPlugin PCREPlugin - -include Makefile.inc - -allplugins: - @list='$(PLUGINS)'; for p in $$list; do cp Makefile Makefile.var plugins/$$p; cd plugins/$$p ; make ; rm *.o ; cd ../.. ; done diff --git a/Makefile.winCE b/Makefile.winCE deleted file mode 100644 index e08f1e0..0000000 --- a/Makefile.winCE +++ /dev/null @@ -1,34 +0,0 @@ -# -# 3 proxy Makefile for GCC/windows -# -# You can try to remove -DWITH_STD_MALLOC to CFLAGS to use optimized malloc -# libraries -# -# remove -DNOODBC from CFLAGS and add -lodbc to LDFLAGS to compile with ODBC -# library support - - -BUILDDIR = ../bin/ -CC = /opt/cegcc/arm-wince-cegcc/bin/gcc -CFLAGS = -O2 -s -c -mthreads -DWITH_STD_MALLOC -DNOODBC -D_WINCE -D_WIN32 -D__USE_W32_SOCKETS -COUT = -o -LN = /opt/cegcc/arm-wince-cegcc/bin/gcc -LDFLAGS = -O2 -s -mthreads -DLFLAGS = -shared -DLSUFFICS = .dll -LIBS = -lws2 -LNOUT = -o -EXESUFFICS = .exe -OBJSUFFICS = .o -DEFINEOPTION = -D -COMPFILES = *.tmp -REMOVECOMMAND = rm -f -TYPECOMMAND = more -COMPATLIBS = -MAKEFILE = Makefile.winCE -PLUGINS = TrafficPlugin StringsPlugin PCREPlugin - -include Makefile.inc - -allplugins: - @list='$(PLUGINS)'; for p in $$list; do cp Makefile Makefile.var plugins/$$p; cd plugins/$$p ; make ; rm *.o ; cd ../.. ; done diff --git a/cfg/0.scenario.txt b/cfg/0.scenario.txt deleted file mode 100644 index 0713f6d..0000000 --- a/cfg/0.scenario.txt +++ /dev/null @@ -1,17 +0,0 @@ -Please read doc/config.txt before using 3proxy. - -In all examples next scenario is used: - -3proxy is installed on multihomed host. IP address of internal interface -is 192.168.1.1. IP address of external interface is 10.1.1.1. -Internal network has few subnetworks for 192.168.0.0/16. -Users are named user1, user2, etc. - -You use external DNS server 10.1.2.1 and 10.1.2.2 - -Provider has networks with free access. A list of networks is published -on the provider's Web server. - -Provider has proxy server 10.1.2.5. Traffic from proxy server is not free, but -is cheaper than traffic from non-free networks. - diff --git a/cfg/3proxy.cfg.sample b/cfg/3proxy.cfg.sample deleted file mode 100644 index b8063c2..0000000 --- a/cfg/3proxy.cfg.sample +++ /dev/null @@ -1,201 +0,0 @@ -#!/usr/local/bin/3proxy -# Yes, 3proxy.cfg can be executable, in this case you should place -# something like -#config /usr/local/3proxy/3proxy.cfg -# to show which configuration 3proxy should re-read on realod. - -#system "echo Hello world!" -# you may use system to execute some external command if proxy starts - -# We can configure nservers to avoid unsafe gethostbyname() usage -nserver 10.1.2.1 -nserver 10.2.2.2 -# nscache is good to save speed, traffic and bandwidth -nscache 65536 - -#nsrecord porno.security.nnov.ru 0.0.0.0 -# nobody will be able to access porno.security.nnov.ru by the name. -#nsrecord wpad.security.nnov.ru www.security.nnov.ru -# wpad.security.nnov.ru will resolve to www.security.nnov.ru for -# clients - - -timeouts 1 5 30 60 180 1800 15 60 -# Here we can change timeout values - -users 3APA3A:CL:3apa3a "test:CR:$1$qwer$CHFTUFGqkjue9HyhcMHEe1" -# note that "" required, overvise $... is treated as include file name. -# $1$qwer$CHFTUFGqkjue9HyhcMHEe1 is 'test' in MD5 crypt format. -#users $/usr/local/etc/3proxy/passwd -# this example shows you how to include passwd file. For included files -# and are treated as field separators. - -#daemon -# now we will not depend on any console (daemonize). daemon must be given -# before any significant command on *nix. - -service -# service is required under NT if you want 3proxy to start as service - -#log /usr/local/etc/3proxy/logs/3proxy.log D -log c:\3proxy\logs\3proxy.log D -# log allows to specify log file location and rotation, D means logfile -# is created daily - -#logformat "L%d-%m-%Y %H:%M:%S %z %N.%p %E %U %C:%c %R:%r %O %I %h %T" -#logformat "Linsert into log (l_date, l_user, l_service, l_in, l_out, l_descr) values ('%d-%m-%Y %H:%M:%S', '%U', '%N', %I, %O, '%T')" -#Compatible with Squid access.log: -# -#"- +_G%t.%. %D %C TCP_MISS/200 %I %1-1T %2-2T %U DIRECT/%R application/unknown" -#or, more compatible format without %D -#"- +_G%t.%. 1 %C TCP_MISS/200 %I %1-1T %2-2T %U DIRECT/%R application/unknown" -# -#Compatible with ISA 2000 proxy WEBEXTD.LOG (fields are TAB-delimited): -# -#"- + L%C %U Unknown Y %Y-%m-%d %H:%M:%S w3proxy 3PROXY - %n %R %r %D %O %I http TCP %1-1T %2-2T - - %E - - -" -# -#Compatible with ISA 2004 proxy WEB.w3c -# -#"- + L%C %U Unknown %Y-%m-%d %H:%M:%S 3PROXY - %n %R %r %D %O %I http %1-1T %2-2T - %E - - Internal External 0x0 Allowed" -# -#Compatible with ISA 2000/2004 firewall FWSEXTD.log (fields are TAB-delimited): -# -#"- + L%C %U unnknown:0:0.0 N %Y-%m-%d %H:%M:%S fwsrv 3PROXY - %n %R %r %D %O %I %r TCP Connect - - - %E - - - - -" -# -#Compatible with HTTPD standard log (Apache and others) -# -#"-""+_L%C - %U [%d/%o/%Y:%H:%M:%S %z] ""%T"" %E %I" -#or more compatible without error code -#"-""+_L%C - %U [%d/%o/%Y:%H:%M:%S %z] ""%T"" 200 %I" - -# in log file we want to have underscores instead of spaces -logformat "- +_L%t.%. %N.%p %E %U %C:%c %R:%r %O %I %h %T" - - -#archiver gz /bin/gzip %F -#archiver zip zip -m -qq %A %F -#archiver zip pkzipc -add -silent -move %A %F -archiver rar rar a -df -inul %A %F -# if archiver specified log file will be compressed after closing. -# you should specify extension, path to archiver and command line, %A will be -# substituted with archive file name, %f - with original file name. -# Original file will not be removed, so archiver should care about it. - -rotate 30 -# We will keep last 30 log files - -auth iponly -#auth nbname -#auth strong -# auth specifies type of user authentication. If you specify none proxy -# will not do anything to check name of the user. If you specify -# nbname proxy will send NetBIOS name request packet to UDP/137 of -# client and parse request for NetBIOS name of messanger service. -# Strong means that proxy will check password. For strong authentication -# unknown user will not be allowed to use proxy regardless of ACL. -# If you do not want username to be checked but wanna ACL to work you should -# specify auth iponly. - - -#allow ADMINISTRATOR,root -#allow * 127.0.0.1,192.168.1.1 * * -#parent 1000 http 192.168.1.2 80 * * * 80 -#allow * 192.168.1.0/24 * 25,53,110,20-21,1024-65535 -# we will allow everything if username matches ADMINISTRATOR or root or -# client ip is 127.0.0.1 or 192.168.1.1. Overwise we will redirect any request -# to port 80 to our Web-server 192.168.0.2. -# We will allow any outgoing connections from network 192.168.1.0/24 to -# SMTP, POP3, FTP, DNS and unprivileged ports. -# Note, that redirect may also be used with proxy or portmapper. It will -# allow you to redirect requests to different ports or different server -# for different clients. - -# sharing access to internet - -external 10.1.1.1 -# external is address 3proxy uses for outgoing connections. 0.0.0.0 means any -# interface. Using 0.0.0.0 is not good because it allows to connect to 127.0.0.1 - -internal 192.168.1.1 -# internal is address of interface proxy will listen for incoming requests -# 127.0.0.1 means only localhost will be able to use this proxy. This is -# address you should specify for clients as proxy IP. -# You MAY use 0.0.0.0 but you shouldn't, because it's a chance for you to -# have open proxy in your network in this case. - -auth none -# no authentication is requires - -dnspr - -# dnsproxy listens on UDP/53 to answer client's DNS requests. It requires -# nserver/nscache configuration. - - -#external $./external.ip -#internal $./internal.ip -# this is just an alternative form fo giving external and internal address -# allows you to read this addresses from files - -auth strong -# We want to protect internal interface -deny * * 127.0.0.1,192.168.1.1 -# and llow HTTP and HTTPS traffic. -allow * * * 80-88,8080-8088 HTTP -allow * * * 443,8443 HTTPS -proxy -n - -auth none -# pop3p will be used without any authentication. It's bad choice -# because it's possible to use pop3p to access any port -pop3p - -tcppm 25 mail.my.provider 25 -#udppm -s 53 ns.my.provider 53 -# we can portmap port TCP/25 to provider's SMTP server and UDP/53 -# to provider's DNS. -# Now we can use our proxy as SMTP and DNS server. -# -s switch for UDP means "single packet" service - instead of setting -# association for period of time association will only be set for 1 packet. -# It's very userfull for services like DNS but not for some massive services -# like multimedia streams or online games. - -auth strong -flush -allow 3APA3A,test -maxconn 20 -socks -# for socks we will use password authentication and different access control - -# we flush previously configured ACL list and create new one to allow users -# test and 3APA3A to connect from any location - - -auth strong -flush -internal 127.0.0.1 -allow 3APA3A 127.0.0.1 -maxconn 3 -admin -#only allow acces to admin interface for user 3APA3A from 127.0.0.1 address -#via 127.0.0.1 address. - -# map external 80 and 443 ports to internal Web server -# examples below show how to use 3proxy to publish Web server in internal -# network to Internet. We must switch internal and external addresses and -# flush any ACLs - -#auth none -#flush -#external $./internal.ip -#internal $./external.ip -#maxconn 300 -#tcppm 80 websrv 80 -#tcppm 443 websrv 443 - - -#chroot /usr/local/jail -#setgid 65535 -#setuid 65535 -# now we needn't any root rights. We can chroot and setgid/setuid. - - diff --git a/cfg/counters.sample b/cfg/counters.sample deleted file mode 100644 index 185d7a2..0000000 --- a/cfg/counters.sample +++ /dev/null @@ -1,52 +0,0 @@ -# Scenario: -# You're billed for traffic except internal networks -# 192.168.0.0 mask 255.255.0.0 and 10.0.0.0 mask 255.0.0.0. -# If you exceed 2Gb limit you will have very high penalty -# -# You want to have daily report about common amount of external traffic. -# You also need to know amount of Web traffic for every user -# You want to limit Web traffic to 100Mb/day to whole campus and -# to 20MB/day to every user - -# see explanations in 3proxy.cfg.sample -internal 192.168.1.1 -external 10.1.1.1 -nserver 10.1.2.1 -nserver 10.2.2.2 -nscache 65536 -dnspr - -# no logging will be used, only traffic reports - -# use d:\3proxy\3profy.3cf to store counters data -# generate daily traffic reports in d:\3proxy\traf\ -counter "d:\3proxy\3profy.3cf" D "d:\3proxy\traf\traf" - -# define users -users "user1:CL:password1" "user2:CL:password2" "user3:CL:password3" -users "user4:CL:password4" "user5:CL:password5" "user6:CL:password6" -# ... - -# do not count traffic for 192.168.0.0/16,10.0.0.0/8 -nocountin * * 192.168.0.0/16,10.0.0.0/8 -# Count external traffic summary for all clients with limit to 100MB/day -countin "1/Test 1" D 100 * -# Count external Web traffic summary for all clients to 1Gb/month -countin "2/Test 2" M 1024 vlad,3APA3A,test 127.0.0.1 * 80,81,8080-8088 -# For every user count and limit daily Web traffic to 20 Mb -# There is no way to configure it in a single line, we need a line -# for every user we have -countin "3/User 1" D 20 user1 * * 80,81,8080-8088 -countin "4/User 2" D 20 user2 * * 80,81,8080-8088 -# ... -countin "202/User 200" D 20 user200 * * 80,81,8080-8088 - -# enable proxy -auth strong -proxy - -# enable administration to user1 from localhost -internal 127.0.0.1 -allow user1 -admin - diff --git a/cfg/sql/3proxy.cfg.sample b/cfg/sql/3proxy.cfg.sample deleted file mode 100644 index ca2d9a4..0000000 --- a/cfg/sql/3proxy.cfg.sample +++ /dev/null @@ -1,53 +0,0 @@ -# By Mark Dreuband -nserver 10.1.2.1 -nscache 65536 - -# we can grab wpad file from provider and feed it to dighosts -# to build list of free networks -# system "c:\3proxy\dighosts.exe -m http://wpad.security.nnov.ru/wpad.dat c:\3proxy\freenetworks.net" - -service - -internal 192.168.1.1 -external 10.1.1.1 - -dnspr - -log &3proxylog,root -#log c:\3proxy\logs\proxy.log D -#logformat "Linsert into log (timestamp, username, service, clientip, remoteip, remoteport, bytesin, bytesout,request,error) values ( -#logformat "%t '%U' '%N' '%C' '%R' %r %I %O '%T' %E" -logformat "-\'+_Linsert into log (time, bytesin, bytesout, username, url, host, port, service) values ('%Y-%m-%d %H:%M:%S', %I, %O, '%U', '%T', '%n', %r, '%N');" -archiver zip c:\3proxy\zip.exe -m -qq %A %F -rotate 50 - - -auth strong -users temp:CL:password root:CL:password - -# access free networks directly -allow * * $c:\3proxy\freenetworks.net -# redirect web traffic for non-free networks to provider's proxy -allow * * * 80 -parent 1000 http 10.1.2.5 3128 -# allow rest of traffic -allow * -proxy - -flush - -auth iponly -allow * -pop3p -tcppm 25 mail.security.nnov.ru 25 - -flush -# redirect port 80 traffic via SOCKS server to local HTTP proxy to -# have URLs logged -allow * * * 80 -parent 1000 http 0.0.0.0 0 -allow * -socks - -#daemon - diff --git a/cfg/sql/create.sql b/cfg/sql/create.sql deleted file mode 100644 index 80f3969..0000000 --- a/cfg/sql/create.sql +++ /dev/null @@ -1,56 +0,0 @@ -# Connection: localhost -# Host: 127.0.0.1 -# Saved: 2004-04-09 18:53:52 -# -# Host: 127.0.0.1 -# Database: 3proxy -# Table: 'log' -# -CREATE TABLE `log` ( - `time` datetime NOT NULL default '0000-00-00 00:00:00', - `bytesin` int(11) NOT NULL default '0', - `bytesout` int(11) NOT NULL default '0', - `username` varchar(20) NOT NULL default '', - `service` varchar(7) NOT NULL default '', - `host` varchar(100) NOT NULL default '', - `port` int(11) NOT NULL default '0', - `url` varchar(255) NOT NULL default '' -) TYPE=MyISAM; - -CREATE TABLE `services` ( - `startport` int(11) NOT NULL default '0', - `endport` int(11) NOT NULL default '0', - `service` varchar(100) NOT NULL default '', - `description` varchar(100) NOT NULL default '' -) TYPE=MyISAM; - -CREATE TABLE `timelimit` ( - `datefrom` datetime NOT NULL default '0000-00-00 00:00:00', - `dateto` datetime NOT NULL default '0000-00-00 00:00:00' -) TYPE=MyISAM; - -INSERT INTO services (80, 80, NULL, 'Access to Web Server'); - -INSERT INTO services (443, 443, NULL, 'Secure Access to Web Server'); - -INSERT INTO services (3128, 3128, NULL, 'Access to Web server via external Proxy'); -INSERT INTO services (1080, 1080, NULL, 'Access to external SOCKS server'); -INSERT INTO services (5190, 5190, NULL, 'Access to ICQ'); -INSERT INTO services (6666, 6668, NULL, 'Access to IRC'); - -INSERT INTO services (119, 119, NULL, 'Access to news server'); -INSERT INTO services (25, 25, NULL, 'Sent Mail'); - -INSERT INTO services (0, 0, 'POP3P', 'Received Mail'); -INSERT INTO services (0, 0, 'SMTPP', 'Sent Mail'); -INSERT INTO services (0, 0, 'TCPPM', 'Access to external server via TCP'); -INSERT INTO services (0, 0, 'UDPPM', 'Access to external server via UDP'); -INSERT INTO services (0, 0, 'PROXY', 'Access to external server via Proxy'); -INSERT INTO services (0, 0, 'FTPPR', 'Access to external server via FTP Proxy'); -INSERT INTO services (0, 0, 'ICQPR', 'Access to external server via ICQ Proxy'); -INSERT INTO services (0, 0, 'SOCKS4', 'Access to external server via Socks v4'); -INSERT INTO services (0, 0, 'SOCKS5', 'Access to external server via Socks v5'); -INSERT INTO services (0, 0, 'DNSPR', 'Name resolution'); -INSERT INTO services (0, 0, NULL, 'Unknown'); - - diff --git a/cfg/sql/report.xls b/cfg/sql/report.xls deleted file mode 100644 index 8065fa20f4792110381bfd396bfc72cdf60c080e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 57856 zcmeHw3t(JTng6+yNis>BHht1}Z_}1E&4YO)nVF_3nVC%5O45|3K$Sw9Cet>MN1IHs zEUzgALB+p_?8@ru))i!Rmj!jVyMI@uAS?I)!PONNCA?PFCc?>ze58Ka;6!h)wnnp-Cd#G7L!q9_Hg!B3E`T!=6{ z1%Nll#>Ny<2zXDscMu2OKv_dZJ34VM1hCDE0WLrZpcF6#FcnY+mN0gC{O0ZRZ&0XkqApaQTQumZ3Wa3-JC!Fy8-V3TnN|>xCn4DU?(63=mzWp z^Z|iPqT!Ju2hse&{|;;LOX6oJ9eV2qauRV+=1(PvSm-4VujE&4J7Ob><@M>(R<_* ztpBmQUy%1y8kKu0CO^LmBeGd{_E$T%v+qus@8|_T%gDdPg;Ez4icijaxcHmL;01G@ z5)N^X^FCaKcp9)>>|_1T@9*yI8|WL>TMz6S9=fb=Q2ztEuq;Ej#xfiOgPXM?)YO6b z=HG$>Iz9uXTo zAULIMbF@gh56NqVyiUVa6aOrq`LV=!M1^<=^kdiD%oZ2l5hYp(!rO;V+>Z_vLDw0^ zfb@Ssb!39&g0Nik6*A_8rFUYeXC1X1R4YzMwZwTA28TI9TaJ-?IsV*WO^dS**CxnR zEimc$CC(sbp9S`hT!`)%!ytK4)`y!gZ7ocFxDI({&(#{c#2JN5=_h(TTM5z=x)f8E zPiQ+($JIzNv!0AmJUCIj`FsVaE5>=Jp5?U#qg1U};=B~Iq-}OP!0sKGF4ZGsxivd$ zJgFG3vdfG!v%3P#)?`;ZD;u(9YDZBMUYN&GJ-hG(C)qtAwCs&@3JGG0SVB%R`OF%Z9`_L9Np8pWU2%_q!u zS#68w+-sjsi7mZ`6|LldM*3B@_#&jw@|VxEmWLsUA76Z^a*pG-S?P-)f0CYyap_EY z1J6aO9e#E?Ugeu)shQ3+nZ8`iThcM;xyU#0A9XlIdBQcu`;3HB-e)F?p}fyY6v+GBMA6tzjnaKRCiEwCCRwO0#6lp1MS(|RTkEY@uf%?z%lH&ppSVdl zF>w@&f6$y*Uue!VFatSBB%MP}{u*k<75AHC^U(d5p)yktCJwHQ+J#g%3ZeAK8cw5N z6%Y-b;$S>BJlNge+8yuS;aS6nqM)OyBc_v%)qu0oxz`X~ZXvWy&@EG3XCbsr(KFE$ zRT-Oer|6X_PPY)+meDKAIDr&>6HU=4Q(SAw+P2p9GR0{YLfbOd%M_a|gtjR*$P~*g zgtjR*$Q0LD2yIhrlqpWN5Zb2LC{qkt2yIjJ%M_2u* znWEo9Xq#ftCPh0!uj&dVmK5!>1|d6FqlM5mMb#CoDcTY$33pjiw9Q&cc!Pz|Hbo`j z))Z|CmEaazQnbxl3GM{4R)T9y(Kc%(k43q&R`NK3td%@kQ?$)mi5bVy4C_ykg< zfLCktEoHQ24+XqtB7~INYHgk+McY~jrI@)vm|S|;WnC`?T(i*GC8*k^)snGodh7@_ zX(hBJq`H=(M`nYjs71FpZ! z5Cl|9=T_4Ls-<&l-vQOqxs~dGYU$j%azM3oZWTD77;aTBZTYBLn#y3Z1?^f|=`gul zTBUb(&ISysmbR*bb|nm|mbNNxwuGvsb1QB^)zVgF$2LXP(z%tLplWGH?pmvs<_dVR zxT!!MWPpMu-AF9HBi=U<+tH6b&iFjhLhP)hkxx4V8;oZ=Tb%1)Vca1CPCu?b?2Ha$ z=lURQ{r$M_!OjGXf)PAgAnwy#032`lnkN1m8{E@{IL@O0*knDfnQY)iSsA?!5@*DT$hgW>vUScis9v)q<(_IM9!(|IaU`P|59-1T$|mO~ zPzI1p1N`lHZk@A=wY1nV8yhk(jTsn!1}2b!38rKG?hK441LMuW_%bl{8JLVR`!mYy z&nUA$qs;z{G6yos9LOkhAfwEIj4}r@${ffjb0DM4fs8T-GRhptD048Q%)yK@2Q$hX z%qVj(qs+mKG6x&Sum|Z9Kf*a7NVfPY&I%pJy#wck66hd5#l0LIWIz|<2<|nJaUMj^!ooy($oNbum7~lAi=Y5W1-0fQ}#Qw8zp2y8D#cltoxb{Mn>7Ris?eH$~ z`_H}dy^dX*&)y;Nt0lf#Uaysy1ZYgR5_=jrDj*Ia<~}DkPgu0WlKMJ%?GQ83%eUii z55|ygoW9{6;s%^U(Q(qKTZ~|{dl=_YV)As(Mw~?AS)_EQIYr?UqTUgCIZ>$LwARO` z)Vq37>gmvqxo1&>JrWJ)TjW+q`okv~=0HWqJ9)!9&!FIDajhFSomT-&J&1PP_uFq; zBGUqDe=7}nI`}8Yflp)dDnU=6?DD)%jaFlb+vwSf8KY-wIGN=@U%N^U5kmZA&OC%2 zGR&ubGH20vSnl47TFT`$qYPg6~aB-5J`+@`0lk}X52M}*QUxL!! z;!1`~aawX?donx)CnpDHCc_xiv=t@X#C3?9~0V5c3r{j1q zHXVnxTLzBekxs{hwCOk=tWC!)w83%8OQ*vGn}Ne*n}NfGYr$y_HB>JUU&H#DQa2wP z;`8xWATg9VD~1wh#Zca?7)qNJ!(6NwN}3fzIkRFYWmXJj%!;9eSuvC^D~8f##Zb1a z7)q8EL%FhIC{G{4e;n&{q?|6#%WQC5e5BJYx52Hj!L78xooR!s zw85>i!ByGduHIdhfDJBagIi;R<58USJl5Lanr(3FY;at4q^8GFPX{h3*~C!#tQg9k6+_9hVkmc3 z45iMBq0Ct^lsGGf@@BDLniWGyvtlS`Rt%-gilK~IF_bVXhVo^_P`a!b%9a&F z$+BW7S5^$A%8H>(SuvC-D~9r9#Za287|N0rLrJn?C`VQdrO1k*3|TRhpd^Ol;4wK4 zp8OcdCpiwbAmvoqBrarw3)|o#X*f!83vkJj62sK27^Y>#Fr_5shgg)~2FzMxjDJCF zrXqcO18`8Hk8{q}0EOVebWw1evNBybk5h)Bz#iuun(iE;R6d8w^6;!!=a?yua)BUA zY*H^~dMu2}0KT!iv<9)Epd3Y^n`bQ>d{5Ko{MoGTsjK}|d?zRk1$BeDKi zPh3AR!t;Csv6_(s1FLpj9*>Rm4OX4yan}bL{EanxheqNxpt!8BCpJ>o8yo2v?%Nmd z8^Ze%Wu?1^hX(Zip*`aSH8eU(n$_s{_r_v_DRlAf;kb+<^d2M;tUP<#)cU-*`;@n^wgM@({-J!X?j>(Ev|rq)3vGD zw{Ljp;N_@AQ){#<(%f-**SYO_XKOg3`|27zdh2lCWk?W|O|7A=p>U`xYCO`^72R@v zbW3ypP)~P1b8k9tV{7y9&``W-bEvE9g3c|i%}tv-w`^_p`P_|7otw9A>_m1=U0XZ0 zHa9t3O~OI39Czgt7nNpTfoqW{z~dBZii<H6<}mwm}4Qsw5O%U z)1J0sc9NdV^MOnEEzw8Z#vFNhOu&hy-wA~G{&g`o@)v&xaejY#yHdP#vYrBdqa+s z>g{JCu7(QC-n~Q|x$WteBKdx@L)ro#aPHS=M{gCcy|DsUp&biF#TlBYQ~uTze?)`} zH*3X?DdeEn?XIt@uM2!l?jsiO{yA6Mz(XOuWt~G`?%gW7#~Wmwe?lz8oWlQFFsVIU)J4!AU2|} zsx-%d${N$_aaUHoQ+V&qkN50$ljJ?@4X2_ILs!a2h~EN6!c3FN$UjLTuFsG6TntT8 zh+z=R`)-}youe7hOxbK5cUPf>_{?)-S~gfclfA@*UP?i3VapXY67^CK+>xM!YhG%bxR zsU{B>C`%*#Fb~qQ0Y$p|3h!FSgRA>=G+=W&lTG41|RG}pZv5i$|DMGY5sgRBk z4Mso2)8A(ks|{^>M2ozti?qurucU(a#O9>NQ&Ssk%u^fG(F1Y~AvqX%S{pQm@5Vf} zL7Mp|$@^1N8*I!|8(e~+dXkJhtqqz&oToOp7!%_pd4FnZgN=D=gNwk%$uZJ@S{pQk z*q^61xDYG2N%H>G)CT=|YJ&@~_?;vpPiupw5a+24^1YHt^8VD^=JV&d&Bsq@Op=kO zxA{yV&U2gZ4Cus@FpFiA$9R_sh6&Qr0Q1LMskd4FmucK$pSyVsy0bR{s9!b;5+hlkU*Y_-Q-`z37ndW zT_8`zZt|~#1Z@?&bNFkjC;d)SiVz3iF|RZQ^VI7m|29bQ)YR*OdFpkOeAOp=UYwu%sReU zGB(E3^mgAU%9h^u)khda@)ujPQJxr&FSYY`6lC5L&7bcNJern27JMh=m_JYb^R0l1 z=C6bH01FLg)*q{$lXA?T`I>GbiEIIpS%1D*z;_YI4!*Czy6~L_)`#ys@J$H58^QKv zk@-di-?89Z7jGg{zL_x-FblxwjRe;riYCsL37ElK`3jjqEzrKxc%>c+hEO-PaUi|*2kRLLG zH3h%TE#&ug_%TO*=A{|HPc)tlXaR%(VL$}X3Wx&Q0P6wJSmihO--Y`*fOY_08xorU zcy$OLHpFiR09cPM+_wVG1Dp@I0I&`4Zoqp07Xr2eE&^N(*a6rH=mzll9^88YF~DxX z9>88eAK((erGS3G0ALU>1lR}I4;TiF0OEiHfXe{y1snui4)`;`6@V)NR{^dDTmwh| zw7HOgyH* zk)SM&jg^BtvV8JuRFY_%Ukoh)U~g> zC#2od*4;l6o7x*m49D;j;k)|hEESuFW4*DS{_gjSqK&=cuC2od%EB$tgZqX?VzU=* z6|sSR{rLV*t2>5|Vmemb5HbfdcnjQH)&DsP zBzt(O?{xp4a5u=&|L@G&|G)kGEBdP*bpF!OaJOT`u@9XeeSfDr;C0su-B}(fM&DnA zzR#|INcMep{rk(=_hr|2qVGQxVb^!bzR#|IGyA^m`k!~nzR#`?LiBxheZjuZu3w<~ zKD&NV-hH3k8SnoqF#V>^|1}72Uw98yb1)j71KUGi>-&zZo{~W*k@RLfk5^`gLcHKfg_4)MYVr2d)=V*B3W3 zjP=D%MPkV-b$ziH@fu>47#hU5nfdQb@iW#AZ{m0-4V{Tg^_w{BU6Q{A3yd>G#UYo} zu4IY{em&4w)E;s_E`JKG6{KQiedr0AV zHSw+#e=1&TY@@^=FFyM^{Rx+o50rBh0G`_0Ji{M=KR`e7+Kbyh!@mmt#|{5H_^DKg zL*>r3xXqJ(m#YZ=ZOZTDZ6_~@l4SXj7d5B71`YFiNcvSeQeQZv(rKaY0D4Ampg%Po zl#R~h33RBO{I5ZJ%*+AY%rwiQ?ZmD3x(v9M} zROoPB@>}!xY<%6h2V%pQZ^hgYt80~?*8~mIi@t^FG2e3W-Q&+c_k#ZN=<(4Po_qE9 zOHZqM%@p_l?&X*M`^D#8eEvE8=c6wlf9aLcqfpf__r2#rW9_$e< z_<;c69mAY7q?*ku2SHb2Z%7gF2n&GM@gxMC%h3TJMdt|MrA)EQs z^B$Cg{G1~qL;VK^21iy^w61BbsH#(4L6(#8D@3wyL7>*1L#$$u=X(Nd<4=uQ18i%&qFW-7-BR+7w zG%l`OsFgdbqwUp+r5K8YITj`4U{qFGP*V_Ee4nFI4oAWqk90X8wbt*AxnuE>RS$gR zoTk=3{6gsdxE>nOBMsYZh536DqjF$6bZg7qPS+ggjLL5;^k|FFGlluJUQh8N3Idg1=06yy)(ak7`t`Fb;x>!F^w`1>yH{JKNMn?~wFy}heiZaQ) z#zx}qzQOMJ{Uxm*+UA21qN1us@7f>eU(;MP(>eW6QQejn{DenrWN)M-`Z|8a6u0m3JOOFLa?B_7t)U9z-7$?#Q2O{s&#rudIna=?YDI%=K(* z_;VjD_;kyWBV}COm~LGE$ZdaI@F8}u<#_T&z-jv8K`{P@se{g-5svpSm zowh$p#V3dT!S}~7jhwvwq2M^0{s}BZXn(i|iycb!6ilK&aRC7b6zmUgZe$G5(%JQY z{1(=@dS{SL@Kz2wrd$Xp2AKWIY7I8lN{G+mRQ40ue{hXw!Dr0u-p)JwmxleUA?!OH zz}`|!?xkg^SXOj7ba-lV9Mf6)tb{2MyWqcgibCwbPFR=N0u6VE+{a5Hn~)dzTevro zhp07gH3(Dl=N@9dj`in$DAmA;*8djJ?lCgjf!)F|b|H6w16#1G_%7@~M#f8L5S`$* z;3Vo#Tg_ORk*Hx|!meqlS$@Y_TErNizW=1UBIz{k2;!&AY?byNcy|KETY`Q%GezE& z<4*5##9Sx)TXuVq+Fvr$a2yWHeAsK)dS*^ZpDOQSv;*x-%xfp^JOq>OjDlEhq_H5< z0((;uaUl;zpXeEfWXIsIzZb#}Gp~S|VLKXkxAC_cs#YVm-@MqY_5#;{j)yMsWJ(@+ zduhL3ZZ$8#bTJ$0$RQMdc2J$^8s;Lm;is8r8~vc6f1lx}+2cm~K~Iy<5&A*HLjcDN zKWQGNA2c+dJWsztgI_!&US==Zm1c&aS;#aaF<-Z&SEeRu9zi*UGArl6jP#jifPR>o*5I~T`jv_3X62VAqT3X`G~LLuA$^*fjuA*hM(oX(eRTeM+`st|1a>HrlUvUXMUPC3ZH2@qI$k<&AXx2T8%^cNt%X6 zk*l34$JS(X2*lR{4g=69#r1&q0d4@W`QH!t0N{gwn*dmYi~k4sFo1i-A2IG9HST|o z`(FS)2DlCImw=B0J^}bEz$XEp0{k`L2;kFzzX5y(a68}*z-Iw>0{#~8Il$)ue+T$` zz+HfU0Nf3@2k-^J7Xe=a{3GC>07n7;4EPto{|9^-@UMWc0KN+N8sJ{QF~EI*`vG4E zJOKDNz&8L70v-Z<6Ywp-w*jp0!?-^J_%48={}|wVfPV*kAMgXfe*k_6cpUH}0H6B_ z?oR-I3iug-y?qq$6yRyVGk|9S&jJ1u@N>ZPfd2yg0`T8}7XU8;UIM%fI1YFP!1Vve zxYK&X@N2lg4)_h=w}9UPeh+v9@FrjkU<{5lX+$h04aO-`%o(D!Zy;$agFd|x`um>P zFn*Cr7i}3FSDOw%DvHgm?)fr%|86&5j>&N@en%$G-svYQ-z7L((? z;fa|XYhZvoITIJl|4ubICXH3O3~^SI<4*0JWpX^(dLD$lnd73zB3HyaL?}(3L5`v2 zG4U=3N9Sc?l_Ly8EtmyI6W}V`(fh`9egr#TL zYO6aUZFSQ}d{g%X5AEI`*Mh~LIJ{tF|Lw5PJvF#Td!pBI`=Ea9<=T&~eY`30jJB@F zH8eO_Jcm{}VeS(-S7=)1V#99!j+R(g1jAh6zgJ$`W_o^>-&-&< z3L~7hJW}wnh}Ks2>gLL_b1Q4!=X~Svxs~5I_w1|m1=m!yoO4apoBB0X&vac=6~6iD zHP2rA;x&s`G=$0yzWU*38}x9u=(&_Xy*t=@=-TL-W}YR|uPq1#^iNw1Z4gL1H+)_K z=u~jvfZ&ztfS^3-Sz5C^W~QNuLgevVxqM%5IdxYL zEv;=5r*4*G`Co_WXgSWOE=NjhpdcvyZ#}wu2q!c>z(k-AcHplQr~VYC1LsjApy-6o ztT0M@+-_)*jd+TfC=`r3oM&yv-*RC3a6a?^Cb52@BNmexFg@_MVbB`JJ%nZdKEx8+ zjdP@Zzz@nZrAc0vYgA*beBkLr-=z59K{@MDM)Jbs!!UB+gK~A_v@6TlC#@4B$h||B zkntmc-6*LJUQn@O$zz~M4SA62cJN{wcoqdG>ZCu4ob1wxVrQLckVkxy?Zeb};rwk3 zG0dwS`RtM<82hJdjx3d@NwBdwlD{4^>9@aut z4FeN`j~wzKR10WDx(!A>Lx@$UOY0517pF{@%aV9;XFIE!Yz7~*wR1$4ZvfXplsK0J zbm8m)wwAzyUMT@>c!K>TiW0IPb$}{>rnZrJ{m%Y54ZXDRL93T{!gkIE9% z;>vTn94{2t$iIL=!Si}v^j1iGkZ9bLA~ z#OtbwspAsThLQ&H=SS%qWewY8-u0+qJ;Hv(Q$oVpt%p?7x6R&JMZA;`2j65>!SWO^UkJK2*1vK5sCBx_s;%7aM7ejG^B z<;xk)M^Dv7%RW51p#1te$IhENra&d-9HRdCs~@x*6gf2faxiSBxKB0COR)#irlf2} zoXnJ!$(+}CS4+!O41cD#KrT2_u`n>Cc4)(Y$7O|>S8JVNr`x%}+3XBBeelgjYk1IB zrZK7>yon*jIZ)}+X~)L+3V?L1>dFEZsC4`l77tzkp)hAAHXpw)Y`*B?!81HbOec>5 zr6=Q+$@pxNS(uWH7s>EIBAuJ1xftt()YAB5GW9megi@06;Ti5L(rrjqY8qrN)h^D8 zWt!~9#=?$t%CRwSQ_$^Xa!+B!GB$P)UQJ8j%4TA%t<5#L5X+q{1;|I%xNOh7U3fC+ z?aJ%z$cJK>E1z%u?WS*Bvh-6eANcssO5P~`x0^`M&iX?2%GOVufAOX-y!VbcOzzxVam9{Ko#CVorNW8b`W z=3bd7f{cZ*W`HV+S766=Y7?OwMi5+m{6q5jxMchcXv zdv{+?Y|a5UHq<)0+J=S)Mk3SQI6jA0Cgd9viHqE#1O*x^(8P`?f5sT6n&nyDR2<@kyxSg50p@K;H-^OQ5A1|zs94*P8bkqKiDhx^ z$Bozb!ri9YD9e81m%$ENrmus1lsh=7%ye)HnggkZ9R!#{F&`6_Lo9SSFp)(NYd7^! z((D}e$&eZz#WkB#li@TFjg1w_!>gKnd5$vs2XfjuUrMN7nNQo zwBdy64(lBAi=EC0Rt3|vnRr`3 zG+wpbTjxeUTfTnH_6s&{!gA<>uI*iyk6^Vw;PY(zAG|KwDgI`6f-2Ir(N8626y2K84n@7KZ2>Gcdx0LF1aEmJHnlk?lGJxV z)QQCdUF!a;TcPs0p3MI5kCDSS3sp9$`FrxpSrK#pw+vodE69h5B=IVUwitxgUElX& z1)HCneG>ftC9;66M!Nb)Z9}*X8i~j43D<^OZ;v)4qM=YCQlBU+^4=It+_q=9djL9E zUw>?5dt|75U|?v_S=7LtBhl4a*V^8`{DyMv zaEI>k)VcLe$F4*7>Fs^HhP!VXz8tU9YI8+#!ePz~>#h^iaE_o0n!%lkVQ^tY_!8)S z!tvSG`UY<_5%ttY-GMf3rz=z&5YAe+7dlfQQs3$hhfC`V-EHMvZ5>|s!uHDWV*S{T z@0@v-XnI3bc#a9jlEas5+#hmo*nh%RPc^v3?TM229TQq;URyXA z^amPUZMAKQ57ySV`L$!a!+u|FTL|h(TSL(6i})N3H#W9*M$W_Wj;lS}c|?1AOM7P| z)ZW!n0Oey~-*(QW?*2fX``E6qzb>}+VDCdc=dBeL38)3a)C*daVi0<4`i%R(S14xP zuibGOtWU0%QaLfU;9bJ?qP(S`R+vlmd$?8)Ilkrce$Vwci;h9uHiR|L{XgExrSp<7 zUO=xo_x^>8e_9cCRfo0t7_E=X33UCO@D&Tiv`}KYM=bc{`T}oz!P#X`Eh=2*D_iZY zF7vJ`<5g@ttL);Ep#|$^`O17hs4nxZD)Zs$F8e~|)CC`^F55N0S>``tqm?}aLoFXW z5dK*As-L=?-s|?4IA31)R3bFcIPcAk%l0-t6)|KgpW8>zSv{gjd!On%oM22JZGCja znLd7C$nFnsL7xXgkpR63c;;%LYytDo)uz324xVBEWlpp((tT6iM5X`CEq7mhPUrQH zj0Rf=9>+@!v=Y)<_zZxK(;8G7QBZ1~+8Fm=yujJTm2lmcC2rXX;(|t;cB5{T+9574 zR%x*$H!H6!l_t&|kHNd@#*>Aj1l6~5^NmqCJx;xqk&eaN`Nk-k9#c}3j!|J0K<12W zpoHN~`SJB5G333uI0Tu4iAzCF4R})nJ_cArVFns}+yqa@#>ke=E_hH9LL)BGMh;#qD!Bn9N?O`y@Qxg2!&6>9V&Hyb z+^zE$%QA~R6>ZayDAo_MEW<-`WK{zz##3WBRm>gI88k8X=Z+v}p+qGrA2 zf}KU`R%sgzt)%h&22L{?vPETVTv;S{8hgNW$5K@!t})CdhPlERUtoZYjjEP3sPHu` z!hRzga>dA5{H1|=%D8XNC_?+Auh;(e!iD8ueGXgutv}mRj4pqq5f$qshZIvJhiHPKd%uC3VTkTdi8U|eP`U|+99jed2v7!xIOkAW zn75QerRXs8Lq-PX-Q>^b4E!s`eV>sxF#fK@yS*dEqVxTo^ad;1;z4 zZCb{U^_s(^{2<6R#)Btwv)}(gv5m1Ub4;bIr8@RRv>I&M@}m|qH1Uf$-eefNjG-sR zZly5Zaf}zaaCq{KW7tT>NR(zk%32`oU{+kwP#*~S8^gicP(z>%tB|E$p+3bE!pfb|}CBe7G!VNH$eBRc^dUtJv z^+XlhY6H=FAFJq&1U(*9GjvrG77I<|Pq|Z4@HWfO0N@iK8t-lbp>l zXj_s&0WTODzH|g%2#BFvW^ZqH*XZN_k+M?R&zn6B^)F{_04b*?!^Ee;p8f{6fgxa6;KA42AB>g2h0G>1k3`= z2FwBQlR{?zc)W8yU;$tuU=d(3U zI>1=~H^2k%0(^jaKm(u=;0FW%TrIBwuwHA8yV+My-^a$3JVBU@UfvuC)aV4irx5~E zkIQ>bbdKarjQE9`xwc7;USPEtz5cIX{Y~fI^1u6tOH@~W36@=TCX)*##*Lxo@*U`Y(yA##l@q>qd@K<#U%Rl-t)W7C8ut!72Q6a8a zSpUrc&YRl+X8`sBrU3QCt7oFF{6EAf9VMIi8IByyHHf{HmLrAC_^<93C{jN$HWrVuUv>!aW}2%NmpZ zOft3fXOc1L&v>)ulZ;7!#+UV(WK8-q^;w@u#-u;fkoB2lO!_m8S)WP9q(9@&`b;t= z{h2`4XOc1L&jiPxNsIAjZS9np^k=fRsW;hjX>yPflb%}Emh&dtCq1=fOnPcr+XqHR zc0`-5kP?%gTGm$ZCV8D+wq#6tYFS&sm$emAV$xFcWo-pt)>cS~Nlz`=3TgH6C1cW` zNwz}zGs&3rXOiuc{!B6^{h6#S=S#+hzeb49!{qnEbQ!--fIV zZOF=khO8`T$X+`(t3hFTTjfIi$5#Z{8_o?&&oA_R<8N8a?PKWYyPZU^JlM5R<8N8axIXJ zYgyC6Z+vFyZh@>^3uNV5AS>4bS-BR-%C$gNt_8AkEs(vYS-F;sNE^PgP89e7oh)3# z@4IA+$;vhSo<_E3vT_YSUy$vYM)@^osVOXbP<{$($MZkm;oCQ?-pLSCp-(_PlRB8G zQ~XY9Bh*N!nK9*uUU=@sm!2Md@x|Xgr$77r=*y!&f9XX0$3*x^V9{zFN0s)pHBha;k5q?*%ho& diff --git a/man/3proxy.8 b/man/3proxy.8 deleted file mode 100644 index a6313a7..0000000 --- a/man/3proxy.8 +++ /dev/null @@ -1,151 +0,0 @@ -.TH 3proxy "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B 3proxy -\- 3[APA3A] tiny proxy server, or trivial proxy server, or free proxy -server -.SH SYNOPSIS -.B 3proxy -.RI [ config_file ] -.br -.B 3proxy -.RI [ \-\-install ] -.br -.B 3proxy -.RI [ \-\-remove ] -.SH DESCRIPTION -.B 3proxy -is universal proxy server. It can be used to provide internal users wuth -fully controllable access to external resources or to provide external -users with access to internal resources. 3proxy is not developed to replace -.BR squid (8), -but it can extend functionality of existing cashing proxy. -It can be used to route requests between different types of clients and proxy -servers. Think about it as application level -gateway with configuration like hardware router has for network layer. -It can establish multiple -gateways with HTTP and HTTPS proxy with FTP over HTTP support, SOCKS v4, -v4.5 and v5, POP3 proxy, UDP and TCP portmappers. Each gateway is started -from configuration file like independant service -.BR proxy (8) -.BR socks (8) -.BR pop3p (8) -.BR tcppm (8) -.BR udppm (8) -.BR ftppr (8) -.BR dnspr -but -.BR 3proxy -is not a kind of wrapper or superserver for this daemons. It just has same -code compiled in, but provides much more functionality. SOCKSv5 -implementatation allows to use 3proxy with any UDP or TCP based client -applications designed without -proxy support (with -.IR SocksCAP , -.I FreeCAP -or another client-side redirector under Windows of with socksification library -under Unix). So you can play your favourite games, listen music, exchange -files and messages and even accept incoming connections behind proxy server. -.PP -.I dnspr -does not exist as independant service. It\' DNS caching proxy (it requires -.I nscache -and -.I nserver -to be set in configuration. Only A-records are cached. Please note, the -this caching is mostly a 'hack' and has nothing to do with real -DNS server, but it works perfectly for SOHO networks. - -.PP -3proxy supports access control lists (ACL) like network router. Source -and destination networks and destination port can be specified. In addition, -usernames and gateway action (for example GET or POST) can be used in ACLs. -In order to filter request on username basis user must be authenticated somehow. There are few -authentication types including password authentication and authentication by -NetBIOS name for Windows clients (it\'s very like ident authentication). -Depending on ACL action request can be allowed, denied or redirected to another -host or to another proxy server or even to a chain of proxy servers. -.PP -It supports different types of logging: to logfiles, -.BR syslog (3) -(only under Unix) or to ODBC database. Logging format is turnable to provide -compatibility with existing log file parsers. It makes it possible to use -3proxy with IIS, ISA, Apache or Squid log parsers. -.SH OPTIONS -.TP -.B config_file -Name of config file. See -.BR 3proxy.cfg (3) -for configuration file format. Under Windows, if config_file is not specified, -.BR 3proxy -looks for file named -.I 3proxy.cfg -in the default location (in same directory with executable file and in current -directory). Under Unix, if no config file is specified, 3proxy reads -configuration from stdin. It makes it possible to use 3proxy.cfg file as -executable script just by setting +x mode and adding -.br -#!/usr/local/3proxy/3proxy -.br -as a first line in 3proxy.cfg -.TP -.B --install -(Windows NT family only) install -.BR 3proxy -as a system service -.TP -.B --remove -(Windows NT family only) remove -.BR 3proxy -from system services -.SH SIGNALS -Under Unix there are few signals -.BR 3proxy -catches. See -.BR kill (1). -.TP -.B SIGTERM -cleanup connections and exit -.TP -.B SIGPAUSE -stop to accept new connections, on second signal - start and re-read -configuration -.TP -.B SIGCONT -start to accept new conenctions -.TP -.B SIGUSR1 -reload configuration -.PP -Under Windows, if -.BR 3proxy -is installed as service you can standard service management to start, stop, -pause and continue 3proxy service, for example: -.br -.BR "net start 3proxy" -.br -.BR "net stop 3proxy" -.br -.BR "net pause 3proxy" -.br -.BR "net continue 3proxy" -.PP -Web admin service can also be used to reload configuration. Use -wget to automate this task. -.SH FILES -.TP -.I "/usr/local/3proxy/3proxy.cfg (3proxy.cfg)" -.BR 3proxy -configuration file -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy.cfg(3), proxy(8), ftppr(8), socks(8), pop3p(8), tcppm(8), udppm(8), -kill(1), syslogd(8), -.br -http://3proxy.ru/ -.SH TRIVIA -3APA3A is pronounced as \`\`zaraza\'\'. -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/3proxy.cfg.3 b/man/3proxy.cfg.3 deleted file mode 100644 index ac87e42..0000000 --- a/man/3proxy.cfg.3 +++ /dev/null @@ -1,951 +0,0 @@ -.TH 3proxy.cfg "3" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B 3proxy.cfg -\- 3proxy configuration file -.SH DESCRIPTION - Common structure: -.br - Configuration file is a text file 3proxy reads configuration from. Each line -of the file is a command executed immediately, as it was given from -console. Sequence of commands is important. Configuration file as actually a -script for 3proxy executable. -Each line of the file is treated as a blank (space or tab) separated -command line. Additional space characters are ignored. -Think about 3proxy as "application level router" with console interface. - -.br - Comments: -.br - Any string beginning with space character or \'#\' character is comment. It\'s -ignored. s are ignored. is end of command. - -.br - Quotation: -.br - Quotation character is " (double quote). Quotation must be used to quote -spaces or another special characters. To use quotation character inside -quotation character must be dubbed (BASIC convention). For example to use -HELLO "WORLD" as an argument you should use it as "HELLO ""WORLD"""\. -Good practice is to quote any argument you use. - -.br - File inclusion: -.br - You can include file by using $FILENAME macro (replace FILENAME with a path -to file, for example $/usr/local/etc/3proxy/conf.incl or - $"c:\\Program Files\\3proxy\\include.cfg" Quotation is -required in last example because path contains space character. -For included file (end of line characters) is treated as space character -(arguments delimiter instead of end of command delimiter). -Thus, include files are only useful to store long signle-line commands -(like userlist, network lists, etc). -To use dollar sign somewhere in argument it must be quoted. -Recursion is not allowed. - -.br - Next commands start gateway services: -.br - -.br -.B proxy -[options] -.br -.B socks -[options] -.br -.B pop3p -[options] -.br -.B ftppr -[options] -.br -.B admin -[options] -.br -.B dnspr -[options] -.br -.B tcppm -[options] - -.br -.B udppm -[options] - -.br - Descriptions: -.br -.B proxy -\- HTTP/HTTPS proxy (default port 3128) -.br -.B socks -\- SOCKS 4/4.5/5 proxy (default port 1080) -.br -.B pop3p -\- POP3 proxy (default port 110) -.br -.B ftppr -\- FTP proxy (default port 21) -.br -.B admin -\- Web interface (default port 80) -.br -.B dnspr -\- caching DNS proxy (default port 53) -.br -.B tcppm -\- TCP portmapper -.br -.B udppm -\- UDP portmapper -.br - - Options: -.br -.B -pNUMBER -change default server port to NUMBER -.br -.B -n -disable NTLM authentication (required if passwords are stored in Unix crypt format. -.br -.B -n1 -enable NTLMv1 authentication. -.br -.B -s -(for admin) - secure, allow only secure operations (currently only traffic counters -view without ability to reset). -.br -(for dnspr) - simple, do not use 'resolver' and 3proxy cache, always use external DNS server. -.br -(for udppm) - singlepacket, expect only one packet from both client and server -.br -.B -u -Never ask for username/password -.br -.B -u2 -(socks) require username/password in authentication methods -.br -.B -a -(for proxy) - anonymous proxy (no information about client reported) -.br -.B -a1 -(for proxy) - anonymous proxy (random client information reported) -.br -.B -a2 -(for proxy) - generate Via: and X-Forwared-For: instead of Forwarded: -.br -.B -6 -Only resolve IPv6 addresses. IPv4 addresses are packed in IPv6 in IPV6_V6ONLY compatible way. -.br -.B -4 -Only resolve IPv4 addresses -.br -.B -46 -Resolve IPv6 addresses if IPv4 address is not resolvable -.br -.B -64 -Resolve IPv4 addresses if IPv6 address is not resolvable -.br -.B -RHOST:port -listen on given local HOST:port for incoming connections instead of making remote outgoing connection. Can be used with another 3proxy service running -r option for connect back functionality. Most commonly used with tcppm. HOST can be given as IP or hostname, useful in case of dynamic DNS. -.br -.B -rHOST:port -connect to given remote HOST:port instead of listening local connection on -p or default port. Can be used with another 3proxy service running -R option for connect back functionality. Most commonly used with proxy or socks. HOST can be given as IP or hostname, useful in case of dynamic DNS. -.br - Also, all options mentioned for -.BR proxy (8) -.BR socks (8) -.BR pop3p (8) -.BR tcppm (8) -.BR udppm (8) -.BR ftppr (8) - are also supported. -.br - Portmapping services listen at SRCPORT and connect to DSTADDR:DSTPORT -HTTP and SOCKS proxies are standard. -.br - POP3 proxy must be configured as POP3 server and requires username in the form of: -pop3username@pop3server. If POP3 proxy access must be authenticated, you can -specify username as proxy_username:proxy_password:POP3_username@pop3server -.br - DNS proxy resolves any types of records but only hostnames are cached. It -requires nserver/nscache to be configured. If nserver is configured as TCP, -redirections are applied on connection, so parent proxy may be used to resolve -names to IP. -.br - FTP proxy can be used as FTP server in any FTP client or configured as FTP -proxy on a client with FTP proxy support. Username format is one of -.br - FTPuser@FTPServer -.br - FTPuser:FTPpassword@FTPserver -.br - proxyuser:proxypassword:FTPuser:FTPpassword@FTPserver -.br - Please note, if you use FTP client interface for FTP proxy do not add FTPpassword and FTPServer to username, because FTP client does it for you. That is, if you use 3proxy with authentication use proxyuser:proxypassword:FTPuser as FTP username, otherwise do not change original FTP user name - -.br -.B include - -.br - Include config file - -.br -.B config - -.br - Path to configuration file to use on 3proxy restart or to save configuration. - -.br -.B writable -.br - ReOpens configuration file for write access via Web interface, -and re-reads it. Usually should be first command on config file -but in combination with "config" it can be used anywhere to open -alternate config file. Think twice before using it. - -.br -.B end -.br - End of configuration - -.br -.B log -[[@|&]logfile] [] -.br - sets logfile for all gateways -.br - @ - (for Unix) use syslog, filename is used as ident name -.br - & - use ODBC, filename consists of comma-delimited datasource,username,password (username and password are optional) -.br - LOGTYPE is one of: -.br - M - Monthly -.br - W - Weekly (starting from Sunday) -.br - D - Daily -.br - H - Hourly -.br - if logfile is not specified logging goes to stdout. You can specify individual logging options for gateway by using --l option in gateway configuration. -.br - "log" command supports same format specifications for filename template -as "logformat" (if filename contains '%' sign it's believed to be template). -As with "logformat" filename must begin with 'L' or 'G' to specify Local or -Grinwitch time zone for all time-based format specificators. - -.br -.B rotate - - how many archived log files to keep - -.br -.B logformat - -.br - Format for log record. First symbol in format must be L (local time) -or G (absolute Grinwitch time). -It can be preceeded with -XXX+Y where XXX is list of characters to be -filtered in user input (any non-printable characters are filtered too -in this case) and Y is replacement character. For example, "-,%+ L" in -the beginning of logformat means comma and percent are replaced -with space and all time based elemnts are in local time zone. -.br - You can use: - -.br - %y - Year in 2 digit format -.br - %Y - Year in 4 digit format -.br - %m - Month number -.br - %o - Month abbriviature -.br - %d - Day -.br - %H - Hour -.br - %M - Minute -.br - %S - Second -.br - %t - Timstamp (in seconds since 01-Jan-1970) -.br - %. - milliseconds -.br - %z - timeZone (from Grinvitch) -.br - %D - request duration (in milliseconds) -.br - %b - average send rate per request (in Bytes per second) this speed is typically below connection speed shown by download manager. -.br - %B - average receive rate per request (in Bytes per second) this speed is typically below connection speed shown by download manager. -.br - %U - Username -.br - %N - service Name -.br - %p - service Port -.br - %E - Error code -.br - %C - Client IP -.br - %c - Client port -.br - %R - Remote IP -.br - %r - Remote port -.br - %e - External IP used to establish connection -.br - %Q - Requested IP -.br - %q - Requested port -.br - %n - requested hostname -.br - %I - bytes In -.br - %O - bytes Out -.br - %h - Hops (redirections) count -.br - %T - service specific Text -.br - %N1-N2T - (N1 and N2 are positive numbers) - log only fields from N1 thorugh N2 of service specific text -.br - in case of ODBC logging logformat specifies SQL statement, for exmample: -.br - logformat "-'+_Linsert into log (l_date, l_user, l_service, l_in, l_out, l_descr) values ('%d-%m-%Y %H:%M:%S', '%U', '%N', %I, %O, '%T')" - -.br -.B logdump - -.br - Immediately creates additional log records if given amount of incoming/outgoing -traffic is achieved for connection, without waiting for connection to finish. -It may be useful to prevent information about long-lasting downloads on server -shutdown. - -.br -.B archiver - -.br - Archiver to use for log files. is file extension produced by -archiver. Filename will be last argument to archiver, optionally you -can use %A as produced archive name and %F as filename. - -.br -.B timeouts - -.br - Sets timeout values -.br - BYTE_SHORT - short timeout for single byte, is usually used for receiving single byte from stream. -.br - BYTE_LONG - long timeout for single byte, is usually used for receiving first byte in frame (for example first byte in socks request). -.br - STRING_SHORT - short timeout, for character string within stream (for example to wait between 2 HTTP headers) -.br - STRING_LONG - long timeout, for first string in stream (for example to wait for HTTP request). -.br - CONNECTION_SHORT - inactivity timeout for short connections (HTTP, POP3, etc). -.br - CONNECTION_LONG - inactivity timeout for long connection (SOCKS, portmappers, etc). -.br - DNS - timeout for DNS request before requesting next server -.br - CHAIN - timeout for reading data from chained connection -.br - -.br -.B nserver -[:port][/tcp] -.br -Nameserver to use for name resolutions. If none specified -or name server fails system routines for name resolution will be -used. It's better to specify nserver because gethostbyname() may -be thread unsafe. Optional port number may be specified. -If optional /tcp is added to IP address, name resolution will be -performed over TCP. - -.br -.B nscache - -.B nscache6 - -.br - Cache records for name resolution (nscache for IPv4, -nscache6 for IPv6). Cachesize usually should be large enougth -(for example 65536). - -.br -.B nsrecord - -.br - Adds static record to nscache. nscache must be enabled. If 0.0.0.0 -is used as a hostaddr host will never resolve, it can be used to -blacklist something or together with -.B dialer -command to set up UDL for dialing. - -.br -.B fakeresolve -.br - All names are resolved to 127.0.0.2 address. Usefull if all requests are -redirected to parent proxy with http, socks4+, connect+ or socks5+. - -.br -.B dialer - -.br - Execute progname if external name can't be resolved. -Hint: if you use nscache, dialer may not work, because names will -be resolved through cache. In this case you can use something like -http://dial.right.now/ from browser to set up connection. - - -.br -.B internal - -.br - sets ip address of internal interface. This IP address will be used -to bind gateways. Alternatively you can use -i option for individual -gateways. Since 0.8 version, IPv6 address may be used. - -.br -.B external - -.br - sets ip address of external interface. This IP address will be source -address for all connections made by proxy. Alternatively you can use --e option to specify individual address for gateway. Since 0.8 version -External or -e can be given twice: once with IPv4 and once with IPv6 address. - -.br -.B maxconn - -.br - sets maximum number of simulationeous connections to each services -started after this command. Default is 100. - -.br -.B service -.br - (depricated). Indicates 3proxy to behave as Windows 95/98/NT/2000/XP -service, no effect for Unix. Not required for 3proxy 0.6 and above. If -you upgraded from previous version of 3proxy use --remove and --install -to reinstall service. - -.br -.B daemon -.br - Should be specified to close console. Do not use 'daemon' with 'service'. -At least under FreeBSD 'daemon' should preceed any proxy service -and log commands to avoid sockets problem. Always place it in the beginning -of the configuration file. - -.br -.B auth - [...] -.br - Type of user authorization. Currently supported: -.br - none - no authentication or authorization required. -.br - Note: is auth is none any ip based limitation, redirection, etc will not work. -This is default authentication type -.br - iponly - authentication by access control list with username ignored. - Appropriate for most cases -.br - useronly - authentication by username without checking for any password with -authorization by ACLs. Useful for e.g. SOCKSv4 proxy and icqpr (icqpr set UIN / -AOL screen name as a username) -.br - dnsname - authentication by DNS hostnname with authorization by ACLs. -DNS hostname is resolved via PTR (reverse) record and validated (resolved -name must resolve to same IP address). It's recommended to use authcache by -ip for this authentication. -NB: there is no any password check, name may be spoofed. -.br - strong - username/password authentication required. It will work with -SOCKSv5, FTP, POP3 and HTTP proxy. -.br - cache - cached authentication, may be used with 'authcache'. -.br - Plugins may add additional authentication types. -.br - - It's possible to use few authentication types in the same commands. E.g. -.br -auth iponly strong -.br - In this case 'strong' authentication will be used only in case resource -access can not be performed with 'iponly' authentication, that is username is -required in ACL. It's usefull to protect access to some resources with -password allowing passwordless access to another resources, or to use -IP-based authentication for dedicated laptops and request username/password for -shared ones. - -.br -.B authcache - -.br - Cache authentication information to given amount of time (cachetime) in seconds. -Cahtype is one of: -.br - ip - after successful authentication all connections during caching time -from same IP are assigned to the same user, username is not requested. -.br - ip,user username is requested and all connections from the same IP are -assigned to the same user without actual authentication. -.br - user - same as above, but IP is not checked. -.br - user,password - both username and password are checked against cached ones. -.br -Use auth type 'cache' for cached authentication - -.br -.B allow - - -.br -.B deny - - -.br - Access control entries. All lists are comma-separated, no spaces are -allowed. Usernames are case sensitive (if used with authtype nbname -username must be in uppercase). Source and target lists may contain -IP addresses (W.X.Y.Z), ranges A.B.C.D - W.X.Y.Z (since 0.8) or CIDRs -(W.X.Y.Z/L). Since 0.6, targetlist may also contain host names, -instead of addresses. It's possible to use wildmask in -the begginning and in the the end of hostname, e.g. *badsite.com or -*badcontent*. Hostname is only checked if hostname presents in request. -Targetportlist may contain ports (X) or port ranges lists (X-Y). For any field -* sign means "ANY" If access list is empty it's assumed to be -.br - allow * -.br - If access list is not empty last item in access list is assumed to be -.br - deny * -.br - You may want explicitly add "deny *" to the end of access list to prevent -HTTP proxy from requesting user's password. -Access lists are checked after user have requested any resource. -If you want 3proxy to reject connections from specific addresses -immediately without any conditions you should either bind proxy -to appropriate interface only or to use ip filters. -.br - -Operation is one of: -.br - CONNECT - establish outgoing TCP connection -.br - BIND - bind TCP port for listening -.br - UDPASSOC - make UDP association -.br - ICMPASSOC - make ICMP association (for future use) -.br - HTTP_GET - HTTP GET request -.br - HTTP_PUT - HTTP PUT request -.br - HTTP_POST - HTTP POST request -.br - HTTP_HEAD - HTTP HEAD request -.br - HTTP_CONNECT - HTTP CONNECT request -.br - HTTP_OTHER - over HTTP request -.br - HTTP - matches any HTTP request except HTTP_CONNECT -.br - HTTPS - same as HTTP_CONNECT -.br - FTP_GET - FTP get request -.br - FTP_PUT - FTP put request -.br - FTP_LIST - FTP list request -.br - FTP_DATA - FTP data connection. Note: FTP_DATA requires access to dynamic -non-ptivileged (1024-65535) ports on remote side. -.br - FTP - matches any FTP/FTP Data request -.br - ADMIN - access to administration interface -.br - Weeksdays are week days numbers or periods, 0 or 7 means Sunday, 1 is Monday, 1-5 means Monday through Friday. Timeperiodlists is a list of time -periods in HH:MM:SS-HH:MM:SS format. For example, 00:00:00-08:00:00,17:00:00-24:00:00 lists non-working hours. - -.br -.B parent - -.br - this command must follow "allow" rule. It extends last allow rule to -build proxy chain. Proxies may be grouped. Proxy inside the -group is selected randomly. If few groups are specified one proxy -is randomly picked from each group and chain of proxies is created -(that is second proxy connected through first one and so on). -Weight is used to group proxies. Weigt is a number between 1 and 1000. -Weights are summed and proxies are grouped together untill weight of -group is 1000. That is: -.br - allow * -.br - parent 500 socks5 192.168.10.1 1080 -.br - parent 500 connect 192.168.10.1 3128 -.br - makes 3proxy to randomly choose between 2 proxies for all outgoing -connections. These 2 proxies form 1 group (summarized weight is 1000). -.br - allow * * * 80 -.br - parent 1000 socks5 192.168.10.1 1080 -.br - parent 1000 connect 192.168.20.1 3128 -.br - parent 300 socks4 192.168.30.1 1080 -.br - parent 700 socks5 192.168.40.1 1080 -.br - creates chain of 3 proxies: 192.168.10.1, 192.168.20.1 and third -is (192.168.30.1 with probability of 0.3 or 192.168.40.1 -with probability of 0.7) for outgoing web connections. - -.br - type is one of: -.br - tcp - simply redirect connection. TCP is always last in chain. -.br - http - redirect to HTTP proxy. HTTP is always last chain. -.br - pop3 - redirect to POP3 proxy (only local redirection is supported, can not be -used for chaining) -.br - ftp - redirect to FTP proxy (only local redirection is supported, can not be -used for chaining) -.br - connect - parent is HTTP CONNECT method proxy -.br - connect+ - parent is HTTP CONNECT proxy with name resolution -.br - socks4 - parent is SOCKSv4 proxy -.br - socks4+ - parent is SOCKSv4 proxy with name resolution (SOCKSv4a) -.br - socks5 - parent is SOCKSv5 proxy -.br - socks5+ - parent is SOCKSv5 proxy with name resolution -.br - socks4b - parent is SOCKS4b (broken SOCKSv4 implementation with shortened -server reply. I never saw this kind ofservers byt they say there are). -Normally you should not use this option. Do not mess this option with -SOCKSv4a (socks4+). -.br - socks5b - parent is SOCKS5b (broken SOCKSv5 implementation with shortened -server reply. I think you will never find it useful). Never use this option -unless you know exactly you need it. -.br - admin - redirect request to local 'admin' service (with -s parameter). -.br - Use "+" proxy only with "fakeresolve" option -.br - - IP and port are ip addres and port of parent proxy server. -If IP is zero, ip is taken from original request, only port is changed. -If port is zero, it's taken from original request, only IP is changed. -If both IP and port are zero - it's a special case of local redirection, -it works only with -.B socks -proxy. In case of local redirection request is redirected to different service, -.B ftp -locally redirects to -.B ftppr -.B pop3 -locally redirects to -.B pop3p -.B http -locally redurects to -.B proxy -.B admin -locally redirects to admin -s service. -.br - - Main purpose of local redirections is to have requested resource -(URL or POP3 username) logged and protocol-specific filters to be applied. -In case of local redirection ACLs are revied twice: first, by SOCKS proxy up to -'parent' command and then with gateway service connection is -redirected (HTTP, FTP or POP3) after 'parent' command. It means, -additional 'allow' command is required for redirected requests, for -example: -.br - allow * * * 80 -.br - parent 1000 http 0.0.0.0 0 -.br - allow * * * 80 HTTP_GET,HTTP_POST -.br - socks -.br - redirects all SOCKS requests with target port 80 to local HTTP proxy, -local HTTP proxy parses requests and allows only GET and POST requests. -.br - parent 1000 http 1.2.3.4 0 -.br - Changes external address for given connection to 1.2.3.4 -(an equivalent to -e1.2.3.4) -.br - Optional username and password are used to authenticate on parent -proxy. Username of '*' means username must be supplied by user. - - -.br -.B nolog - -.br - extends last allow or deny command to prevent logging, e.g. -.br -allow * * 192.168.1.1 -.br -nolog - - -.br -.B weight - -.br - extends last allow or deny command to set weight for this request -.br - allow * * 192.168.1.1 -.br - weight 100 -.br - Weight may be used for different purposes. - -.br -.B bandlimin - -.br -.B nobandlimin - -.br -.B bandlimout - -.br -.B nobandlimout - -.br - bandlim sets bandwith limitation filter to bps (bits per second) -(if you want to specife bytes per second - multiply your value to 8). -bandlim rules act in a same manner as allow/deny rules except -one thing: bandwidth limiting is applied to all services, not to some -specific service. -bandlimin and nobandlimin applies to incoming traffic -bandlimout and nobandlimout applies to outgoing traffic -If tou want to ratelimit your clients with ip's 192.168.10.16/30 (4 -addresses) to 57600 bps you have to specify 4 rules like -.br - bandlimin 57600 * 192.168.10.16 -.br - bandlimin 57600 * 192.168.10.17 -.br - bandlimin 57600 * 192.168.10.18 -.br - bandlimin 57600 * 192.168.10.19 -.br - and every of you clients will have 56K channel. If you specify -.br - bandlimin 57600 * 192.168.10.16/30 -.br - you will have 56K channel shared between all clients. -if you want, for example, to limit all speed ecept access to POP3 you can use -.br - nobandlimin * * * 110 -.br - before the rest of bandlim rules. - -.br -.B counter - -.br -.B countin - -.br -.B nocountin - -.br -.B countout - -.br -.B nocountout - -.br - - counter, countin, nocountin, countout, noucountout commands are -used to set traffic limit -in MB for period of time (day, week or month). Filename is a path -to a special file where traffic information is permanently stored. -number is sequential number of record in this file. If number is 0 -no traffic information on this counter is saved in file (that is -if proxy restarted all information is loosed) overwise it should be -unique sequential number. -Type specifies a type of counter. Type is one of: -.br - H - counter is resetted hourly -.br - D - counter is resetted daily -.br - W - counter is resetted weekly -.br - M - counter is resetted monthely -.br - reporttype/repotname may be used to generate traffic reports. -Reporttype is one of D,W,M,H(hourly) and repotname specifies filename -template for reports. Report is text file with counter values in -format: -.br - -.br - The rest of parameters is identical to bandlim/nobandlim. - -.br -.B users -username[:pwtype:password] ... -.br - pwtype is one of: -.br - none (empty) - use system authentication -.br - CL - password is cleartext -.br - CR - password is crypt-style password -.br - NT - password is NT password (in hex) -.br - example: -.br - users test1:CL:password1 "test2:CR:$1$lFDGlder$pLRb4cU2D7GAT58YQvY49." -.br - users test3:NT:BD7DFBF29A93F93C63CB84790DA00E63 -.br - Note: double quotes are requiered because password contains $ sign. - -.br -.B flush -.br - empty active access list. Access list must be flushed avery time you creating -new access list for new service. For example: -.br - allow * -.br - pop3p -.br - flush -.br - allow * 192.168.1.0/24 -.br - socks -.br - sets different ACLs for -.B pop3p -and -.B socks - -.br -.B system - -.br - execute system command - -.br -.B pidfile - -.br - write pid of current process to file. It can be used to manipulate -3proxy with signals under Unix. Currently next signals are available: - -.br -.B monitor - -.br - If file monitored changes in modification time or size, 3proxy reloads -configuration within one minute. Any number of files may be monitored. - -.br -.B setuid - -.br - calls setuid(uid), uid must be numeric. Unix only. Warning: under some Linux -kernels setuid() works onle for current thread. It makes it impossible to suid -for all threads. - -.br -.B setgid - -.br - calls setgid(gid), gid must be numeric. Unix only. - -.br -.B chroot - -.br - calls chroot(path). Unix only. - -.br -.B stacksize - -.br - Change default size for threads stack. May be required in some situation, - e.g. with non-default plugins, on on some platforms (some FreeBSD version - may require adjusting stack size due to invalid defined value in system - header files, this value is also oftent reqruied to be changed for ODBC and - PAM support on Linux. If you experience 3proxy - crash on request processing, try to set some positive value. You may start with - stacksize 65536 - and then find the minimal value for service to work. If you experience - memory shortage, you can try to experiment with negative values. -.SH PLUGINS - -.br -.B plugin - [ ...] -.br - Loads specified library and calls given export function with given arguments, -as -.br - int functions_to_call(struct pluginlink * pl, int argc, char * argv[]); -.br - function_to_call must return 0 in case of success, value > 0 to indicate error. - -.br -.B filtermaxsize - -.br - If Content-length (or another data length) is greater than given value, no -data filtering will be performed thorugh filtering plugins to avoid data -corruption and/or Content-Length chaging. Default is 1MB (1048576). - -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), proxy(8), ftppr(8), socks(8), pop3p(8), tcppm(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH TRIVIA -3APA3A is pronounced as \`\`zaraza\'\'. -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/ftppr.8 b/man/ftppr.8 deleted file mode 100644 index 4a285e4..0000000 --- a/man/ftppr.8 +++ /dev/null @@ -1,87 +0,0 @@ -.TH ftppr "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B ftppr -\- FTP proxy gateway service -.SH SYNOPSIS -.BR "ftppr " [ -d ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -p port\fR] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.IB \fR[ -h default_ip[:port]\fR] -.SH DESCRIPTION -.B ftppr -is FTP gateway service to allow internal users to access external FTP -servers. -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -u -Never look for username authentication. -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -h -Default destination. It's used if targed address is not specified by user. -.TP -.B -p -Port. Port proxy listens for incoming connections. Default is 21. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH CLIENTS -You can use any FTP client, regardless of FTP proxy support. For client with -FTP proxy support configure -.I internal_ip -and -.IR port -in FTP proxy parameters. -For clients without FTP proxy support use -.I internal_ip -and -.IR port -as FTP server. Address of real FTP server must be configured as a part of -FTP username. Format for username is -.IR username \fB@ server , -where -.I server -is address of FTP server and -.I username -is user\'s login on this FTP server. Login itself may contain \'@\' sign. -Only cleartext authentication is currently supported. -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), proxy(8), pop3p(8), socks(8), tcppm(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/icqpr.8 b/man/icqpr.8 deleted file mode 100644 index b2e7fdc..0000000 --- a/man/icqpr.8 +++ /dev/null @@ -1,80 +0,0 @@ -.TH icqpr "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B icqpr -\- ICQ (AOL OSCAR) proxy -.SH SYNOPSIS -.BR "icqpr " [ -d ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.I local_port remote_host remote_port -.SH DESCRIPTION -.B icqpr -forwards ICQ connections from local to remote ICQ host. Most usual is -.B icqpr 5190 login.icq.com 5190 -Also, icqpr adds UIN / AOL screen name as a username. It makes it possible -to control user's access to ICQ/AOL by UIN/screen name (use -.B auth useronly -in 3proxy). -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH ARGUMENTS -.TP -.I local_port -- port icqpr accepts connection -.TP -.I remote_host -- IP address of the host connection is forwarded to -.TP -.I remote_port -- remote port connection is forwarded to -.SH CLIENTS -You can use any ICQ/AOL client where server address configuration is supported -or spoof login server name (e.g. login.icq.com) with IP address of proxy server -via DNS record or hosts file. Transparent redirection is also possible. Use -.I internal_ip -and -.I local_port -as a destination in client application. Connection is forwarded to -.IR remote_host : remote_port -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), proxy(8), ftppr(8), socks(8), pop3p(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/pop3p.8 b/man/pop3p.8 deleted file mode 100644 index 607c183..0000000 --- a/man/pop3p.8 +++ /dev/null @@ -1,83 +0,0 @@ -.TH pop3p "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B pop3p -\- POP3 proxy gateway service -.SH SYNOPSIS -.BR "pop3p " [ -d ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -p port\fR] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.IB \fR[ -h default_ip[:port]\fR] -.SH DESCRIPTION -.B pop3p -is POP3 gateway service to allow internal users to access external POP3 -servers. -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -u -Never look for username authentication. -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -p -Port. Port proxy listens for incoming connections. Default is 110. -.TP -.B -h -Default destination. It's used if targed address is not specified by user. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH CLIENTS -You can use any MUA (Mail User Agent) with POP3 support. Set client to use -.I internal_ip -and -.IR port -as a POP3 server. Address of real POP3 server must be configured as a part of -POP3 username. Format for username is -.IR username \fB@ server , -where -.I server -is address of POP3 server and -.I username -is user\'s login on this POP3 server. Login itself may contain \'@\' sign. -Only cleartext authentication is supported, because challenge-response -authentication (APOP, CRAM-MD5, etc) requires challenge from server before -we know which server to connect. -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), ftppr(8), proxy(8), socks(8), tcppm(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/proxy.8 b/man/proxy.8 deleted file mode 100644 index da11304..0000000 --- a/man/proxy.8 +++ /dev/null @@ -1,78 +0,0 @@ -.TH proxy "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B proxy -\- HTTP proxy gateway service -.SH SYNOPSIS -.BR "proxy " [ -d ][ -a ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -p port\fR] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.SH DESCRIPTION -.B proxy -is HTTP gateway service with HTTPS and FTP over HTTPS support. -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -u -Never ask for username authentication -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -a -Anonymous. Hide information about client. -.TP -.B -a1 -Anonymous. Show fake information about client. -.TP -.B -p -Port. Port proxy listens for incoming connections. Default is 3128. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH CLIENTS -You should use client with HTTP proxy support or configure router to redirect -HTTP traffic to proxy (transparent proxy). Configure client to connect to -.I internal_ip -and -.IR port . -HTTPS support allows to use almost any TCP based protocol. If you need to -limit clients, use -.BR 3proxy (8) -instead. -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), ftppr(8), socks(8), pop3p(8), tcppm(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/smtpp.8 b/man/smtpp.8 deleted file mode 100644 index 16a0ed7..0000000 --- a/man/smtpp.8 +++ /dev/null @@ -1,84 +0,0 @@ -.TH smtpp "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B smtpp -\- SMTP proxy gateway service -.SH SYNOPSIS -.BR "smtpp " [ -d ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -p port\fR] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.IB \fR[ -h default_ip[:port]\fR] -.SH DESCRIPTION -.B smtpp -is SMTP gateway service to allow internal users to access external SMTP -servers. -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -u -Never look for username authentication. -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -p -Port. Port proxy listens for incoming connections. Default is 25. -.TP -.B -h -Default destination. It's used if targed address is not specified by user. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH CLIENTS -You can use any MUA (Mail User Agent) with SMTP authentication support. -Set client to use -.I internal_ip -and -.IR port -as a SMTP server. Address of real SMTP server must be configured as a part of -SMTP username. Format for username is -.IR username \fB@ server , -where -.I server -is address of SMTP server and -.I username -is user\'s login on this SMTP server. Login itself may contain \'@\' sign. -Only cleartext authentication is supported, because challenge-response -authentication (CRAM-MD5, SPA, etc) requires challenge from server before -we know which server to connect. -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), ftppr(8), proxy(8), socks(8), tcppm(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/socks.8 b/man/socks.8 deleted file mode 100644 index 993cf1d..0000000 --- a/man/socks.8 +++ /dev/null @@ -1,79 +0,0 @@ -.TH socks "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B socks -\- SOCKS 4/4.5/5 gateway service -.SH SYNOPSIS -.BR "socks " [ -d ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -p port\fR] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.SH DESCRIPTION -.B socks -is SOCKS server. It supports SOCKSv4, SOCKSv4.5 (extension to v4 for -server side name resolution) and SOCKSv5. SOCKSv5 specification allows both -outgoing and reverse TCP connections and UDP portmapping. -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -u -Never ask for username authentication -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. External IP must be specified if you need incoming connections. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -p -Port. Port proxy listens for incoming connections. Default is 1080. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH CLIENTS -You should use client with SOCKS support or use some socksification support -(for example -.I SocksCAP -or -.IR FreeCAP ). -Configure client to use -.I internal_ip -and -.IR port . -SOCKS allows to use almost any application protocol without limitation. This -implementation also allows to open priviledged port on server (if socks has -sufficient privileges). If you need to control access use -.BR 3proxy (8) -instead. -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), proxy(8), ftppr(8), pop3p(8), tcppm(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/tcppm.8 b/man/tcppm.8 deleted file mode 100644 index cb40876..0000000 --- a/man/tcppm.8 +++ /dev/null @@ -1,73 +0,0 @@ -.TH tcppm "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B tcppm -\- TCP port mapper -.SH SYNOPSIS -.BR "tcppm " [ -d ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.I local_port remote_host remote_port -.SH DESCRIPTION -.B tcppm -forwards connections from local to remote TCP port -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -e -External address. IP address of interface proxy should initiate connections -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts connections to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH ARGUMENTS -.TP -.I local_port -- port tcppm accepts connection -.TP -.I remote_host -- IP address of the host connection is forwarded to -.TP -.I remote_port -- remote port connection is forwarded to -.SH CLIENTS -Any TCP based application can be used as a client. Use -.I internal_ip -and -.I local_port -as a destination in client application. Connection is forwarded to -.IR remote_host : remote_port -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), proxy(8), ftppr(8), socks(8), pop3p(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/man/udppm.8 b/man/udppm.8 deleted file mode 100644 index 1b18b5d..0000000 --- a/man/udppm.8 +++ /dev/null @@ -1,79 +0,0 @@ -.TH udppm "8" "January 2016" "3proxy 0.8" "Universal proxy server" -.SH NAME -.B udppm -\- UDP port mapper -.SH SYNOPSIS -.BR "pop3p " [ -ds ] -.IB \fR[ -l \fR[ \fR[ @ \fR] logfile \fR]] -.IB \fR[ -i internal_ip\fR] -.IB \fR[ -e external_ip\fR] -.I local_port remote_host remote_port -.SH DESCRIPTION -.B udppm -forwards datagrams from local to remote UDP port -.SH OPTIONS -.TP -.B -I -Inetd mode. Standalone service only. -.TP -.B -d -Daemonise. Detach service from console and run in the background. -.TP -.B -t -Be silenT. Do not log start/stop/accept error records. -.TP -.B -e -External address. IP address of interface proxy should initiate datagrams -from. -By default system will deside which address to use in accordance -with routing table. -.TP -.B -i -Internal address. IP address proxy accepts datagrams to. -By default connection to any interface is accepted. It\'s usually unsafe. -.TP -.B -l -Log. By default logging is to stdout. If -.I logfile -is specified logging is to file. Under Unix, if -.RI \' @ \' -preceeds -.IR logfile , -syslog is used for logging. -.TP -.B -s -Single packet. By default only one client can use udppm service, but -if -s is specified only one packet will be forwarded between client and server. -It allows to share service between multiple clients for single packet services -(for example name lookups). -.TP -.B -S -Increase or decrease stack size. You may want to try something like -S8192 if you experience 3proxy -crashes. -.SH ARGUMENTS -.TP -.I local_port -- port udppm accepts datagrams -.TP -.I remote_host -- IP address of the host datagrams are forwarded to -.TP -.I remote_port -- remote port datagrams are forwarded to -.SH CLIENTS -Any UDP based application can be used as a client. Use -.I internal_ip -and -.I local_port -as a destination in client application. All datagrams are forwarded to -.IR remote_host : remote_port -.SH BUGS -Report all bugs to -.BR 3proxy@3proxy.ru -.SH SEE ALSO -3proxy(8), proxy(8), ftppr(8), socks(8), pop3p(8), udppm(8), syslogd(8), -.br -http://3proxy.ru/ -.SH AUTHORS -3proxy is designed by Vladimir 3APA3A Dubrovin -.RI ( 3proxy@3proxy.ru ) diff --git a/scripts/3proxy.cfg b/scripts/3proxy.cfg deleted file mode 100644 index a2d7a06..0000000 --- a/scripts/3proxy.cfg +++ /dev/null @@ -1,32 +0,0 @@ -#!/usr/local/etc/3proxy/bin/3proxy -daemon -pidfile /usr/local/etc/3proxy/3proxy.pid -nscache 65536 -nserver 127.0.0.1 - -config /usr/local/etc/3proxy/3proxy.cfg -monitor /usr/local/etc/3proxy/3proxy.cfg -monitor /usr/local/etc/3proxy/counters -monitor /usr/local/etc/3proxy/passwd -monitor /usr/local/etc/3proxy/bandlimiters - -log /usr/local/etc/3proxy/log/log D -rotate 60 -counter /usr/local/etc/3proxy/3proxy.3cf - -users $/usr/local/etc/3proxy/passwd - -include /usr/local/etc/3proxy/counters -include /usr/local/etc/3proxy/bandlimiters - -auth strong -deny * * 127.0.0.1 -allow * -proxy -n -socks -flush -allow admin - -admin -p8080 - - diff --git a/scripts/add3proxyuser.sh b/scripts/add3proxyuser.sh deleted file mode 100644 index bd63a98..0000000 --- a/scripts/add3proxyuser.sh +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -if [ $4 ]; then - echo $1:`/usr/local/etc/3proxy/bin/mycrypt $$ $2` >> /usr/local/etc/3proxy/passwd - echo countin \"`wc -l /usr/local/etc/3proxy/counters|awk '{print $1}'`/$1\" D $3 $1 >> /usr/local/etc/3proxy/counters - echo bandlimin $4 $1 >> /usr/local/etc/3proxy/bandlimiters -else - echo usage: $0 username password day_limit bandwidth - echo " "day_limit - traffic limit in MB per day - echo " "bandwidth - bandwith in bits per second 1048576 = 1Mbps -fi diff --git a/scripts/install-unix.sh b/scripts/install-unix.sh deleted file mode 100644 index a165550..0000000 --- a/scripts/install-unix.sh +++ /dev/null @@ -1,21 +0,0 @@ -#!/bin/sh -cd .. -cp Makefile.unix Makefile -make -if [ ! -d /usr/local/etc/3proxy/bin ]; then mkdir -p /usr/local/etc/3proxy/bin/; fi -install src/3proxy /usr/local/etc/3proxy/bin/3proxy -install src/mycrypt /usr/local/etc/3proxy/bin/mycrypt -install scripts/rc.d/proxy.sh /usr/local/etc/rc.d/proxy.sh -install scripts/add3proxyuser.sh /usr/local/etc/3proxy/bin/ -if [ -s /usr/local/etc/3proxy/3proxy.cfg ]; then - echo /usr/local/etc/3proxy/3proxy.cfg already exists -else - install scripts/3proxy.cfg /usr/local/etc/3proxy/ - if [ ! -d /var/log/3proxy/ ]; then - mkdir /var/log/3proxy/ - fi - touch /usr/local/etc/3proxy/passwd - touch /usr/local/etc/3proxy/counters - touch /usr/local/etc/3proxy/bandlimiters - echo Run /usr/local/etc/3proxy/bin/add3proxyuser.sh to add \'admin\' user -fi diff --git a/scripts/rc.d/proxy.sh b/scripts/rc.d/proxy.sh deleted file mode 100644 index c157486..0000000 --- a/scripts/rc.d/proxy.sh +++ /dev/null @@ -1,48 +0,0 @@ -#!/bin/sh -# -# chkconfig: 2345 20 80 -# description: 3proxy tiny proxy server -# -# -# -# - -case "$1" in - start) - echo Starting 3Proxy - - /usr/local/etc/3proxy/bin/3proxy /usr/local/etc/3proxy/3proxy.cfg - - RETVAL=$? - echo - [ $RETVAL ] - ;; - - stop) - echo Stopping 3Proxy - if [ /usr/local/etc/3proxy/3proxy.pid ]; then - /bin/kill `cat /usr/local/etc/3proxy/3proxy.pid` - else - /usr/bin/killall 3proxy - fi - - RETVAL=$? - echo - [ $RETVAL ] - ;; - - restart|reload) - echo Reloading 3Proxy - if [ /usr/local/etc/3proxy/3proxy.pid ]; then - /bin/kill -s USR1 `cat /usr/local/etc/3proxy/3proxy.pid` - else - /usr/bin/killall -s USR1 3proxy - fi - ;; - - - *) - echo Usage: $0 "{start|stop|restart}" - exit 1 -esac -exit 0 \ No newline at end of file diff --git a/src/3proxy.c b/src/3proxy.c deleted file mode 100644 index 09cf607..0000000 --- a/src/3proxy.c +++ /dev/null @@ -1,561 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" -#ifndef _WIN32 -#include -#ifndef NOPLUGINS -#include -#endif -#endif - -#ifndef DEFAULTCONFIG -#define DEFAULTCONFIG conf.stringtable[25] -#endif - -FILE * confopen(); -extern unsigned char *strings[]; -extern FILE *writable; -extern struct counter_header cheader; -extern struct counter_record crecord; - - - -time_t basetime = 0; - -void doschedule(void); - - -#ifdef _WIN32 -OSVERSIONINFO osv; -int service = 0; - -void cyclestep(void); -#ifndef _WINCE -SERVICE_STATUS_HANDLE hSrv; -DWORD dwCurrState; -int SetStatus( DWORD dwState, DWORD dwExitCode, DWORD dwProgress ) -{ - SERVICE_STATUS srvStatus; - srvStatus.dwServiceType = SERVICE_WIN32_OWN_PROCESS; - srvStatus.dwCurrentState = dwCurrState = dwState; - srvStatus.dwControlsAccepted = SERVICE_ACCEPT_STOP | SERVICE_ACCEPT_PAUSE_CONTINUE | SERVICE_ACCEPT_SHUTDOWN; - srvStatus.dwWin32ExitCode = dwExitCode; - srvStatus.dwServiceSpecificExitCode = 0; - srvStatus.dwCheckPoint = dwProgress; - srvStatus.dwWaitHint = 3000; - return SetServiceStatus( hSrv, &srvStatus ); -} - -void __stdcall CommandHandler( DWORD dwCommand ) -{ - switch( dwCommand ) - { - case SERVICE_CONTROL_STOP: - case SERVICE_CONTROL_SHUTDOWN: - SetStatus( SERVICE_STOP_PENDING, 0, 1 ); - conf.timetoexit = 1; - conf.paused++; - Sleep(2000); - SetStatus( SERVICE_STOPPED, 0, 0 ); -#ifndef NOODBC - pthread_mutex_lock(&log_mutex); - close_sql(); - pthread_mutex_unlock(&log_mutex); -#endif - break; - case SERVICE_CONTROL_PAUSE: - SetStatus( SERVICE_PAUSE_PENDING, 0, 1 ); - conf.paused++; - SetStatus( SERVICE_PAUSED, 0, 0 ); - break; - case SERVICE_CONTROL_CONTINUE: - SetStatus( SERVICE_CONTINUE_PENDING, 0, 1 ); - conf.needreload = 1; - SetStatus( SERVICE_RUNNING, 0, 0 ); - break; - default: ; - } -} - - -void __stdcall ServiceMain(int argc, unsigned char* argv[] ) -{ - - hSrv = RegisterServiceCtrlHandler((LPCSTR)conf.stringtable[1], (LPHANDLER_FUNCTION)CommandHandler); - if( hSrv == 0 ) return; - - SetStatus( SERVICE_START_PENDING, 0, 1 ); - SetStatus( SERVICE_RUNNING, 0, 0 ); - cyclestep(); -} -#endif - -#else - - -void mysigusr1 (int sig){ - conf.needreload = 1; -} - -int even = 0; - -void mysigpause (int sig){ - - conf.paused++; - even = !even; - if(!even){ - conf.needreload = 1; - } -} - -void mysigterm (int sig){ - conf.paused++; - usleep(999*SLEEPTIME); - usleep(999*SLEEPTIME); -#ifndef NOODBC - pthread_mutex_lock(&log_mutex); - close_sql(); - pthread_mutex_unlock(&log_mutex); -#endif - conf.timetoexit = 1; -} - -#endif - -void dumpmem(void); - -struct schedule *schedule; - - -int wday = 0; - -int timechanged (time_t oldtime, time_t newtime, ROTATION lt){ - struct tm tmold; - struct tm *tm; - tm = localtime(&oldtime); - tmold = *tm; - tm = localtime(&newtime); - switch(lt){ - case MINUTELY: - if(tm->tm_min != tmold.tm_min)return 1; - break; - case HOURLY: - if(tm->tm_hour != tmold.tm_hour)return 1; - break; - case DAILY: - if(tm->tm_yday != tmold.tm_yday)return 1; - break; - case MONTHLY: - if(tm->tm_mon != tmold.tm_mon)return 1; - break; - case ANNUALLY: - if(tm->tm_year != tmold.tm_year)return 1; - break; - case WEEKLY: - if(((newtime - oldtime) > (60*60*24*7)) - || tm->tm_wday < tmold.tm_wday - || (tm->tm_wday == tmold.tm_wday && (newtime - oldtime) > (60*60*24*6)) - )return 1; - break; - default: - break; - } - return 0; -} - -void doschedule(void){ - struct schedule *sched, *prevsched = NULL, *nextsched; - int res; - - conf.time = time(0); - for(sched=schedule; sched; sched=sched->next){ - if(conf.needreload || conf.timetoexit || (conf.time > sched->start_time && timechanged(sched->start_time, conf.time, sched->type))){ - sched->start_time = conf.time; - nextsched = sched->next; - res = (*sched->function)(sched->data); - switch(res){ - case 1: - if(prevsched) prevsched->next = nextsched; - else schedule = nextsched; - break; - } - } - prevsched = sched; - } -} - -void dumpcounters(struct trafcount *tlin, int counterd){ - - unsigned char tmpbuf[8192]; - struct trafcount *tl; - if(counterd >= 0 && tlin) { - - conf.time = time(0); - if(cheader.updated && conf.countertype && timechanged(cheader.updated, conf.time, conf.countertype)){ - FILE * cfp; - - cfp = fopen((char *)dologname(tmpbuf, (unsigned char *)conf.counterfile, NULL, conf.countertype, cheader.updated), "w"); - if(cfp){ - for(tl = tlin; cfp && tl; tl = tl->next){ - if(tl->type >= conf.countertype) - fprintf(cfp, "%05d %020"PRINTF_INT64_MODIFIER"u%s%s\n", tl->number, tl->traf64, tl->comment?" #" : "", tl->comment? tl->comment : ""); - } - fclose(cfp); - } - } - - - cheader.updated = conf.time; - lseek(counterd, 0, SEEK_SET); - write(counterd, &cheader, sizeof(struct counter_header)); - for(tl=tlin; tl; tl = tl->next){ - if(tl->number){ - lseek(counterd, - sizeof(struct counter_header) + (tl->number - 1) * sizeof(struct counter_record), - SEEK_SET); - crecord.traf64 = tl->traf64; - crecord.cleared = tl->cleared; - crecord.updated = tl->updated; - write(counterd, &crecord, sizeof(struct counter_record)); - } - if(tl->type!=NEVER && timechanged(tl->cleared, conf.time, tl->type)){ - tl->cleared = conf.time; - tl->traf64 = 0; - } - } - } -} - -void cyclestep(void){ - struct tm *tm; - time_t minutecounter; - unsigned char tmpbuf[8192]; - - minutecounter = time(0); - for(;;){ - usleep(SLEEPTIME*999); - - conf.time = time(0); - if(conf.needreload) { - doschedule(); - reload(); - conf.needreload = 0; - } - doschedule(); - if(conf.stdlog)fflush(conf.stdlog); - if(timechanged(minutecounter, conf.time, MINUTELY)) { - struct filemon *fm; - struct stat sb; - - for(fm=conf.fmon; fm; fm=fm->next){ - if(!stat(fm->path, &sb)){ - if(fm->sb.st_mtime != sb.st_mtime || fm->sb.st_size != sb.st_size){ - stat(fm->path, &fm->sb); - conf.needreload = 1; - } - } - } - - } - if(timechanged(basetime, conf.time, DAILY)) { - tm = localtime(&conf.time); - wday = (1 << tm->tm_wday); - tm->tm_hour = tm->tm_min = tm->tm_sec = 0; - basetime = mktime(tm); - } - if(conf.logname) { - if(timechanged(conf.logtime, conf.time, conf.logtype)) { - FILE *fp; - fp = fopen((char *)dologname (tmpbuf, conf.logname, NULL, conf.logtype, conf.time), "a"); - if (fp) { - pthread_mutex_lock(&log_mutex); - fclose(conf.stdlog); - conf.stdlog = fp; - pthread_mutex_unlock(&log_mutex); - } - fseek(stdout, 0L, SEEK_END); - usleep(SLEEPTIME); - conf.logtime = conf.time; - if(conf.logtype != NONE && conf.rotate) { - int t; - t = 1; - switch(conf.logtype){ - case ANNUALLY: - t = t * 12; - case MONTHLY: - t = t * 4; - case WEEKLY: - t = t * 7; - case DAILY: - t = t * 24; - case HOURLY: - t = t * 60; - case MINUTELY: - t = t * 60; - default: - break; - } - dologname (tmpbuf, conf.logname, (conf.archiver)?conf.archiver[1]:NULL, conf.logtype, (conf.logtime - t * conf.rotate)); - remove ((char *) tmpbuf); - if(conf.archiver) { - int i; - *tmpbuf = 0; - for(i = 2; i < conf.archiverc && strlen((char *)tmpbuf) < 512; i++){ - strcat((char *)tmpbuf, " "); - if(!strcmp((char *)conf.archiver[i], "%A")){ - strcat((char *)tmpbuf, "\""); - dologname (tmpbuf + strlen((char *)tmpbuf), conf.logname, conf.archiver[1], conf.logtype, (conf.logtime - t)); - strcat((char *)tmpbuf, "\""); - } - else if(!strcmp((char *)conf.archiver[i], "%F")){ - strcat((char *)tmpbuf, "\""); - dologname (tmpbuf+strlen((char *)tmpbuf), conf.logname, NULL, conf.logtype, (conf.logtime-t)); - strcat((char *)tmpbuf, "\""); - } - else - strcat((char *)tmpbuf, (char *)conf.archiver[i]); - } - system((char *)tmpbuf+1); - } - } - } - } - if(conf.counterd >= 0 && conf.trafcounter) { - if(timechanged(cheader.updated, conf.time, MINUTELY)){ - dumpcounters(conf.trafcounter, conf.counterd); - } - } - if(conf.timetoexit){ - conf.paused++; - doschedule(); - usleep(SLEEPTIME*999); - usleep(SLEEPTIME*999); - usleep(SLEEPTIME*999); - return; - } - - } -} - - -#define RETURN(x) {res = x; goto CLEARRETURN;} - - - -#ifndef _WINCE -int main(int argc, char * argv[]) { -#else -int WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLine, int nCmdShow){ - int argc; - char ** argv; - WNDCLASS wc; - HWND hwnd = 0; -#endif - - int res = 0; - FILE * fp = NULL; - -#ifdef _WIN32 - unsigned char * arg; - WSADATA wd; - unsigned char tmpbuf[8192]; - - WSAStartup(MAKEWORD( 1, 1 ), &wd); - osv.dwOSVersionInfoSize = sizeof(osv); - GetVersionEx(&osv); -#endif - - -#ifdef _WINCE - argc = ceparseargs((char *)lpCmdLine); - argv = ceargv; - if(FindWindow(L"3proxy", L"3proxy")) return 0; - ZeroMemory(&wc,sizeof(wc)); - wc.hbrBackground=(HBRUSH)GetStockObject(BLACK_BRUSH); - wc.hInstance=hInstance; - wc.hCursor=LoadCursor(NULL,IDC_ARROW); - wc.lpfnWndProc=DefWindowProc; - wc.style=CS_HREDRAW|CS_VREDRAW; - wc.lpszClassName=L"3proxy"; - RegisterClass(&wc); - - hwnd = CreateWindowEx(0,L"3proxy",L"3proxy",WS_VISIBLE|WS_POPUP,0,0,0,0,0,0,hInstance,0); -#endif - - conf.stringtable = strings; -#ifdef _WIN32 -#ifndef _WINCE - if((argc == 2 || argc == 3)&& !strcmp((char *)argv[1], "--install")) { - - sprintf((char *)tmpbuf, "%s will be installed and started.\n" - "By clicking Yes you confirm you read and accepted License Agreement.\n" - "You can use Administration/Services to control %s service.", - conf.stringtable[1], conf.stringtable[2]); - if(MessageBox(NULL, (LPCSTR)tmpbuf, (LPCSTR)conf.stringtable[2], MB_YESNO|MB_ICONASTERISK) != IDYES) return 1; - - - *tmpbuf = '\"'; - if (!(res = SearchPath(NULL, argv[0], ".exe", 256, (char *)tmpbuf+1, (LPTSTR*)&arg))) { - perror("Failed to find executable filename"); - RETURN(102); - } - strcat((char *)tmpbuf, "\" \""); - if(!(res = GetFullPathName ((argc == 3)?argv[2]:(char*)DEFAULTCONFIG, 256, (char *)tmpbuf+res+4, (char **)&arg))){ - perror("Failed to find config filename"); - RETURN(103); - } - strcat((char *)tmpbuf, "\" --service"); - if(osv.dwPlatformId == VER_PLATFORM_WIN32_NT){ - SC_HANDLE sch; - - if(!(sch = OpenSCManager(NULL, NULL, GENERIC_WRITE|SERVICE_START ))){ - perror("Failed to open Service Manager"); - RETURN(101); - } - if (!(sch = CreateService(sch, (LPCSTR)conf.stringtable[1], (LPCSTR)conf.stringtable[2], GENERIC_EXECUTE, SERVICE_WIN32_OWN_PROCESS, SERVICE_AUTO_START, SERVICE_ERROR_IGNORE, (char *)tmpbuf, NULL, NULL, NULL, NULL, NULL))){ - perror("Failed to create service"); - RETURN(103); - } - if (!StartService(sch, 0, NULL)) { - perror("Failed to start service"); - RETURN(103); - } - } - else { - HKEY runsrv; - - if(RegOpenKeyEx( HKEY_LOCAL_MACHINE, - "Software\\Microsoft\\Windows\\CurrentVersion\\RunServices", - 0, - KEY_ALL_ACCESS, - &runsrv) != ERROR_SUCCESS){ - perror("Failed to open registry"); - RETURN(104); - } - if(RegSetValueEx( runsrv, - (LPCSTR)conf.stringtable[1], - 0, - REG_EXPAND_SZ, - (BYTE *)tmpbuf, - (int)strlen((char *)tmpbuf)+1)!=ERROR_SUCCESS){ - perror("Failed to set registry value"); - RETURN(105); - } - - } - return 0; - } - if((argc == 2 || argc == 3)&& !strcmp((char *)argv[1], "--remove")) { - - if(osv.dwPlatformId == VER_PLATFORM_WIN32_NT){ - SC_HANDLE sch; - - if(!(sch = OpenSCManager(NULL, NULL, GENERIC_WRITE))){ - perror("Failed to open Service Manager\n"); - RETURN(106); - } - if (!(sch = OpenService(sch, (LPCSTR)conf.stringtable[1], DELETE))){ - perror("Failed to open service"); - RETURN(107); - } - if (!DeleteService(sch)){ - perror("Failed to delete service"); - RETURN(108); - } - } - else { - HKEY runsrv; - if(RegOpenKeyEx( HKEY_LOCAL_MACHINE, - "Software\\Microsoft\\Windows\\CurrentVersion\\RunServices", - 0, - KEY_ALL_ACCESS, - &runsrv) != ERROR_SUCCESS){ - perror("Failed to open registry"); - RETURN(109); - } - if(RegDeleteValue(runsrv, (LPCSTR)conf.stringtable[1]) != ERROR_SUCCESS){ - perror("Failed to clear registry"); - RETURN(110); - } - } - RETURN(0); - } - if(argc==3 && !strcmp(argv[2], "--service")){ - service = 1; - argc = 2; - } -#endif -#endif - conf.conffile = mystrdup((argc==2)?argv[1]:(char*)DEFAULTCONFIG); - if(conf.conffile && *conf.conffile != '-') { - fp = confopen(); -#ifndef _WIN32 - if(!fp) fp = stdin; -#endif - } - if(argc > 2 || !(fp)) { - - fprintf(stderr, "Usage: %s [conffile]\n", argv[0]); -#ifdef _WIN32 - fprintf(stderr, "\n\t%s --install [conffile]\n\tto install as service\n" - "\n\t%s --remove\n\tto remove service\n", argv[0], argv[0]); -#else - fprintf(stderr, "\n if conffile is missing, configuration is expected from stdin\n"); -#endif - fprintf(stderr, "\n%s %s\n%s\n", conf.stringtable[2], conf.stringtable[3], copyright); - - return 1; - } - - pthread_mutex_init(&config_mutex, NULL); - pthread_mutex_init(&bandlim_mutex, NULL); - pthread_mutex_init(&hash_mutex, NULL); - pthread_mutex_init(&tc_mutex, NULL); - pthread_mutex_init(&pwl_mutex, NULL); - pthread_mutex_init(&log_mutex, NULL); - - freeconf(&conf); - res = readconfig(fp); - conf.version++; - - if(res) RETURN(res); - if(!writable)fclose(fp); - -#ifdef _WIN32 - -#ifndef _WINCE - if(service){ - SERVICE_TABLE_ENTRY ste[] = - { - { (LPSTR)conf.stringtable[1], (LPSERVICE_MAIN_FUNCTION)ServiceMain}, - { NULL, NULL } - }; - if(!StartServiceCtrlDispatcher( ste ))cyclestep(); - } - else -#endif - { - cyclestep(); - } - - -#else - signal(SIGCONT, mysigpause); - signal(SIGTERM, mysigterm); - signal(SIGUSR1, mysigusr1); - signal(SIGPIPE, SIG_IGN); - cyclestep(); - -#endif - -CLEARRETURN: - - return 0; - -} diff --git a/src/Makefile.inc b/src/Makefile.inc index 69724fa..4c9c876 100644 --- a/src/Makefile.inc +++ b/src/Makefile.inc @@ -2,7 +2,7 @@ # 3 proxy common Makefile # -all: $(BUILDDIR)3proxy$(EXESUFFICS) $(BUILDDIR)mycrypt$(EXESUFFICS) $(BUILDDIR)dighosts$(EXESUFFICS) $(BUILDDIR)pop3p$(EXESUFFICS) $(BUILDDIR)smtpp$(EXESUFFICS) $(BUILDDIR)ftppr$(EXESUFFICS) $(BUILDDIR)tcppm$(EXESUFFICS) $(BUILDDIR)icqpr$(EXESUFFICS) $(BUILDDIR)udppm$(EXESUFFICS) $(BUILDDIR)socks$(EXESUFFICS) $(BUILDDIR)proxy$(EXESUFFICS) allplugins +all: $(BUILDDIR)proxy$(EXESUFFICS) sockmap$(OBJSUFFICS): sockmap.c proxy.h structures.h @@ -14,149 +14,25 @@ common$(OBJSUFFICS): common.c proxy.h structures.h myalloc$(OBJSUFFICS): myalloc.c proxy.h structures.h $(CC) $(CFLAGS) myalloc.c -plugins$(OBJSUFFICS): plugins.c proxy.h structures.h - $(CC) $(CFLAGS) plugins.c - base64$(OBJSUFFICS): base64.c $(CC) $(CFLAGS) base64.c ftp$(OBJSUFFICS): ftp.c proxy.h structures.h $(CC) $(CFLAGS) ftp.c -#$(COMPATLIBS): -# $(CC) $(CFLAGS) strncasecmp.c - sockgetchar$(OBJSUFFICS): sockgetchar.c proxy.h structures.h $(CC) $(CFLAGS) sockgetchar.c proxy$(OBJSUFFICS): proxy.c proxy.h structures.h proxymain.c $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)NOPORTMAP $(DEFINEOPTION)ANONYMOUS proxy.c -pop3p$(OBJSUFFICS): pop3p.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)NOPORTMAP pop3p.c - -smtpp$(OBJSUFFICS): smtpp.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)NOPORTMAP smtpp.c - -ftppr$(OBJSUFFICS): ftppr.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)NOPORTMAP ftppr.c - -tcppm$(OBJSUFFICS): tcppm.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)PORTMAP tcppm.c - -icqpr$(OBJSUFFICS): icqpr.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)PORTMAP icqpr.c - -socks$(OBJSUFFICS): socks.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)NOPORTMAP socks.c - -udppm$(OBJSUFFICS): udppm.c proxy.h structures.h proxymain.c - $(CC) $(CFLAGS) $(DEFINEOPTION)WITHMAIN $(DEFINEOPTION)PORTMAP udppm.c - -3proxy$(OBJSUFFICS): 3proxy.c proxy.h structures.h - $(CC) $(CFLAGS) 3proxy.c - $(BUILDDIR)proxy$(EXESUFFICS): sockmap$(OBJSUFFICS) proxy$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) base64$(OBJSUFFICS) ftp$(OBJSUFFICS) $(COMPATLIBS) $(LN) $(LNOUT)$(BUILDDIR)proxy$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) proxy$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) base64$(OBJSUFFICS) ftp$(OBJSUFFICS) $(COMPATLIBS) $(LIBS) -$(BUILDDIR)pop3p$(EXESUFFICS): sockmap$(OBJSUFFICS) pop3p$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(COMPATLIBS) - $(LN) $(LNOUT)$(BUILDDIR)pop3p$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) pop3p$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(COMPATLIBS) $(LIBS) - -$(BUILDDIR)smtpp$(EXESUFFICS): sockmap$(OBJSUFFICS) smtpp$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) base64$(OBJSUFFICS) $(COMPATLIBS) - $(LN) $(LNOUT)$(BUILDDIR)smtpp$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) smtpp$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) base64$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(COMPATLIBS) $(LIBS) - -$(BUILDDIR)ftppr$(EXESUFFICS): sockmap$(OBJSUFFICS) ftppr$(OBJSUFFICS) ftp$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(COMPATLIBS) - $(LN) $(LNOUT)$(BUILDDIR)ftppr$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) ftppr$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) ftp$(OBJSUFFICS) $(COMPATLIBS) $(LIBS) - -$(BUILDDIR)socks$(EXESUFFICS): sockmap$(OBJSUFFICS) socks$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) - $(LN) $(LNOUT)$(BUILDDIR)socks$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) socks$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(LIBS) - -$(BUILDDIR)tcppm$(EXESUFFICS): sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) tcppm$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) - $(LN) $(LNOUT)$(BUILDDIR)tcppm$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) tcppm$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(LIBS) - -$(BUILDDIR)icqpr$(EXESUFFICS): sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) icqpr$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) - $(LN) $(LNOUT)$(BUILDDIR)icqpr$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) icqpr$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(LIBS) - -$(BUILDDIR)udppm$(EXESUFFICS): sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) udppm$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) - $(LN) $(LNOUT)$(BUILDDIR)udppm$(EXESUFFICS) $(LDFLAGS) sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) udppm$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(LIBS) - mainfunc$(OBJSUFFICS): proxy.h structures.h proxymain.c $(CC) $(COUT)mainfunc$(OBJSUFFICS) $(CFLAGS) $(DEFINEOPTION)MODULEMAINFUNC=mainfunc proxymain.c -srvproxy$(OBJSUFFICS): proxy.c proxy.h structures.h - $(CC) $(COUT)srvproxy$(OBJSUFFICS) $(CFLAGS) proxy.c - -srvpop3p$(OBJSUFFICS): pop3p.c proxy.h structures.h - $(CC) $(COUT)srvpop3p$(OBJSUFFICS) $(CFLAGS) pop3p.c - -srvsmtpp$(OBJSUFFICS): smtpp.c proxy.h structures.h - $(CC) $(COUT)srvsmtpp$(OBJSUFFICS) $(CFLAGS) smtpp.c - -srvftppr$(OBJSUFFICS): ftppr.c proxy.h structures.h - $(CC) $(COUT)srvftppr$(OBJSUFFICS) $(CFLAGS) ftppr.c - -srvtcppm$(OBJSUFFICS): tcppm.c proxy.h structures.h - $(CC) $(COUT)srvtcppm$(OBJSUFFICS) $(CFLAGS) tcppm.c - -srvicqpr$(OBJSUFFICS): icqpr.c proxy.h structures.h - $(CC) $(COUT)srvicqpr$(OBJSUFFICS) $(CFLAGS) icqpr.c - -srvsocks$(OBJSUFFICS): socks.c proxy.h structures.h - $(CC) $(COUT)srvsocks$(OBJSUFFICS) $(CFLAGS) socks.c - -srvwebadmin$(OBJSUFFICS): webadmin.c proxy.h structures.h - $(CC) $(COUT)srvwebadmin$(OBJSUFFICS) $(CFLAGS) webadmin.c - -srvudppm$(OBJSUFFICS): udppm.c proxy.h structures.h - $(CC) $(COUT)srvudppm$(OBJSUFFICS) $(CFLAGS) udppm.c - -srvdnspr$(OBJSUFFICS): dnspr.c proxy.h structures.h - $(CC) $(COUT)srvdnspr$(OBJSUFFICS) $(CFLAGS) dnspr.c - -auth$(OBJSUFFICS): auth.c proxy.h structures.h - $(CC) $(COUT)auth$(OBJSUFFICS) $(CFLAGS) auth.c - -conf$(OBJSUFFICS): conf.c proxy.h structures.h - $(CC) $(COUT)conf$(OBJSUFFICS) $(CFLAGS) conf.c - -datatypes$(OBJSUFFICS): datatypes.c proxy.h structures.h - $(CC) $(COUT)datatypes$(OBJSUFFICS) $(CFLAGS) datatypes.c - -mycrypt$(OBJSUFFICS): mycrypt.c - $(CC) $(COUT)mycrypt$(OBJSUFFICS) $(CFLAGS) mycrypt.c - -dighosts$(OBJSUFFICS): dighosts.c - $(CC) $(COUT)dighosts$(OBJSUFFICS) $(CFLAGS) dighosts.c - -$(BUILDDIR)dighosts$(EXESUFFICS): dighosts$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(COMPATLIBS) - $(LN) $(LNOUT)$(BUILDDIR)dighosts$(EXESUFFICS) $(LDFLAGS) dighosts$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) $(COMPATLIBS) $(LIBS) - -mycryptmain$(OBJSUFFICS): mycrypt.c - $(CC) $(COUT)mycryptmain$(OBJSUFFICS) $(CFLAGS) $(DEFINEOPTION)WITHMAIN mycrypt.c - -$(BUILDDIR)mycrypt$(EXESUFFICS): md4$(OBJSUFFICS) md5$(OBJSUFFICS) mycryptmain$(OBJSUFFICS) base64$(OBJSUFFICS) - $(LN) $(LNOUT)$(BUILDDIR)mycrypt$(EXESUFFICS) $(LDFLAGS) md4$(OBJSUFFICS) md5$(OBJSUFFICS) base64$(OBJSUFFICS) mycryptmain$(OBJSUFFICS) - - -md4$(OBJSUFFICS): libs/md4.h libs/md4.c - $(CC) $(COUT)md4$(OBJSUFFICS) $(CFLAGS) libs/md4.c - -smbdes$(OBJSUFFICS): libs/smbdes.c - $(CC) $(COUT)smbdes$(OBJSUFFICS) $(CFLAGS) libs/smbdes.c - -md5$(OBJSUFFICS): libs/md5.h libs/md5.c - $(CC) $(COUT)md5$(OBJSUFFICS) $(CFLAGS) libs/md5.c - -ntlm$(OBJSUFFICS): ntlm.c - $(CC) $(COUT)ntlm$(OBJSUFFICS) $(CFLAGS) ntlm.c - -stringtable$(OBJSUFFICS): stringtable.c - $(CC) $(COUT)stringtable$(OBJSUFFICS) $(CFLAGS) stringtable.c - -$(BUILDDIR)3proxy$(EXESUFFICS): 3proxy$(OBJSUFFICS) mainfunc$(OBJSUFFICS) srvproxy$(OBJSUFFICS) srvpop3p$(OBJSUFFICS) srvsmtpp$(OBJSUFFICS) srvftppr$(OBJSUFFICS) srvsocks$(OBJSUFFICS) srvtcppm$(OBJSUFFICS) srvicqpr$(OBJSUFFICS) srvudppm$(OBJSUFFICS) sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) auth$(OBJSUFFICS) conf$(OBJSUFFICS) datatypes$(OBJSUFFICS) md4$(OBJSUFFICS) md5$(OBJSUFFICS) mycrypt$(OBJSUFFICS) base64$(OBJSUFFICS) ftp$(OBJSUFFICS) smbdes$(OBJSUFFICS) ntlm$(OBJSUFFICS) stringtable$(OBJSUFFICS) srvwebadmin$(OBJSUFFICS) srvdnspr$(OBJSUFFICS) plugins$(OBJSUFFICS) $(COMPATLIBS) - $(LN) $(LNOUT)$(BUILDDIR)3proxy$(EXESUFFICS) $(LDFLAGS) $(VERFILE) 3proxy$(OBJSUFFICS) mainfunc$(OBJSUFFICS) auth$(OBJSUFFICS) conf$(OBJSUFFICS) datatypes$(OBJSUFFICS) srvproxy$(OBJSUFFICS) srvpop3p$(OBJSUFFICS) srvsmtpp$(OBJSUFFICS) srvftppr$(OBJSUFFICS) srvsocks$(OBJSUFFICS) srvtcppm$(OBJSUFFICS) srvicqpr$(OBJSUFFICS) srvudppm$(OBJSUFFICS) sockmap$(OBJSUFFICS) sockgetchar$(OBJSUFFICS) myalloc$(OBJSUFFICS) common$(OBJSUFFICS) mycrypt$(OBJSUFFICS) md5$(OBJSUFFICS) md4$(OBJSUFFICS) base64$(OBJSUFFICS) ftp$(OBJSUFFICS) smbdes$(OBJSUFFICS) ntlm$(OBJSUFFICS) stringtable$(OBJSUFFICS) srvwebadmin$(OBJSUFFICS) srvdnspr$(OBJSUFFICS) plugins$(OBJSUFFICS) $(COMPATLIBS) $(LIBS) - clean: @$(REMOVECOMMAND) *$(OBJSUFFICS) $(COMPFILES) diff --git a/src/auth.c b/src/auth.c deleted file mode 100644 index 3908bb3..0000000 --- a/src/auth.c +++ /dev/null @@ -1,1367 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - - -int clientnegotiate(struct chain * redir, struct clientparam * param, struct sockaddr * addr){ - unsigned char *buf; - unsigned char *username; - int res; - int len=0; - unsigned char * user, *pass; - - - user = redir->extuser; - pass = redir->extpass; - if (param->srvinbuf < 4096){ - if(param->srvbuf)myfree(param->srvbuf); - param->srvbuf = myalloc(4096); - param->srvbufsize = 4096; - } - buf = param->srvbuf; - username = buf + 2048; - if(user) { - if (*user == '*') { - if(!param->username) return 4; - user = param->username; - pass = param->password; - } - } - switch(redir->type){ - case R_TCP: - case R_HTTP: - return 0; - case R_CONNECT: - case R_CONNECTP: - { - len = sprintf((char *)buf, "CONNECT "); - if(redir->type == R_CONNECTP && param->hostname) { - char * needreplace; - needreplace = strchr((char *)param->hostname, ':'); - if(needreplace) buf[len++] = '['; - len += sprintf((char *)buf + len, "%.256s", (char *)param->hostname); - if(needreplace) buf[len++] = ']'; - } - else { - if(*SAFAMILY(addr) == AF_INET6) buf[len++] = '['; - len += myinet_ntop(*SAFAMILY(addr), SAADDR(addr), (char *)buf+len, 256); - if(*SAFAMILY(addr) == AF_INET6) buf[len++] = ']'; - } - len += sprintf((char *)buf + len, - ":%hu HTTP/1.0\r\nProxy-Connection: keep-alive\r\n", ntohs(*SAPORT(addr))); - if(user){ - len += sprintf((char *)buf + len, "Proxy-authorization: basic "); - sprintf((char *)username, "%.128s:%.128s", user, pass?pass:(unsigned char *)""); - en64(username, buf+len, (int)strlen((char *)username)); - len = (int)strlen((char *)buf); - len += sprintf((char *)buf + len, "\r\n"); - } - len += sprintf((char *)buf + len, "\r\n"); - if(socksend(param->remsock, buf, len, conf.timeouts[CHAIN_TO]) != (int)strlen((char *)buf)) - return 31; - param->statssrv64+=len; - param->nwrites++; - if((res = sockgetlinebuf(param, SERVER,buf,13,'\n',conf.timeouts[CHAIN_TO])) < 13) - return 32; - if(buf[9] != '2') return 33; - while((res = sockgetlinebuf(param, SERVER,buf,1023,'\n', conf.timeouts[CHAIN_TO])) > 2); - if(res <= 0) return 34; - return 0; - } - case R_SOCKS4: - case R_SOCKS4P: - case R_SOCKS4B: - { - - if(*SAFAMILY(addr) != AF_INET) return 44; - buf[0] = 4; - buf[1] = 1; - memcpy(buf+2, SAPORT(addr), 2); - if(redir->type == R_SOCKS4P && param->hostname) { - buf[4] = buf[5] = buf[6] = 0; - buf[7] = 3; - } - else memcpy(buf+4, SAADDR(addr), 4); - if(!user)user = (unsigned char *)"anonymous"; - len = (int)strlen((char *)user) + 1; - memcpy(buf+8, user, len); - len += 8; - if(redir->type == R_SOCKS4P && param->hostname) { - int hostnamelen; - - hostnamelen = (int)strlen((char *)param->hostname) + 1; - if(hostnamelen > 255) hostnamelen = 255; - memcpy(buf+len, param->hostname, hostnamelen); - len += hostnamelen; - } - if(socksend(param->remsock, buf, len, conf.timeouts[CHAIN_TO]) < len){ - return 41; - } - param->statssrv64+=len; - param->nwrites++; - if((len = sockgetlinebuf(param, SERVER, buf, (redir->type == R_SOCKS4B)? 3:8, EOF, conf.timeouts[CHAIN_TO])) != ((redir->type == R_SOCKS4B)? 3:8)){ - return 42; - } - if(buf[1] != 90) { - return 43; - } - - } - return 0; - - case R_SOCKS5: - case R_SOCKS5P: - case R_SOCKS5B: - { - int inbuf = 0; - buf[0] = 5; - buf[1] = 1; - buf[2] = user? 2 : 0; - if(socksend(param->remsock, buf, 3, conf.timeouts[CHAIN_TO]) != 3){ - return 51; - } - param->statssrv64+=len; - param->nwrites++; - if(sockgetlinebuf(param, SERVER, buf, 2, EOF, conf.timeouts[CHAIN_TO]) != 2){ - return 52; - } - if(buf[0] != 5) { - return 53; - } - if(buf[1] != 0 && !(buf[1] == 2 && user)){ - return 54; - } - if(buf[1] == 2){ - buf[inbuf++] = 1; - buf[inbuf] = (unsigned char)strlen((char *)user); - memcpy(buf+inbuf+1, user, buf[inbuf]); - inbuf += buf[inbuf] + 1; - buf[inbuf] = pass?(unsigned char)strlen((char *)pass):0; - if(pass)memcpy(buf+inbuf+1, pass, buf[inbuf]); - inbuf += buf[inbuf] + 1; - if(socksend(param->remsock, buf, inbuf, conf.timeouts[CHAIN_TO]) != inbuf){ - return 51; - } - param->statssrv64+=inbuf; - param->nwrites++; - if(sockgetlinebuf(param, SERVER, buf, 2, EOF, 60) != 2){ - return 55; - } - if(buf[0] != 1 || buf[1] != 0) { - return 56; - } - } - buf[0] = 5; - buf[1] = 1; - buf[2] = 0; - if(redir->type == R_SOCKS5P && param->hostname) { - buf[3] = 3; - len = (int)strlen((char *)param->hostname); - if(len > 255) len = 255; - buf[4] = len; - memcpy(buf + 5, param->hostname, len); - len += 5; - } - else { - len = 3; - buf[len++] = (*SAFAMILY(addr) == AF_INET)? 1 : 4; - memcpy(buf+len, SAADDR(addr), SAADDRLEN(addr)); - len += SAADDRLEN(addr); - } - memcpy(buf+len, SAPORT(addr), 2); - len += 2; - if(socksend(param->remsock, buf, len, conf.timeouts[CHAIN_TO]) != len){ - return 51; - } - param->statssrv64+=len; - param->nwrites++; - if(sockgetlinebuf(param, SERVER, buf, 4, EOF, conf.timeouts[CHAIN_TO]) != 4){ - return 57; - } - if(buf[0] != 5) { - return 53; - } - if(buf[1] != 0) { - return 60 + (buf[1] % 10); - } - if(buf[3] != 1) { - return 58; - } - if (redir->type != R_SOCKS5B && sockgetlinebuf(param, SERVER, buf, 6, EOF, conf.timeouts[CHAIN_TO]) != 6){ - return 59; - } - return 0; - } - - default: - - return 30; - } -} - - -int handleredirect(struct clientparam * param, struct ace * acentry){ - int connected = 0; - int weight = 1000; - int res; - int done = 0; - struct chain * cur; - struct chain * redir = NULL; - int r2; - - if(param->remsock != INVALID_SOCKET) { - return 0; - } - if(SAISNULL(¶m->req) || !*SAPORT(¶m->req)) { - return 100; - } - - r2 = (myrand(param, sizeof(struct clientparam))%1000); - - for(cur = acentry->chains; cur; cur=cur->next){ - if(((weight = weight - cur->weight) > r2)|| done) { - if(weight <= 0) { - weight += 1000; - done = 0; - r2 = (myrand(param, sizeof(struct clientparam))%1000); - } - continue; - } - param->redirected++; - done = 1; - if(weight <= 0) { - weight += 1000; - done = 0; - r2 = (myrand(param, sizeof(struct clientparam))%1000); - } - if(!connected){ - if(cur->type == R_EXTIP){ - param->sinsl = cur->addr; - if(cur->next)continue; - return 0; - } - else if(SAISNULL(&cur->addr) && !*SAPORT(&cur->addr)){ - if(cur->extuser){ - if(param->extusername) - myfree(param->extusername); - param->extusername = (unsigned char *)mystrdup((char *)((*cur->extuser == '*' && param->username)? param->username : cur->extuser)); - if(cur->extpass){ - if(param->extpassword) - myfree(param->extpassword); - param->extpassword = (unsigned char *)mystrdup((char *)((*cur->extuser == '*' && param->password)?param->password : cur->extpass)); - } - if(*cur->extuser == '*' && !param->username) return 4; - } - switch(cur->type){ - case R_POP3: - param->redirectfunc = pop3pchild; - break; - case R_FTP: - param->redirectfunc = ftpprchild; - break; - case R_ADMIN: - param->redirectfunc = adminchild; - break; - case R_ICQ: - param->redirectfunc = icqprchild; - break; - case R_SMTP: - param->redirectfunc = smtppchild; - break; - default: - param->redirectfunc = proxychild; - } - if(cur->next)continue; - return 0; - } - else if(!*SAPORT(&cur->addr) && !SAISNULL(&cur->addr)) { - unsigned short port = *SAPORT(¶m->sinsr); - param->sinsr = cur->addr; - *SAPORT(¶m->sinsr) = port; - } - else if(SAISNULL(&cur->addr) && *SAPORT(&cur->addr)) *SAPORT(¶m->sinsr) = *SAPORT(&cur->addr); - else { - param->sinsr = cur->addr; - } - - if((res = alwaysauth(param))){ - return (res == 10)? res : 60+res; - } - } - else { - res = (redir)?clientnegotiate(redir, param, (struct sockaddr *)&cur->addr):0; - if(res) return res; - } - redir = cur; - param->redirtype = redir->type; - if(redir->type == R_TCP || redir->type ==R_HTTP) { - if(cur->extuser){ - if(*cur -> extuser == '*' && !param->username) return 4; - if(param->extusername) - myfree(param->extusername); - param->extusername = (unsigned char *)mystrdup((char *)((*cur->extuser == '*' && param->username)? param->username : cur->extuser)); - if(cur->extpass){ - if(param->extpassword) - myfree(param->extpassword); - param->extpassword = (unsigned char *)mystrdup((char *)((*cur->extuser == '*' && param->password)?param->password : cur->extpass)); - } - } - return 0; - } - connected = 1; - } - - if(!connected) return 9; - return (redir)?clientnegotiate(redir, param, (struct sockaddr *)¶m->req):0; -} - -int IPInentry(struct sockaddr *sa, struct iplist *ipentry){ - int addrlen; - unsigned char *ip, *ipf, *ipt; - - - if(!sa || ! ipentry || *SAFAMILY(sa) != ipentry->family) return 0; - - ip = (unsigned char *)SAADDR(sa); - ipf = (unsigned char *)&ipentry->ip_from; - ipt = (unsigned char *)&ipentry->ip_to; - - - addrlen = SAADDRLEN(sa); - - if(memcmp(ip,ipf,addrlen) < 0 || memcmp(ip,ipt,addrlen) > 0) return 0; - return 1; - -} - -int ACLmatches(struct ace* acentry, struct clientparam * param){ - struct userlist * userentry; - struct iplist *ipentry; - struct portlist *portentry; - struct period *periodentry; - unsigned char * username; - struct hostname * hstentry=NULL; - int i; - int match = 0; - - username = param->username?param->username:(unsigned char *)"-"; - if(acentry->src) { - for(ipentry = acentry->src; ipentry; ipentry = ipentry->next) - if(IPInentry((struct sockaddr *)¶m->sincr, ipentry)) { - break; - } - if(!ipentry) return 0; - } - if((acentry->dst && !SAISNULL(¶m->req)) || (acentry->dstnames && param->hostname)) { - for(ipentry = acentry->dst; ipentry; ipentry = ipentry->next) - if(IPInentry((struct sockaddr *)¶m->req, ipentry)) { - break; - } - if(!ipentry) { - if(acentry->dstnames && param->hostname){ - for(i=0; param->hostname[i]; i++){ - param->hostname[i] = tolower(param->hostname[i]); - } - while(i > 5 && param->hostname[i-1] == '.') param->hostname[i-1] = 0; - for(hstentry = acentry->dstnames; hstentry; hstentry = hstentry->next){ - switch(hstentry->matchtype){ - case 0: - if(strstr((char *)param->hostname, (char *)hstentry->name)) match = 1; - break; - - case 1: - if(strstr((char *)param->hostname, (char *)hstentry->name) == (char *)param->hostname) match = 1; - break; - - case 2: - if(strstr((char *)param->hostname, (char *)hstentry->name) == (char *)(param->hostname + i - (strlen((char *)hstentry->name)))) match = 1; - break; - - default: - if(!strcmp((char *)param->hostname, (char *)hstentry->name)) match = 1; - break; - } - if(match) break; - } - } - } - if(!ipentry && !hstentry) return 0; - } - if(acentry->ports && *SAPORT(¶m->req)) { - for (portentry = acentry->ports; portentry; portentry = portentry->next) - if(ntohs(*SAPORT(¶m->req)) >= portentry->startport && - ntohs(*SAPORT(¶m->req)) <= portentry->endport) { - break; - } - if(!portentry) return 0; - } - if(acentry->wdays){ - if(!(acentry -> wdays & wday)) return 0; - } - if(acentry->periods){ - int start_time = (int)(param->time_start - basetime); - for(periodentry = acentry->periods; periodentry; periodentry = periodentry -> next) - if(start_time >= periodentry->fromtime && start_time < periodentry->totime){ - break; - } - if(!periodentry) return 0; - } - if(acentry->users){ - for(userentry = acentry->users; userentry; userentry = userentry->next) - if(!strcmp((char *)username, (char *)userentry->user)){ - break; - } - if(!userentry) return 0; - } - if(acentry->operation) { - if((acentry->operation & param->operation) != param->operation){ - return 0; - } - } - if(acentry->weight && (acentry->weight < param->weight)) return 0; - return 1; -} - -static void initbandlims (struct clientparam *param){ - struct bandlim * be; - int i; - for(i=0, be = conf.bandlimiter; be && inext) { - if(ACLmatches(be->ace, param)){ - if(be->ace->action == NOBANDLIM) { - break; - } - param->bandlims[i++] = be; - param->bandlimfunc = conf.bandlimfunc; - } - } - if(ibandlims[i] = NULL; - for(i=0, be = conf.bandlimiterout; be && inext) { - if(ACLmatches(be->ace, param)){ - if(be->ace->action == NOBANDLIM) { - break; - } - param->bandlimsout[i++] = be; - param->bandlimfunc = conf.bandlimfunc; - } - } - if(ibandlimsout[i] = NULL; -} - -unsigned bandlimitfunc(struct clientparam *param, unsigned nbytesin, unsigned nbytesout){ - unsigned sleeptime = 0, nsleeptime; - unsigned long sec; - unsigned msec; - unsigned now; - int i; - -#ifdef _WIN32 - struct timeb tb; - - ftime(&tb); - sec = (unsigned)tb.time; - msec = (unsigned)tb.millitm*1000; -#else - struct timeval tv; - gettimeofday(&tv, NULL); - - sec = tv.tv_sec; - msec = tv.tv_usec; -#endif - - if(!nbytesin && !nbytesout) return 0; - pthread_mutex_lock(&bandlim_mutex); - if(param->paused != conf.paused){ - return (1); - } - for(i=0; nbytesin&& ibandlims[i]; i++){ - if( !param->bandlims[i]->basetime || - param->bandlims[i]->basetime > sec || - param->bandlims[i]->basetime < (sec - 120) - ) - { - param->bandlims[i]->basetime = sec; - param->bandlims[i]->nexttime = 0; - continue; - } - now = ((sec - param->bandlims[i]->basetime) * 1000000) + msec; - nsleeptime = (param->bandlims[i]->nexttime > now)? - param->bandlims[i]->nexttime - now : 0; - sleeptime = (nsleeptime > sleeptime)? nsleeptime : sleeptime; - param->bandlims[i]->basetime = sec; - param->bandlims[i]->nexttime = msec + nsleeptime + ((param->bandlims[i]->rate > 1000000)? ((nbytesin/32)*(256000000/param->bandlims[i]->rate)) : (nbytesin * (8000000/param->bandlims[i]->rate))); - } - for(i=0; nbytesout && ibandlimsout[i]; i++){ - if( !param->bandlimsout[i]->basetime || - param->bandlimsout[i]->basetime > sec || - param->bandlimsout[i]->basetime < (sec - 120) - ) - { - param->bandlimsout[i]->basetime = sec; - param->bandlimsout[i]->nexttime = 0; - continue; - } - now = ((sec - param->bandlimsout[i]->basetime) * 1000000) + msec; - nsleeptime = (param->bandlimsout[i]->nexttime > now)? - param->bandlimsout[i]->nexttime - now : 0; - sleeptime = (nsleeptime > sleeptime)? nsleeptime : sleeptime; - param->bandlimsout[i]->basetime = sec; - param->bandlimsout[i]->nexttime = msec + nsleeptime + ((param->bandlimsout[i]->rate > 1000000)? ((nbytesout/32)*(256000000/param->bandlimsout[i]->rate)) : (nbytesout * (8000000/param->bandlimsout[i]->rate))); - } - pthread_mutex_unlock(&bandlim_mutex); - return sleeptime/1000; -} - -void trafcountfunc(struct clientparam *param){ - struct trafcount * tc; - int countout = 0; - - pthread_mutex_lock(&tc_mutex); - for(tc = conf.trafcounter; tc; tc = tc->next) { - if(ACLmatches(tc->ace, param)){ - time_t t; - if(tc->ace->action == NOCOUNTIN) break; - if(tc->ace->action != COUNTIN) { - countout = 1; - continue; - } - tc->traf64 += param->statssrv64; - time(&t); - tc->updated = t; - } - } - if(countout) for(tc = conf.trafcounter; tc; tc = tc->next) { - if(ACLmatches(tc->ace, param)){ - time_t t; - if(tc->ace->action == NOCOUNTOUT) break; - if(tc->ace->action != COUNTOUT) { - continue; - } - tc->traf64 += param->statscli64; - time(&t); - tc->updated = t; - } - } - - pthread_mutex_unlock(&tc_mutex); -} - -int alwaysauth(struct clientparam * param){ - int res; - struct trafcount * tc; - int countout = 0; - - res = doconnect(param); - if(!res){ - if(param->srv->paused != conf.paused) return 333; - initbandlims(param); - for(tc = conf.trafcounter; tc; tc = tc->next) { - if(tc->disabled) continue; - if(ACLmatches(tc->ace, param)){ - if(tc->ace->action == NOCOUNTIN) break; - if(tc->ace->action != COUNTIN) { - countout = 1; - continue; - } - - if(tc->traflim64 <= tc->traf64) return 10; - param->trafcountfunc = conf.trafcountfunc; - param->maxtrafin64 = tc->traflim64 - tc->traf64; - } - } - if(countout)for(tc = conf.trafcounter; tc; tc = tc->next) { - if(tc->disabled) continue; - if(ACLmatches(tc->ace, param)){ - if(tc->ace->action == NOCOUNTOUT) break; - if(tc->ace->action != COUNTOUT) { - continue; - } - - if(tc->traflim64 <= tc->traf64) return 10; - param->trafcountfunc = conf.trafcountfunc; - param->maxtrafout64 = tc->traflim64 - tc->traf64; - } - } - - } - return res; -} - -int checkACL(struct clientparam * param){ - struct ace* acentry; - - if(!param->srv->acl) { - return alwaysauth(param); - } - for(acentry = param->srv->acl; acentry; acentry = acentry->next) { - if(ACLmatches(acentry, param)) { - param->nolog = acentry->nolog; - param->weight = acentry->weight; - if(acentry->action == 2) { - struct ace dup; - - if(param->operation < 256 && !(param->operation & CONNECT)){ - continue; - } - if(param->redirected && acentry->chains && SAISNULL(&acentry->chains->addr) && !*SAPORT(&acentry->chains->addr)) { - continue; - } - dup = *acentry; - return handleredirect(param, &dup); - } - return acentry->action; - } - } - return 3; -} - -struct authcache { - char * username; - char * password; - time_t expires; -#ifndef NOIPV6 - struct sockaddr_in6 sa; -#else - struct sockaddr_in sa; -#endif - struct authcache *next; -} *authc = NULL; - - -int cacheauth(struct clientparam * param){ - struct authcache *ac, *last=NULL; - - pthread_mutex_lock(&hash_mutex); - for(ac = authc; ac; ){ - if(ac->expires <= conf.time){ - if(ac->username)myfree(ac->username); - if(ac->password)myfree(ac->password); - if(!last){ - authc = ac->next; - myfree(ac); - ac = authc; - } - else { - last->next = ac->next; - myfree(ac); - ac = last->next; - } - continue; - - } - if(((!(conf.authcachetype&2)) || (param->username && ac->username && !strcmp(ac->username, (char *)param->username))) && - ((!(conf.authcachetype&1)) || (*SAFAMILY(&ac->sa) == *SAFAMILY(¶m->sincr) && !memcmp(SAADDR(&ac->sa), ¶m->sincr, SAADDRLEN(&ac->sa)))) && - (!(conf.authcachetype&4) || (ac->password && param->password && !strcmp(ac->password, (char *)param->password)))) { - if(param->username){ - myfree(param->username); - } - param->username = (unsigned char *)mystrdup(ac->username); - pthread_mutex_unlock(&hash_mutex); - return 0; - } - last = ac; - ac = ac->next; - } - - pthread_mutex_unlock(&hash_mutex); - return 4; -} - -int doauth(struct clientparam * param){ - int res = 0; - struct auth *authfuncs; - struct authcache *ac; - char * tmp; - int ret = 0; - - for(authfuncs=param->srv->authfuncs; authfuncs; authfuncs=authfuncs->next){ - res = authfuncs->authenticate?(*authfuncs->authenticate)(param):0; - if(!res) { - if(authfuncs->authorize && - (res = (*authfuncs->authorize)(param))) - return res; - if(conf.authcachetype && authfuncs->authenticate && authfuncs->authenticate != cacheauth && param->username && (!(conf.authcachetype&4) || (!param->pwtype && param->password))){ - pthread_mutex_lock(&hash_mutex); - for(ac = authc; ac; ac = ac->next){ - if((!(conf.authcachetype&2) || !strcmp(ac->username, (char *)param->username)) && - (!(conf.authcachetype&1) || (*SAFAMILY(&ac->sa) == *SAFAMILY(¶m->sincr) && !memcmp(SAADDR(&ac->sa), ¶m->sincr, SAADDRLEN(&ac->sa)))) && - (!(conf.authcachetype&4) || (ac->password && !strcmp(ac->password, (char *)param->password)))) { - ac->expires = conf.time + conf.authcachetime; - if(strcmp(ac->username, (char *)param->username)){ - tmp = ac->username; - ac->username = mystrdup((char *)param->username); - myfree(tmp); - } - if((conf.authcachetype&4)){ - tmp = ac->password; - ac->password = mystrdup((char *)param->password); - myfree(tmp); - } - ac->sa = param->sincr; - break; - } - } - if(!ac){ - ac = myalloc(sizeof(struct authcache)); - if(ac){ - ac->expires = conf.time + conf.authcachetime; - ac->username = mystrdup((char *)param->username); - ac->sa = param->sincr; - ac->password = NULL; - if((conf.authcachetype&4) && param->password) ac->password = mystrdup((char *)param->password); - } - ac->next = authc; - authc = ac; - } - pthread_mutex_unlock(&hash_mutex); - } - break; - } - if(res > ret) ret = res; - } - if(!res){ - return alwaysauth(param); - } - - return ret; -} - - -int ipauth(struct clientparam * param){ - int res; - unsigned char *username; - username = param->username; - param->username = NULL; - res = checkACL(param); - param->username = username; - return res; -} - -int userauth(struct clientparam * param){ - return (param->username)? 0:4; -} - -int dnsauth(struct clientparam * param){ - char buf[128]; - char addr[16]; - char dig[]="0123456789abcdef"; - - unsigned u; - int i; - - if(*SAFAMILY(¶m->sincr)!=AF_INET){ - char *s = buf; - for(i=15; i>=0; i--){ - unsigned char c=((unsigned char *)SAADDR(¶m->sincr))[i]; - *s++ = dig[(c&0xf)]; - *s++ = '.'; - *s++ = dig[(c>>4)]; - *s++ = '.'; - } - sprintf(s, "ip6.arpa"); - } - else { - u = ntohl(*(unsigned long *)SAADDR(¶m->sincr)); - - sprintf(buf, "%u.%u.%u.%u.in-addr.arpa", - ((u&0x000000FF)), - ((u&0x0000FF00)>>8), - ((u&0x00FF0000)>>16), - ((u&0xFF000000)>>24)); - - } - if(!udpresolve(*SAFAMILY(¶m->sincr), (unsigned char *)buf, (unsigned char *)addr, NULL, param, 1)) return 6; - if(!memcmp(SAADDR(¶m->sincr), addr, SAADDRLEN(¶m->sincr))) return 6; - - return param->username? 0:4; -} - -int strongauth(struct clientparam * param){ - struct passwords * pwl; - unsigned char buf[256]; - - - if(!param->username) return 4; - pthread_mutex_lock(&pwl_mutex); - for(pwl = conf.pwl; pwl; pwl=pwl->next){ - if(!strcmp((char *)pwl->user, (char *)param->username)) switch(pwl->pwtype) { - case CL: - if(!pwl->password || !*pwl->password){ - break; - } - else if (!param->pwtype && param->password && !strcmp((char *)param->password, (char *)pwl->password)){ - break; - } -#ifndef NOCRYPT - else if (param->pwtype == 2 && param->password) { - ntpwdhash(buf, pwl->password, 0); - mschap(buf, param->password, buf + 16); - if(!memcmp(buf+16, param->password+8, 24)) { - break; - } - } -#endif - pthread_mutex_unlock(&pwl_mutex); - return 6; -#ifndef NOCRYPT - case CR: - if(param->password && !param->pwtype && !strcmp((char *)pwl->password, (char *)mycrypt(param->password, pwl->password,buf))) { - break; - } - pthread_mutex_unlock(&pwl_mutex); - return 7; - case NT: - if(param->password && !param->pwtype && !memcmp(pwl->password, ntpwdhash(buf,param->password, 1), 32)) { - break; - } - else if (param->pwtype == 2){ - fromhex(pwl->password, buf, 16); - mschap(buf, param->password, buf + 16); - if(!memcmp(buf + 16, param->password+8, 24)) { - break; - } - } - pthread_mutex_unlock(&pwl_mutex); - return 8; -#endif - default: - pthread_mutex_unlock(&pwl_mutex); - return 999; - } - else continue; - pthread_mutex_unlock(&pwl_mutex); - return 0; - } - pthread_mutex_unlock(&pwl_mutex); - return 5; -} - - -struct auth authfuncs[] = { - {authfuncs+1, NULL, NULL, ""}, - {authfuncs+2, ipauth, NULL, "iponly"}, - {authfuncs+3, userauth, checkACL, "useronly"}, - {authfuncs+4, dnsauth, checkACL, "dnsname"}, - {authfuncs+5, strongauth, checkACL, "strong"}, - {authfuncs+6, cacheauth, checkACL, "cache"}, - {authfuncs+7, NULL, NULL, "none"}, - - {NULL, NULL, NULL, ""} -}; - - - -struct hashtable dns_table = {0, 4, {0,0,0,0}, NULL, NULL, NULL}; -struct hashtable dns6_table = {0, 16, {0,0,0,0}, NULL, NULL, NULL}; - - -void nametohash(const unsigned char * name, unsigned char *hash, unsigned char *rnd){ - unsigned i, j, k; - memcpy(hash, rnd, sizeof(unsigned)*4); - for(i=0, j=0, k=0; name[j]; j++){ - hash[i] += (toupper(name[j]) - 32)+rnd[((toupper(name[j]))*29277+rnd[(k+j+i)%16]+k+j+i)%16]; - if(++i == sizeof(unsigned)*4) { - i = 0; - k++; - } - } -} - -unsigned hashindex(struct hashtable *ht, const unsigned char* hash){ - unsigned t1, t2, t3, t4; - t1 = *(unsigned *)hash; - t2 = *(unsigned *)(hash + sizeof(unsigned)); - t3 = *(unsigned *)(hash + (2*sizeof(unsigned))); - t4 = *(unsigned *)(hash + (3*sizeof(unsigned))); - return (t1 + (t2 * 7) + (t3 * 17) + (t4 * 29) ) % (ht->hashsize >> 2); -} - - -void destroyhashtable(struct hashtable *ht){ - pthread_mutex_lock(&hash_mutex); - if(ht->hashtable){ - myfree(ht->hashtable); - ht->hashtable = NULL; - } - if(ht->hashvalues){ - myfree(ht->hashvalues); - ht->hashvalues = NULL; - } - ht->hashsize = 0; - pthread_mutex_unlock(&hash_mutex); -} - -#define hvalue(I) ((struct hashentry *)((char *)ht->hashvalues + (I)*(sizeof(struct hashentry) + ht->recsize - 4))) -int inithashtable(struct hashtable *ht, unsigned nhashsize){ - unsigned i; - clock_t c; - - -#ifdef _WIN32 - struct timeb tb; - - ftime(&tb); - -#else - struct timeval tb; - struct timezone tz; - gettimeofday(&tb, &tz); -#endif - c = clock(); - - if(nhashsize<4) return 1; - pthread_mutex_lock(&hash_mutex); - if(ht->hashtable){ - myfree(ht->hashtable); - ht->hashtable = NULL; - } - if(ht->hashvalues){ - myfree(ht->hashvalues); - ht->hashvalues = NULL; - } - ht->hashsize = 0; - if(!(ht->hashtable = myalloc((nhashsize>>2) * sizeof(struct hashentry *)))){ - pthread_mutex_unlock(&hash_mutex); - return 2; - } - if(!(ht->hashvalues = myalloc(nhashsize * (sizeof(struct hashentry) + (ht->recsize-4))))){ - myfree(ht->hashtable); - ht->hashtable = NULL; - pthread_mutex_unlock(&hash_mutex); - return 3; - } - ht->hashsize = nhashsize; - ht->rnd[0] = myrand(&tb, sizeof(tb)); - ht->rnd[1] = myrand(ht->hashtable, sizeof(ht->hashtable)); - ht->rnd[2] = myrand(&c, sizeof(c)); - ht->rnd[3] = myrand(ht->hashvalues,sizeof(ht->hashvalues)); - memset(ht->hashtable, 0, (ht->hashsize>>2) * sizeof(struct hashentry *)); - memset(ht->hashvalues, 0, ht->hashsize * (sizeof(struct hashentry) + ht->recsize -4)); - - for(i = 0; i< (ht->hashsize - 1); i++) { - hvalue(i)->next = hvalue(i+1); - } - ht->hashempty = ht->hashvalues; - pthread_mutex_unlock(&hash_mutex); - return 0; -} - -void hashadd(struct hashtable *ht, const unsigned char* name, unsigned char* value, time_t expires){ - struct hashentry * hen, *he; - struct hashentry ** hep; - - unsigned index; - - pthread_mutex_lock(&hash_mutex); - if(!ht||!value||!name||!ht->hashtable||!ht->hashempty) { - pthread_mutex_unlock(&hash_mutex); - return; - } - hen = ht->hashempty; - ht->hashempty = ht->hashempty->next; - nametohash(name, hen->hash, (unsigned char *)ht->rnd); - memcpy(hen->value, value, ht->recsize); - hen->expires = expires; - hen->next = NULL; - index = hashindex(ht, hen->hash); - - for(hep = ht->hashtable + index; (he = *hep)!=NULL; ){ - if(he->expires < conf.time || !memcmp(hen->hash, he->hash, sizeof(he->hash))) { - (*hep) = he->next; - he->expires = 0; - he->next = ht->hashempty; - ht->hashempty = he; - } - else hep=&(he->next); - } - hen->next = ht->hashtable[index]; - ht->hashtable[index] = hen; - pthread_mutex_unlock(&hash_mutex); -} - -unsigned long hashresolv(struct hashtable *ht, const unsigned char* name, unsigned char* value, unsigned *ttl){ - unsigned char hash[sizeof(unsigned)*4]; - struct hashentry ** hep; - struct hashentry *he; - unsigned index; - - pthread_mutex_lock(&hash_mutex); - if(!ht || !ht->hashtable || !name) { - pthread_mutex_unlock(&hash_mutex); - return 0; - } - nametohash(name, hash, (unsigned char *)ht->rnd); - index = hashindex(ht, hash); - for(hep = ht->hashtable + index; (he = *hep)!=NULL; ){ - if(he->expires < conf.time) { - (*hep) = he->next; - he->expires = 0; - he->next = ht->hashempty; - ht->hashempty = he; - } - else if(!memcmp(hash, he->hash, sizeof(unsigned)*4)){ - if(ttl) *ttl = (unsigned)(he->expires - conf.time); - memcpy(value, he->value, ht->recsize); - pthread_mutex_unlock(&hash_mutex); - return 1; - } - else hep=&(he->next); - } - pthread_mutex_unlock(&hash_mutex); - return 0; -} - -struct nserver nservers[MAXNSERVERS] = {{{0},0}, {{0},0}, {{0},0}, {{0},0}, {{0},0}}; -struct nserver authnserver; - - -unsigned long udpresolve(int af, unsigned char * name, unsigned char * value, unsigned *retttl, struct clientparam* param, int makeauth){ - - int i,n; - unsigned long retval; - - if((af == AF_INET) && (retval = hashresolv(&dns_table, name, value, retttl))) { - return retval; - } - if((af == AF_INET6) && (retval = hashresolv(&dns6_table, name, value, retttl))) { - return retval; - } - n = (makeauth && !SAISNULL(&authnserver.addr))? 1 : numservers; - for(i=0; isinsl : &addr; - sinsr = (param && !makeauth)? ¶m->sinsr : &addr; - memset(sinsl, 0, sizeof(addr)); - memset(sinsr, 0, sizeof(addr)); - - - if(makeauth && !SAISNULL(&authnserver.addr)){ - usetcp = authnserver.usetcp; - *SAFAMILY(sinsl) = *SAFAMILY(&authnserver.addr); - } - else { - usetcp = nservers[i].usetcp; - *SAFAMILY(sinsl) = *SAFAMILY(&nservers[i].addr); - } - if((sock=so._socket(SASOCK(sinsl), usetcp?SOCK_STREAM:SOCK_DGRAM, usetcp?IPPROTO_TCP:IPPROTO_UDP)) == INVALID_SOCKET) break; - if(so._bind(sock,(struct sockaddr *)sinsl,SASIZE(sinsl))){ - so._shutdown(sock, SHUT_RDWR); - so._closesocket(sock); - break; - } - if(makeauth && !SAISNULL(&authnserver.addr)){ - *sinsr = authnserver.addr; - } - else { - *sinsr = nservers[i].addr; - } - if(usetcp){ - if(so._connect(sock,(struct sockaddr *)sinsr,SASIZE(sinsr))) { - so._shutdown(sock, SHUT_RDWR); - so._closesocket(sock); - break; - } - } - len = (int)strlen((char *)name); - - serial = myrand(name,len); - *(unsigned short*)buf = serial; /* query id */ - buf[2] = 1; /* recursive */ - buf[3] = 0; - buf[4] = 0; - buf[5] = 1; /* 1 request */ - buf[6] = buf[7] = 0; /* no replies */ - buf[8] = buf[9] = 0; /* no ns count */ - buf[10] = buf[11] = 0; /* no additional */ - if(len > 255) { - len = 255; - } - memcpy(buf + 13, name, len); - len += 13; - buf[len] = 0; - for(s2 = buf + 12; (s1 = (unsigned char *)strchr((char *)s2 + 1, '.')); s2 = s1)*s2 = (unsigned char)((s1 - s2) - 1); - *s2 = (len - (int)(s2 - buf)) - 1; - len++; - buf[len++] = 0; - buf[len++] = (makeauth == 1)? 0x0c : (af==AF_INET6? 0x1c:0x01); /* PTR:host address */ - buf[len++] = 0; - buf[len++] = 1; /* INET */ - if(usetcp){ - buf-=2; - *(unsigned short*)buf = htons(len); - len+=2; - } - - if(socksendto(sock, (struct sockaddr *)sinsr, buf, len, conf.timeouts[SINGLEBYTE_L]*1000) != len){ - so._shutdown(sock, SHUT_RDWR); - so._closesocket(sock); - continue; - } - if(param) param->statscli64 += len; - len = sockrecvfrom(sock, (struct sockaddr *)sinsr, buf, 4096, conf.timeouts[DNS_TO]*1000); - so._shutdown(sock, SHUT_RDWR); - so._closesocket(sock); - if(len <= 13) { - continue; - } - if(param) param->statssrv64 += len; - if(usetcp){ - unsigned short us; - us = ntohs(*(unsigned short*)buf); - len-=2; - buf+=2; - if(us > 4096 || us < len || (us > len && sockrecvfrom(sock, (struct sockaddr *)sinsr, buf+len, us-len, conf.timeouts[DNS_TO]*1000) != us-len)) { - continue; - } - } - if(*(unsigned short *)buf != serial)continue; - if((na = buf[7] + (((unsigned short)buf[6])<<8)) < 1) { - return 0; - } - nq = buf[5] + (((unsigned short)buf[4])<<8); - if (nq != 1) { - continue; /* we did only 1 request */ - } - for(k = 13; k= len) { - continue; - } - k += 4; - if(na > 255) na = 255; /* somebody is very evil */ - for (j = 0; j < na; j++) { /* now there should be answers */ - if((k+(af == AF_INET6?28:16)) > len) { - break; - } - flen = buf[k+11] + (((unsigned short)buf[k+10])<<8); - if((k+12+flen) > len) { - break; - } - if(makeauth != 1){ - if(buf[k+2] != 0 || buf[k+3] != (af == AF_INET6?0x1c:0x1) || flen != (af == AF_INET6?16:4)) { - k+= (12 + flen); - continue; /* we need A IPv4 */ - } - ttl = ntohl(*(unsigned long *)(buf + k + 6)); - memcpy(value, buf + k + 12, af == AF_INET6? 16:4); - if(ttl < 60 || ttl > (3600*12)) ttl = 300; - if(ttl){ - hashadd(af == AF_INET6?&dns6_table:&dns_table, name, value, conf.time+ttl); - - } - if(retttl) *retttl = ttl; - return 1; - } - else { - - if(buf[k+2] != 0 || buf[k+3] != 0x0c) { - k+= (12 + flen); - continue; /* we need A PTR */ - } - for (s2 = buf + k + 12; s2 < (buf + k + 12 + len) && *s2; ){ - s1 = s2 + ((unsigned)*s2) + 1; - *s2 = '.'; - s2 = s1; - } - *s2 = 0; - if(param->username)myfree(param->username); - param->username = (unsigned char *)mystrdup ((char *)buf + k + 13); - - return udpresolve(af,param->username, value, NULL, NULL, 2); - } - } - } - return 0; -} - -unsigned long myresolver(int af, unsigned char * name, unsigned char * value){ - return udpresolve(af, name, value, NULL, NULL, 0); -} - -unsigned long fakeresolver (int af, unsigned char *name, unsigned char * value){ - memset(value, 0, af == AF_INET6? 16 : 4); - if(af == AF_INET6){ - memset(value, 0, 16); - value[15] = 2; - } - else { - value[0] = 127; - value[1] = 0; - value[2] = 0; - value[3] = 2; - } - return 1; -} - -#ifndef NOODBC - -SQLHENV henv = NULL; -SQLHSTMT hstmt = NULL; -SQLHDBC hdbc = NULL; -char * sqlstring = NULL; - - -void close_sql(){ - if(hstmt) { - SQLFreeHandle(SQL_HANDLE_STMT, hstmt); - hstmt = NULL; - } - if(hdbc){ - SQLDisconnect(hdbc); - SQLFreeHandle(SQL_HANDLE_DBC, hdbc); - hdbc = NULL; - } - if(henv) { - SQLFreeHandle(SQL_HANDLE_ENV, henv); - henv = NULL; - } -} - -int attempt = 0; -time_t attempt_time = 0; - -int init_sql(char * s){ - SQLRETURN retcode; - char * datasource; - char * username; - char * password; - char * string; - - if(!s) return 0; - if(!sqlstring || strcmp(sqlstring, s)){ - string = sqlstring; - sqlstring=mystrdup(s); - if(string)myfree(string); - } - - if(hstmt || hdbc || henv) close_sql(); - attempt++; - attempt_time = time(0); - if(!henv){ - retcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv); - if (!henv || (retcode != SQL_SUCCESS && retcode != SQL_SUCCESS_WITH_INFO)){ - henv = NULL; - return 0; - } - retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0); - - if (retcode != SQL_SUCCESS && retcode != SQL_SUCCESS_WITH_INFO) { - return 0; - } - } - if(!hdbc){ - retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc); - if (!hdbc || (retcode != SQL_SUCCESS && retcode != SQL_SUCCESS_WITH_INFO)) { - hdbc = NULL; - SQLFreeHandle(SQL_HANDLE_ENV, henv); - henv = NULL; - return 0; - } - SQLSetConnectAttr(hdbc, SQL_LOGIN_TIMEOUT, (void*)15, 0); - } - string = mystrdup(sqlstring); - if(!string) return 0; - datasource = strtok(string, ","); - username = strtok(NULL, ","); - password = strtok(NULL, ","); - - - /* Connect to data source */ - retcode = SQLConnect(hdbc, (SQLCHAR*) datasource, (SQLSMALLINT)strlen(datasource), - (SQLCHAR*) username, (SQLSMALLINT)((username)?strlen(username):0), - (SQLCHAR*) password, (SQLSMALLINT)((password)?strlen(password):0)); - - myfree(string); - if (retcode != SQL_SUCCESS && retcode != SQL_SUCCESS_WITH_INFO){ - SQLFreeHandle(SQL_HANDLE_DBC, hdbc); - hdbc = NULL; - SQLFreeHandle(SQL_HANDLE_ENV, henv); - henv = NULL; - return 0; - } - retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt); - if (retcode != SQL_SUCCESS && retcode != SQL_SUCCESS_WITH_INFO){ - close_sql(); - return 0; - } - return 1; -} - -void sqlerr (char *buf){ - if(conf.stdlog){ - fprintf(conf.stdlog, "%s\n", buf); - fflush(conf.stdlog); - } - pthread_mutex_unlock(&log_mutex); -} - -void logsql(struct clientparam * param, const unsigned char *s) { - SQLRETURN ret; - int len; - - - if(param->nolog) return; - pthread_mutex_lock(&log_mutex); - len = dobuf(param, tmpbuf, s, (unsigned char *)"\'"); - - if(attempt > 5){ - time_t t; - - t = time(0); - if (t - attempt_time < 180){ - sqlerr((char *)tmpbuf); - return; - } - } - if(!hstmt){ - if(!init_sql(sqlstring)) { - sqlerr((char *)tmpbuf); - return; - } - } - if(hstmt){ - ret = SQLExecDirect(hstmt, (SQLCHAR *)tmpbuf, (SQLINTEGER)len); - if(ret != SQL_SUCCESS && ret != SQL_SUCCESS_WITH_INFO){ - close_sql(); - if(!init_sql(sqlstring)){ - sqlerr((char *)tmpbuf); - return; - } - if(hstmt) { - ret = SQLExecDirect(hstmt, (SQLCHAR *)tmpbuf, (SQLINTEGER)len); - if(ret != SQL_SUCCESS && ret != SQL_SUCCESS_WITH_INFO){ - sqlerr((char *)tmpbuf); - return; - } - attempt = 0; - } - } - attempt = 0; - } - pthread_mutex_unlock(&log_mutex); -} - -#endif - \ No newline at end of file diff --git a/src/conf.c b/src/conf.c deleted file mode 100644 index dd0de27..0000000 --- a/src/conf.c +++ /dev/null @@ -1,1708 +0,0 @@ -#include "proxy.h" -#ifndef _WIN32 -#include -#ifndef NOPLUGINS -#include -#endif -#endif - -#ifndef DEFAULTCONFIG -#define DEFAULTCONFIG conf.stringtable[25] -#endif - -pthread_mutex_t bandlim_mutex; -pthread_mutex_t tc_mutex; -pthread_mutex_t pwl_mutex; -pthread_mutex_t hash_mutex; -pthread_mutex_t config_mutex; - -int haveerror = 0; -int linenum = 0; - -FILE *writable; -struct counter_header cheader = {"3CF", (time_t)0}; -struct counter_record crecord; - -int mainfunc (int argc, char** argv); - -struct proxydef childdef = {NULL, 0, 0, S_NOSERVICE, ""}; - -#define STRINGBUF 65535 -#define NPARAMS 4096 - -#ifndef _WIN32 -char *chrootp = NULL; -static pthread_attr_t pa; -#endif -char * curconf = NULL; - -FILE * confopen(){ - curconf = conf.conffile; -#ifndef _WIN32 - if(chrootp){ - if(strstr(curconf, chrootp) == curconf) - curconf += strlen(chrootp); - } -#endif - if(writable) { - rewind(writable); - return writable; - } - return fopen(curconf, "r"); -} - - -#ifdef _WIN32 -DWORD WINAPI startsrv(LPVOID data) { -#else -void * startsrv(void * data) { -#endif - struct child *d = (struct child *)data; - mainfunc(d->argc, (char **)d->argv); - return 0; -} - -int included =0; - -int getrotate(char c){ - switch(c){ - case 'c': - case 'C': - return MINUTELY; - case 'h': - case 'H': - return HOURLY; - case 'd': - case 'D': - return DAILY; - case 'w': - case 'W': - return WEEKLY; - case 'y': - case 'Y': - return ANNUALLY; - case 'm': - case 'M': - return MONTHLY; - default: - return NEVER; - } -} - - -unsigned char * dologname (unsigned char *buf, unsigned char *name, const unsigned char *ext, ROTATION lt, time_t t) { - struct tm *ts; - - ts = localtime(&t); - if(strchr((char *)name, '%')){ - struct clientparam fakecli; - - memset(&fakecli, 0, sizeof(fakecli)); - dobuf2(&fakecli, buf, NULL, NULL, ts, (char *)name); - } - else switch(lt){ - case NONE: - sprintf((char *)buf, "%s", name); - break; - case ANNUALLY: - sprintf((char *)buf, "%s.%04d", name, ts->tm_year+1900); - break; - case MONTHLY: - sprintf((char *)buf, "%s.%04d.%02d", name, ts->tm_year+1900, ts->tm_mon+1); - break; - case WEEKLY: - t = t - (ts->tm_wday * (60*60*24)); - ts = localtime(&t); - sprintf((char *)buf, "%s.%04d.%02d.%02d", name, ts->tm_year+1900, ts->tm_mon+1, ts->tm_mday); - break; - case DAILY: - sprintf((char *)buf, "%s.%04d.%02d.%02d", name, ts->tm_year+1900, ts->tm_mon+1, ts->tm_mday); - break; - case HOURLY: - sprintf((char *)buf, "%s.%04d.%02d.%02d-%02d", name, ts->tm_year+1900, ts->tm_mon+1, ts->tm_mday, ts->tm_hour); - break; - case MINUTELY: - sprintf((char *)buf, "%s.%04d.%02d.%02d-%02d.%02d", name, ts->tm_year+1900, ts->tm_mon+1, ts->tm_mday, ts->tm_hour, ts->tm_min); - break; - default: - break; - } - if(ext){ - strcat((char *)buf, "."); - strcat((char *)buf, (char *)ext); - } - return buf; -} - -int start_proxy_thread(struct child * chp){ - pthread_t thread; -#ifdef _WIN32 - HANDLE h; -#endif - - conf.threadinit = 1; -#ifdef _WIN32 -#ifndef _WINCE - h = (HANDLE)_beginthreadex((LPSECURITY_ATTRIBUTES )NULL, 16384+conf.stacksize, (void *)startsrv, (void *) chp, (DWORD)0, &thread); -#else - h = (HANDLE)CreateThread((LPSECURITY_ATTRIBUTES )NULL, 16384+conf.stacksize, (void *)startsrv, (void *) chp, (DWORD)0, &thread); -#endif - if(h)CloseHandle(h); -#else - pthread_attr_init(&pa); - pthread_attr_setstacksize(&pa,PTHREAD_STACK_MIN + (16384+conf.stacksize)); - pthread_attr_setdetachstate(&pa,PTHREAD_CREATE_DETACHED); - pthread_create(&thread, &pa, startsrv, (void *)chp); -#endif - while(conf.threadinit)usleep(SLEEPTIME); - if(haveerror) { - fprintf(stderr, "Service not started on line: %d\n", linenum); - return(40); - } - return 0; -} - -static int h_proxy(int argc, unsigned char ** argv){ - struct child ch; - - ch.argc = argc; - ch.argv = argv; - if(!strcmp((char *)argv[0], "proxy")) { - childdef.pf = proxychild; - childdef.port = 3128; - childdef.isudp = 0; - childdef.service = S_PROXY; - childdef.helpmessage = " -n - no NTLM support\n"; -#ifdef NOIPV6 - if(!resolvfunc || (resolvfunc == myresolver && !dns_table.hashsize)){ - fprintf(stderr, "[line %d] Warning: no nserver/nscache configured, proxy may run very slow\n", linenum); - } -#endif - } - else if(!strcmp((char *)argv[0], "pop3p")) { - childdef.pf = pop3pchild; - childdef.port = 110; - childdef.isudp = 0; - childdef.service = S_POP3P; - childdef.helpmessage = " -hdefault_host[:port] - use this host and port as default if no host specified\n"; - } - else if(!strcmp((char *)argv[0], "smtpp")) { - childdef.pf = smtppchild; - childdef.port = 25; - childdef.isudp = 0; - childdef.service = S_SMTPP; - childdef.helpmessage = " -hdefault_host[:port] - use this host and port as default if no host specified\n"; - } - else if(!strcmp((char *)argv[0], "ftppr")) { - childdef.pf = ftpprchild; - childdef.port = 21; - childdef.isudp = 0; - childdef.service = S_FTPPR; - childdef.helpmessage = " -hdefault_host[:port] - use this host and port as default if no host specified\n"; - } - else if(!strcmp((char *)argv[0], "socks")) { - childdef.pf = sockschild; - childdef.port = 1080; - childdef.isudp = 0; - childdef.service = S_SOCKS; - childdef.helpmessage = " -n - no NTLM support\n"; -#ifdef NOIPV6 - if(!resolvfunc || (resolvfunc == myresolver && !dns_table.hashsize)){ - fprintf(stderr, "[line %d] Warning: no nserver/nscache configured, socks may run very slow\n", linenum); - } -#endif - } - else if(!strcmp((char *)argv[0], "tcppm")) { - childdef.pf = tcppmchild; - childdef.port = 0; - childdef.isudp = 0; - childdef.service = S_TCPPM; - childdef.helpmessage = ""; - } - else if(!strcmp((char *)argv[0], "icqpr")) { - childdef.pf = icqprchild; - childdef.port = 0; - childdef.isudp = 0; - childdef.service = S_ICQPR; - childdef.helpmessage = ""; - } -/* - else if(!strcmp((char *)argv[0], "msnpr")) { - childdef.pf = msnprchild; - childdef.port = 0; - childdef.isudp = 0; - childdef.service = S_MSNPR; - childdef.helpmessage = ""; - } -*/ - else if(!strcmp((char *)argv[0], "udppm")) { - childdef.pf = udppmchild; - childdef.port = 0; - childdef.isudp = 1; - childdef.service = S_UDPPM; - childdef.helpmessage = " -s single packet UDP service for request/reply (DNS-like) services\n"; - } - else if(!strcmp((char *)argv[0], "admin")) { - childdef.pf = adminchild; - childdef.port = 80; - childdef.isudp = 0; - childdef.service = S_ADMIN; - } - else if(!strcmp((char *)argv[0], "dnspr")) { - childdef.pf = dnsprchild; - childdef.port = 53; - childdef.isudp = 1; - childdef.service = S_DNSPR; - childdef.helpmessage = " -s - simple DNS forwarding - do not use 3proxy resolver / name cache\n"; -#ifndef NOIPV6 - if(!resolvfunc || (resolvfunc == myresolver && !dns_table.hashsize) || resolvfunc == fakeresolver){ - fprintf(stderr, "[line %d] Warning: no nserver/nscache configured, dnspr will not work as expected\n", linenum); - } -#endif - } - return start_proxy_thread(&ch); -} - -static int h_internal(int argc, unsigned char ** argv){ - getip46(46, argv[1], (struct sockaddr *)&conf.intsa); - return 0; -} - -static int h_external(int argc, unsigned char ** argv){ - int res; -#ifndef NOIPV6 - struct sockaddr_in6 sa6; - memset(&sa6, 0, sizeof(sa6)); - res = getip46(46, argv[1], (struct sockaddr *)&sa6); - if(!res) return 1; - if (*SAFAMILY(&sa6)==AF_INET) conf.extsa = sa6; - else conf.extsa6 = sa6; -#else - res = getip46(46, argv[1], (struct sockaddr *)&conf.extsa); - if(!res) return 1; -#endif - return 0; -} - -static int h_log(int argc, unsigned char ** argv){ - unsigned char tmpbuf[8192]; - conf.logfunc = logstdout; - if(conf.logtarget){ - myfree(conf.logtarget); - conf.logtarget = NULL; - } - if(argc > 1) { - conf.logtarget = (unsigned char *)mystrdup((char *)argv[1]); - if(*argv[1]=='@'){ -#ifndef _WIN32 - openlog((char *)conf.logtarget+1, LOG_PID, LOG_DAEMON); - conf.logfunc = logsyslog; -#endif - } -#ifndef NOODBC - else if(*argv[1]=='&'){ - pthread_mutex_lock(&log_mutex); - close_sql(); - init_sql((char *)argv[1]+1); - pthread_mutex_unlock(&log_mutex); - conf.logfunc = logsql; - } -#endif - else { - FILE *fp; - if(argc > 2) { - conf.logtype = getrotate(*argv[2]); - } - conf.logtime = time(0); - if(conf.logname)myfree(conf.logname); - conf.logname = (unsigned char *)mystrdup((char *)argv[1]); - fp = fopen((char *)dologname (tmpbuf, conf.logname, NULL, conf.logtype, conf.logtime), "a"); - if(!fp){ - perror(tmpbuf); - return 1; - } - else { - if(conf.stdlog)fclose(conf.stdlog); - conf.stdlog = fp; -#ifdef _WINCE - freopen(tmpbuf, "w", stdout); - freopen(tmpbuf, "w", stderr); -#endif - } - } - } - return 0; -} - -static int h_stacksize(int argc, unsigned char **argv){ - conf.stacksize = atoi((char *)argv[1]); - return 0; -} - - -static int h_force(int argc, unsigned char **argv){ - conf.noforce = 0; - return 0; -} - -static int h_noforce(int argc, unsigned char **argv){ - conf.noforce = 1; - return 0; -} - -static int h_service(int argc, unsigned char **argv){ - return 0; -} - -static int h_daemon(int argc, unsigned char **argv){ - if(!conf.demon)daemonize(); - conf.demon = 1; - return 0; -} - -static int h_config(int argc, unsigned char **argv){ - if(conf.conffile)myfree(conf.conffile); - conf.conffile = mystrdup((char *)argv[1]); - return 0; -} - -static int h_include(int argc, unsigned char **argv){ - int res; - FILE *fp1; - - fp1 = fopen((char *)argv[1], "r"); - if(!fp1){ - fprintf(stderr, "Unable to open included file: %s\n", argv[1]); - return 1; - } - res = readconfig(fp1); - fclose(fp1); - return res; -} - -static int h_archiver(int argc, unsigned char **argv){ - int j; - - conf.archiver = myalloc(argc * sizeof(char *)); - if(conf.archiver) { - conf.archiverc = argc; - for(j = 0; j < conf.archiverc; j++) conf.archiver[j] = (unsigned char *)mystrdup((char *)argv[j]); - } - return 0; -} - -static int h_counter(int argc, unsigned char **argv){ - struct counter_header ch1; - if(conf.counterd >=0)close(conf.counterd); - if(!conf.trafcountfunc) conf.trafcountfunc = trafcountfunc; - conf.counterd = open((char *)argv[1], O_BINARY|O_RDWR|O_CREAT, 0660); - if(conf.counterd<0){ - fprintf(stderr, "Unable to open counter file %s, line %d\n", argv[1], linenum); - return 1; - } - if(read(conf.counterd, &ch1, sizeof(ch1))==sizeof(ch1)){ - if(memcmp(&ch1, &cheader, 4)){ - fprintf(stderr, "Not a counter file %s, line %d\n", argv[1], linenum); - return 2; - } -#ifdef _MSC_VER -#ifdef _TIME64_T_DEFINED -#ifndef _MAX__TIME64_T -#define _MAX__TIME64_T 0x793406fffi64 -#endif - if(ch1.updated >= _MAX__TIME64_T){ - fprintf(stderr, "Invalid or corrupted counter file %s. Use countersutil utility to convert from older version\n", argv[1]); - return 3; - } -#endif -#endif - cheader.updated = ch1.updated; - } - if(argc >=4) { - conf.countertype = getrotate(*argv[2]); - if(conf.counterfile) myfree(conf.counterfile); - conf.counterfile = mystrdup((char *)argv[3]); - } - return 0; -} - -static int h_rotate(int argc, unsigned char **argv){ - conf.rotate = atoi((char *)argv[1]); - return 0; -} - -static int h_logformat(int argc, unsigned char **argv){ - if(conf.logformat) myfree(conf.logformat); - conf.logformat = (unsigned char *)mystrdup((char *)argv[1]); - return 0; -} - -static int h_timeouts(int argc, unsigned char **argv){ - int j; - - for(j = 0; conf.timeouts[j] && j + 1 < argc; j++) { - if((conf.timeouts[j] = atoi((char *)argv[j + 1])) <= 0 || conf.timeouts[j] > 2000000){ - fprintf(stderr, "Invalid timeout: %s, line %d\n", argv[j + 1], linenum); - return(1); - } - } - return 0; -} - -static int h_noop(int argc, unsigned char **argv){ - return 0; -} - -static int h_auth(int argc, unsigned char **argv){ - struct auth *au, * newau; - - freeauth(conf.authfuncs); - conf.authfuncs = NULL; - if(!conf.bandlimfunc)conf.bandlimfunc = bandlimitfunc; - for(argc--; argc; argc--){ - for(au = authfuncs; au; au=au->next){ - if(!strcmp((char *)argv[argc], au->desc)){ - newau = myalloc(sizeof(struct auth)); - newau->next = conf.authfuncs; - conf.authfuncs = newau; - conf.authfuncs->desc = au->desc; - conf.authfuncs->authenticate = au->authenticate; - conf.authfuncs->authorize = au->authorize; - break; - } - } - if(!au) return 1; - } - conf.authfunc = doauth; - return 0; -} - -static int h_users(int argc, unsigned char **argv){ - int j; - unsigned char *arg; - struct passwords *pwl = NULL; - - for (j = 1; juser = (unsigned char *)mystrdup((char *)argv[j]); - pwl->pwtype = SYS; - } - else { - *arg = 0; - pwl->user = (unsigned char *)mystrdup((char *)argv[j]); - if((arg[1] == 'C' && arg[2] == 'L' && (pwl->pwtype = CL)) || - (arg[1] == 'C' && arg[2] == 'R' && (pwl->pwtype = CR)) || - (arg[1] == 'N' && arg[2] == 'T' && (pwl->pwtype = NT)) || - (arg[1] == 'L' && arg[2] == 'M' && (pwl->pwtype = LM))){ - pwl->password = (unsigned char *)mystrdup((char *)arg+4); - } - else { - pwl->password = (unsigned char *) mystrdup((char *)arg + 1); - pwl->pwtype = UN; - } - } - pthread_mutex_lock(&pwl_mutex); - pwl->next = conf.pwl; - conf.pwl = pwl; - pthread_mutex_unlock(&pwl_mutex); - - - } - return 0; -} - -static int h_maxconn(int argc, unsigned char **argv){ - conf.maxchild = atoi((char *)argv[1]); - if(!conf.maxchild) { - return(1); - } -#ifndef _WIN32 - { - struct rlimit rl; - if(!getrlimit(RLIMIT_NOFILE, &rl)){ - if((conf.maxchild<<1) > rl.rlim_cur) - fprintf(stderr, "[line %d] Warning: current open file ulimits are too low (cur: %d/max: %d)," - " maxconn requires at least %d for every running service." - " Configure ulimits according to system documentation\n", - linenum, (int)rl.rlim_cur, (int)rl.rlim_max, (conf.maxchild<<1)); - } - } -#endif - return 0; -} - -static int h_flush(int argc, unsigned char **argv){ - freeacl(conf.acl); - conf.acl = NULL; - return 0; -} - -/* -static int h_flushusers(int argc, unsigned char **argv){ - freepwl(conf.pwl); - conf.pwl = NULL; - return 0; -} -*/ - -static int h_nserver(int argc, unsigned char **argv){ - char *str; - - if(numservers < MAXNSERVERS) { - if((str = strchr((char *)argv[1], '/'))) - *str = 0; - if(!getip46(46, argv[1], (struct sockaddr *)&nservers[numservers].addr)) return 1; - *SAPORT(&nservers[numservers].addr) = htons(53); - if(str) { - nservers[numservers].usetcp = strstr(str + 1, "tcp")? 1:0; - *str = '/'; - } - numservers++; - - } - resolvfunc = myresolver; - return 0; -} - -static int h_authnserver(int argc, unsigned char **argv){ - char *str; - - if((str = strchr((char *)argv[1], '/'))) - *str = 0; - if(!getip46(46, argv[1], (struct sockaddr *)&authnserver.addr)) return 1; - *SAPORT(&authnserver.addr) = htons(53); - if(str) { - authnserver.usetcp = strstr(str + 1, "tcp")? 1:0; - *str = '/'; - } - return 0; -} - -static int h_fakeresolve(int argc, unsigned char **argv){ - resolvfunc = fakeresolver; - return 0; -} - -static int h_nscache(int argc, unsigned char **argv){ - int res; - - res = atoi((char *)argv[1]); - if(res < 256) { - fprintf(stderr, "Invalid NS cache size: %d\n", res); - return 1; - } - if(inithashtable(&dns_table, (unsigned)res)){ - fprintf(stderr, "Failed to initialize NS cache\n"); - return 2; - } - return 0; -} -static int h_nscache6(int argc, unsigned char **argv){ - int res; - - res = atoi((char *)argv[1]); - if(res < 256) { - fprintf(stderr, "Invalid NS cache size: %d\n", res); - return 1; - } - if(inithashtable(&dns6_table, (unsigned)res)){ - fprintf(stderr, "Failed to initialize NS cache\n"); - return 2; - } - return 0; -} - -static int h_nsrecord(int argc, unsigned char **argv){ -#ifndef NOIPV6 - struct sockaddr_in6 sa; -#else - struct sockaddr_in sa; -#endif - memset(&sa, 0, sizeof(sa)); - if(!getip46(46, argv[2], (struct sockaddr *)&sa)) return 1; - - hashadd(*SAFAMILY(&sa)==AF_INET6?&dns6_table:&dns_table, argv[1], SAADDR(&sa), (time_t)0xffffffff); - return 0; -} - -static int h_dialer(int argc, unsigned char **argv){ - if(conf.demanddialprog) myfree(conf.demanddialprog); - conf.demanddialprog = mystrdup((char *)argv[1]); - return 0; -} - -static int h_system(int argc, unsigned char **argv){ - int res; - - if((res = system((char *)argv[1])) == -1){ - fprintf(stderr, "Failed to start %s\n", argv[1]); - return(1); - } - return 0; -} - -static int h_pidfile(int argc, unsigned char **argv){ - FILE *pidf; - - if(!(pidf = fopen((char *)argv[1], "w"))){ - fprintf(stderr, "Failed to open pid file %s\n", argv[1]); - return(1); - } - fprintf(pidf,"%u", (unsigned)getpid()); - fclose(pidf); - return 0; -} - -static int h_monitor(int argc, unsigned char **argv){ - struct filemon * fm; - - fm = myalloc(sizeof (struct filemon)); - if(stat((char *)argv[1], &fm->sb)){ - myfree(fm); - fprintf(stderr, "Warning: file %s doesn't exist on line %d\n", argv[1], linenum); - } - else { - fm->path = mystrdup((char *)argv[1]); - fm->next = conf.fmon; - conf.fmon = fm; - } - return 0; -} - -static int h_parent(int argc, unsigned char **argv){ - struct ace *acl = NULL; - struct chain *chains; - - acl = conf.acl; - while(acl && acl->next) acl = acl->next; - if(!acl || (acl->action && acl->action != 2)) { - fprintf(stderr, "Chaining error: last ACL entry was not \"allow\" or \"redirect\" on line %d\n", linenum); - return(1); - } - acl->action = 2; - - chains = NULL; - if(!acl->chains) { - chains = acl->chains = myalloc(sizeof(struct chain)); - } - else { - chains = acl->chains; - while(chains->next)chains = chains->next; - chains->next = myalloc(sizeof(struct chain)); - chains = chains->next; - } - memset(chains, 0, sizeof(struct chain)); - if(!chains){ - fprintf(stderr, "Chainig error: unable to allocate memory for chain\n"); - return(2); - } - chains->weight = (unsigned)atoi((char *)argv[1]); - if(chains->weight == 0 || chains->weight >1000) { - fprintf(stderr, "Chaining error: bad chain weight %u line %d\n", chains->weight, linenum); - return(3); - } - if(!strcmp((char *)argv[2], "tcp"))chains->type = R_TCP; - else if(!strcmp((char *)argv[2], "http"))chains->type = R_HTTP; - else if(!strcmp((char *)argv[2], "connect"))chains->type = R_CONNECT; - else if(!strcmp((char *)argv[2], "socks4"))chains->type = R_SOCKS4; - else if(!strcmp((char *)argv[2], "socks5"))chains->type = R_SOCKS5; - else if(!strcmp((char *)argv[2], "connect+"))chains->type = R_CONNECTP; - else if(!strcmp((char *)argv[2], "socks4+"))chains->type = R_SOCKS4P; - else if(!strcmp((char *)argv[2], "socks5+"))chains->type = R_SOCKS5P; - else if(!strcmp((char *)argv[2], "socks4b"))chains->type = R_SOCKS4B; - else if(!strcmp((char *)argv[2], "socks5b"))chains->type = R_SOCKS5B; - else if(!strcmp((char *)argv[2], "pop3"))chains->type = R_POP3; - else if(!strcmp((char *)argv[2], "ftp"))chains->type = R_FTP; - else if(!strcmp((char *)argv[2], "admin"))chains->type = R_ADMIN; - else if(!strcmp((char *)argv[2], "icq"))chains->type = R_ICQ; - else if(!strcmp((char *)argv[2], "extip"))chains->type = R_EXTIP; - else if(!strcmp((char *)argv[2], "smtp"))chains->type = R_SMTP; - else { - fprintf(stderr, "Chaining error: bad chain type (%s)\n", argv[2]); - return(4); - } - if(!getip46(46, argv[3], (struct sockaddr *)&chains->addr)) return 5; - *SAPORT(&chains->addr) = htons((unsigned short)atoi((char *)argv[4])); - if(argc > 5) chains->extuser = (unsigned char *)mystrdup((char *)argv[5]); - if(argc > 6) chains->extpass = (unsigned char *)mystrdup((char *)argv[6]); - return 0; - -} - -static int h_nolog(int argc, unsigned char **argv){ - struct ace *acl = NULL; - - acl = conf.acl; - if(!acl) { - fprintf(stderr, "Chaining error: last ACL entry was not \"allow/deny\" on line %d\n", linenum); - return(1); - } - while(acl->next) acl = acl->next; - if(!strcmp((char *)argv[0],"nolog")) acl->nolog = 1; - else acl->weight = atoi((char*)argv[1]); - return 0; -} - -int scanipl(unsigned char *arg, struct iplist *dst){ -#ifndef NOIPV6 - struct sockaddr_in6 sa; -#else - struct sockaddr_in sa; -#endif - char * slash, *dash; - int masklen, addrlen; - if((slash = strchr((char *)arg, '/'))) *slash = 0; - if((dash = strchr((char *)arg,'-'))) *dash = 0; - - if(!getip46(46, arg, (struct sockaddr *)&sa)) return 1; - memcpy(&dst->ip_from, SAADDR(&sa), SAADDRLEN(&sa)); - dst->family = *SAFAMILY(&sa); - if(dash){ - if(!getip46(46, (unsigned char *)dash+1, (struct sockaddr *)&sa)) return 2; - memcpy(&dst->ip_to, SAADDR(&sa), SAADDRLEN(&sa)); - if(*SAFAMILY(&sa) != dst->family || memcmp(&dst->ip_to, &dst->ip_from, SAADDRLEN(&sa)) < 0) return 3; - return 0; - } - memcpy(&dst->ip_to, &dst->ip_from, SAADDRLEN(&sa)); - if(slash){ - addrlen = SAADDRLEN(&sa); - masklen = atoi(slash+1); - if(masklen < 0 || masklen > (addrlen*8)) return 4; - else { - int i, nbytes = masklen / 8, nbits = (8 - (masklen % 8)) % 8; - - for(i = addrlen; i>(nbytes + (nbits > 0)); i--){ - ((unsigned char *)&dst->ip_from)[i-1] = 0x00; - ((unsigned char *)&dst->ip_to)[i-1] = 0xff; - } - for(;nbits;nbits--){ - ((unsigned char *)&dst->ip_from)[nbytes] &= ~(0x01<<(nbits-1)); - ((unsigned char *)&dst->ip_to)[nbytes] |= (0x01<<(nbits-1)); - } - return 0; - } - } - return 0; -} - -struct ace * make_ace (int argc, unsigned char ** argv){ - struct ace * acl; - unsigned char *arg; - struct iplist *ipl=NULL; - struct portlist *portl=NULL; - struct userlist *userl=NULL; - struct hostname *hostnamel=NULL; - int res; - - acl = myalloc(sizeof(struct ace)); - if(!acl) return acl; - memset(acl, 0, sizeof(struct ace)); - if(argc > 0 && strcmp("*", (char *)argv[0])) { - arg = argv[0]; - arg = (unsigned char *)strtok((char *)arg, ","); - do { - if(!acl->users) { - acl->users = userl = myalloc(sizeof(struct userlist)); - } - else { - userl->next = myalloc(sizeof(struct userlist)); - userl = userl -> next; - } - if(!userl) { - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(NULL); - } - memset(userl, 0, sizeof(struct userlist)); - userl->user=(unsigned char*)mystrdup((char *)arg); - } while((arg = (unsigned char *)strtok((char *)NULL, ","))); - } - if(argc > 1 && strcmp("*", (char *)argv[1])) { - arg = (unsigned char *)strtok((char *)argv[1], ","); - do { - if(!acl->src) { - acl->src = ipl = myalloc(sizeof(struct iplist)); - } - else { - ipl->next = myalloc(sizeof(struct iplist)); - ipl = ipl -> next; - } - if(!ipl) { - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(NULL); - } - memset(ipl, 0, sizeof(struct iplist)); - if (scanipl(arg, ipl)) { - fprintf(stderr, "Invalid IP, IP range or CIDR, line %d\n", linenum); - return(NULL); - } - } while((arg = (unsigned char *)strtok((char *)NULL, ","))); - } - if(argc > 2 && strcmp("*", (char *)argv[2])) { - arg = (unsigned char *)strtok((char *)argv[2], ","); - do { - int arglen; - unsigned char *pattern; - - arglen = (int)strlen((char *)arg); - if(arglen > 0 && (arg[arglen-1] < '0' || arg[arglen-1] > '9')){ - if(!acl->dstnames) { - acl->dstnames = hostnamel = myalloc(sizeof(struct hostname)); - } - else { - hostnamel->next = myalloc(sizeof(struct hostname)); - hostnamel = hostnamel -> next; - } - if(!hostnamel){ - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(NULL); - } - memset(hostnamel, 0, sizeof(struct hostname)); - hostnamel->matchtype = 3; - pattern = arg; - if(pattern[arglen-1] == '*'){ - arglen --; - pattern[arglen] = 0; - hostnamel->matchtype ^= MATCHEND; - } - if(pattern[0] == '*'){ - pattern++; - arglen--; - hostnamel->matchtype ^= MATCHBEGIN; - } - hostnamel->name = (unsigned char *) mystrdup( (char *)pattern); - if(!hostnamel->name) { - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(NULL); - } - } - else { - - if(!acl->dst) { - acl->dst = ipl = myalloc(sizeof(struct iplist)); - } - else { - ipl->next = myalloc(sizeof(struct iplist)); - ipl = ipl -> next; - } - if(!ipl) { - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(NULL); - } - memset(ipl, 0, sizeof(struct iplist)); - if (scanipl(arg, ipl)) { - fprintf(stderr, "Invalid IP, IP range or CIDR, line %d\n", linenum); - return(NULL); - } - } - }while((arg = (unsigned char *)strtok((char *)NULL, ","))); - } - if(argc > 3 && strcmp("*", (char *)argv[3])) { - arg = (unsigned char *)strtok((char *)argv[3], ","); - do { - if(!acl->ports) { - acl->ports = portl = myalloc(sizeof(struct portlist)); - } - else { - portl->next = myalloc(sizeof(struct portlist)); - portl = portl -> next; - } - if(!portl) { - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(NULL); - } - memset(portl, 0, sizeof(struct portlist)); - res = sscanf((char *)arg, "%hu-%hu", &portl->startport, &portl->endport); - if(res < 1) { - fprintf(stderr, "Invalid port or port range, line %d\n", linenum); - return(NULL); - } - if (res == 1) portl->endport = portl->startport; - } while((arg = (unsigned char *)strtok((char *)NULL, ","))); - } - if(argc > 4 && strcmp("*", (char *)argv[4])) { - arg = (unsigned char *)strtok((char *)argv[4], ","); - do { - if(!strcmp((char *)arg, "CONNECT")){ - acl->operation |= CONNECT; - } - else if(!strcmp((char *)arg, "BIND")){ - acl->operation |= BIND; - } - else if(!strcmp((char *)arg, "UDPASSOC")){ - acl->operation |= UDPASSOC; - } - else if(!strcmp((char *)arg, "ICMPASSOC")){ - acl->operation |= ICMPASSOC; - } - else if(!strcmp((char *)arg, "HTTP_GET")){ - acl->operation |= HTTP_GET; - } - else if(!strcmp((char *)arg, "HTTP_PUT")){ - acl->operation |= HTTP_PUT; - } - else if(!strcmp((char *)arg, "HTTP_POST")){ - acl->operation |= HTTP_POST; - } - else if(!strcmp((char *)arg, "HTTP_HEAD")){ - acl->operation |= HTTP_HEAD; - } - else if(!strcmp((char *)arg, "HTTP_OTHER")){ - acl->operation |= HTTP_OTHER; - } - else if(!strcmp((char *)arg, "HTTP_CONNECT")){ - acl->operation |= HTTP_CONNECT; - } - else if(!strcmp((char *)arg, "HTTP")){ - acl->operation |= HTTP; - } - else if(!strcmp((char *)arg, "HTTPS")){ - acl->operation |= HTTPS; - } - else if(!strcmp((char *)arg, "FTP_GET")){ - acl->operation |= FTP_GET; - } - else if(!strcmp((char *)arg, "FTP_PUT")){ - acl->operation |= FTP_PUT; - } - else if(!strcmp((char *)arg, "FTP_LIST")){ - acl->operation |= FTP_LIST; - } - else if(!strcmp((char *)arg, "FTP_DATA")){ - acl->operation |= FTP_DATA; - } - else if(!strcmp((char *)arg, "FTP")){ - acl->operation |= FTP; - } - else if(!strcmp((char *)arg, "ADMIN")){ - acl->operation |= ADMIN; - } - else if(!strcmp((char *)arg, "DNSRESOLVE")){ - acl->operation |= DNSRESOLVE; - } - else if(!strcmp((char *)arg, "ICQ")){ - acl->operation |= IM_ICQ; - } - else { - fprintf(stderr, "Unknown operation type: %s line %d\n", arg, linenum); - return(NULL); - } - } while((arg = (unsigned char *)strtok((char *)NULL, ","))); - } - if(argc > 5){ - for(arg = argv[5]; *arg;){ - int val, val1; - - if(!isnumber(*arg)){ - arg++; - continue; - } - val1 = val = (*arg - '0'); - arg++; - if(*arg == '-' && isnumber(*(arg+1)) && (*(arg+1) - '0') > val) { - val1 = (*(arg+1) - '0'); - arg+=2; - } - for(; val<=val1; val++) acl->wdays |= (1 << (val % 7)); - } - - } - if(argc > 6){ - for(arg = argv[6]; strlen((char *)arg) >= 17 && - isdigit(arg[0]) && - isdigit(arg[1]) && - isdigit(arg[3]) && - isdigit(arg[4]) && - isdigit(arg[6]) && - isdigit(arg[7]) && - isdigit(arg[9]) && - isdigit(arg[10]) && - isdigit(arg[12]) && - isdigit(arg[13]) && - isdigit(arg[15]) && - isdigit(arg[16]) - ; arg+=18){ - - int t1, t2; - struct period *sp; - - t1 = (arg[0] - '0') * 10 + (arg[1] - '0'); - t1 = (t1 * 60) + (arg[3] - '0') * 10 + (arg[4] - '0'); - t1 = (t1 * 60) + (arg[6] - '0') * 10 + (arg[7] - '0'); - t2 = (arg[9] - '0') * 10 + (arg[10] - '0'); - t2 = (t2 * 60) + (arg[12] - '0') * 10 + (arg[13] - '0'); - t2 = (t2 * 60) + (arg[15] - '0') * 10 + (arg[16] - '0'); - if(t2 < t1) break; - sp = myalloc(sizeof(struct period)); - if(sp){ - sp->fromtime = t1; - sp->totime = t2; - sp->next = acl->periods; - acl->periods = sp; - } - if(arg[17]!=',') break; - } - } - if (argc > 7){ - acl->weight = atoi((char *)argv[7]); - } - - return acl; -} - - -static int h_ace(int argc, unsigned char **argv){ - int res = 0; - int offset = 0; - struct ace *acl = NULL; - struct bandlim * nbl; - struct trafcount * tl; - - if(!strcmp((char *)argv[0], "allow")){ - res = ALLOW; - } - else if(!strcmp((char *)argv[0], "deny")){ - res = DENY; - } - else if(!strcmp((char *)argv[0], "redirect")){ - res = REDIRECT; - offset = 2; - } - else if(!strcmp((char *)argv[0], "bandlimin")||!strcmp((char *)argv[0], "bandlimout")){ - res = BANDLIM; - offset = 1; - } - else if(!strcmp((char *)argv[0], "nobandlimin")||!strcmp((char *)argv[0], "nobandlimout")){ - res = NOBANDLIM; - } - else if(!strcmp((char *)argv[0], "countin")){ - res = COUNTIN; - offset = 3; - } - else if(!strcmp((char *)argv[0], "nocountin")){ - res = NOCOUNTIN; - } - else if(!strcmp((char *)argv[0], "countout")){ - res = COUNTOUT; - offset = 3; - } - else if(!strcmp((char *)argv[0], "nocountout")){ - res = NOCOUNTOUT; - } - acl = make_ace(argc - (offset+1), argv + (offset + 1)); - if(!acl) { - fprintf(stderr, "Unable to parse ACL entry, line %d\n", linenum); - return(1); - } - acl->action = res; - switch(acl->action){ - case REDIRECT: - acl->chains = myalloc(sizeof(struct chain)); - memset(acl->chains, 0, sizeof(struct chain)); - if(!acl->chains) { - fprintf(stderr, "No memory for ACL entry, line %d\n", linenum); - return(2); - } - acl->chains->type = R_HTTP; - if(!getip46(46, argv[1], (struct sockaddr *)&acl->chains->addr)) return 5; - *SAPORT(&acl->chains->addr) = htons((unsigned short)atoi((char *)argv[2])); - acl->chains->weight = 1000; - acl->chains->extuser = NULL; - acl->chains->extpass = NULL; - acl->chains->next = NULL; - case ALLOW: - case DENY: - if(!conf.acl){ - conf.acl = acl; - } - else { - struct ace * acei; - - for(acei = conf.acl; acei->next; acei = acei->next); - acei->next = acl; - } - break; - case BANDLIM: - case NOBANDLIM: - - nbl = myalloc(sizeof(struct bandlim)); - if(!nbl) { - fprintf(stderr, "No memory to create band limit filter\n"); - return(3); - } - memset(nbl, 0, sizeof(struct bandlim)); - nbl->ace = acl; - if(acl->action == BANDLIM) { - sscanf((char *)argv[1], "%u", &nbl->rate); - if(nbl->rate < 300) { - fprintf(stderr, "Wrong bandwidth specified, line %d\n", linenum); - return(4); - } - } - pthread_mutex_lock(&bandlim_mutex); - if(!strcmp((char *)argv[0], "bandlimin") || !strcmp((char *)argv[0], "nobandlimin")){ - if(!conf.bandlimiter){ - conf.bandlimiter = nbl; - } - else { - struct bandlim * bli; - - for(bli = conf.bandlimiter; bli->next; bli = bli->next); - bli->next = nbl; - } - } - else { - if(!conf.bandlimiterout){ - conf.bandlimiterout = nbl; - } - else { - struct bandlim * bli; - - for(bli = conf.bandlimiterout; bli->next; bli = bli->next); - bli->next = nbl; - } - } - - pthread_mutex_unlock(&bandlim_mutex); - break; - - case COUNTIN: - case NOCOUNTIN: - case COUNTOUT: - case NOCOUNTOUT: - tl = myalloc(sizeof(struct trafcount)); - if(!tl) { - fprintf(stderr, "No memory to create traffic limit filter\n"); - return(5); - } - memset(tl, 0, sizeof(struct trafcount)); - tl->ace = acl; - - if((acl->action == COUNTIN)||(acl->action == COUNTOUT)) { - unsigned long lim; - - tl->comment = ( char *)argv[1]; - while(isdigit(*tl->comment))tl->comment++; - if(*tl->comment== '/')tl->comment++; - tl->comment = mystrdup(tl->comment); - - sscanf((char *)argv[1], "%u", &tl->number); - sscanf((char *)argv[3], "%lu", &lim); - tl->type = getrotate(*argv[2]); - tl->traflim64 = ((uint64_t)lim)*(1024*1024); - if(!tl->traflim64) { - fprintf(stderr, "Wrong traffic limit specified, line %d\n", linenum); - return(6); - } - if(tl->number != 0 && conf.counterd >= 0) { - lseek(conf.counterd, - sizeof(struct counter_header) + (tl->number - 1) * sizeof(struct counter_record), - SEEK_SET); - memset(&crecord, 0, sizeof(struct counter_record)); - read(conf.counterd, &crecord, sizeof(struct counter_record)); - tl->traf64 = crecord.traf64; - tl->cleared = crecord.cleared; - tl->updated = crecord.updated; -#ifdef _MAX__TIME64_T - if(tl->cleared >= _MAX__TIME64_T || tl->updated >= _MAX__TIME64_T){ - fprintf(stderr, "Invalid or corrupted counter file. Use countersutil utility to convert from older version\n"); - return(6); - } -#endif - } - } - pthread_mutex_lock(&tc_mutex); - if(!conf.trafcounter){ - conf.trafcounter = tl; - } - else { - struct trafcount * ntl; - - for(ntl = conf.trafcounter; ntl->next; ntl = ntl->next); - ntl->next = tl; - } - pthread_mutex_unlock(&tc_mutex); - - } - return 0; -} - -static int h_logdump(int argc, unsigned char **argv){ - conf.logdumpsrv = (unsigned) atoi((char *) *(argv + 1)); - if(argc > 2) conf.logdumpcli = (unsigned) atoi((char *) *(argv + 2)); - return 0; -} - - -static int h_filtermaxsize(int argc, unsigned char **argv){ - conf.filtermaxsize = atoi((char *) *(argv + 1)); - return 0; -} - -static int h_delimchar(int argc, unsigned char **argv){ - conf.delimchar = *argv[1]; - return 0; -} - -static int h_authcache(int argc, unsigned char **argv){ - conf.authcachetype = 0; - if(strstr((char *) *(argv + 1), "ip")) conf.authcachetype |= 1; - if(strstr((char *) *(argv + 1), "user")) conf.authcachetype |= 2; - if(strstr((char *) *(argv + 1), "pass")) conf.authcachetype |= 4; - if(argc > 2) conf.authcachetime = (unsigned) atoi((char *) *(argv + 2)); - if(!conf.authcachetype) conf.authcachetype = 6; - if(!conf.authcachetime) conf.authcachetime = 600; - return 0; -} - -static int h_plugin(int argc, unsigned char **argv){ -#ifdef NOPLUGINS - return 999; -#else -#ifdef _WIN32 - HINSTANCE hi; - FARPROC fp; - -#ifdef _WINCE - hi = LoadLibraryW((LPCWSTR)CEToUnicode(argv[1])); -#else - hi = LoadLibrary((char *)argv[1]); -#endif - if(!hi) { - fprintf(stderr, "Failed to load %s, code %d\n", argv[1], (int)GetLastError()); - return 1; - } -#ifdef _WINCE - fp = GetProcAddressW(hi, (LPCWSTR)CEToUnicode(argv[2])); -#else - fp = GetProcAddress(hi, (char *)argv[2]); -#endif - if(!fp) { - printf("%s not found in %s, code: %d\n", argv[2], argv[1], (int)GetLastError()); - return 2; - } - return (*(PLUGINFUNC)fp)(&pluginlink, argc - 2, (char **)argv + 2); -#else - void *hi, *fp; - hi = dlopen((char *)argv[1], RTLD_LAZY); - if(!hi) return 1; - fp = dlsym(hi, (char *)argv[2]); - if(!fp) return 2; - return (*(PLUGINFUNC)fp)(&pluginlink, argc - 2, (char **)argv + 2); -#endif -#endif -} - -#ifndef _WIN32 -static int h_setuid(int argc, unsigned char **argv){ - int res; - res = atoi((char *)argv[1]); - if(!res || setreuid(res,res)) { - fprintf(stderr, "Unable to set uid %d", res); - return(1); - } - return 0; -} - -static int h_setgid(int argc, unsigned char **argv){ - int res; - - res = atoi((char *)argv[1]); - if(!res || setregid(res,res)) { - fprintf(stderr, "Unable to set gid %d", res); - return(1); - } - return 0; -} - - -static int h_chroot(int argc, unsigned char **argv){ - if(!chrootp){ - char *p; - if(chroot((char *)argv[1])) { - fprintf(stderr, "Unable to chroot %s", argv[1]); - return(1); - } - p = (char *)argv[1] + strlen((char *)argv[1]) ; - while (p > (char *)argv[1] && p[-1] == '/'){ - p--; - *p = 0; - } - chrootp = mystrdup((char *)argv[1]); - } - return 0; -} -#endif - - -struct commands specificcommands[]={ -#ifndef _WIN32 - {specificcommands+1, "setuid", h_setuid, 2, 2}, - {specificcommands+2, "setgid", h_setgid, 2, 2}, - {specificcommands+3, "chroot", h_chroot, 2, 2}, -#endif - {NULL, "", h_noop, 1, 0} -}; - -struct commands commandhandlers[]={ - {commandhandlers+1, "", h_noop, 1, 0}, - {commandhandlers+2, "proxy", h_proxy, 1, 0}, - {commandhandlers+3, "pop3p", h_proxy, 1, 0}, - {commandhandlers+4, "ftppr", h_proxy, 1, 0}, - {commandhandlers+5, "socks", h_proxy, 1, 0}, - {commandhandlers+6, "tcppm", h_proxy, 4, 0}, - {commandhandlers+7, "udppm", h_proxy, 4, 0}, - {commandhandlers+8, "admin", h_proxy, 1, 0}, - {commandhandlers+9, "dnspr", h_proxy, 1, 0}, - {commandhandlers+10, "internal", h_internal, 2, 2}, - {commandhandlers+11, "external", h_external, 2, 2}, - {commandhandlers+12, "log", h_log, 1, 0}, - {commandhandlers+13, "service", h_service, 1, 1}, - {commandhandlers+14, "daemon", h_daemon, 1, 1}, - {commandhandlers+15, "config", h_config, 2, 2}, - {commandhandlers+16, "include", h_include, 2, 2}, - {commandhandlers+17, "archiver", h_archiver, 3, 0}, - {commandhandlers+18, "counter", h_counter, 2, 4}, - {commandhandlers+19, "rotate", h_rotate, 2, 2}, - {commandhandlers+20, "logformat", h_logformat, 2, 2}, - {commandhandlers+21, "timeouts", h_timeouts, 2, 0}, - {commandhandlers+22, "auth", h_auth, 2, 0}, - {commandhandlers+23, "users", h_users, 2, 0}, - {commandhandlers+24, "maxconn", h_maxconn, 2, 2}, - {commandhandlers+25, "flush", h_flush, 1, 1}, - {commandhandlers+26, "nserver", h_nserver, 2, 2}, - {commandhandlers+27, "fakeresolve", h_fakeresolve, 1, 1}, - {commandhandlers+28, "nscache", h_nscache, 2, 2}, - {commandhandlers+29, "nscache6", h_nscache6, 2, 2}, - {commandhandlers+30, "nsrecord", h_nsrecord, 3, 3}, - {commandhandlers+31, "dialer", h_dialer, 2, 2}, - {commandhandlers+32, "system", h_system, 2, 2}, - {commandhandlers+33, "pidfile", h_pidfile, 2, 2}, - {commandhandlers+34, "monitor", h_monitor, 2, 2}, - {commandhandlers+35, "parent", h_parent, 5, 0}, - {commandhandlers+36, "allow", h_ace, 1, 0}, - {commandhandlers+37, "deny", h_ace, 1, 0}, - {commandhandlers+38, "redirect", h_ace, 3, 0}, - {commandhandlers+39, "bandlimin", h_ace, 2, 0}, - {commandhandlers+40, "bandlimout", h_ace, 2, 0}, - {commandhandlers+41, "nobandlimin", h_ace, 1, 0}, - {commandhandlers+42, "nobandlimout", h_ace, 1, 0}, - {commandhandlers+43, "countin", h_ace, 4, 0}, - {commandhandlers+44, "nocountin", h_ace, 1, 0}, - {commandhandlers+45, "countout", h_ace, 4, 0}, - {commandhandlers+46, "nocountout", h_ace, 1, 0}, - {commandhandlers+47, "plugin", h_plugin, 3, 0}, - {commandhandlers+48, "logdump", h_logdump, 2, 3}, - {commandhandlers+49, "filtermaxsize", h_filtermaxsize, 2, 2}, - {commandhandlers+50, "nolog", h_nolog, 1, 1}, - {commandhandlers+51, "weight", h_nolog, 2, 2}, - {commandhandlers+52, "authcache", h_authcache, 2, 3}, - {commandhandlers+53, "smtpp", h_proxy, 1, 0}, - {commandhandlers+54, "icqpr", h_proxy, 4, 0}, - {commandhandlers+55, "msnpr", h_proxy, 4, 0}, - {commandhandlers+56, "delimchar",h_delimchar, 2, 2}, - {commandhandlers+57, "authnserver", h_authnserver, 2, 2}, - {commandhandlers+58, "stacksize", h_stacksize, 2, 2}, - {commandhandlers+59, "force", h_force, 1, 1}, - {commandhandlers+60, "noforce", h_noforce, 1, 1}, - {specificcommands, "", h_noop, 1, 0} -}; - -int parsestr (unsigned char *str, unsigned char **argm, int nitems, unsigned char ** buff, int *inbuf, int *bufsize){ -#define buf (*buff) - int argc = 0; - int space = 1; - int comment = 0; - unsigned char * incbegin = 0; - int fd; - int res, len; - int i = 1; - unsigned char *str1; - - for(;;str++){ - if(*str == '\"'){ - str1 = str; - do { - *str1 = *(str1 + 1); - }while(*(str1++)); - if(!comment || *str != '\"'){ - comment = !comment; - } - } - switch(*str){ - case '\0': - if(comment) return -1; - argm[argc] = 0; - return argc; - case '$': - if(!comment && !included){ - incbegin = str; - *str = 0; - } - break; - case '\r': - case '\n': - case '\t': - case ' ': - if(!comment){ - *str = 0; - space = 1; - i = 0; - if(incbegin){ - argc--; - if((fd = open((char *)incbegin+1, O_RDONLY)) <= 0){ - fprintf(stderr, "Failed to open %s\n", incbegin+1); - break; - } - if((*bufsize - *inbuf) = nitems) return argc; - space = 0; - } - } - } -#undef buf -} - - -int readconfig(FILE * fp){ - unsigned char ** argv = NULL; - unsigned char * buf = NULL; - int bufsize = STRINGBUF*2; - int inbuf = 0; - int argc; - struct commands * cm; - int res = 0; - - if( !(buf = myalloc(bufsize)) || ! (argv = myalloc((NPARAMS + 1) * sizeof(unsigned char *))) ) { - fprintf(stderr, "No memory for configuration"); - return(10); - } - for (linenum = 1; fgets((char *)buf, STRINGBUF, fp); linenum++){ - if(!*buf || isspace(*buf) || (*buf) == '#')continue; - - inbuf = (int)(strlen((char *)buf) + 1); - argc = parsestr (buf, argv, NPARAMS-1, &buf, &inbuf, &bufsize); - if(argc < 1) { - fprintf(stderr, "Parse error line %d\n", linenum); - return(21); - } - argv[argc] = NULL; - if(!strcmp((char *)argv[0], "end") && argc == 1) { - break; - } - else if(!strcmp((char *)argv[0], "writable") && argc == 1) { - if(!writable){ - writable = freopen(curconf, "r+", fp); - if(!writable){ - fprintf(stderr, "Unable to reopen config for writing: %s\n", curconf); - return 1; - } - } - continue; - } - - res = 1; - for(cm = commandhandlers; cm; cm = cm->next){ - if(!strcmp((char *)argv[0], (char *)cm->command) && argc >= cm->minargs && (!cm->maxargs || argc <= cm->maxargs)){ - res = (*cm->handler)(argc, argv); - if(res > 0){ - fprintf(stderr, "Command: '%s' failed with code %d, line %d\n", argv[0], res, linenum); - return(linenum); - } - if(!res) break; - } - } - if(res != 1)continue; - fprintf(stderr, "Unknown command: '%s' line %d\n", argv[0], linenum); - return(linenum); - } - myfree(buf); - myfree(argv); - return 0; - -} - - - -void freepwl(struct passwords *pwl){ - for(; pwl; pwl = (struct passwords *)itfree(pwl, pwl->next)){ - if(pwl->user)myfree(pwl->user); - if(pwl->password)myfree(pwl->password); - } -} - - -void freeconf(struct extparam *confp){ - struct bandlim * bl; - struct bandlim * blout; - struct trafcount * tc; - struct passwords *pw; - struct ace *acl; - struct filemon *fm; - int counterd, archiverc; - unsigned char *logname, *logtarget; - unsigned char **archiver; - unsigned char * logformat; - - int i; - - - - - pthread_mutex_lock(&tc_mutex); - confp->trafcountfunc = NULL; - tc = confp->trafcounter; - confp->trafcounter = NULL; - counterd = confp->counterd; - confp->counterd = -1; - confp->countertype = NONE; - pthread_mutex_unlock(&tc_mutex); - - pthread_mutex_lock(&bandlim_mutex); - bl = confp->bandlimiter; - blout = confp->bandlimiterout; - confp->bandlimiter = NULL; - confp->bandlimiterout = NULL; - confp->bandlimfunc = NULL; - pthread_mutex_unlock(&bandlim_mutex); - - pthread_mutex_lock(&pwl_mutex); - pw = confp->pwl; - confp->pwl = NULL; - pthread_mutex_unlock(&pwl_mutex); - - - logtarget = confp->logtarget; - confp->logtarget = NULL; - logformat = confp->logformat; - confp->logformat = NULL; - logname = confp->logname; - confp->logname = NULL; - confp->rotate = 0; - confp->logtype = NONE; - - archiverc = confp->archiverc; - confp->archiverc = 0; - archiver = confp->archiver; - confp->archiver = NULL; - fm = confp->fmon; - confp->fmon = NULL; - confp->bandlimfunc = NULL; - memset(&confp->intsa, 0, sizeof(confp->intsa)); - memset(&confp->extsa, 0, sizeof(confp->extsa)); -#ifndef NOIPV6 - memset(&confp->extsa6, 0, sizeof(confp->extsa6)); - *SAFAMILY(&confp->extsa6) = AF_INET6; -#endif - *SAFAMILY(&confp->intsa) = AF_INET; - *SAFAMILY(&confp->extsa) = AF_INET; - confp->singlepacket = 0; - confp->maxchild = 100; - resolvfunc = NULL; - numservers = 0; - acl = confp->acl; - confp->acl = NULL; - confp->logtime = confp->time = 0; - - usleep(SLEEPTIME); - - { - char * args[] = {"auth", "iponly", NULL}; - h_auth(2, (unsigned char **)args); - } - if(tc)dumpcounters(tc,counterd); - for(; tc; tc = (struct trafcount *) itfree(tc, tc->next)){ - if(tc->comment)myfree(tc->comment); - freeacl(tc->ace); - } - - - freeacl(acl); - freepwl(pw); - for(; bl; bl = (struct bandlim *) itfree(bl, bl->next)) freeacl(bl->ace); - for(; blout; blout = (struct bandlim *) itfree(blout, blout->next))freeacl(blout->ace); - - if(counterd != -1) { - close(counterd); - } - for(; fm; fm = (struct filemon *)itfree(fm, fm->next)){ - if(fm->path) myfree(fm->path); - } - if(logtarget) { - myfree(logtarget); - } - if(logname) { - myfree(logname); - } - if(logformat) { - myfree(logformat); - } - if(archiver) { - for(i = 0; i < archiverc; i++) myfree(archiver[i]); - myfree(archiver); - } - -} - -int reload (void){ - FILE *fp; - int error = -2; - - conf.paused++; - freeconf(&conf); - conf.paused++; - - fp = confopen(); - if(fp){ - error = readconfig(fp); - conf.version++; - if(error) { - freeconf(&conf); - } - if(!writable)fclose(fp); - } - return error; -} diff --git a/src/datatypes.c b/src/datatypes.c deleted file mode 100644 index d009671..0000000 --- a/src/datatypes.c +++ /dev/null @@ -1,817 +0,0 @@ -/* - * Copyright (c) 2000-2008 3APA3A - * - * please read License Agreement - * - */ - -#include "proxy.h" - -static void pr_unsigned64(struct node *node, CBFUNC cbf, void*cb){ - char buf[32]; - if(node->value)(*cbf)(cb, buf, sprintf(buf, "%"PRINTF_INT64_MODIFIER"u", *(uint64_t *)node->value)); -} - -static void pr_integer(struct node *node, CBFUNC cbf, void*cb){ - char buf[16]; - if(node->value)(*cbf)(cb, buf, sprintf(buf, "%d", *(int *)node->value)); -} - -static void pr_short(struct node *node, CBFUNC cbf, void*cb){ - char buf[8]; - if(node->value)(*cbf)(cb, buf, sprintf(buf, "%hu", *(unsigned short*)node->value)); -} - -static void pr_char(struct node *node, CBFUNC cbf, void*cb){ - if(node->value)(*cbf)(cb, (char *)node->value, 1); -} - - -static void pr_unsigned(struct node *node, CBFUNC cbf, void*cb){ - char buf[16]; - if(node->value)(*cbf)(cb, buf, sprintf(buf, "%u", *(unsigned *)node->value)); -} - -static void pr_traffic(struct node *node, CBFUNC cbf, void*cb){ - char buf[16]; - unsigned long u1, u2; - if(node->value){ - u1 = ((unsigned long *)node->value)[0]; - u2 = ((unsigned long *)node->value)[0]; - (*cbf)(cb, buf, sprintf(buf, "%lu", (u1>>20) + (u2<<10))); - } -} - -static void pr_port(struct node *node, CBFUNC cbf, void*cb){ - char buf[8]; - if(node->value)(*cbf)(cb, buf, sprintf(buf, "%hu", ntohs(*(unsigned short*)node->value))); -} - -static void pr_datetime(struct node *node, CBFUNC cbf, void*cb){ - char *s; - if(node->value){ - s = ctime((time_t *)node->value); - - (*cbf)(cb, s, (int)strlen(s)-1); - } -} - -static void pr_ip(struct node *node, CBFUNC cbf, void*cb){ - char buf[16]; - if(node->value)(*cbf)(cb, buf, myinet_ntop(AF_INET, node -> value, buf, 4)); -} - -static void pr_ip6(struct node *node, CBFUNC cbf, void*cb){ - char buf[64]; - if(node->value)(*cbf)(cb, buf, myinet_ntop(AF_INET6, node -> value, buf, 16)); -} - -static void pr_sa(struct node *node, CBFUNC cbf, void*cb){ -#ifdef NOIPV6 - if(node->value)return pr_ip(node, cbf, cb); -#else - char buf[64]; - buf[0] = '['; - buf[1] = 0; - inet_ntop(*SAFAMILY(node->value), node->value, buf+1, sizeof(buf)-10); - sprintf(buf + strlen(buf), "]:%hu", (unsigned short)*SAPORT(node->value)); - if(node->value)(*cbf)(cb, buf, strlen(buf)); -#endif -} - -static void pr_wdays(struct node *node, CBFUNC cbf, void*cb){ - char buf[16]; - int i, found = 0; - if(node -> value)for(i = 0; i<8; i++){ - if( (1< value ) { - sprintf(buf, "%s%d", found?",":"", i); - (*cbf)(cb, buf, found? 2:1); - found = 1; - } - } -} - -static void pr_time(struct node *node, CBFUNC cbf, void*cb){ - char buf[16]; - int t = *(int *)node; - - (*cbf)(cb, buf, sprintf(buf, "%02d:%02d:%02d", (t/3600)%24, (t/60)%60, t%60)); -} - -int cidrprint(char *buf, unsigned long u){ - unsigned long u1 = 0xffffffff; - int i; - - u = ntohl(u); - for(i = 32; i && (u1!=u); i--){ - u1 = (u1 << 1); - } - if (i == 32) { - return 0; - } - return sprintf(buf, "/%d", i); -} - -static void pr_cidr(struct node *node, CBFUNC cbf, void*cb){ - char buf[4]; - int i; - - if(node->value){ - if ((i = cidrprint(buf, *(unsigned *)node -> value))) - (*cbf)(cb, buf, i); - else (*cbf)(cb, "/32", 3); - } -} - -static void pr_string(struct node *node, CBFUNC cbf, void*cb){ - if(node->value){ - (*cbf)(cb, (char*)node->value, (int)strlen((char*)node->value)); - } - else (*cbf)(cb, "(NULL)", 6); -} - -static void pr_rotation(struct node *node, CBFUNC cbf, void*cb){ - char * lstrings[] = { - "N", "C", "H", "D", "W", "M", "Y", "N" - }; - int i; - - if(node->value && (i = *(int*)node->value) > 1 && i < 6){ - (*cbf)(cb, lstrings[i], 1); - } -} - -static void pr_operations(struct node *node, CBFUNC cbf, void*cb){ - char buf[64]; - int operation; - int delim = 0; - - *buf = 0; - if(!node->value || !(operation = *(int*)node->value)){ - (*cbf)(cb, "*", 1); - return; - } - if(operation & HTTP){ - if((operation & HTTP) == HTTP) - (*cbf)(cb, buf, sprintf(buf, "HTTP")); - else - (*cbf)(cb, buf, sprintf(buf, "%s%s%s%s%s%s%s%s%s", - (operation & HTTP_GET)? "HTTP_GET" : "", - ((operation & HTTP_GET) && (operation & (HTTP_PUT|HTTP_POST|HTTP_HEAD|HTTP_OTHER)))? "," : "", - (operation & HTTP_PUT)? "HTTP_PUT" : "", - ((operation & HTTP_PUT) && (operation & (HTTP_POST|HTTP_HEAD|HTTP_OTHER)))? "," : "", - (operation & HTTP_POST)? "HTTP_POST" : "", - ((operation & HTTP_POST) && (operation & (HTTP_HEAD|HTTP_OTHER)))? "," : "", - (operation & HTTP_HEAD)? "HTTP_HEAD" : "", - ((operation & HTTP_HEAD) && (operation & HTTP_OTHER))? "," : "", - (operation & HTTP_OTHER)? "HTTP_OTHER" : "")); - delim = 1; - } - if(operation & HTTP_CONNECT){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "HTTP_CONNECT")); - delim = 1; - } - if(operation & FTP) { - if((operation & FTP) == FTP) - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "FTP")); - else - (*cbf)(cb, buf, sprintf(buf, "%s%s%s%s%s%s", - delim? ",":"", - (operation & FTP_GET)? "FTP_GET" : "", - ((operation & FTP_GET) && (operation & (FTP_PUT|FTP_LIST)))? ",":"", - (operation & FTP_PUT)? "FTP_PUT" : "", - ((operation & FTP_PUT) && (operation & FTP_LIST))? ",":"", - (operation & FTP_LIST)? "FTP_LIST" : "")); - delim = 1; - } - if(operation & CONNECT){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "CONNECT")); - delim = 1; - } - if(operation & BIND){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "BIND")); - delim = 1; - } - if(operation & UDPASSOC){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "UDPASSOC")); - delim = 1; - } - if(operation & ICMPASSOC){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "ICMPASSOC")); - delim = 1; - } - if(operation & DNSRESOLVE){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "DNSRESOLVE")); - delim = 1; - } - if(operation & ADMIN){ - (*cbf)(cb, buf, sprintf(buf, "%s%s", delim?",":"", "ADMIN")); - } -} - -static void pr_portlist(struct node *node, CBFUNC cbf, void*cb){ - struct portlist *pl= (struct portlist *)node->value; - char buf[16]; - if(!pl) { - (*cbf)(cb, "*", 1); - return; - } - for(; pl; pl = pl->next) { - if(pl->startport == pl->endport) - (*cbf)(cb, buf, sprintf(buf, "%hu", pl->startport)); - else - (*cbf)(cb, buf, sprintf(buf, "%hu-%hu", pl->startport, pl->endport)); - if(pl->next)(*cbf)(cb, ",", 1); - } -} - -static void pr_userlist(struct node *node, CBFUNC cbf, void*cb){ - struct userlist *ul= (struct userlist *)node->value; - if(!ul) { - (*cbf)(cb, "*", 1); - return; - } - for(; ul; ul = ul->next){ - (*cbf)(cb, (char *)ul->user, (int)strlen((char *)ul->user)); - if(ul->next)(*cbf)(cb, ",", 1); - } -} - -int printiple(char *buf, struct iplist* ipl){ - int addrlen = (ipl->family == AF_INET6)?16:4, i; - i = myinet_ntop(ipl->family, &ipl->ip_from, buf, addrlen); - if(memcmp(&ipl->ip_from, &ipl->ip_to, addrlen)){ - buf[i++] = '-'; - i += myinet_ntop(ipl->family, &ipl->ip_from, buf+i, addrlen); - } - if(ipl->next){ - buf[i++] = ','; - buf[i++] = ' '; - } - return i; -} - -static void pr_iplist(struct node *node, CBFUNC cbf, void*cb){ - char buf[128]; - struct iplist *il = (struct iplist *)node->value; - - if(!il) { - (*cbf)(cb, "*", 1); - return; - } - for(; il; il = il->next){ - (*cbf)(cb, buf, printiple(buf, il)); - } -} - -static void * ef_portlist_next(struct node *node){ - return (((struct portlist *)node->value) -> next); -} - - -static void * ef_portlist_start(struct node *node){ - return &(((struct portlist *)node->value) -> startport); -} - -static void * ef_portlist_end(struct node *node){ - return &(((struct portlist *)node->value) -> endport); -} - -static void * ef_iplist_next(struct node *node){ - return (((struct iplist *)node->value) -> next); -} - -static void * ef_userlist_next(struct node * node){ - return (((struct userlist *)node->value) -> next); -} - -static void * ef_userlist_user(struct node * node){ - return (((struct userlist *)node->value) -> user); -} - -static void * ef_pwlist_next(struct node * node){ - return (((struct passwords *)node->value) -> next); -} - -static void * ef_pwlist_user(struct node * node){ - return (((struct passwords *)node->value) -> user); -} - -static void * ef_pwlist_password(struct node * node){ - return (((struct passwords *)node->value) -> password); -} - -static void * ef_pwlist_type(struct node * node){ - switch (((struct passwords *)node->value) -> pwtype) { - case SYS: - return "SYS"; - case CL: - return "CL"; - case CR: - return "CR"; - case NT: - return "NT"; - case LM: - return "LM"; - default: - return "UNKNOWN"; - } -} - -static void * ef_chain_next(struct node * node){ - return ((struct chain *)node->value) -> next; -} - -static void * ef_chain_type(struct node * node){ - switch (((struct chain *)node->value) -> type) { - case R_TCP: - return "tcp"; - case R_CONNECT: - return "connect"; - case R_SOCKS4: - return "socks4"; - case R_SOCKS5: - return "socks5"; - case R_HTTP: - return "http"; - case R_FTP: - return "ftp"; - case R_POP3: - return "pop3"; - default: - return ""; - } -} - -static void * ef_chain_addr(struct node * node){ - return &((struct chain *)node->value) -> addr; -} - -static void * ef_chain_weight(struct node * node){ - return &((struct chain *)node->value) -> weight; -} - -static void * ef_chain_user(struct node * node){ - return ((struct chain *)node->value) -> extuser; -} - -static void * ef_chain_password(struct node * node){ - return ((struct chain *)node->value) -> extpass; -} - -static void * ef_ace_next(struct node * node){ - return ((struct ace *)node->value) -> next; -} - -static void * ef_ace_type(struct node * node){ - switch (((struct ace *)node->value) -> action) { - case ALLOW: - case REDIRECT: - return "allow"; - case DENY: - return "deny"; - case BANDLIM: - return "bandlim"; - case NOBANDLIM: - return "nobandlim"; - case COUNTIN: - return "countin"; - case NOCOUNTIN: - return "nocountin"; - case COUNTOUT: - return "countout"; - case NOCOUNTOUT: - return "nocountout"; - default: - return "unknown"; - } -} - - -static void * ef_ace_operations(struct node * node){ - if(!((struct ace *)node->value) -> operation) return NULL; - return &((struct ace *)node->value) -> operation; -} - -static void * ef_ace_users(struct node * node){ - return ((struct ace *)node->value) -> users; -} - -static void * ef_ace_src(struct node * node){ - return ((struct ace *)node->value) -> src; -} - - -static void * ef_ace_dst(struct node * node){ - return ((struct ace *)node->value) -> dst; -} - - -static void * ef_ace_ports(struct node * node){ - return ((struct ace *)node->value) -> ports; -} - -static void * ef_ace_chain(struct node * node){ - return ((struct ace *)node->value) -> chains; -} - -static void * ef_ace_weekdays(struct node * node){ - return (((struct ace *)node->value) -> wdays) ? &((struct ace *)node->value) -> wdays : NULL; -} - -static void * ef_ace_period(struct node * node){ - return ((struct ace *)node->value) -> periods; -} - - -static void * ef_bandlimit_next(struct node * node){ - return ((struct bandlim *)node->value) -> next; -} - -static void * ef_bandlimit_ace(struct node * node){ - return ((struct bandlim *)node->value) -> ace; -} - -static void * ef_bandlimit_rate(struct node * node){ - return &((struct bandlim *)node->value) -> rate; -} - -static void * ef_trafcounter_next(struct node * node){ - return ((struct trafcount *)node->value) -> next; -} - -static void * ef_trafcounter_ace(struct node * node){ - return ((struct trafcount *)node->value) -> ace; -} - -static void * ef_trafcounter_number(struct node * node){ - return &((struct trafcount *)node->value) -> number; -} - -static void * ef_trafcounter_type(struct node * node){ - return &((struct trafcount *)node->value) -> type; -} - -static void * ef_trafcounter_traffic64(struct node * node){ - return &((struct trafcount *)node->value) -> traf64; -} -static void * ef_trafcounter_limit64(struct node * node){ - return &((struct trafcount *)node->value) -> traflim64; -} -static void * ef_client_maxtrafin64(struct node * node){ - return &((struct clientparam *)node->value) -> maxtrafin64; -} - -static void * ef_client_maxtrafout64(struct node * node){ - return &((struct clientparam *)node->value) -> maxtrafout64; -} - -static void * ef_client_bytesin64(struct node * node){ - return &((struct clientparam *)node->value) -> statssrv64; -} - -static void * ef_client_bytesout64(struct node * node){ - return &((struct clientparam *)node->value) -> statscli64; -} - -static void * ef_trafcounter_cleared(struct node * node){ - return &((struct trafcount *)node->value) -> cleared; -} - -static void * ef_trafcounter_updated(struct node * node){ - return &((struct trafcount *)node->value) -> updated; -} - -static void * ef_trafcounter_comment(struct node * node){ - return ((struct trafcount *)node->value) -> comment; -} - -static void * ef_trafcounter_disabled(struct node * node){ - return &((struct trafcount *)node->value) -> disabled; -} - -static void * ef_server_next(struct node * node){ - return ((struct srvparam *)node->value) -> next; -} - -static void * ef_server_type(struct node * node){ - int service = ((struct srvparam *)node->value) -> service; - return (service>=0 && service < 15)? (void *)conf.stringtable[SERVICES + service] : (void *)"unknown"; -} - -static void * ef_server_child(struct node * node){ - return ((struct srvparam *)node->value) -> child; -} - -static void * ef_server_auth(struct node * node){ - AUTHFUNC af = ((struct srvparam *)node->value) -> authfunc; - - if(af == alwaysauth) return "none"; - if(af == ipauth) return "iponly"; - if(af == strongauth) return "strong"; - return "uknown"; -} - -static void * ef_server_childcount(struct node * node){ - return &((struct srvparam *)node->value) -> childcount; -} - -static void * ef_server_log(struct node * node){ - if(((struct srvparam *)node->value) -> logfunc == lognone) return "none"; - else if(((struct srvparam *)node->value) -> logfunc == logstdout) - return (((struct srvparam *)node->value) -> logtarget)?"file":"stdout"; -#ifndef _WIN32 - else if(((struct srvparam *)node->value) -> logfunc == logsyslog) return "syslog"; -#endif -#ifndef NOODBC - else if(((struct srvparam *)node->value) -> logfunc == logsql) return "odbc"; -#endif - return NULL; -} - -static void * ef_server_logformat(struct node * node){ - return ((struct srvparam *)node->value) -> logformat; -} - -static void * ef_server_nonprintable(struct node * node){ - return ((struct srvparam *)node->value) -> nonprintable; -} - -static void * ef_server_replacement(struct node * node){ - if(((struct srvparam *)node->value) -> nonprintable)return &((struct srvparam *)node->value) -> replace; - return NULL; -} - -static void * ef_server_logtarget(struct node * node){ - return ((struct srvparam *)node->value) -> logtarget; -} - - -static void * ef_server_target(struct node * node){ - return ((struct srvparam *)node->value) -> target; -} - -static void * ef_server_targetport(struct node * node){ - return &((struct srvparam *)node->value) -> targetport; -} - -static void * ef_server_intsa(struct node * node){ - return &((struct srvparam *)node->value) -> intsa; -} - -static void * ef_server_extsa(struct node * node){ - return &((struct srvparam *)node->value) -> extsa; -} - -#ifndef NOIPV6 -static void * ef_server_extsa6(struct node * node){ - return &((struct srvparam *)node->value) -> extsa6; -} -#endif - -static void * ef_server_acl(struct node * node){ - return ((struct srvparam *)node->value) -> acl; -} - -static void * ef_server_singlepacket(struct node * node){ - return &((struct srvparam *)node->value) -> singlepacket; -} - -static void * ef_server_usentlm(struct node * node){ - return &((struct srvparam *)node->value) -> usentlm; -} - -static void * ef_server_starttime(struct node * node){ - return &((struct srvparam *)node->value) -> time_start; -} - - -static void * ef_client_next(struct node * node){ - return ((struct clientparam *)node->value) -> next; -} - -static void * ef_client_type(struct node * node){ - int service = ((struct clientparam *)node->value) -> service; - return (service>=0 && service < 15)? (void *)conf.stringtable[SERVICES + service] : (void *)"unknown"; -} - -static void * ef_client_operation(struct node * node){ - if(!((struct clientparam *)node->value) -> operation) return NULL; - return &((struct clientparam *)node->value) -> operation; - -} - -static void * ef_client_redirected(struct node * node){ - return &((struct clientparam *)node->value) -> redirected; - -} - -static void * ef_client_hostname(struct node * node){ - return ((struct clientparam *)node->value) -> hostname; -} - -static void * ef_client_username(struct node * node){ - return ((struct clientparam *)node->value) -> username; -} - -static void * ef_client_password(struct node * node){ - return ((struct clientparam *)node->value) -> password; -} - -static void * ef_client_extusername(struct node * node){ - return ((struct clientparam *)node->value) -> extusername; -} - -static void * ef_client_extpassword(struct node * node){ - return ((struct clientparam *)node->value) -> extpassword; -} - -static void * ef_client_clisa(struct node * node){ - return &((struct clientparam *)node->value) -> sincr; -} - -static void * ef_client_srvsa(struct node * node){ - return &((struct clientparam *)node->value) -> sinsr; -} - -static void * ef_client_reqsa(struct node * node){ - return &((struct clientparam *)node->value) -> req; -} - -static void * ef_client_pwtype(struct node * node){ - return &((struct clientparam *)node->value) -> pwtype; -} - -static void * ef_client_threadid(struct node * node){ - return &((struct clientparam *)node->value) -> threadid; -} - -static void * ef_client_starttime(struct node * node){ - return &((struct clientparam *)node->value) -> time_start; -} - -static void * ef_client_starttime_msec(struct node * node){ - return &((struct clientparam *)node->value) -> msec_start; -} - -static void * ef_period_fromtime(struct node * node){ - return &((struct period *)node->value) -> fromtime; -} - -static void * ef_period_totime(struct node * node){ - return &((struct period *)node->value) -> totime; -} - -static void * ef_period_next(struct node * node){ - return ((struct period *)node->value) -> next; -} - -static struct property prop_portlist[] = { - {prop_portlist + 1, "start", ef_portlist_start, TYPE_PORT, "port range start"}, - {prop_portlist + 2, "end", ef_portlist_end, TYPE_PORT, "port range end"}, - {NULL, "next", ef_portlist_next, TYPE_PORTLIST, "next"} -}; - -static struct property prop_userlist[] = { - {prop_userlist+1, "user", ef_userlist_user, TYPE_STRING, "user name"}, - {NULL, "next", ef_userlist_next, TYPE_USERLIST, "next"} -}; - -static struct property prop_pwlist[] = { - {prop_pwlist + 1, "user", ef_pwlist_user, TYPE_STRING, "user name"}, - {prop_pwlist + 2, "password", ef_pwlist_password, TYPE_STRING, "password string"}, - {prop_pwlist + 3, "type", ef_pwlist_type, TYPE_STRING, "password type"}, - {NULL, "next", ef_pwlist_next, TYPE_PWLIST, "next"} -}; - -static struct property prop_chain[] = { - {prop_chain + 1, "addr", ef_chain_addr, TYPE_SA, "parent address"}, - {prop_chain + 2, "type", ef_chain_type, TYPE_STRING, "parent type"}, - {prop_chain + 3, "weight", ef_chain_weight, TYPE_SHORT, "parent weight 0-1000"}, - {prop_chain + 4, "user", ef_chain_user, TYPE_STRING, "parent login"}, - {prop_chain + 5, "password", ef_chain_password, TYPE_STRING, "parent password"}, - {NULL, "next", ef_chain_next, TYPE_CHAIN, "next"} -}; - -static struct property prop_period[] = { - {prop_period + 1, "fromtime", ef_period_fromtime, TYPE_TIME, "from time" }, - {prop_period + 2, "totime", ef_period_totime, TYPE_TIME, "to time" }, - {NULL, "next", ef_period_next, TYPE_PERIOD, "next"} -}; - -static struct property prop_ace[] = { - {prop_ace + 1, "type", ef_ace_type, TYPE_STRING, "ace action"}, - {prop_ace + 2, "operations", ef_ace_operations, TYPE_OPERATIONS, "request type"}, - {prop_ace + 3, "users", ef_ace_users, TYPE_USERLIST, "list of users"}, - {prop_ace + 4, "src", ef_ace_src, TYPE_IPLIST, "list of source ips"}, - {prop_ace + 5, "dst", ef_ace_dst, TYPE_IPLIST, "list of destination ips"}, - {prop_ace + 6, "ports", ef_ace_ports, TYPE_PORTLIST, "list of destination ports"}, - {prop_ace + 7, "chain", ef_ace_chain, TYPE_CHAIN, "redirect to parent(s)"}, - {prop_ace + 8, "wdays", ef_ace_weekdays, TYPE_WEEKDAYS, "days of week"}, - {prop_ace + 9, "periods", ef_ace_period, TYPE_PERIOD, "time of the day"}, - {NULL, "next", ef_ace_next, TYPE_ACE, "next"} -}; - -static struct property prop_bandlimit[] = { - {prop_bandlimit + 1, "ace", ef_bandlimit_ace, TYPE_ACE, "acl to apply"}, - {prop_bandlimit + 2, "rate", ef_bandlimit_rate, TYPE_UNSIGNED, "max allowed bandwidth"}, - {NULL, "next", ef_bandlimit_next, TYPE_BANDLIMIT, "next"} -}; - -static struct property prop_trafcounter[] = { - {prop_trafcounter + 1, "disabled", ef_trafcounter_disabled, TYPE_INTEGER, "counter status"}, - {prop_trafcounter + 2, "ace", ef_trafcounter_ace, TYPE_ACE, "traffic to count"}, - {prop_trafcounter + 3, "number", ef_trafcounter_number, TYPE_UNSIGNED, "counter number"}, - {prop_trafcounter + 4, "type", ef_trafcounter_type, TYPE_ROTATION, "rotation type"}, - - - {prop_trafcounter + 5, "traffic", ef_trafcounter_traffic64, TYPE_UNSIGNED64, "counter value"}, - {prop_trafcounter + 6, "limit", ef_trafcounter_limit64, TYPE_UNSIGNED64, "counter limit"}, - {prop_trafcounter + 7, "cleared", ef_trafcounter_cleared, TYPE_DATETIME, "last rotated"}, - {prop_trafcounter + 8, "updated", ef_trafcounter_updated, TYPE_DATETIME, "last updated"}, - {prop_trafcounter + 9, "comment", ef_trafcounter_comment, TYPE_STRING, "counter comment"}, - {NULL, "next", ef_trafcounter_next, TYPE_TRAFCOUNTER} -}; - -/* -*/ - -static struct property prop_server[] = { - {prop_server + 1, "servicetype", ef_server_type, TYPE_STRING, "type of the service/client"}, - {prop_server + 2, "target", ef_server_target, TYPE_STRING, "portmapper target ip"}, - {prop_server + 3, "targetport", ef_server_targetport, TYPE_PORT, "portmapper target port"}, - {prop_server + 4, "starttime", ef_server_starttime, TYPE_DATETIME, "service started seconds"}, - {prop_server + 5, "intsa", ef_server_intsa, TYPE_SA, "ip address of internal interface"}, - {prop_server + 6, "extsa", ef_server_extsa, TYPE_SA, "ip address of external interface"}, - {prop_server + 7, "auth", ef_server_auth, TYPE_STRING, "service authentication type"}, - {prop_server + 8, "acl", ef_server_acl, TYPE_ACE, "access control list"}, - {prop_server + 9, "singlepacket", ef_server_singlepacket, TYPE_INTEGER, "is single packet redirection"}, - {prop_server + 10, "usentlm", ef_server_usentlm, TYPE_INTEGER, "allow NTLM authentication"}, - {prop_server + 11, "log", ef_server_log, TYPE_STRING, "type of logging"}, - {prop_server + 12, "logtarget", ef_server_logtarget, TYPE_STRING, "log target options"}, - {prop_server + 13, "logformat", ef_server_logformat, TYPE_STRING, "logging format string"}, - {prop_server + 14, "nonprintable", ef_server_nonprintable, TYPE_STRING, "non printable characters"}, - {prop_server + 15, "replacement", ef_server_replacement, TYPE_CHAR, "replacement character"}, - {prop_server + 16, "childcount", ef_server_childcount, TYPE_INTEGER, "number of servers connected"}, - {prop_server + 17, "child", ef_server_child, TYPE_CLIENT, "connected clients"}, -#ifndef NOIPV6 - {prop_server + 18, "extsa6", ef_server_extsa6, TYPE_SA, "ipv6 address of external interface"}, -#endif - {NULL, "next", ef_server_next, TYPE_SERVER, "next"} -}; - - -static struct property prop_client[] = { - {prop_client + 1, "servicetype", ef_client_type, TYPE_STRING, "type of the client"}, - {prop_client + 2, "threadid", ef_client_threadid, TYPE_INTEGER, "process thread id"}, - {prop_client + 3, "starttime", ef_client_starttime, TYPE_DATETIME, "client started seconds"}, - {prop_client + 4, "starttime_msec", ef_client_starttime_msec, TYPE_UNSIGNED, "client started milliseconds"}, - {prop_client + 5, "redirected", ef_client_redirected, TYPE_INTEGER, "number of redirections"}, - {prop_client + 6, "operation", ef_client_operation, TYPE_OPERATIONS, "action requested by client"}, - {prop_client + 7, "hostname", ef_client_hostname, TYPE_STRING, "name of the requested host"}, - {prop_client + 8, "extusername", ef_client_extusername, TYPE_STRING, "username for requested host"}, - {prop_client + 9, "extpassword", ef_client_extpassword, TYPE_STRING, "password for requested host"}, - {prop_client + 10, "username", ef_client_username, TYPE_STRING, "client username"}, - {prop_client + 11, "password", ef_client_password, TYPE_STRING, "client password"}, - {prop_client + 12, "clisa", ef_client_clisa, TYPE_SA, "client sa"}, - {prop_client + 13, "srvsa", ef_client_srvsa, TYPE_IP, "target server sa"}, - {prop_client + 14, "reqsa", ef_client_reqsa, TYPE_IP, "requested server sa"}, - {prop_client + 15, "bytesin", ef_client_bytesin64, TYPE_UNSIGNED64, "bytes from server to client"}, - {prop_client + 16, "bytesout", ef_client_bytesout64, TYPE_UNSIGNED64, "bytes from client to server"}, - {prop_client + 17, "maxtrafin", ef_client_maxtrafin64, TYPE_UNSIGNED64, "maximum traffic allowed for download"}, - {prop_client + 18, "maxtrafout", ef_client_maxtrafout64, TYPE_UNSIGNED64, "maximum traffic allowed for upload"}, - {prop_client + 19, "pwtype", ef_client_pwtype, TYPE_INTEGER, "type of client password"}, - {NULL, "next", ef_client_next, TYPE_CLIENT, "next"} - - -}; - -struct datatype datatypes[64] = { - {"integer", NULL, pr_integer, NULL}, - {"short", NULL, pr_short, NULL}, - {"char", NULL, pr_char, NULL}, - {"unsigned", NULL, pr_unsigned, NULL}, - {"unsigned64", NULL, pr_unsigned64, NULL}, - {"traffic", NULL, pr_traffic, NULL}, - {"port", NULL, pr_port, NULL}, - {"ip", NULL, pr_ip, NULL}, - {"sa", NULL, pr_sa, NULL}, - {"cidr", NULL, pr_cidr, NULL}, - {"string", NULL, pr_string, NULL}, - {"datetime", NULL, pr_datetime, NULL}, - {"operations", NULL, pr_operations, NULL}, - {"rotation", NULL, pr_rotation, NULL}, - {"portlist", ef_portlist_next, pr_portlist, prop_portlist}, - {"iplist", ef_iplist_next, pr_iplist, NULL}, - {"userlist", ef_userlist_next, pr_userlist, prop_userlist}, - {"pwlist", ef_pwlist_next, NULL, prop_pwlist}, - {"chain", ef_chain_next, NULL, prop_chain}, - {"ace", ef_ace_next, NULL, prop_ace}, - {"bandlimit", ef_bandlimit_next, NULL, prop_bandlimit}, - {"trafcounter", ef_trafcounter_next, NULL, prop_trafcounter}, - {"client", ef_client_next, NULL, prop_client}, - {"weekdays", NULL, pr_wdays, NULL}, - {"time", NULL, pr_time, NULL}, - {"period", ef_period_next, NULL, prop_period}, - {"server", ef_server_next, NULL, prop_server} -}; diff --git a/src/dighosts.c b/src/dighosts.c deleted file mode 100644 index ccf9c43..0000000 --- a/src/dighosts.c +++ /dev/null @@ -1,141 +0,0 @@ -/* - * Copyright (c) 2000-2008 3APA3A - * - * please read License Agreement - * - */ - -#include "proxy.h" -pthread_mutex_t log_mutex; - - -int sockgetchar(SOCKET sock, int timeosec, int timeousec){ - unsigned char buf; - fd_set fds; - struct timeval tv; - - tv.tv_sec = timeosec; - tv.tv_usec = timeousec; - FD_ZERO(&fds); - FD_SET(sock, &fds); - if (select (((int)sock)+1, &fds, NULL, NULL, &tv)!=1) return EOF; - if (recv(sock, (char *)&buf, 1, 0)!=1) return EOF; - return((int)buf); -} - - -int sockgetline(SOCKET sock, unsigned char * buf, int bufsize, int delim, int to){ - int c; - int i=0, tos, tou; - if(bufsize<2) return 0; - c = sockgetchar(sock, to, 0); - if (c == EOF) { - return 0; - } - tos = to/16; - tou = ((to * 1000) / bufsize)%1000; - do { - buf[i++] = c; - if(delim != EOF && c == delim) break; - }while(i < bufsize && (c = sockgetchar(sock, tos, tou)) != EOF); - return i; -} - - -unsigned char request[] = "GET %.1024s HTTP/1.0\r\nHost: %.256s\r\n\r\n"; - -int main(int argc, char *argv[]){ - unsigned char *host, *hostend; - SOCKET sock; - struct sockaddr_in sa; - FILE *fp; - unsigned char buf[16000]; - int i; - unsigned x,y,z,w,cidr, x1,y1,z1,w1, mask; - int first = 1; - -#ifdef _WIN32 - WSADATA wd; - WSAStartup(MAKEWORD( 1, 1 ), &wd); -#endif - - if(argc < 3 || argc > 4 || (argc == 4 && (argv[1][0] != '-' || argv[1][1] != 'm'))) { - fprintf(stderr, "Usage: %s [-m] \n" - " program retrieves requested and builds comma delimited list of networks\n" - " list than stored in \n" - " networks are searched in xxx.yyy.zzz.www/cidr format\n" - " switches:\n" - " -m networks are searched in xxx.yyy.zzz.www mmm.mmm.mmm.mmm format\n" - "\n(c)2002 by 3APA3A\n", - argv[0]); - return 1; - } - if(strncasecmp(argv[argc-2], "http://", 7)) { - fprintf(stderr, "URL must be HTTP://\n"); - return 2; - } - hostend = (unsigned char *)strchr((char *)argv[argc-2] + 7, '/'); - if(!hostend) { - fprintf(stderr, "Wrong URL syntaxis\n"); - return 3; - } - *hostend = 0; - if(!(host = (unsigned char *)strdup((char *)argv[argc-2] + 7))) { - return 4; - } - *hostend = '/'; - if(!getip46(4, host, (struct sockaddr *)&sa)) { - fprintf(stderr, "Unable to resolve %s\n", host); - return 5; - } - sa.sin_port = htons(80); - if((sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) == INVALID_SOCKET) return 6; - sprintf((char *)buf, (char *)request, hostend, host); - if(connect(sock,(struct sockaddr *)&sa,sizeof(sa))) { - fprintf(stderr, "Unable to connect: %s\n", host); - return 8; - } - if(send(sock, (char *)buf, (int)strlen((char *)buf), 0) != (int)strlen((char *)buf)) return 9; - while( (i = sockgetline(sock, buf, sizeof(buf) - 1, '\n', 30)) > 2); - if(i<1) return 9; - if(!(fp = fopen(argv[argc-1], "w"))) { - fprintf(stderr, "Unable to open: %s\n", argv[2]); - return 7; - } - while( (i = sockgetline(sock, buf, sizeof(buf) - 1, '\n', 30)) > 0){ - buf[i] = 0; - for(i = 0; buf[i]; i++){ - if((buf[i]<'0' || buf[i] > '9') && buf[i] != '.' && buf[i] != '/')buf[i] = ' '; - } - if(argc == 3){ - if((i=sscanf((char *)buf, "%u.%u.%u.%u/%u", &x, &y, &z, &w, &cidr)) == 5 && - x<256 && y<256 && z<256 && w<256 && - cidr <= 32){ - if(!first)fprintf(fp, ","); - fprintf(fp, "%u.%u.%u.%u/%u", x, y, z, w, cidr); - first = 0; - } - } - else{ - if((i = sscanf((char *)buf, "%u.%u.%u.%u %u.%u.%u.%u", &x, &y, &z, &w, &x1, &y1, &z1, &w1)) == 8 && - x<256 && y<256 && z<256 && w<256 && - x1<256 && y1<256 && z1<256 && w1<256 - ){ - mask = (x1<<24)|(y1<<16)|(z1<<8)|w1; - for(cidr = 0; cidr <= 32; cidr++)if((((unsigned long)(0xFFFFFFFF))<<(32-cidr)) == mask) break; - if(cidr > 32) continue; - if(!first)fprintf(fp, ","); - fprintf(fp, "%u.%u.%u.%u/%u", x, y, z, w, cidr); - first = 0; - } - } - } - shutdown(sock, SHUT_RDWR); -#ifdef _WIN32 - closesocket(sock); -#else - close(sock); -#endif - fclose(fp); - return 0; -} diff --git a/src/dnspr.c b/src/dnspr.c deleted file mode 100644 index 078447c..0000000 --- a/src/dnspr.c +++ /dev/null @@ -1,211 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#ifndef UDP -#define UDP -#endif -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -#define BUFSIZE 16384 - - -void * dnsprchild(struct clientparam* param) { - unsigned long ip = 0; - unsigned char *bbuf; - unsigned char *buf, *s1, *s2; - char * host = NULL; - unsigned char c; - SASIZETYPE size; - int res, i; - int len; - unsigned type=0; - unsigned ttl; - unsigned char addr[16]; -#ifdef _WIN32 - unsigned long ul = 1; -#endif - - - if(!(bbuf = myalloc(BUFSIZE+2))){ - param->srv->fds.events = POLLIN; - RETURN (21); - } - buf = bbuf+2; - size = sizeof(param->sincr); - i = so._recvfrom(param->srv->srvsock, (char *)buf, BUFSIZE, 0, (struct sockaddr *)¶m->sincr, &size); - size = sizeof(param->sinsl); - getsockname(param->srv->srvsock, (struct sockaddr *)¶m->sincl, &size); -#ifdef _WIN32 - if((param->clisock=so._socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP)) == INVALID_SOCKET) { - RETURN(818); - } - ioctlsocket(param->clisock, FIONBIO, &ul); - if(so._setsockopt(param->clisock, SOL_SOCKET, SO_REUSEADDR, (char *)&ul, sizeof(int))) {RETURN(820);}; - if(so._bind(param->clisock,(struct sockaddr *)¶m->sincl,SASIZE(¶m->sincl))) { - RETURN(822); - } - -#else - param->clisock = param->srv->srvsock; -#endif - param->srv->fds.events = POLLIN; - - if(i < 0) { - RETURN(813); - } - buf[BUFSIZE - 1] = 0; - if(i<=13 || i>1000){ - RETURN (814); - } - param->operation = DNSRESOLVE; - if((res = (*param->srv->authfunc)(param))) {RETURN(res);} - - if(buf[4]!=0 || buf[5]!=1) RETURN(816); - for(len = 12; len (i-4)) {RETURN(817);} - - host = mystrdup((char *)buf+13); - if(!host) {RETURN(21);} - - for(s2 = buf + 12; (s1 = (unsigned char *)strchr((char *)s2 + 1, '.')); s2 = s1)*s2 = (unsigned char)((s1 - s2) - 1); - *s2 = (len - (int)(s2 - buf)) - 1; - - type = ((unsigned)buf[len+1])*256 + (unsigned)buf[len+2]; - if((type==0x01 || type==0x1c) && !param->srv->singlepacket){ - ip = udpresolve((type==0x1c)?AF_INET6:AF_INET, (unsigned char *)host, addr, &ttl, param, 0); - } - - len+=5; - - if(ip){ - buf[2] = 0x85; - buf[3] = 0x80; - buf[6] = 0; - buf[7] = 1; - buf[8] = buf[9] = buf[10] = buf[11] = 0; - memset(buf+len, 0, 16); - buf[len] = 0xc0; - buf[len+1] = 0x0c; - buf[len+3] = type; - buf[len+5] = 1; - ttl = htonl(ttl); - memcpy(buf + len + 6, &ttl, 4); - buf[len+11] = type==1? 4:16; - memcpy(buf+len+12,(void *)&addr,type==1? 4:16); - len+=(type==1?16:28); - } - else if(type == 0x0c) { - unsigned a, b, c, d; - sscanf(host, "%u.%u.%u.%u", &a, &b, &c, &d); - ip = htonl((d<<24) ^ (c<<16) ^ (b<<8) ^ a); - if(*SAFAMILY(¶m->sincl) == AF_INET && ip == *(unsigned long*)SAADDR(¶m->sincl)){ - buf[2] = 0x85; - buf[3] = 0x80; - buf[6] = 0; - buf[7] = 1; - buf[8] = buf[9] = buf[10] = buf[11] = 0; - memset(buf+len, 0, 20); - buf[len] = 0xc0; - buf[len+1] = 0x0c; - buf[len+3] = 0x0c; - buf[len+5] = 1; - ttl = htonl(3600); - memcpy(buf + len + 6, &ttl, 4); - buf[len+11] = 7; - buf[len+12] = 6; - memcpy(buf+len+13,(void *)"3proxy",6); - len+=20; - } - else ip = 0; - } - if(!ip && numservers){ - if((param->remsock=so._socket(SASOCK(&nservers[0].addr), nservers[0].usetcp? SOCK_STREAM:SOCK_DGRAM, nservers[0].usetcp?IPPROTO_TCP:IPPROTO_UDP)) == INVALID_SOCKET) { - RETURN(818); - } - memset(¶m->sinsl, 0, sizeof(param->sinsl)); - *SAFAMILY(¶m->sinsl) = *SAFAMILY(&nservers[0].addr); - if(so._bind(param->remsock,(struct sockaddr *)¶m->sinsl,SASIZE(¶m->sinsl))) { - RETURN(819); - } - param->sinsr = nservers[0].addr; - if(nservers[0].usetcp) { - if(so._connect(param->remsock,(struct sockaddr *)¶m->sinsr,SASIZE(¶m->sinsr))) RETURN(830); - buf-=2; - *(unsigned short*)buf = htons(i); - i+=2; - } - else { -#ifdef _WIN32 -/* ioctlsocket(param->remsock, FIONBIO, &ul); */ -#else -/* fcntl(param->remsock,F_SETFL,O_NONBLOCK); */ -#endif - } - - if(socksendto(param->remsock, (struct sockaddr *)¶m->sinsr, buf, i, conf.timeouts[SINGLEBYTE_L]*1000) != i){ - RETURN(820); - } - param->statscli64 += i; - param->nwrites++; - len = sockrecvfrom(param->remsock, (struct sockaddr *)¶m->sinsr, buf, BUFSIZE, conf.timeouts[DNS_TO]*1000); - if(len <= 13) { - RETURN(821); - } - param->statssrv64 += len; - param->nreads++; - if(nservers[0].usetcp) { - unsigned short us; - us = ntohs(*(unsigned short *)buf); - if(us > 4096) RETURN(833); - buf += 2; - len -= 2; - if(len < us) len += sockgetlinebuf(param, SERVER, buf+len, us - len, 0, conf.timeouts[SINGLEBYTE_L]); - if(len != us) RETURN(832); - } - if(buf[6] || buf[7]){ - if(socksendto(param->clisock, (struct sockaddr *)¶m->sincr, buf, len, conf.timeouts[SINGLEBYTE_L]*1000) != len){ - RETURN(822); - } - RETURN(0); - } - - } - if(!ip) { - buf[2] = 0x85; - buf[3] = 0x83; - } - res = socksendto(param->clisock, (struct sockaddr *)¶m->sincr, buf, len, conf.timeouts[SINGLEBYTE_L]*1000); - if(res != len){RETURN(819);} - if(!ip) {RETURN(888);} - -CLEANRET: - - if(param->res!=813){ - sprintf((char *)buf, "%04x/%s/", - (unsigned)type, - host?host:""); - if((ip && type == 0x01) || type == 0x1c){ - myinet_ntop(type == 0x01? AF_INET:AF_INET6, addr, (char *)buf+strlen((char *)buf), 64); - } - (*param->srv->logfunc)(param, buf); - } - if(bbuf)myfree(bbuf); - if(host)myfree(host); -#ifndef _WIN32 - param->clisock = INVALID_SOCKET; -#endif - freeparam(param); - return (NULL); -} - diff --git a/src/ftppr.c b/src/ftppr.c deleted file mode 100644 index 0cc0762..0000000 --- a/src/ftppr.c +++ /dev/null @@ -1,328 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } -#define BUFSIZE 2048 - -void * ftpprchild(struct clientparam* param) { - int i=0, res; - unsigned char *buf; - unsigned char *se; - int status = 0; - int inbuf; - int pasv = 0; - SOCKET sc = INVALID_SOCKET, ss = INVALID_SOCKET, clidatasock = INVALID_SOCKET; - SASIZETYPE sasize; - char * req = NULL; - struct linger lg; - struct pollfd fds; - - if(!(buf = myalloc(BUFSIZE))) RETURN(876); - param->ctrlsock = param->clisock; - param->operation = CONNECT; - lg.l_onoff = 1; - lg.l_linger = conf.timeouts[STRING_L];; - if(socksend(param->ctrlsock, (unsigned char *)"220 Ready\r\n", 11, conf.timeouts[STRING_S])!=11) {RETURN (801);} - for(;;){ - i = sockgetlinebuf(param, CLIENT, buf, BUFSIZE - 10, '\n', conf.timeouts[CONNECTION_S]); - if(!i) { - RETURN(0); - } - if(i<4) {RETURN(802);} - buf[i] = 0; - if ((se=(unsigned char *)strchr((char *)buf, '\r'))) *se = 0; - if (req) myfree (req); - req = NULL; - - if (!strncasecmp((char *)buf, "OPEN ", 5)){ - if(parsehostname((char *)buf+5, param, 21)){RETURN(803);} - if(param->remsock != INVALID_SOCKET) { - so._shutdown(param->remsock, SHUT_RDWR); - so._closesocket(param->remsock); - param->remsock = INVALID_SOCKET; - } - if((res = (*param->srv->authfunc)(param))) {RETURN(res);} - param->ctrlsocksrv = param->remsock; - if(socksend(param->ctrlsock, (unsigned char *)"220 Ready\r\n", 11, conf.timeouts[STRING_S])!=11) {RETURN (801);} - status = 1; - } - else if (!strncasecmp((char *)buf, "USER ", 5)){ - if(parseconnusername((char *)buf +5, param, 0, 21)){RETURN(804);} - if(!status){ - if((res = (*param->srv->authfunc)(param))) {RETURN(res);} - param->ctrlsocksrv = param->remsock; - } - if(socksend(param->ctrlsock, (unsigned char *)"331 ok\r\n", 8, conf.timeouts[STRING_S])!=8) {RETURN (807);} - status = 2; - - } - else if (!strncasecmp((char *)buf, "PASS ", 5)){ - param->extpassword = (unsigned char *)mystrdup((char *)buf+5); - inbuf = BUFSIZE; - res = ftplogin(param, (char *)buf, &inbuf); - param->res = res; - if(inbuf && inbuf != BUFSIZE && socksend(param->ctrlsock, buf, inbuf, conf.timeouts[STRING_S])!=inbuf) {RETURN (807);} - if(!res) status = 3; - sprintf((char *)buf, "%.128s@%.128s%c%hu", param->extusername, param->hostname, (ntohs(*SAPORT(¶m->sinsr))==21)?0:':', ntohs(*SAPORT(¶m->sinsr))); - req = mystrdup((char *)buf); -#ifndef WITHMAIN - { - int action, reqbufsize, reqsize; - reqbufsize = BUFSIZE; - reqsize = (int)strlen((char *)buf) + 1; - - action = handlereqfilters(param, &buf, &reqbufsize, 0, &reqsize); - if(action == HANDLED){ - RETURN(0); - } - if(action != PASS) RETURN(877); - } -#endif - } - else if (status >= 3 && ( - (!strncasecmp((char *)buf, "PASV", 4) && (pasv = 1)) || - (!strncasecmp((char *)buf, "PORT ", 5) && !(pasv = 0)) - )){ -#ifndef WITHMAIN - { - int action, reqbufsize, reqsize; - reqbufsize = BUFSIZE; - reqsize = (int)strlen((char *)buf) + 1; - - action = handlehdrfilterscli(param, &buf, &reqbufsize, 0, &reqsize); - if(action == HANDLED){ - RETURN(0); - } - if(action != PASS) RETURN(878); - } -#endif - if(sc != INVALID_SOCKET) { - so._shutdown(sc, SHUT_RDWR); - so._closesocket(sc); - sc = INVALID_SOCKET; - } - if(ss != INVALID_SOCKET) { - so._shutdown(ss, SHUT_RDWR); - so._closesocket(ss); - ss = INVALID_SOCKET; - } - if(clidatasock != INVALID_SOCKET) { - so._shutdown(clidatasock, SHUT_RDWR); - so._closesocket(clidatasock); - clidatasock = INVALID_SOCKET; - } - if ((clidatasock=socket(SASOCK(¶m->sincl), SOCK_STREAM, IPPROTO_TCP)) == INVALID_SOCKET) {RETURN(821);} - *SAPORT(¶m->sincl) = 0; - if(so._bind(clidatasock, (struct sockaddr *)¶m->sincl, SASIZE(¶m->sincl))){RETURN(822);} - if (pasv) { - if(so._listen(clidatasock, 1)) {RETURN(823);} - sasize = sizeof(param->sincl); - if(so._getsockname(clidatasock, (struct sockaddr *)¶m->sincl, &sasize)){RETURN(824);} - if(*SAFAMILY(¶m->sincl) == AF_INET) - sprintf((char *)buf, "227 OK (%u,%u,%u,%u,%u,%u)\r\n", - (unsigned)(((unsigned char *)(SAADDR(¶m->sincl)))[0]), - (unsigned)(((unsigned char *)(SAADDR(¶m->sincl)))[1]), - (unsigned)(((unsigned char *)(SAADDR(¶m->sincl)))[2]), - (unsigned)(((unsigned char *)(SAADDR(¶m->sincl)))[3]), - (unsigned)(((unsigned char *)(SAPORT(¶m->sincl)))[0]), - (unsigned)(((unsigned char *)(SAPORT(¶m->sincl)))[1]) - ); - else sprintf((char *)buf, "227 OK (127,0,0,1,%u,%u)\r\n", - (unsigned)(((unsigned char *)(SAPORT(¶m->sincl)))[0]), - (unsigned)(((unsigned char *)(SAPORT(¶m->sincl)))[1]) - ); - } - else { - unsigned long b1, b2, b3, b4; - unsigned short b5, b6; - - if(sscanf((char *)buf+5, "%lu,%lu,%lu,%lu,%hu,%hu", &b1, &b2, &b3, &b4, &b5, &b6)!=6) {RETURN(828);} - *SAPORT(¶m->sincr) = htons((unsigned short)((b5<<8)^b6)); - if(so._connect(clidatasock, (struct sockaddr *)¶m->sincr, SASIZE(¶m->sincr))) { - so._closesocket(clidatasock); - clidatasock = INVALID_SOCKET; - RETURN(826); - } - sprintf((char *)buf, "200 OK\r\n"); - } -#ifndef WITHMAIN - { - int action, reqbufsize, reqsize; - reqbufsize = BUFSIZE; - reqsize = (int)strlen((char *)buf) + 1; - - action = handlehdrfilterssrv(param, &buf, &reqbufsize, 0, &reqsize); - if(action == HANDLED){ - RETURN(0); - } - if(action != PASS) RETURN(879); - } -#endif - if(socksend(param->ctrlsock, buf, (int)strlen((char *)buf), conf.timeouts[STRING_S])!=(int)strlen((char *)buf)) {RETURN (825);} - status = 4; - } - else if (status == 4 && ( - !(strncasecmp((char *)buf, "RETR ", 5) && (param->operation = FTP_GET)) || - !(strncasecmp((char *)buf, "LIST", 4) && (param->operation = FTP_LIST))|| - !(strncasecmp((char *)buf, "NLST ", 5) && (param->operation = FTP_LIST)) || - !(strncasecmp((char *)buf, "MLSD", 4) && (param->operation = FTP_LIST)) || - !(strncasecmp((char *)buf, "APPE ", 5) && (param->operation = FTP_PUT)) || - !(strncasecmp((char *)buf, "STOR ", 5) && (param->operation = FTP_PUT)) - )){ - int arg = (buf[4] && buf[5])? 1:0; - int ressent = 0; - - -#ifndef WITHMAIN - { - int action, reqbufsize, reqsize; - reqbufsize = BUFSIZE; - reqsize = (int)strlen((char *)buf) + 1; - - action = handlehdrfilterscli(param, &buf, &reqbufsize, 0, &reqsize); - if(action == HANDLED){ - RETURN(0); - } - if(action != PASS) RETURN(880); - } -#endif - if(clidatasock == INVALID_SOCKET) { RETURN (829);} - if(pasv){ - - memset(&fds, 0, sizeof(fds)); - fds.fd = clidatasock; - fds.events = POLLIN; - - res = so._poll (&fds, 1, conf.timeouts[STRING_L]*1000); - if(res != 1) { - RETURN(857); - } - sasize = sizeof(param->sincr); - ss = so._accept(clidatasock, (struct sockaddr *)¶m->sincr, &sasize); - if (ss == INVALID_SOCKET) { RETURN (858);} - so._shutdown(clidatasock, SHUT_RDWR); - so._closesocket(clidatasock); - clidatasock = ss; - ss = INVALID_SOCKET; - } - if(clidatasock == INVALID_SOCKET){RETURN(828);} - req = mystrdup((char *)buf); - buf[4] = 0; - status = 3; - ss = ftpcommand(param, buf, arg? buf+5 : NULL); - if (ss == INVALID_SOCKET) { - so._shutdown(clidatasock, SHUT_RDWR); - so._closesocket(clidatasock); - clidatasock = INVALID_SOCKET; - - if(socksend(param->ctrlsock, (unsigned char *)"550 err\r\n", 9, conf.timeouts[STRING_S])!=9) {RETURN (831);} - continue; - } - - if(socksend(param->ctrlsock, (unsigned char *)"125 data\r\n", 10, conf.timeouts[STRING_S]) != 10) { - param->remsock = INVALID_SOCKET; - RETURN (832); - } - if(param->srvoffset < param->srvinbuf)while((i = sockgetlinebuf(param, SERVER, buf, BUFSIZE, '\n', 0)) > 3){ - if(socksend(param->ctrlsock, buf, i, conf.timeouts[STRING_S])!=i) {RETURN(833);} - if(isnumber(*buf) && buf[3] != '-') { - ressent = 1; - break; - } - } - sc = param->remsock; - param->remsock = ss; - so._setsockopt(param->remsock, SOL_SOCKET, SO_LINGER, (char *)&lg, sizeof(lg)); - so._setsockopt(clidatasock, SOL_SOCKET, SO_LINGER, (char *)&lg, sizeof(lg)); - param->clisock = clidatasock; - res = sockmap(param, conf.timeouts[CONNECTION_S]); - if(param->remsock != INVALID_SOCKET) { - so._shutdown (param->remsock, SHUT_RDWR); - so._closesocket(param->remsock); - } - if(param->clisock != INVALID_SOCKET) { - so._shutdown (param->clisock, SHUT_RDWR); - so._closesocket(param->clisock); - } - param->clisock = param->ctrlsock; - param->remsock = sc; - sc = INVALID_SOCKET; - ss = INVALID_SOCKET; - clidatasock = INVALID_SOCKET; - if(!ressent){ - while((i = sockgetlinebuf(param, SERVER, buf, BUFSIZE, '\n', conf.timeouts[STRING_L])) > 3){ - if(socksend(param->ctrlsock, buf, i, conf.timeouts[STRING_S])!=i) {RETURN(833);} - if(isnumber(*buf) && buf[3] != '-') break; - } - if(i < 3) {RETURN(834);} - } - } - else { - if(status < 3) { - if(socksend(param->remsock, (unsigned char *)"530 login\r\n", 11, conf.timeouts[STRING_S])!=1) {RETURN (810);} - continue; - } - if(!strncasecmp((char *)buf, "QUIT", 4)) status = 5; - if(!strncasecmp((char *)buf, "CWD ", 4)) req = mystrdup((char *)buf); - i = (int)strlen((char *)buf); - buf[i++] = '\r'; - buf[i++] = '\n'; - if(socksend(param->remsock, buf, i, conf.timeouts[STRING_S])!=i) {RETURN (811);} - param->statscli64+=(i); - param->nwrites++; - while((i = sockgetlinebuf(param, SERVER, buf, BUFSIZE, '\n', conf.timeouts[STRING_L])) > 0){ - if(socksend(param->ctrlsock, buf, i, conf.timeouts[STRING_S])!=i) {RETURN (812);} - if(i > 4 && isnumber(*buf) && buf[3] != '-') break; - } - if(status == 5) {RETURN (0);} - if(i < 3) {RETURN (813);} - } - sasize = sizeof(param->sincr); - if(so._getpeername(param->ctrlsock, (struct sockaddr *)¶m->sincr, &sasize)){RETURN(819);} - if(req && (param->statscli64 || param->statssrv64)){ - (*param->srv->logfunc)(param, (unsigned char *)req); - } - } - -CLEANRET: - - if(sc != INVALID_SOCKET) { - so._shutdown(sc, SHUT_RDWR); - so._closesocket(sc); - } - if(ss != INVALID_SOCKET) { - so._shutdown(ss, SHUT_RDWR); - so._closesocket(ss); - } - if(clidatasock != INVALID_SOCKET) { - so._shutdown(clidatasock, SHUT_RDWR); - so._closesocket(clidatasock); - } - sasize = sizeof(param->sincr); - so._getpeername(param->ctrlsock, (struct sockaddr *)¶m->sincr, &sasize); - if(param->res != 0 || param->statscli64 || param->statssrv64 ){ - (*param->srv->logfunc)(param, (unsigned char *)((req && (param->res > 802))? req:NULL)); - } - if(req) myfree(req); - if(buf) myfree(buf); - freeparam(param); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - ftpprchild, - 21, - 0, - S_FTPPR, - " -hdefault_host[:port] - use this host and port as default if no host specified\n" -}; -#include "proxymain.c" -#endif diff --git a/src/icqpr.c b/src/icqpr.c deleted file mode 100644 index bd45687..0000000 --- a/src/icqpr.c +++ /dev/null @@ -1,529 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#ifndef PORTMAP -#define PORTMAP -#endif -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -static void hexdump(unsigned char *data, int len){ - for(; len; data++, len--){ - printf("%02x", (unsigned)*data); - } - printf("\n"); -} - -struct flap_header { - unsigned char id; - unsigned char chan; - unsigned short seq; - unsigned short size; - char data[0]; -}; - -struct snack_header { - unsigned family; - unsigned short flags; - unsigned id; - char data[0]; -}; - -struct tlv_header { - unsigned short type; - unsigned short size; - char data[0]; -}; - - -typedef enum { - ONBEGIN = 0, - ONCHAN, - ONSEQ1, - ONSEQ2, - ONSIZE1, - ONSIZE2, - ONDATA -} ICQSTATE; - -struct icqstate { - ICQSTATE state; - int leftinstate; - unsigned short seq; - unsigned short srvseq; - unsigned short gotseq; - unsigned short resyncseq; - char channel; -}; - - - - - -typedef enum { - ICQUNKNOWN, - ICQCLEAR, - ICQMD5, - ICQCOOKIE -} LOGINTYPE; - - -struct icq_cookie { - struct icq_cookie *next; - char *id; - int size; - char * cookie; - char * connectstring; -}; - -static struct icq_cookie *icq_cookies = NULL; -pthread_mutex_t icq_cookie_mutex; -int icq_cookie_mutex_init = 0; - - -static void icq_clear(void *fo){ -}; - -static void addbuffer(int increment, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int * length_p){ - int bufsize = *length_p + increment + 40; - unsigned char *newbuf; - int len = 0; - - - if(bufsize > *bufsize_p){ - newbuf = myalloc(bufsize); - if(!newbuf) return; - memcpy(newbuf, *buf_p, *length_p); - myfree(*buf_p); - *buf_p = newbuf; - *bufsize_p = bufsize; - } - if(increment) len = sockrecvfrom(param->remsock, (struct sockaddr *)¶m->sinsr, *buf_p + *length_p, increment, conf.timeouts[STRING_S]*1000); - if(len > 0) { - *length_p += len; - param->nreads++; - param->statssrv64 += len; - } - return; -} - - - -static int searchcookie(struct clientparam *param, struct flap_header * flap, int len, int * dif, struct tlv_header *tlv, int extra){ - struct icq_cookie *ic; - char smallbuf[64]; - struct tlv_header *bostlv = NULL; - struct sockaddr_in sa; - SASIZETYPE size = sizeof(sa); - int movelen = 0; - - if(!icq_cookie_mutex_init){ - pthread_mutex_init(&icq_cookie_mutex, NULL); - icq_cookie_mutex_init = 1; - } - pthread_mutex_lock(&icq_cookie_mutex); - for(ic = icq_cookies; ic; ic = ic->next)if(!strcmp((char *)param->username, ic->id))break; - if(!ic){ - ic = myalloc(sizeof(struct icq_cookie)); - memset(ic, 0, sizeof(struct icq_cookie)); - ic->id = mystrdup((char *)param->username); - ic->next = icq_cookies; - icq_cookies = ic; - } - for(; ntohs(tlv->size) < 65500 && len >= (ntohs(tlv->size) + 4); len -= (ntohs(tlv->size) + 4), tlv = (struct tlv_header *)(tlv->data + ntohs(tlv->size))){ - if(ntohs(tlv->type) == 0x0006){ - if(ic->cookie)myfree(ic->cookie); - ic->cookie = myalloc(ntohs(tlv->size)); - memcpy(ic->cookie, tlv->data, ntohs(tlv->size)); - ic->size = tlv->size; - } - else if(ntohs(tlv->type) == 0x0005){ - if(ic->connectstring)myfree(ic->connectstring); - ic->connectstring = myalloc(ntohs(tlv->size)+1); - memcpy(ic->connectstring, tlv->data, ntohs(tlv->size)); - ic->connectstring[ntohs(tlv->size)] = 0; - bostlv = tlv; - movelen = extra + (len - 4) - ntohs(bostlv->size); - } - - } - if(!ic->connectstring || !ic->cookie){ - if(ic->cookie)myfree(ic->cookie); - if(ic->connectstring)myfree(ic->connectstring); - ic->cookie = NULL; - ic->connectstring = NULL; - ic->size = 0; - bostlv = NULL; - } - pthread_mutex_unlock(&icq_cookie_mutex); - if(bostlv){ - if(so._getsockname(param->clisock, (struct sockaddr *)&sa, &size)==-1) return 1; - len = myinet_ntop(*SAFAMILY(&sa),SAADDR(&sa), smallbuf, 64); - if(strchr(ic->connectstring, ':'))sprintf(smallbuf+len, ":%hu", ntohs(sa.sin_port)); - len = (int)strlen(smallbuf); - *dif = len - (int)ntohs(bostlv->size); - if(*dif != 0 && movelen > 0){ - memmove(bostlv->data + len, bostlv->data + ntohs(bostlv->size), movelen); - } - memcpy(bostlv->data, smallbuf, len); - bostlv->size = htons(len); - len = ((int)ntohs(flap->size)) + *dif; - flap->size = htons(len); - } - return 0; -} - - -static FILTER_ACTION icq_srv(void *fc, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int ioffset, int * length_p){ - unsigned char * start = *buf_p + ioffset; - int len = *length_p - ioffset; - struct icqstate *state = (struct icqstate *)fc; - int size; - int offset; - - while (len > 0){ - switch(state->state){ - case ONBEGIN: - - if((*start) == 0x2A) { - if(len < 6){ - offset = (int)(start - *buf_p); - addbuffer(6-len, param, buf_p, bufsize_p, length_p); - start = *buf_p + offset; - len = (int)(*buf_p + *length_p - start); - - } - state->state = ONCHAN; - } - else { - if(!state->leftinstate)param->srv->logfunc(param, (unsigned char *)"Warning: need resync"); - state->leftinstate++; - if(state->leftinstate > 65535){ - param->srv->logfunc(param, (unsigned char *)"Out of Sync"); - return REJECT; - } - } - start++; - len--; - break; - case ONCHAN: - if (*start >= 10){ - param->srv->logfunc(param, (unsigned char *)"Warning: Wrong channel"); - state->state = ONBEGIN; - } - else { - state->state = ONSEQ1; - state->channel = *start; - start++; - len--; - } - break; - case ONSEQ1: - state->gotseq = (((unsigned)*start) << 8); - state->state = ONSEQ2; - *(start) = (state->seq>>8); - start++; - len--; - break; - case ONSEQ2: - state->gotseq += *start; - if(state->gotseq != state->srvseq){ - unsigned char smallbuf[64]; - if(((state->gotseq < state->srvseq) || ((state->gotseq - state->srvseq) > 10 )) && (!state->resyncseq || state->gotseq != state->resyncseq)){ - sprintf((char *)smallbuf, "Warning: Wrong sequence, expected: %04hx got: %04hx", state->srvseq, state->gotseq); - param->srv->logfunc(param, smallbuf); - state->state = ONBEGIN; - state->resyncseq = state->gotseq; - break; - } - sprintf((char *)smallbuf, "Warning: %d flaps are lost on resync", state->gotseq - state->srvseq ); - param->srv->logfunc(param, smallbuf); - state->srvseq = state->gotseq; - *(start-1) = (state->seq>>8); - } - *start = (state->seq & 0x00FF); - state->srvseq = state->srvseq + 1; - state->seq = state->seq + 1; - state->state = ONSIZE1; - start++; - len--; - break; - case ONSIZE1: - state->leftinstate = (((unsigned)(*start))<<8); - state->state = ONSIZE2; - start++; - len--; - break; - case ONSIZE2: - state->leftinstate += *start; - state->state = (state->leftinstate)?ONDATA:ONBEGIN; - start++; - len--; - if(state->leftinstate > 30 && state->channel == 2) { - - if(len < state->leftinstate) { - offset = (int)(start - *buf_p); - addbuffer(state->leftinstate - len, param, buf_p, bufsize_p, length_p); - start = *buf_p + offset; - len = (int)(*length_p - offset); - - } - size = 0; - if ((start[4] & 0x80)) { - size = htons(*(unsigned short *)(start+10)) + 2; - if(size > 8) size = 0; - } - if (start[0] == 0 && start[1] == 1 && - ((start[2] == 0 && start[3] == 5) || (start[2] == 1 && start[3] == 2))){ - int dif = 0; - - offset = (int)(start - *buf_p); - addbuffer(0, param, buf_p, bufsize_p, length_p); - start = *buf_p + offset; - searchcookie(param, (struct flap_header *) (start-6), state->leftinstate-(size+10), &dif, (struct tlv_header *) (start + size + 10), len - state->leftinstate); - *length_p += dif; - start += (state->leftinstate + dif); - len -= state->leftinstate; - state->leftinstate = 0; - state->state = ONBEGIN; - } - } - break; - - case ONDATA: - size = (state->leftinstate > len)? len : state->leftinstate; - - start += size; - len -= size; - state->leftinstate -= size; - if(!state->leftinstate) { - state->state = ONBEGIN; - } - break; - } - } - - return CONTINUE; -} - -static struct filter icqfilter = { - NULL, - "icqfilter", - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - *icq_srv, - *icq_clear, - NULL -}; - - -static int readflap(struct clientparam * param, int direction, unsigned char *buf, int buflen){ - int i, len; - - struct flap_header *flap = (struct flap_header *)buf; - - i = sockgetlinebuf(param, direction, buf, 6, EOF, conf.timeouts[STRING_L]); - if(i!=6) return 1; - if(flap->id != 0x2a) return 2; - len = ntohs(flap->size); - if(len > buflen-6) return 3; - i = sockgetlinebuf(param, direction, (unsigned char *)flap->data, len, EOF, conf.timeouts[STRING_S]); - if(len != i) return 4; - return 0; - -} - -#define flap ((struct flap_header *)buf) -#define snack ((struct snack_header *)(buf+6)) -void * icqprchild(struct clientparam* param) { - int res; - unsigned char tmpsend[1024]; - unsigned char *buf; - int i,j,len,len1; - int offset = 0; - int buflen = 16384; - LOGINTYPE logintype = ICQUNKNOWN; - int greet = 0; - struct icq_cookie *ic; - struct tlv_header *tlv; - struct icqstate mystate = { - ONBEGIN, - 0, 0, 0, - 0 - }; - struct filterp icqfilterp = { - &icqfilter, - (void *)&mystate - }; - struct filterp **newfilters; - char handshake[] = {'\052', '\001', '\000', '\000', '\000', '\004', '\000', '\000', '\000', '\001'}; - - - - memcpy(tmpsend, handshake, 10); - if(socksend(param->clisock, tmpsend, 10, conf.timeouts[STRING_S])!=10) {RETURN (1101);} - buf = myalloc(65600); - - if((res = readflap(param, CLIENT, buf, 1000))) {RETURN (1180 + res);} - if(ntohs(flap->size) == 4 || ntohs(flap->size) == 12){ - tmpsend[2] = buf[2]; - tmpsend[3] = buf[3]; - greet = 1; - if(readflap(param, CLIENT, buf, 65550)) {RETURN (110);} - } - if(flap->chan != 1 && (flap->chan != 2 || snack->family != htonl(0x00170006))){ - RETURN(1104); - } - - len = ntohs(flap->size); - if(flap->chan == 1){ - tlv = (struct tlv_header *)(flap->data + 4); - len -= 4; - } - else { - tlv = (struct tlv_header *)(flap->data + 10); - len -= 10; - } - - for(; len >= (ntohs(tlv->size) + 4); len -= (ntohs(tlv->size) + 4), tlv = (struct tlv_header *)(tlv->data + ntohs(tlv->size))){ - switch(ntohs(tlv->type)){ - case 0x0001: - if(flap->chan == 2 && !logintype)logintype = ICQMD5; - if(!param->username){ - param->username = myalloc(ntohs(tlv->size) + 1); - for(i=0, j=0; i < ntohs(tlv->size); i++){ - if(!isspace(tlv->data[i]))param->username[j++]=tolower(tlv->data[i]); - } - param->username[j] = 0; - } - break; - case 0x0002: - logintype = ICQCLEAR; - break; - case 0x0006: - logintype = ICQCOOKIE; - - for(ic = icq_cookies; ic; ic=ic->next){ - if(ic->size && ic->size == tlv->size && !memcmp(ic->cookie, tlv->data, ntohs(tlv->size))){ - parsehostname((char *)ic->connectstring, param, ntohs(param->srv->targetport)); - if(!param->username && ic->id) param->username = (unsigned char *)mystrdup(ic->id); - break; - } - } - if(!ic) RETURN(1132); - break; - } - } - if(!logintype) RETURN(1133); - if(logintype != ICQCOOKIE) { - parsehostname((char *)param->srv->target, param, ntohs(param->srv->targetport)); - } - param->operation = CONNECT; - res = (*param->srv->authfunc)(param); - if(res) {RETURN(res);} - - if(greet){ - if(socksend(param->remsock, tmpsend, 10, conf.timeouts[STRING_S])!=10) {RETURN (1105);} - param->statscli64 += 10; - } - if(readflap(param, SERVER, tmpsend, 1024)) {RETURN (1111);} - param->statssrv64 += (ntohs(((struct flap_header *)tmpsend)->size) + 6); - mystate.srvseq = ntohs(((struct flap_header *)tmpsend)->seq) + 1; - mystate.seq = 1; - len = ntohs(flap->size) + 6; - if((res=handledatfltcli(param, &buf, &buflen, offset, &len))!=PASS) RETURN(res); - if(socksend(param->remsock, buf+offset, len, conf.timeouts[STRING_S])!=(ntohs(flap->size)+6)) {RETURN (1106);} - offset = 0; - param->statscli64 += len; - - if(logintype == ICQMD5) { - if(readflap(param, SERVER, buf, 65550)) {RETURN (1112);} - mystate.srvseq = ntohs(flap->seq) + 1; - flap->seq = htons(mystate.seq); - mystate.seq++; - len = ntohs(flap->size) + 6; - if((res=handledatfltsrv(param, &buf, &buflen, offset, &len))!=PASS) RETURN(res); - if(socksend(param->clisock, buf+offset, len, conf.timeouts[STRING_S])!=len) {RETURN (1113);} - offset = 0; - - if(readflap(param, CLIENT, buf, 65550)) {RETURN (1114);} - len = ntohs(flap->size) + 6; - if((res=handledatfltcli(param, &buf, &buflen, offset, &len))!=PASS) RETURN(res); - if(socksend(param->remsock, buf+offset, len, conf.timeouts[STRING_S])!=len) {RETURN (1115);} - param->statscli64 += len; - offset = 0; - } - if(logintype != ICQCOOKIE) { - if(readflap(param, SERVER, buf, 65550)) {RETURN (1116);} - mystate.srvseq = ntohs(flap->seq) + 1; - flap->seq = htons(mystate.seq); - mystate.seq++; - len = ntohs(flap->size); - - if(!param->username) {RETURN (1117);} - if(flap->chan == 1 || flap->chan == 4){ - if(flap->data[0] == 0 && flap->data[1] == 0 && flap->data[2] == 0 && flap->data[3] == 1){ - tlv = (struct tlv_header *)(flap->data + 4); - len -= 4; - } - else - tlv = (struct tlv_header *)(flap->data); - } - else { - tlv = (struct tlv_header *)(flap->data + 10); - len -= 10; - } - - len1 = ntohs(flap->size); - if(searchcookie(param, flap, len, &len1, tlv, 0)){RETURN (1118);} - - len = ntohs(flap->size) + 6; - if((res=handledatfltsrv(param, &buf, &buflen, offset, &len))!=PASS) RETURN(res); - if(socksend(param->clisock, buf+offset, len, conf.timeouts[STRING_S])!=len) {RETURN (1117);} - offset = 0; - } - - param->ndatfilterssrv++; - newfilters = myalloc(param->ndatfilterssrv * sizeof(struct filterp *)); - if(param->ndatfilterssrv > 1){ - memcpy(newfilters, param->datfilterssrv, (param->ndatfilterssrv - 1) * sizeof(struct filterp *)); - myfree(param->datfilterssrv); - } - param->datfilterssrv = newfilters; - newfilters[param->ndatfilterssrv - 1] = &icqfilterp; - - param->res = sockmap(param, conf.timeouts[CONNECTION_L]); - - param->ndatfilterssrv--; - -CLEANRET: - - - (*param->srv->logfunc)(param, NULL); - freeparam(param); - if(buf) myfree(buf); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - icqprchild, - 0, - 0, - S_ICQPR, - "" -}; -#include "proxymain.c" -#endif diff --git a/src/mycrypt.c b/src/mycrypt.c deleted file mode 100644 index 4381410..0000000 --- a/src/mycrypt.c +++ /dev/null @@ -1,199 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ -#include "libs/md5.h" -#include "libs/md4.h" -#include - -#define MD5_SIZE 16 - -#ifdef _WIN32 -#pragma warning (disable : 4996) -#endif - - -void tohex(unsigned char *in, unsigned char *out, int len); - -static unsigned char itoa64[] = - "./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; - -void -_crypt_to64(unsigned char *s, unsigned long v, int n) -{ - while (--n >= 0) { - *s++ = itoa64[v&0x3f]; - v >>= 6; - } -} - - -unsigned char * ntpwdhash (unsigned char *szHash, const unsigned char *szPassword, int ctohex) -{ - unsigned char szUnicodePass[513]; - unsigned int nPasswordLen; - MD4_CTX ctx; - unsigned int i; - - /* - * NT passwords are unicode. Convert plain text password - * to unicode by inserting a zero every other byte - */ - nPasswordLen = (int)strlen((char *)szPassword); - if(nPasswordLen > 255)nPasswordLen = 255; - for (i = 0; i < nPasswordLen; i++) { - szUnicodePass[i << 1] = szPassword[i]; - szUnicodePass[(i << 1) + 1] = 0; - } - - /* Encrypt Unicode password to a 16-byte MD4 hash */ - MD4Init(&ctx); - MD4Update(&ctx, szUnicodePass, (nPasswordLen<<1)); - MD4Final(szUnicodePass, &ctx); - if (ctohex){ - tohex(szUnicodePass, szHash, 16); - } - else memcpy(szHash, szUnicodePass, 16); - return szHash; -} - - -unsigned char * mycrypt(const unsigned char *pw, const unsigned char *salt, unsigned char *passwd){ - - const unsigned char *ep; - if(salt[0] == '$' && salt[1] == '1' && salt[2] == '$' && (ep = (unsigned char *)strchr((char *)salt+3, '$'))) { - static unsigned char *magic = (unsigned char *)"$1$"; - unsigned char *p; - const unsigned char *sp; - unsigned char final[MD5_SIZE]; - int sl,pl,i; - MD5_CTX ctx,ctx1; - unsigned long l; - - /* Refine the Salt first */ - sp = salt +3; - - /* get the length of the true salt */ - sl = (int)(ep - sp); - - MD5Init(&ctx); - - /* The password first, since that is what is most unknown */ - MD5Update(&ctx,pw,strlen((char *)pw)); - - /* Then our magic string */ - MD5Update(&ctx,magic,strlen((char *)magic)); - - /* Then the raw salt */ - MD5Update(&ctx,sp,sl); - - /* Then just as many unsigned characters of the MD5(pw,salt,pw) */ - MD5Init(&ctx1); - MD5Update(&ctx1,pw,strlen((char *)pw)); - MD5Update(&ctx1,sp,sl); - MD5Update(&ctx1,pw,strlen((char *)pw)); - MD5Final(final,&ctx1); - for(pl = (int)strlen((char *)pw); pl > 0; pl -= MD5_SIZE) - MD5Update(&ctx,final,pl>MD5_SIZE ? MD5_SIZE : pl); - - /* Don't leave anything around in vm they could use. */ - memset(final,0,sizeof final); - - /* Then something really weird... */ - for (i = (int)strlen((char *)pw); i ; i >>= 1) - if(i&1) - MD5Update(&ctx, final, 1); - else - MD5Update(&ctx, pw, 1); - - /* Now make the output string */ - strcpy((char *)passwd,(char *)magic); - strncat((char *)passwd,(char *)sp,sl); - strcat((char *)passwd,"$"); - - MD5Final(final,&ctx); - - /* - * and now, just to make sure things don't run too fast - * On a 60 Mhz Pentium this takes 34 msec, so you would - * need 30 seconds to build a 1000 entry dictionary... - */ - for(i=0;i<1000;i++) { - MD5Init(&ctx1); - if(i & 1) - MD5Update(&ctx1,pw,strlen((char *)pw)); - else - MD5Update(&ctx1,final,MD5_SIZE); - - if(i % 3) - MD5Update(&ctx1,sp,sl); - - if(i % 7) - MD5Update(&ctx1,pw,strlen((char *)pw)); - - if(i & 1) - MD5Update(&ctx1,final,MD5_SIZE); - else - MD5Update(&ctx1,pw,strlen((char *)pw)); - MD5Final(final,&ctx1); - } - - p = passwd + strlen((char *)passwd); - - l = (final[ 0]<<16) | (final[ 6]<<8) | final[12]; - _crypt_to64(p,l,4); p += 4; - l = (final[ 1]<<16) | (final[ 7]<<8) | final[13]; - _crypt_to64(p,l,4); p += 4; - l = (final[ 2]<<16) | (final[ 8]<<8) | final[14]; - _crypt_to64(p,l,4); p += 4; - l = (final[ 3]<<16) | (final[ 9]<<8) | final[15]; - _crypt_to64(p,l,4); p += 4; - l = (final[ 4]<<16) | (final[10]<<8) | final[ 5]; - _crypt_to64(p,l,4); p += 4; - l = final[11] ; - _crypt_to64(p,l,2); p += 2; - *p = '\0'; - - /* Don't leave anything around in vm they could use. */ - memset(final,0,sizeof final); - } - else { - *passwd = 0; - } - return passwd; -} - -#ifdef WITHMAIN - -#include -int main(int argc, char* argv[]){ - unsigned char buf[1024]; - unsigned i; - if(argc < 2 || argc > 3) { - fprintf(stderr, "usage: \n" - "\t%s \n" - "\t%s \n" - "Performs NT crypt if no salt specified, MD5 crypt with salt\n" - "This software uses:\n" - " RSA Data Security, Inc. MD4 Message-Digest Algorithm\n" - " RSA Data Security, Inc. MD5 Message-Digest Algorithm\n", - argv[0], - argv[0]); - return 1; - } - if(argc == 2) { - printf("NT:%s\n", ntpwdhash(buf, (unsigned char *)argv[1], 1)); - } - else { - i = (int)strlen((char *)argv[1]); - if (i > 64) argv[1][64] = 0; - sprintf((char *)buf, "$1$%s$", argv[1]); - printf("CR:%s\n", mycrypt((unsigned char *)argv[2], buf, buf+256)); - } - return 0; -} - -#endif diff --git a/src/ntlm.c b/src/ntlm.c deleted file mode 100644 index bde76f8..0000000 --- a/src/ntlm.c +++ /dev/null @@ -1,88 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" -struct ntlmchal { - unsigned char sig[8]; - unsigned char messtype[4]; - unsigned char dom_len[2]; - unsigned char dom_max_len[2]; - unsigned char dom_offset[4]; - unsigned char flags[4]; - unsigned char challenge[8]; - unsigned char reserved[8]; - unsigned char addr_len[2]; - unsigned char addr_max_len[2]; - unsigned char addr_offset[4]; - unsigned char data[1]; -}; - -struct ntlmreq { - unsigned char sig[8]; - unsigned char messtype[4]; - unsigned char flags[4]; - unsigned char dom_len[2]; - unsigned char dom_max_len[2]; - unsigned char dom_offset[4]; - unsigned char pad1[2]; - unsigned char host_len[2]; - unsigned char host_max_len[2]; - unsigned char host_offset[4]; - unsigned char pad2[2]; - unsigned char data[1]; -}; - -int text2unicode(const char * text, char * buf, int buflen){ - int count = 0; - buflen = ((buflen>>1)<<1); - if(!text || !buflen) return 0; - do { - buf[count++] = toupper(*text++); - buf[count++] = '\0'; - } while (*text && count < buflen); - return count; -} - -void unicode2text(const char *unicode, char * buf, int len){ - int i; - if(!unicode || !len) return; - for(i=0; isig, "NTLMSSP", 8); - chal->messtype[0] = 2; - gethostname(hostname, 128); - hostname[15] = 0; - len = (((int)strlen(hostname)) << 1); - chal->dom_len[0] = len; - chal->dom_max_len[0] = len; - chal->dom_offset[0] = (unsigned char)((unsigned char *)chal->data - (unsigned char *)chal); - chal->flags[0] = 0x03; - chal->flags[1] = 0x82; - chal->flags[2] = 0x81; - chal->flags[3] = 0xA0; - text2unicode(hostname, (char *)chal->data, 64); - time((time_t *)challenge); - memcpy(challenge+4, SAADDR(¶m->sincr), 4); - challenge[1]^=*SAPORT(¶m->sincr); - for(i = 0; i < 8; i++) challenge[i] ^= myrand(challenge, 8); - memcpy(chal->challenge, challenge, 8); - en64((unsigned char *)tmpbuf, (unsigned char *)buf, (int)((unsigned char *)chal->data - (unsigned char *)chal) + len); -} diff --git a/src/plugins.c b/src/plugins.c deleted file mode 100644 index e7b0cc9..0000000 --- a/src/plugins.c +++ /dev/null @@ -1,142 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -unsigned bandlimitfunc(struct clientparam *param, unsigned nbytesin, unsigned nbytesout); -void trafcountfunc(struct clientparam *param); -int checkACL(struct clientparam * param); -void nametohash(const unsigned char * name, unsigned char *hash); -unsigned hashindex(const unsigned char* hash); -void decodeurl(unsigned char *s, int allowcr); -int parsestr (unsigned char *str, unsigned char **argm, int nitems, unsigned char ** buff, int *inbuf, int *bufsize); -struct ace * make_ace (int argc, unsigned char ** argv); -extern char * proxy_stringtable[]; -extern char * admin_stringtable[]; -extern struct schedule * schedule; -int start_proxy_thread(struct child * chp); - -extern int linenum; -extern char *conffile; - -struct symbol symbols[] = { - {symbols+1, "conf", (void *) &conf}, - {symbols+2, "socksend", (void *) socksend}, - {symbols+3, "socksendto", (void *) socksendto}, - {symbols+4, "sockrecvfrom", (void *) sockrecvfrom}, - {symbols+5, "sockgetcharcli", (void *) sockgetcharcli}, - {symbols+6, "sockgetcharsrv", (void *) sockgetcharsrv}, - {symbols+7, "sockgetlinebuf", (void *) sockgetlinebuf}, - {symbols+8, "myinet_ntop", (void *) myinet_ntop}, - {symbols+9, "dobuf", (void *) dobuf}, - {symbols+10, "scanaddr", (void *) scanaddr}, - {symbols+11, "getip46", (void *) getip46}, - {symbols+12, "sockmap", (void *) sockmap}, - {symbols+13, "sockfuncs", (void *) &so}, - {symbols+14, "ACLmatches", (void *) ACLmatches}, - {symbols+15, "bandlimitfunc", (void *) bandlimitfunc}, - {symbols+16, "trafcountfunc", (void *) trafcountfunc}, - {symbols+17, "alwaysauth", (void *) alwaysauth}, - {symbols+18, "ipauth", (void *) ipauth}, - {symbols+19, "strongauth", (void *) strongauth}, - {symbols+20, "checkACL", (void *) checkACL}, - {symbols+21, "nametohash", (void *) nametohash}, - {symbols+22, "hashindex", (void *) hashindex}, - {symbols+23, "nservers", (void *) nservers}, - {symbols+24, "udpresolve", (void *) udpresolve}, - {symbols+25, "bandlim_mutex", (void *) &bandlim_mutex}, - {symbols+26, "tc_mutex", (void *) &tc_mutex}, - {symbols+27, "hash_mutex", (void *) &hash_mutex}, - {symbols+28, "pwl_mutex", (void *) &pwl_mutex}, - {symbols+29, "linenum", (void *) &linenum}, - {symbols+30, "proxy_stringtable", (void *) proxy_stringtable}, - {symbols+31, "en64", (void *) en64}, - {symbols+32, "de64", (void *) de64}, - {symbols+33, "tohex", (void *) tohex}, - {symbols+34, "fromhex", (void *) fromhex}, - {symbols+35, "dnspr", (void *) dnsprchild}, - {symbols+36, "pop3p", (void *) pop3pchild}, - {symbols+37, "proxy", (void *) proxychild}, - {symbols+38, "socks", (void *) sockschild}, - {symbols+39, "tcppm", (void *) tcppmchild}, - {symbols+40, "udppm", (void *) udppmchild}, - {symbols+41, "admin", (void *) adminchild}, - {symbols+42, "ftppr", (void *) ftpprchild}, - {symbols+43, "smtpp", (void *) smtppchild}, - {symbols+44, "icqpr", (void *) icqprchild}, -/* - {symbols+45, "msnpr", (void *) msnprchild}, -*/ - {symbols+45, "authfuncs", (void *) &authfuncs}, - {symbols+46, "commandhandlers", (void *) &commandhandlers}, - {symbols+47, "decodeurl", (void *) decodeurl}, - {symbols+48, "parsestr", (void *) parsestr}, - {symbols+49, "make_ace", (void *) make_ace}, - {symbols+50, "freeacl", (void *) freeacl}, - {NULL, "", NULL} -}; - -static void * findbyname(const char *name){ - struct symbol * symbols; - for(symbols = &pluginlink.symbols; symbols; symbols=symbols->next) - if(!strcmp(symbols->name, name)) return symbols->value; - return NULL; -} - - -struct pluginlink pluginlink = { - {symbols, "", NULL}, - &conf, - nservers, - &linenum, - authfuncs, - commandhandlers, - findbyname, - socksend, - socksendto, - sockrecvfrom, - sockgetcharcli, - sockgetcharsrv, - sockgetlinebuf, - myinet_ntop, - dobuf, - dobuf2, - scanaddr, - getip46, - sockmap, - ACLmatches, - alwaysauth, - checkACL, - nametohash, - hashindex, - en64, - de64, - tohex, - fromhex, - decodeurl, - parsestr, - make_ace, - myalloc, - myfree, - myrealloc, - mystrdup, - trafcountfunc, - proxy_stringtable, - &schedule, - freeacl, - admin_stringtable, - &childdef, - start_proxy_thread, - freeparam, - parsehostname, - parseusername, - parseconnusername, - &so, - dologname -}; - diff --git a/src/plugins/FilePlugin/FilePlugin.c b/src/plugins/FilePlugin/FilePlugin.c deleted file mode 100644 index 280dbdf..0000000 --- a/src/plugins/FilePlugin/FilePlugin.c +++ /dev/null @@ -1,917 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2007-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "../../structures.h" -#include "FilePlugin.h" -#include -#include -#include -#include -#include -#include -#include -#include -#include -#ifdef _WIN32 -#ifndef _WINCE -#include -#else -#include -#endif -#else -#include -#ifndef O_BINARY -#define O_BINARY (0) -#endif -#endif - -#ifdef __cplusplus -extern "C" { -#endif - - -#ifndef _WIN32 -#define WINAPI -#define fp_size_t size_t -#else -#define fp_size_t int -#endif - -static struct pluginlink * pl; - -static pthread_mutex_t file_mutex; - -unsigned long preview = 0; - -char path[300]; - -static int counter = 0; -static int timeo = 0; - -static char * fp_stringtable[] = { -/* 0 */ "HTTP/1.0 503 Service Unavailable\r\n" - "Proxy-Connection: close\r\n" - "Content-type: text/html; charset=us-ascii\r\n" - "\r\n" - "503 Service Unavailable\r\n" - "

503 Service Unavailable

HTTP policy violation: you have no permission to perform this action. Please conatct helpdesk or Administrator.

\r\n", -/* 1 */ "421 SMTP policy violation: you have no permission to perform this action. Please conatct helpdesk or Administrator.\r\n", -/* 2 */ "421 FTP policy violation: you have no permission to perform this action. Please conatct helpdesk or Administrator.\r\n", - NULL -}; - -enum states { - STATE_INITIAL = 0, - GOT_HTTP_REQUEST, - GOT_HTTP_CLI_HDR, - GOT_HTTP_SRV_HDR, - GOT_HTTP_CLI_HDR2, - GOT_HTTP_SRV_HDR2, - GOT_HTTP_CLIDATA, - GOT_HTTP_SRVDATA, - GOT_SMTP_REQ, - GOT_SMTP_DATA, - GOT_FTP_REQ, - GOT_FTP_CLIDATA, - GOT_FTP_SRVDATA, - FLUSH_DATA -}; - -struct fp_callback { - struct fp_callback *next; - FP_CALLBACK callback; - void * data; - int what; - int preview_size; - int max_size; -}; - -struct fp_stream { - struct fp_stream *next; - char * buf; - int state; - int what; - int needsrvconnect; - int preview_size; - long bufsize; - unsigned long clihdrwritten, clientwritten, clientsent, srvhdrwritten, serverwritten, serversent; - struct fp_callback *callbacks; - struct fp_filedata fpd; -} *fp_streams = NULL; - -struct sockfuncs sso; - - -static void genpaths(struct fp_stream *fps){ - - if(fps->what & (FP_CLIDATA|FP_CLIHEADER)){ - if(fps->fpd.path_cli) free(fps->fpd.path_cli); - fps->fpd.path_cli = malloc(strlen(path) + 10); - sprintf(fps->fpd.path_cli, path, counter++); - } - if(fps->what & (FP_SRVDATA|FP_SRVHEADER)){ - if(fps->fpd.path_srv) free(fps->fpd.path_srv); - fps->fpd.path_srv = malloc(strlen(path) + 10); - sprintf(fps->fpd.path_srv, path, counter++); - } - -} - -static -#ifdef _WIN32 - HANDLE -#else - int -#endif - initclientfile(struct fp_stream *fps){ - - fps->clientwritten = fps->clientsent = 0; -#ifdef _WIN32 - if(fps->fpd.h_cli != INVALID_HANDLE_VALUE){ - CloseHandle(fps->fpd.h_cli); - } - fps->fpd.h_cli = CreateFile(fps->fpd.path_cli, GENERIC_READ | GENERIC_WRITE, (fps->what & FP_SHAREFILE)? FILE_SHARE_DELETE|FILE_SHARE_READ|FILE_SHARE_WRITE:0, NULL, CREATE_ALWAYS, (fps->what & (FP_KEEPFILE|FP_SHAREFILE))? FILE_ATTRIBUTE_TEMPORARY : FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE, NULL); - return fps->fpd.h_cli; -#else - if(fps->fpd.fd_cli != -1) close(fps->fpd.fd_cli); - fps->fpd.fd_cli = open(fps->fpd.path_cli, O_BINARY|O_RDWR|O_CREAT|O_TRUNC, 0600); - return fps->fpd.fd_cli; -#endif -} - -static -#ifdef _WIN32 - HANDLE -#else - int -#endif - initserverfile(struct fp_stream *fps){ - fps->serverwritten = fps->serversent = 0; -#ifdef _WIN32 - if(fps->fpd.h_srv != INVALID_HANDLE_VALUE){ - CloseHandle(fps->fpd.h_srv); - } - fps->fpd.h_srv = CreateFile(fps->fpd.path_srv, GENERIC_READ | GENERIC_WRITE, (fps->what & FP_SHAREFILE)? FILE_SHARE_DELETE|FILE_SHARE_READ|FILE_SHARE_WRITE:0, NULL, CREATE_ALWAYS, (fps->what & (FP_KEEPFILE|FP_SHAREFILE))? FILE_ATTRIBUTE_TEMPORARY : FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE, NULL); - return fps->fpd.h_srv; -#else - if(fps->fpd.fd_srv != -1) close(fps->fpd.fd_srv); - fps->fpd.fd_srv = open(fps->fpd.path_srv, O_BINARY|O_RDWR|O_CREAT|O_TRUNC, 0600); - return fps->fpd.fd_srv; -#endif -} - -static void closefiles(struct fp_stream *fps){ -#ifdef _WIN32 - if(fps->fpd.h_cli != INVALID_HANDLE_VALUE) { - CloseHandle(fps->fpd.h_cli); - fps->fpd.h_cli = INVALID_HANDLE_VALUE; - - if((fps->what & FP_SHAREFILE) && !(fps->what & FP_KEEPFILE)) DeleteFile(fps->fpd.path_cli); - } - if(fps->fpd.h_srv != INVALID_HANDLE_VALUE) { - CloseHandle(fps->fpd.h_srv); - fps->fpd.h_srv = INVALID_HANDLE_VALUE; - - if((fps->what & FP_SHAREFILE) && !(fps->what & FP_KEEPFILE)) DeleteFile(fps->fpd.path_cli); - } -#else - if(fps->fpd.fd_cli != -1) { - close(fps->fpd.fd_cli); - fps->fpd.fd_cli = -1; - - if(!(fps->what & FP_KEEPFILE)) unlink(fps->fpd.path_cli); - } - if(fps->fpd.fd_srv != -1) { - close(fps->fpd.fd_srv); - fps->fpd.fd_srv = -1; - if(!(fps->what & FP_KEEPFILE)) unlink(fps->fpd.path_srv); - } -#endif - if(fps->fpd.path_cli) { - free(fps->fpd.path_cli); - fps->fpd.path_cli = NULL; - } - if(fps->fpd.path_srv) { - free(fps->fpd.path_srv); - fps->fpd.path_srv = NULL; - } - fps->clihdrwritten = fps->clientwritten = fps->clientsent = fps->srvhdrwritten = fps->serverwritten = fps->serversent = 0; -} - -static int searchsocket(SOCKET s, struct fp_stream **pfps){ - struct fp_stream *fps = NULL; - int ret = 0; - pthread_mutex_lock(&file_mutex); - for(fps = fp_streams; fps; fps = fps->next){ - if(fps->fpd.cp->clisock == s) { - ret = 1; - break; - } - if(fps->fpd.cp->remsock == s) { - ret = 2; - break; - } - if(fps->fpd.cp->ctrlsock == s) { - ret = 3; - break; - } - } - pthread_mutex_unlock(&file_mutex); - *pfps = fps; - return ret; -} - -static void freecallback(struct fp_stream * fps, struct fp_callback * fpc){ - if(fpc->next) freecallback(fps, fpc->next); - if(fpc->what & FP_CALLONREMOVE) (*fpc->callback)(FP_CALLONREMOVE, fpc->data, &fps->fpd, NULL, 0); - free(fpc); -} - -static void removefps(struct fp_stream * fps){ - if(!fp_streams) return; - pthread_mutex_lock(&file_mutex); - if(fp_streams == fps)fp_streams = fps->next; - else { - struct fp_stream *fps2; - - for(fps2 = fp_streams; fps2->next; fps2 = fps2->next){ - if(fps2->next == fps){ - fps2->next = fps->next; - break; - } - } - - } - pthread_mutex_unlock(&file_mutex); - if(fps->callbacks){ - freecallback(fps, fps->callbacks); - fps->callbacks = 0; - } - closefiles(fps); - if(fps->buf) { - free(fps->buf); - fps->buf = NULL; - } - fps->state = 0; -} - -static int WINAPI fp_connect(SOCKET s, const struct sockaddr *name, fp_size_t namelen){ - return sso._connect(s, name, namelen); -} - -void processcallbacks(struct fp_stream *fps, int what, char *msg, int size){ - struct fp_callback *cb; - int state; - - state = fps->state; - if(fps->what & what) { - fps->what = 0; - for(cb = fps->callbacks; cb; cb=cb->next){ - if(cb->what & what){ - cb->what = (*cb->callback)(what, cb->data, &(fps->fpd), msg, size); - } - fps->what |= cb->what; - } - } - if(fps->what & FP_REJECT){ - switch(state){ -/* - Fixme: handle different states -*/ - case GOT_SMTP_REQ: - case GOT_SMTP_DATA: - fps->state = FLUSH_DATA; - pl->socksend(fps->fpd.cp->clisock, fp_stringtable[1], (int)strlen(fp_stringtable[1]), pl->conf->timeouts[STRING_S]); - fps->state = state; - break; - case GOT_HTTP_REQUEST: - case GOT_HTTP_CLI_HDR: - case GOT_HTTP_SRV_HDR: - case GOT_HTTP_CLI_HDR2: - case GOT_HTTP_SRV_HDR2: - case GOT_HTTP_CLIDATA: - case GOT_HTTP_SRVDATA: - if(!fps->serversent){ - fps->state = FLUSH_DATA; - pl->socksend(fps->fpd.cp->clisock, fp_stringtable[0], (int)strlen(fp_stringtable[0]), pl->conf->timeouts[STRING_S]); - fps->state = state; - } - break; - case GOT_FTP_CLIDATA: - case GOT_FTP_REQ: - case GOT_FTP_SRVDATA: - fps->state = FLUSH_DATA; - pl->socksend(fps->fpd.cp->ctrlsock, fp_stringtable[1], (int)strlen(fp_stringtable[1]), pl->conf->timeouts[STRING_S]); - fps->state = state; - break; - default: - break; - } - if(fps->fpd.cp->remsock != INVALID_SOCKET)sso._closesocket(fps->fpd.cp->remsock); - fps->fpd.cp->remsock = INVALID_SOCKET; - if(fps->fpd.cp->clisock != INVALID_SOCKET)sso._closesocket(fps->fpd.cp->clisock); - fps->fpd.cp->clisock = INVALID_SOCKET; - } -} - -static int copyfdtosock(struct fp_stream * fps, DIRECTION which, long len){ - int res; - long toread; - int state; -#ifdef _WIN32 - HANDLE h; -#else - int fd; -#endif - SOCKET sock; - long offset; - int sendchunk = 0; - - state = fps->state; - fps->state = FLUSH_DATA; - if(!fps->buf){ - fps->buf = malloc(2048); - if(!fps->buf) return -2; - fps->bufsize = 2048; - } - if(which == SERVER){ - offset = fps->clientsent; - fps->clientsent += len; -#ifdef _WIN32 - h = fps->fpd.h_cli; -#else - fd = fps->fpd.fd_cli; -#endif - sock = fps->fpd.cp->remsock; - } - else { - if(fps->fpd.cp->chunked){ - if(fps->serversent < fps->srvhdrwritten && (fps->serversent + len) > fps->srvhdrwritten){ - len -= fps->srvhdrwritten - fps->serversent; - if ((res = copyfdtosock(fps, which, fps->srvhdrwritten - fps->serversent))) return res; - } - if(fps->serversent >= fps->srvhdrwritten){ - sprintf(fps->buf, "%lx\r\n", len); - sendchunk = (int)strlen(fps->buf); - if(pl->socksend(fps->fpd.cp->clisock, fps->buf, sendchunk, pl->conf->timeouts[STRING_S]) != sendchunk){ - return -4; - } - } - } - offset = fps->serversent; - fps->serversent += len; -#ifdef _WIN32 - h = fps->fpd.h_srv; -#else - fd = fps->fpd.fd_srv; -#endif - sock = fps->fpd.cp->clisock; - } -#ifdef _WIN32 - if(SetFilePointer(h,offset,0,FILE_BEGIN)!=offset){ - return -1; - } -#else - if(lseek(fd, offset, SEEK_SET) < 0) { - return -1; - } -#endif - - - while(len > 0){ - - -/* - Fixme: prevent client/server timeouts -*/ - toread = (len > fps->bufsize)? fps->bufsize:len; -#ifdef _WIN32 - if(!ReadFile(h, fps->buf, (DWORD)toread,(DWORD *)&res,NULL)) { -#else - if((res = read(fd, fps->buf, toread)) <= 0) { -#endif - return -3; - } - if(pl->socksend(sock, fps->buf, res, pl->conf->timeouts[STRING_S]) != res) { - return -4; - } - len -= res; - } - if(sendchunk){ - if(pl->socksend(sock, "\r\n", 2, pl->conf->timeouts[STRING_S]) != 2) - return -4; - } - fps->state = state; - return 0; -} - -static int WINAPI fp_poll(struct pollfd *fds, unsigned int nfds, int timeout){ - struct fp_stream *fps = NULL; - int res; - unsigned i; - int to; - - for(i = 0; istate == GOT_SMTP_DATA){ - if(fds[i].events & POLLOUT){ - fds[i].revents = POLLOUT; - return 1; - } - } - else if(res == 2 && (((fps->what & FP_CLIHEADER) && (fps->state == GOT_HTTP_REQUEST || fps->state == GOT_HTTP_CLI_HDR2)) || ((fps->what & FP_CLIDATA) && fps->state == GOT_HTTP_CLIDATA))){ - - if(fds[i].events & POLLIN){ - processcallbacks(fps, (fps->state == GOT_HTTP_CLIDATA)?FP_CLIDATA:FP_CALLAFTERCLIHEADERS, NULL, 0); - if(fps->clihdrwritten + fps->clientwritten > fps->clientsent) { - if(copyfdtosock(fps, SERVER, (fps->clihdrwritten + fps->clientwritten) - fps->clientsent)) - return -2; - } - if(fps->state) { - if(fps->what & FP_SRVHEADER) initserverfile(fps); - fps->state = GOT_HTTP_SRV_HDR; - } - } - - else if(fds[i].events & POLLOUT){ - fds[i].revents = POLLOUT; - return 1; - } - - } - else if(res == 1 && (fps->state == GOT_HTTP_SRVDATA || fps->state == GOT_HTTP_SRV_HDR || fps->state == GOT_HTTP_SRV_HDR2)&& (fds[i].events & POLLIN)){ - processcallbacks(fps, (fps->state == GOT_HTTP_SRVDATA)? FP_SRVDATA:FP_CALLAFTERSRVHEADERS, NULL, 0); - if(fps->srvhdrwritten + fps->serverwritten > fps->serversent) { - if(copyfdtosock(fps, CLIENT, (fps->srvhdrwritten + fps->serverwritten) - fps->serversent)) - return -2; - } - closefiles(fps); - fps->state = 0; - } - - } - return sso._poll(fds, nfds, timeout); -} - -static int WINAPI fp_send(SOCKET s, const char *msg, fp_size_t len, int flags){ - struct fp_stream *fps = NULL; - int res; - res = searchsocket(s, &fps); - if(res == 2){ - if(fps->state == GOT_SMTP_DATA) { - if(fps->clihdrwritten + fps->clientwritten > fps->clientsent) { - processcallbacks(fps, FP_CLIDATA, NULL, 0); - if(copyfdtosock(fps, SERVER, (fps->clihdrwritten + fps->clientwritten) - fps->clientsent)) { - return -1; - } - fps->state = 0; - } - closefiles(fps); - fps->state = 0; - return sso._send(s, msg, len, flags); - } - if((((fps->what & FP_CLIHEADER) && (fps->state == GOT_HTTP_REQUEST || fps->state == GOT_HTTP_CLI_HDR2)) || ((fps->what & FP_CLIDATA) && fps->state == GOT_HTTP_CLIDATA))){ -#ifdef _WIN32 - if(SetFilePointer(fps->fpd.h_cli, fps->clientwritten + fps->clihdrwritten, 0, FILE_BEGIN) != (fps->clientwritten + fps->clihdrwritten)){ - return -1; - } - if(!WriteFile(fps->fpd.h_cli, msg, (DWORD)len,(DWORD *)&res,NULL) || res != len){ - return -1; - } -#else - if(lseek(fps->fpd.fd_cli, fps->clientwritten + fps->clihdrwritten, SEEK_SET) < 0) { - return -1; - } - if((res = write(fps->fpd.fd_cli, msg, len) != len)) return -1; -#endif - if(fps->state == GOT_HTTP_CLIDATA)fps->clientwritten += res; - else fps->clihdrwritten += res; - return res; - } - } - if(res == 1){ - if(((fps->what & FP_SRVDATA) && (fps->state == GOT_HTTP_SRVDATA || fps->state == GOT_HTTP_SRV_HDR) && fps->fpd.cp->chunked && len < 16 )){ - int hasnonzero = 0, i; - - for(i=0; i < len; i++){ - char c = msg[i]; - - if(c == '\r' || c == '\n') continue; - if((c<'0'|| c>'9') && (c<'A' || c>'F') && (c<'a' || c>'f')) { - return sso._send(s, msg, len, flags); - } - if(c != '0') hasnonzero = 1; - } - if(i>2 && !hasnonzero){ - - if(fps->srvhdrwritten + fps->serverwritten > fps->serversent) { - processcallbacks(fps, FP_SRVDATA, NULL, 0); - if(copyfdtosock(fps, CLIENT, (fps->srvhdrwritten + fps->serverwritten) - fps->serversent)) { - return -1; - } - fps->state = 0; - } - closefiles(fps); - fps->state = 0; - return sso._send(s, msg, len, flags); - } - return len; - } - if(((fps->what & FP_SRVHEADER) && (fps->state == GOT_HTTP_SRV_HDR || fps->state == GOT_HTTP_SRV_HDR2))){ -#ifdef _WIN32 - if(SetFilePointer(fps->fpd.h_srv, fps->serverwritten + fps->srvhdrwritten, 0, FILE_BEGIN) != (fps->serverwritten + fps->srvhdrwritten)){ - return -1; - } - if(!WriteFile(fps->fpd.h_srv, msg, (DWORD)len,(DWORD *)&res,NULL) || res !=len){ - return -1; - } -#else - if(lseek(fps->fpd.fd_srv, fps->serverwritten + fps->srvhdrwritten, SEEK_SET) < 0) { - return -1; - } - if((res = write(fps->fpd.fd_srv, msg, len) != len)) return -1; -#endif - fps->srvhdrwritten += res; - return res; - } - } - return sso._send(s, msg, len, flags); -} -static int WINAPI fp_sendto(SOCKET s, const void *msg, int len, int flags, const struct sockaddr *to, fp_size_t tolen){ - struct fp_stream *fps = NULL; - int res; - res = searchsocket(s, &fps); - if(res == 2) { - switch(fps->state){ - case GOT_SMTP_REQ: - if(!(fps->what & FP_CLIDATA)) break; - fps->state = GOT_SMTP_DATA; - initclientfile(fps); - case GOT_FTP_REQ: - if(fps->state == GOT_FTP_REQ){ - if(!(fps->what & FP_CLIDATA)) break; - fps->state = GOT_FTP_CLIDATA; - initclientfile(fps); - } - case GOT_HTTP_CLI_HDR2: - if(fps->state == GOT_HTTP_CLI_HDR2){ - processcallbacks(fps, FP_CALLAFTERCLIHEADERS, NULL, 0); - if ((fps->what & FP_REJECT)) return -1; - if((fps->what & FP_CLIDATA) && !(fps->what & FP_CLIHEADER)) initclientfile(fps); - else if(!(fps->what & FP_CLIDATA) && (fps->what & FP_CLIHEADER)){ - if(fps->clihdrwritten + fps->clientwritten > fps->clientsent) { - if(copyfdtosock(fps, SERVER, (fps->clihdrwritten + fps->clientwritten) - fps->clientsent)) - return -2; - } - } - fps->state = GOT_HTTP_CLIDATA; - } - case GOT_HTTP_REQUEST: - if(fps->state == GOT_HTTP_REQUEST && !(fps->what & FP_CLIHEADER)) break; - case GOT_SMTP_DATA: - case GOT_FTP_CLIDATA: - case GOT_FTP_SRVDATA: - case GOT_HTTP_CLIDATA: - if((!fps->what & FP_CLIDATA)) break; -#ifdef _WIN32 - if(SetFilePointer(fps->fpd.h_cli, fps->clientwritten + fps->clihdrwritten, 0, FILE_BEGIN) != (fps->clientwritten + fps->clihdrwritten)){ - return -1; - } - if(!WriteFile(fps->fpd.h_cli, msg, (DWORD)len,(DWORD *)&res,NULL) || res != len) { - return -1; - } -#else - if(lseek(fps->fpd.fd_cli, fps->clientwritten + fps->clihdrwritten, SEEK_SET) < 0) { - return -1; - } - if((res = write(fps->fpd.fd_cli, msg, len) != len)) return -1; -#endif - if(fps->state == GOT_HTTP_REQUEST)fps->clihdrwritten += res; - else fps->clientwritten += res; - if(fps->preview_size && ((fps->clihdrwritten + fps->clientwritten) > (fps->clientsent + fps->preview_size))){ - if(!fps->clientsent){ - processcallbacks(fps, FP_PREVIEWCLI, NULL, 0); - if ((fps->what & FP_REJECT)) return -1; - } - if(copyfdtosock(fps, SERVER, (fps->clihdrwritten + fps->clientwritten) - (fps->clientsent + fps->preview_size))) - return -1; - - } - return res; - } - - } - else if(res == 1){ - switch(fps->state){ - case GOT_HTTP_SRV_HDR2: - processcallbacks(fps, FP_CALLAFTERSRVHEADERS, NULL, 0); - if ((fps->what & FP_REJECT)) return REJECT; - if((fps->what & FP_SRVDATA) && !(fps->what & FP_SRVHEADER)) initserverfile(fps); - else if(!(fps->what & FP_SRVDATA) && (fps->what & FP_SRVHEADER)){ - if(fps->srvhdrwritten + fps->serverwritten > fps->serversent) { - if(copyfdtosock(fps, CLIENT, (fps->srvhdrwritten + fps->serverwritten) - fps->serversent)) - return -2; - } - } - fps->state = GOT_HTTP_SRVDATA; - case GOT_FTP_REQ: - if(fps->state == GOT_FTP_REQ){ - if(!(fps->what & FP_SRVDATA)) break; - fps->state = GOT_FTP_SRVDATA; - initserverfile(fps); - } - case GOT_HTTP_SRV_HDR: - if(fps->state == GOT_HTTP_SRV_HDR && !(fps->what & FP_SRVHEADER)) break; - case GOT_HTTP_SRVDATA: - case GOT_FTP_SRVDATA: - case GOT_FTP_CLIDATA: - if(!(fps->what & FP_SRVDATA)) break; -#ifdef _WIN32 - if(SetFilePointer(fps->fpd.h_srv, fps->serverwritten + fps->srvhdrwritten, 0, FILE_BEGIN) != (fps->serverwritten + fps->srvhdrwritten)){ - return -1; - } - if(!WriteFile(fps->fpd.h_srv, msg, (DWORD)len,(DWORD *)&res,NULL) || res != len){ - return -1; - } -#else - if(lseek(fps->fpd.fd_srv, fps->serverwritten + fps->srvhdrwritten, SEEK_SET) < 0) { - return -1; - } - if((res = write(fps->fpd.fd_srv, msg, len) != len)) return -1; -#endif - if(fps->state == GOT_HTTP_SRV_HDR)fps->srvhdrwritten += res; - else fps->serverwritten += res; - if(fps->preview_size && ((fps->srvhdrwritten + fps->serverwritten) > (fps->serversent + fps->preview_size))){ - if(!fps->serversent){ - processcallbacks(fps, FP_PREVIEWSRV, NULL, 0); - if ((fps->what & FP_REJECT)) return -1; - } - if(copyfdtosock(fps, CLIENT, (fps->srvhdrwritten + fps->serverwritten) - (fps->serversent + fps->preview_size))) - return -1; - - } - return res; - } - } - return sso._sendto(s, msg, len, flags, to, tolen); -} -static int WINAPI fp_recv(SOCKET s, void *buf, fp_size_t len, int flags){ - return sso._recv(s, buf, len, flags); -} -static int WINAPI fp_recvfrom(SOCKET s, void * buf, fp_size_t len, int flags, struct sockaddr * from, fp_size_t * fromlen){ - return sso._recvfrom(s, buf, len, flags, from, fromlen); -} -static int WINAPI fp_shutdown(SOCKET s, int how){ - struct fp_stream *fps = NULL; - - int res; - res = searchsocket(s, &fps); - if(res){ - if(fps->state == GOT_HTTP_SRV_HDR || fps->state == GOT_HTTP_SRVDATA || fps->state == GOT_FTP_SRVDATA){ - if(fps->srvhdrwritten + fps->serverwritten > fps->serversent) { - processcallbacks(fps, FP_SRVDATA, NULL, 0); - copyfdtosock(fps, CLIENT, (fps->srvhdrwritten + fps->serverwritten) - fps->serversent); - } - closefiles(fps); - fps->state = 0; - } - else if(fps->state == GOT_FTP_CLIDATA){ - if(fps->clihdrwritten + fps->clientwritten > fps->clientsent) { - processcallbacks(fps, FP_CLIDATA, NULL, 0); - copyfdtosock(fps, SERVER, (fps->clihdrwritten + fps->clientwritten) - fps->clientsent); - } - closefiles(fps); - fps->state = 0; - } - } - - return sso._shutdown(s, how); -} -static int WINAPI fp_closesocket(SOCKET s){ - return sso._closesocket(s); -} - - - -struct fp_stream * addfps(struct clientparam *cp){ - struct fp_stream *fps; - - for(fps = fp_streams; fps && fps->fpd.cp != cp; fps = fps->next); - if(!fps) { - fps = malloc(sizeof(struct fp_stream)); - if(!fps){ - return NULL; - } - memset(fps, 0, sizeof(struct fp_stream)); - fps->fpd.cp = cp; - fps->next = fp_streams; - fp_streams = fps; -#ifdef _WIN32 - fps->fpd.h_cli = fps->fpd.h_srv = INVALID_HANDLE_VALUE; -#else - fps->fpd.fd_cli = fps->fpd.fd_srv = -1; -#endif - } - return fps; -} - -static int fp_registercallback (int what, int max_size, int preview_size, struct clientparam *cp, FP_CALLBACK cb, void *data){ - struct fp_callback * fpc; - struct fp_stream *fps; - - fpc = malloc(sizeof(struct fp_callback)); - if(!fpc) return 0; - fpc->what = what; - fpc->preview_size = preview_size; - fpc->max_size = max_size; - fpc->data = data; - fpc->callback = cb; - pthread_mutex_lock(&file_mutex); - fps = addfps(cp); - if(fps){ - fpc->next = fps->callbacks; - fps->callbacks = fpc; - fps->what |= fpc->what; - if(preview_size > fps->preview_size) fps->preview_size = preview_size; - } - else free(fpc); - pthread_mutex_unlock(&file_mutex); - return fps?1:0; -} - - -static void * fp_open(void * idata, struct srvparam * param){ - return idata; -} - - -#define FC ((struct fp_stream *)fc) - -static FILTER_ACTION fp_client(void *fo, struct clientparam * param, void** fc){ - - pthread_mutex_lock(&file_mutex); - (*fc) = (void *)addfps(param); - pthread_mutex_unlock(&file_mutex); - return CONTINUE; -} - -static FILTER_ACTION fp_request(void *fc, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int offset, int * length_p){ - if(fc && (param->service == S_PROXY)){ - if(FC->state) { - closefiles(FC); - FC->state = 0; - } - processcallbacks(FC, FP_CALLONREQUEST, *buf_p + offset, *length_p - offset); - if(FC->what &FP_REJECT) return REJECT; - FC->state = GOT_HTTP_REQUEST; - genpaths(FC); - if(FC->what & FP_CLIHEADER) initclientfile(FC); - - } - return CONTINUE; -} - -static FILTER_ACTION fp_hcli(void *fc, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int offset, int * length_p){ - if(fc && param->service == S_SMTPP) { - processcallbacks(FC, FP_CALLONREQUEST, *buf_p + offset, *length_p - offset); - if(FC->what & FP_REJECT) return REJECT; - if(!FC->state)genpaths(FC); - FC->state = GOT_SMTP_REQ; - } - if(fc && param->service == S_FTPPR) { - processcallbacks(FC, FP_CALLONREQUEST, *buf_p + offset, *length_p - offset); - if(FC->what & FP_REJECT) return REJECT; - genpaths(FC); - FC->state = GOT_FTP_REQ; - } - return CONTINUE; -} - -static FILTER_ACTION fp_hsrv(void *fc, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int offset, int * length_p){ - if(fc && param->service == S_PROXY && (FC->state == GOT_HTTP_REQUEST || FC->state == GOT_HTTP_CLI_HDR || FC->state == GOT_HTTP_CLIDATA)){ - if(FC->what & FP_SRVHEADER) initserverfile(FC); - FC->state = GOT_HTTP_SRV_HDR; - - } - return CONTINUE; -} - -static FILTER_ACTION fp_dcli(void *fc, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int offset, int * length_p){ - if(fc && FC->state == GOT_HTTP_REQUEST){ - FC->state = GOT_HTTP_CLI_HDR2; - } - return CONTINUE; -} - - -static FILTER_ACTION fp_dsrv(void *fc, struct clientparam * param, unsigned char ** buf_p, int * bufsize_p, int offset, int * length_p){ - if(fc && (FC->state == GOT_HTTP_REQUEST || FC->state == GOT_HTTP_CLI_HDR || FC->state == GOT_HTTP_CLIDATA || FC->state == GOT_HTTP_CLIDATA || FC->state == GOT_HTTP_SRV_HDR)){ - FC->state = GOT_HTTP_SRV_HDR2; - } - return CONTINUE; -} - -static void fp_clear(void *fc){ - removefps(FC); - free(fc); -} - -static void fp_close(void *fo){ -} - - -static struct filter fp_filter = { - NULL, - "filefilter", - "filefilter", - fp_open, - fp_client, - fp_request, - fp_hcli, - fp_hsrv, - NULL, - fp_dcli, - fp_dsrv, - fp_clear, - fp_close, -}; - -static struct symbol fp_symbols[] = { - {fp_symbols + 1, "fp_registercallback", (void*) fp_registercallback}, - {NULL, "fp_stringtable", (void*) fp_stringtable} -}; - -static int h_cachedir(int argc, unsigned char **argv){ - char * dirp; - size_t len; - - dirp = (argc > 1)? argv[1] : getenv("TEMP"); - len = strlen(dirp); - if(!dirp || !len || len > 200 || strchr(dirp, '%')) { - fprintf(stderr, "FilePlugin: invalid directory path: %s\n", dirp); - return (1); - } -#ifdef _WIN32 - if(dirp[len-1] == '\\') dirp[len-1] = 0; - sprintf(path, "%.256s\\%%07d.tmp", dirp); -#else - if(dirp[len-1] == '/') dirp[len-1] = 0; - sprintf(path, "%.256s/%%07d.tmp", dirp); -#endif - return 0; -} - -static int h_preview(int argc, unsigned char **argv){ - preview = atoi(argv[1]); - return 0; -} - -static struct commands file_commandhandlers[] = { - {file_commandhandlers + 1, "file_cachedir", h_cachedir, 2, 2}, - {NULL, "file_preview", h_preview, 2, 2}, -}; - -static int file_loaded=0; - - -#ifdef _WIN32 -__declspec(dllexport) -#endif - - - int file_plugin (struct pluginlink * pluginlink, - int argc, char** argv){ - - if(!file_loaded){ - pthread_mutex_init(&file_mutex, NULL); - file_loaded = 1; - pl = pluginlink; - memcpy(&sso, pl->so, sizeof(struct sockfuncs)); - pl->so->_poll = fp_poll; - pl->so->_send = fp_send; - pl->so->_sendto = fp_sendto; - pl->so->_recv = fp_recv; - pl->so->_recvfrom = fp_recvfrom; - pl->so->_shutdown = fp_shutdown; - pl->so->_closesocket = fp_closesocket; - fp_filter.next = pl->conf->filters; - pl->conf->filters = &fp_filter; - fp_symbols[1].next = pl->symbols.next; - pl->symbols.next = fp_symbols; - file_commandhandlers[1].next = pl->commandhandlers->next; - pl->commandhandlers->next = file_commandhandlers; - } - h_cachedir(0, NULL); - preview = 32768; - - return 0; - - } -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/FilePlugin/FilePlugin.h b/src/plugins/FilePlugin/FilePlugin.h deleted file mode 100644 index 149d56c..0000000 --- a/src/plugins/FilePlugin/FilePlugin.h +++ /dev/null @@ -1,41 +0,0 @@ -#ifdef __cplusplus -extern "C" { -#endif - - -#define FP_OK 0 -#define FP_REJECT 65536 - -#define FP_CLIDATA 1 -#define FP_SRVDATA 2 -#define FP_CLIHEADER 4 -#define FP_SRVHEADER 8 -#define FP_KEEPFILE 16 -#define FP_SHAREFILE 32 -#define FP_PREVIEWCLI 64 -#define FP_PREVIEWSRV 128 -#define FP_CALLONREQUEST 256 -#define FP_CALLAFTERCLIHEADERS 512 -#define FP_CALLAFTERSRVHEADERS 1024 -#define FP_CALLONREMOVE 2048 - -struct fp_filedata { - struct clientparam *cp; -#ifdef _WIN32 - HANDLE h_cli, h_srv; -#else - int fd_cli, fd_srv; -#endif - char *path_cli; - char *path_srv; -}; - - -typedef int (*FP_CALLBACK)(int what, void *data, struct fp_filedata *fpd, char *buf, int size); - -typedef int (*FP_REGISTERCALBACK) (int what, int max_size, int preview_size, struct clientparam *cp, FP_CALLBACK cb, void *data); - - -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/FilePlugin/Makefile b/src/plugins/FilePlugin/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/FilePlugin/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/FilePlugin/Makefile.inc b/src/plugins/FilePlugin/Makefile.inc deleted file mode 100644 index 882a59a..0000000 --- a/src/plugins/FilePlugin/Makefile.inc +++ /dev/null @@ -1,7 +0,0 @@ -all: $(BUILDDIR)FilePlugin$(DLSUFFICS) - -FilePlugin$(OBJSUFFICS): FilePlugin.c - $(CC) $(DCFLAGS) $(CFLAGS) FilePlugin.c - -$(BUILDDIR)FilePlugin$(DLSUFFICS): FilePlugin$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)FilePlugin$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) FilePlugin$(OBJSUFFICS) diff --git a/src/plugins/LastFRipper/Makefile b/src/plugins/LastFRipper/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/LastFRipper/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/LastFRipper/Makefile.inc b/src/plugins/LastFRipper/Makefile.inc deleted file mode 100644 index 962f012..0000000 --- a/src/plugins/LastFRipper/Makefile.inc +++ /dev/null @@ -1,7 +0,0 @@ -all: $(BUILDDIR)lastFripper$(DLSUFFICS) - -lastFripper$(OBJSUFFICS): lastFripper.c - $(CC) $(DCFLAGS) $(CFLAGS) lastFripper.c - -$(BUILDDIR)lastFripper$(DLSUFFICS): lastFripper$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)lastFripper$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) lastFripper$(OBJSUFFICS) diff --git a/src/plugins/LastFRipper/lastFripper.c b/src/plugins/LastFRipper/lastFripper.c deleted file mode 100644 index d5eea85..0000000 --- a/src/plugins/LastFRipper/lastFripper.c +++ /dev/null @@ -1,704 +0,0 @@ -/* - released as a public domain - std.denis, 2009 -*/ -#include "../../structures.h" -#include "lastFripper.h" - -#define strdup _strdup -#define strnicmp _strnicmp -#define ltoa _ltoa - -#define mkdir _mkdir - -#define PART_SUFFIX "_partial" - -void my_mkdir( char* name ) -{ - char* pdir = name; - - while( 1 ) { - char ch; - char* pnext = pdir; - while( *pnext && *pnext != '\\' && *pnext != '/' ) - pnext++; - if( *pnext == 0 ) - break; - - ch = *pnext; - *pnext = 0; - mkdir( name ); - *pnext = ch; - - pdir = pnext + 1; - } - mkdir( name ); -} - - -__inline void myOutputDebugStringA1( char* str ) -{ -/* char fname[128]; - ltoa( GetCurrentThreadId(), fname, 10 ); - FILE* fp = fopen( fname, "ab" ); - fputs( str, fp ); - fputs( "\r\n", fp ); - fflush( fp ); - fclose( fp ); -*/ -} - -__inline void myOutputDebugStringA( void* buf, int len ) -{ -/* char fname[128]; - ltoa( GetCurrentThreadId(), fname, 10 ); - FILE* fp = fopen( fname, "ab" ); - fwrite( buf, len, 1, fp ); - fputs( "\r\n", fp ); - fflush( fp ); - fclose( fp ); */ -} - -#ifndef isnumber -#define isnumber(i_n_arg) ((i_n_arg>='0')&&(i_n_arg<='9')) -#endif - -#define sizearr(x) (sizeof(x)/sizeof(x[0])) -#define xmalloc( type, len ) ((type*)malloc( (len) * sizeof(type) ) ) -#define xcalloc( type, len ) ((type*)calloc( (len), sizeof(type) ) ) - -int clean_filename( char* filename ) -{ - int i; - for( i = 0; filename[i]; i++ ) - switch( filename[i] ) { - case '*': - case '?': - case '<': - case '>': - case '\\': - case '/': - case ':': - case '"': - filename[i] = '_'; - break; - } - return i; -} - - -static struct pluginlink * pl; -static int lfm_loaded = 0; -static char* g_folder = 0; -static char* g_format = 0; - -static int lfm_format_filename( struct playlist_item* p_item, char* p_filename, int n_filename ) -{ - int i = 0, j; - char ch; - char* fmt; - char *ff = NULL; - - if( g_folder && *g_folder ) { - strncpy( p_filename, g_folder, n_filename ); - i = strlen( p_filename ); - if( i < n_filename-1 && p_filename[i-1] != '\\' ) - p_filename[i++] = '\\'; - } - - fmt = g_format; - if( fmt == NULL ) fmt = "%a\\%t.mp3"; - while( ( ch = *fmt++ ) != 0 ) { - if( ch == '%' ) { - char* p_sz = NULL; - char a_sz[32]; - ch = *fmt++; - switch( ch ) { - case 0: - fmt--; break; - case '%': - p_sz = "%"; - break; - case 'n': { - static unsigned ndx = 0; - ltoa( ndx++, a_sz, 10 ); - p_sz = a_sz; - break; - } - case 'a': - p_sz = p_item->artist; - break; - case 't': - p_sz = p_item->title; - break; - case 'l': - p_sz = p_item->album; - break; - } - if( p_sz ) { - strncpy( p_filename+i, p_sz, n_filename-i ); - p_filename[n_filename-1] = 0; - i += clean_filename( p_filename+i ); - } - } else - if( i < n_filename ) p_filename[i++] = ch; - } - - for( j = i-1; j >= 0; j-- ) - if( p_filename[j] == '\\' || p_filename[j] == '/' ) { - ff = p_filename + j; - break; - } - if( ff ) { - char ch = *ff; - *ff = 0; - my_mkdir( p_filename ); - *ff = ch; - } - - return i; -} - -static void lfm_close_request( struct lfm_client_data* p_client ) -{ - struct lfm_filter_data* p_data; - if( p_client == NULL ) return; - p_data = p_client->p_data; - if( p_data == NULL ) return; - - if( p_client->req_type == LFM_PLAYLIST ) { - free( p_client->pl_xml ); - } else if( p_client->req_type == LFM_GET && p_client->fp ) { - struct playlist_item* p_item = p_client->pl_item; - if( p_item ) { - char id3v1[128]; - memset( id3v1, 0, 128 ); - strcpy( id3v1, "TAG" ); - strncpy( id3v1+3, p_item->title, 30 ); - strncpy( id3v1+33, p_item->artist, 30 ); - strncpy( id3v1+63, p_item->album, 30 ); - id3v1[127] = -1; - fwrite( id3v1, 128, 1, p_client->fp ); - } - fclose( p_client->fp ); -/* - if( p_item ) { - char filename_part[512], filename[512]; - int i = lfm_format_filename( p_item, filename_part, sizearr(filename_part) ); - memcpy( filename, filename_part, sizeof(filename) ); - strncpy( filename_part+i, PART_SUFFIX, sizearr(filename_part)-i ); - rename( filename_part, filename ); - } -*/ - pthread_mutex_lock( &p_data->mutex ); - if( p_data->playlist != NULL && p_item != NULL ) { - if( p_data->playlist == p_item ) - p_data->playlist = p_item->next; - else { - struct playlist_item *p_last = p_data->playlist; - - while( p_last->next != NULL && p_last->next != p_item ) - p_last = p_last->next; - - if( p_last->next ) - p_last->next = p_item->next; - } - if( p_item->artist ) free( p_item->artist ); - if( p_item->title ) free( p_item->title ); - if( p_item->album ) free( p_item->album ); - if( p_item->url ) free( p_item->url ); - free( p_item ); - } - pthread_mutex_unlock( &p_data->mutex ); - } - p_client->req_type = LFM_NONE; -} - -static void* lfm_filter_open( void * idata, struct srvparam * param ){ - struct lfm_filter_data* pdata = (struct lfm_filter_data*)idata; - if( pdata ){ - pthread_mutex_lock( &pdata->mutex ); - pdata->refs++; - pthread_mutex_unlock( &pdata->mutex ); - } else { - if( ( pdata = xcalloc( struct lfm_filter_data, 1 ) ) != NULL ) { - pthread_mutex_init( &pdata->mutex, NULL ); - pdata->playlist = NULL; - pdata->refs++; - } - } - return pdata; -} - -static FILTER_ACTION lfm_filter_client( void *fo, struct clientparam* param, void** fc ) -{ - struct lfm_filter_data* p_data; - struct lfm_client_data* p_client; - *fc = NULL; - if( fo == NULL ) return PASS; - - p_data = (struct lfm_filter_data*)fo; - p_client = xcalloc( struct lfm_client_data, 1 ); - if( p_client == NULL ) return PASS; - - p_client->p_data = p_data; - p_client->req_type = LFM_NONE; - - *fc = p_client; - return CONTINUE; -} - -static void lfm_filter_clear( void *fc ) -{ - struct lfm_client_data* p_client; - - p_client = (struct lfm_client_data*)fc; - if( p_client == NULL ) return; - - lfm_close_request( p_client ); - - free( p_client ); -} - -static void lfm_filter_close(void *fo){ - struct lfm_filter_data* p_data; - struct playlist_item* p_item; - - p_data = (struct lfm_filter_data*)fo; - if( p_data == NULL ) return; - - if( --p_data->refs > 0 ) return; - - pthread_mutex_destroy( &p_data->mutex ); - p_item = p_data->playlist; - while( p_item ) { - struct playlist_item* p_old = p_item; - p_item = p_item->next; - - if( p_old->artist ) free( p_old->artist ); - if( p_old->title ) free( p_old->title ); - if( p_old->album ) free( p_old->album ); - if( p_old->url ) free( p_old->url ); - free( p_old ); - } - - free( p_data ); -} - -static FILTER_ACTION lfm_filter_request( void *fc, struct clientparam *param, unsigned char** buf_p, int* bufsize_p, int offset, int* length_p ) -{ - char* p_buf = (char*)( *buf_p + offset ); - int n_buf = *length_p - offset; - struct lfm_client_data* p_client; - struct lfm_filter_data* p_data; - - if( p_buf == NULL || n_buf < 5 ) return CONTINUE; - - p_client = (struct lfm_client_data*)fc; - if( p_client == NULL ) return CONTINUE; - p_data = p_client->p_data; - if( p_data == NULL ) return CONTINUE; - - pl->conf->filtermaxsize = 0; - - lfm_close_request( p_client ); - - p_client->req_type = LFM_NONE; - p_client->fp = NULL; - - if( strncasecmp( p_buf, "GET ", 4 ) != 0 ) return CONTINUE; - - p_buf += 4; - - if( strncasecmp( p_buf, "http://ws.audioscrobbler.com/radio/xspf.php?", 44 ) == 0 ) { - myOutputDebugStringA1( "getting a playlist" ); - p_client->req_type = LFM_PLAYLIST; - } else { - char zzz[256]; - int i; - struct playlist_item* p_item; - for( i = 0; i < n_buf && i < 256; i++ ) { - if( p_buf[i] == '\r' ) break; - zzz[i] = p_buf[i]; - } - zzz[i] = 0; - myOutputDebugStringA1( zzz ); - pthread_mutex_lock( &p_data->mutex ); - p_item = p_data->playlist; - while( p_item ) { - if( strncasecmp( p_buf, p_item->url, p_item->url_len ) == 0 ) - break; - p_item = p_item->next; - } - pthread_mutex_unlock( &p_data->mutex ); - if( p_item ) { - myOutputDebugStringA1( "getting a known url: " ); - myOutputDebugStringA1( p_item->title ); - p_client->req_type = LFM_GET; - p_client->pl_item = p_item; - } - } - - return CONTINUE; -} - -static FILTER_ACTION lfm_filter_header_srv( void *fc, struct clientparam *param, unsigned char** buf_p, int* bufsize_p, int offset, int* length_p ) -{ - char* p_buf = (char*)( *buf_p + offset ); - struct lfm_client_data* p_client; - int n_buf = *length_p - offset; - struct lfm_filter_data* p_data; - char zzz[100]; - int code; - - if( p_buf == NULL || n_buf < 9 ) return CONTINUE; - - p_client = (struct lfm_client_data*)fc; - if( p_client == NULL ) return CONTINUE; - p_data = p_client->p_data; - if( p_data == NULL ) return CONTINUE; - - code = atoi( p_buf + 9 ); - sprintf( zzz, "http code: %d", code ); - myOutputDebugStringA1( zzz ); - myOutputDebugStringA( p_buf, n_buf ); - if( p_client->req_type == LFM_GET && ( code > 300 && code < 304 || code == 307 ) ) { - p_client->req_type = LFM_REDIR; - do { - char* p_line = p_buf; - int n_line; - - for(; n_buf > 0 && *p_buf != '\r'; p_buf++, n_buf-- ) {}; - n_line = p_buf - p_line; - if( n_line <= 0 ) break; - if( n_line > 10 && strncasecmp( p_line, "location: ", 10 ) == 0 ) { - myOutputDebugStringA1( "redir/location: " ); - myOutputDebugStringA( p_line + 10, n_line - 10 ); - if( p_client->pl_item ) { - char* p_url = p_line + 10; - int n_url = n_line - 10; - pthread_mutex_lock( &p_data->mutex ); - if( p_client->pl_item->url ) free( p_client->pl_item->url ); - p_client->pl_item->url = xmalloc( char, n_url + 1 + 1 ); - memcpy( p_client->pl_item->url, p_url, n_url ); - p_client->pl_item->url[n_url] = ' '; - p_client->pl_item->url[n_url+1] = 0; - p_client->pl_item->url_len = n_url + 1; - myOutputDebugStringA1( "got a url: " ); - myOutputDebugStringA1( p_client->pl_item->url ); - pthread_mutex_unlock( &p_data->mutex ); - } - p_client->req_type = LFM_NONE; - } - for(; n_buf > 0 && ( *p_buf == '\n' || *p_buf == '\r' ); p_buf++, n_buf-- ) {}; - } while( n_buf > 0 ); - } - - if( code == 200 && p_client->req_type == LFM_GET ) { - struct playlist_item* p_item = p_client->pl_item; - char filename[512]; - int i = lfm_format_filename( p_item, filename, sizearr(filename) ); - /* - strncpy( filename + i, PART_SUFFIX, sizearr(filename)-i ); - */ - p_client->fp = fopen( filename, "wb" ); - } - else if( code == 200 && p_client->req_type == LFM_PLAYLIST ) { - p_client->pl_xml = xcalloc( struct xml_state, 1 ); - } - - return CONTINUE; -} - -void playlist_analyze( struct lfm_client_data* p_client, const char* p_buf, int len ); -static FILTER_ACTION lfm_filter_data_srv( void *fc, struct clientparam *param, unsigned char** buf_p, int* bufsize_p, int offset, int* length_p ) -{ - char* p_buf = (char*)( *buf_p + offset ); - int n_buf = *length_p - offset; - struct lfm_client_data* p_client; - struct lfm_filter_data* p_data; - - - myOutputDebugStringA1( "filter_data_srv" ); - myOutputDebugStringA( p_buf, n_buf ); - - if( p_buf == NULL || n_buf < 1 ) return CONTINUE; - - p_client = (struct lfm_client_data*)fc; - if( p_client == NULL ) return CONTINUE; - p_data = p_client->p_data; - if( p_data == NULL ) return CONTINUE; - - if( p_client->req_type == LFM_PLAYLIST ) - myOutputDebugStringA1( "filter_data_srv: playlist" ); - else if( p_client->req_type == LFM_GET ) { - myOutputDebugStringA1( "filter_data_srv: retrieving" ); - if( p_client->fp == NULL ) - myOutputDebugStringA1( "but no file allocated" ); - } - - if( p_client->req_type == LFM_PLAYLIST ) - playlist_analyze( p_client, p_buf, n_buf ); - if( p_client->fp ) - fwrite( p_buf, n_buf, 1, p_client->fp ); - - return CONTINUE; -} - -enum XmlState -{ - XML_TEXT, - XML_TAGNAME, - XML_ATTRNAME_W, - XML_ATTRNAME, - XML_ATTRVALUE_W, - XML_ATTRVALUE, - XML_TAGCLOSE, - XML_TAGOPENCLOSE, -}; - -int xml_get_token_id( char** table, char* token ) -{ - int i; - char* psz; - for( psz = token; *psz; psz++ ) - *psz = tolower( *psz ); - for( i = 0; *table; i++, table++ ) - if( strcmp( *table, token ) == 0 ) return i; - - return -1; -} - -enum { - XT_PLAYLIST, - XT_TRACK_LIST, - XT_TRACK, - XT_LOCATION, - XT_CREATOR, - XT_ALBUM, - XT_TITLE -}; - -char* xt_list[] = { - "playlist", - "tracklist", - "track", - "location", - "creator", - "album", - "title", - NULL -}; - -void playlist_analyze( struct lfm_client_data* p_client, const char* p_buf, int len ) -{ - struct xml_state* xs = p_client->pl_xml; - int n_buf = len; - - if( xs == NULL ) return; - - while( n_buf > 0 ) { - enum { - XMS_NONE, - XMS_TAG, - XMS_ATTR_NAME, - XMS_ATTR_VALUE, - XMS_TEXT - } gotta = XMS_NONE; - char ch = *p_buf++; - n_buf--; -lbl_retry: - switch( xs->state ) { - case XML_TAGNAME: - if( ch == '>' ) { - xs->state = XML_TEXT; - gotta = XMS_TAG; - break; - } else if( ch == '/' ) { - if( xs->n_token == 0 ) - xs->closing = 1; - else { - xs->state = XML_ATTRNAME_W; - gotta = XMS_TAG; - xs->n_token--; - } - break; - } else if( isspace( ch ) ) { - xs->state = XML_ATTRNAME_W; - gotta = XMS_TAG; - break; - } - if( xs->n_token < TOKEN_MAXLEN ) xs->p_token[xs->n_token++] = ch; - break; - case XML_ATTRNAME_W: - if( ch == '>' ) { - xs->state = XML_TEXT; - break; - } else if( ch == '/' ) { - xs->closing = 1; - xs->state = XML_TEXT; - gotta = XMS_TAG; - break; - } else if( !isspace( ch ) ) { - xs->state = XML_ATTRNAME; - goto lbl_retry; - } - break; - case XML_ATTRNAME: - if( ch == '=' ) { - xs->state = XML_ATTRVALUE_W; - gotta = XMS_ATTR_NAME; - break; - } - if( xs->n_token < TOKEN_MAXLEN ) xs->p_token[xs->n_token++] = ch; - break; - case XML_ATTRVALUE_W: - if( ch == '"' || ch == '\'' ) { - xs->sep = ch; - xs->state = XML_ATTRVALUE; - break; - } - break; - case XML_ATTRVALUE: - if( ch == xs->sep ) { - xs->state = XML_ATTRNAME_W; - gotta = XMS_ATTR_VALUE; - break; - } - if( xs->n_token < TOKEN_MAXLEN ) xs->p_token[xs->n_token++] = ch; - break; - case XML_TEXT: - if( ch == '<' ) { - xs->state = XML_TAGNAME; - gotta = XMS_TEXT; - break; - } - if( xs->n_token < TOKEN_MAXLEN ) xs->p_token[xs->n_token++] = ch; - break; - } - - if( gotta != XMS_NONE ) { - xs->p_token[xs->n_token] = 0; - - switch( gotta ) { - case XMS_TAG: { - int id = xml_get_token_id( xt_list, xs->p_token ); - if( !xs->closing ) { - if( xs->level < sizeof(xs->tree) ) xs->tree[xs->level] = id; - xs->level++; - - if( id == XT_TRACK && xs->level == 3 && xs->tree[1] == XT_TRACK_LIST ) - xs->p_item = xcalloc( struct playlist_item, 1 ); - } else { - if( xs->level > 0 ) xs->level--; - if( id == XT_TRACK && xs->level == 2 && xs->tree[1] == XT_TRACK_LIST ) { - char zzz[1024]; - _snprintf( zzz, 1024, "artist: <%s>, title: <%s>, url: <%s>", - xs->p_item->artist, xs->p_item->title, xs->p_item->url ); - myOutputDebugStringA1( zzz ); - pthread_mutex_lock( &p_client->p_data->mutex ); - xs->p_item->next = p_client->p_data->playlist; - p_client->p_data->playlist = xs->p_item; - pthread_mutex_unlock( &p_client->p_data->mutex ); - } - xs->closing = 0; - } - - break; - } - case XMS_ATTR_NAME: - break; - case XMS_ATTR_VALUE: - break; - case XMS_TEXT: - if( xs->level == 4 && xs->tree[1] == XT_TRACK_LIST && xs->tree[2] == XT_TRACK ) { - struct playlist_item* item = xs->p_item; - if( item ) - switch( xs->tree[3] ) { - case XT_LOCATION: - item->url_len = xs->n_token; - item->url = xmalloc( char, item->url_len + 1 + 1); - memcpy( item->url, xs->p_token, item->url_len ); - item->url[item->url_len++] = ' '; - item->url[item->url_len] = 0; - break; - case XT_CREATOR: - item->artist = strdup( xs->p_token ); - break; - case XT_ALBUM: - item->album = strdup( xs->p_token ); - break; - case XT_TITLE: - item->title = strdup( xs->p_token ); - break; - } - } - break; - } - xs->n_token = 0; - } - } -} - - -static struct filter lfm_filter = { - NULL, - "last.fm spy", - NULL, - - lfm_filter_open, - lfm_filter_client, - lfm_filter_request, - NULL, - lfm_filter_header_srv, - NULL, - NULL, - lfm_filter_data_srv, - lfm_filter_clear, - lfm_filter_close -}; - -static int h_lfm_folder( int argc, unsigned char **argv ) -{ - if( g_folder ) free( g_folder ); - g_folder = strdup( (char*)argv[1] ); - return 0; -} - -static int h_lfm_format( int argc, unsigned char **argv ) -{ - if( g_format ) free( g_format ); - g_format = strdup( (char*)argv[1] ); - return 0; -} - -static struct commands lfm_commandhandlers[] = { - {lfm_commandhandlers+1, "lfm_folder", h_lfm_folder, 2, 2}, - {NULL, "lfm_format", h_lfm_format, 2, 2} -}; - -#ifdef __cplusplus -extern "C" { -#endif -#ifdef _WIN32 -__declspec(dllexport) -#endif -int lfm_plugin( struct pluginlink * pluginlink, int argc, char** argv ) -{ - pl = pluginlink; - myOutputDebugStringA1( "lfm_plugin" ); - if( !lfm_loaded ) { - lfm_loaded = 1; - - lfm_filter.next = pl->conf->filters; - pl->conf->filters = &lfm_filter; - - lfm_commandhandlers[1].next = pl->commandhandlers->next; - pl->commandhandlers->next = lfm_commandhandlers; - } - return 0; -} - -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/LastFRipper/lastFripper.h b/src/plugins/LastFRipper/lastFripper.h deleted file mode 100644 index cd1e88b..0000000 --- a/src/plugins/LastFRipper/lastFripper.h +++ /dev/null @@ -1,66 +0,0 @@ -// -// released as a public domain -// std.denis, 2009 -// -/* - #include "direct.h" -*/ - -#ifdef _WIN32 -#define strcasecmp stricmp -#define strncasecmp strnicmp -#else -#define closesocket close -extern pthread_attr_t pa; -#endif - -#ifndef SOCKET_ERROR -#define SOCKET_ERROR -1 -#endif - - -typedef enum { - LFM_NONE, - LFM_PLAYLIST, // GET http://ws.audioscrobbler.com/radio/adjust.php(...) - LFM_REDIR, // GET http://play.last.fm/user/(...) - LFM_GET -} LFM_CLASS; - -struct playlist_item { - struct playlist_item* next; - - char* artist; - char* title; - char* album; - char* url; - int url_len; -}; - -#define TOKEN_MAXLEN 1024 -struct xml_state { - int state; - int closing; - char sep; - - int level; - char tree[128]; // 128 levels nesting - - int n_token; - char p_token[TOKEN_MAXLEN]; - - struct playlist_item* p_item; -}; - -struct lfm_filter_data { - pthread_mutex_t mutex; - struct playlist_item* playlist; - int refs; -}; -struct lfm_client_data { - struct lfm_filter_data* p_data; - - int req_type; - struct xml_state* pl_xml; - struct playlist_item* pl_item; - FILE* fp; -}; diff --git a/src/plugins/LdapPlugin/Makefile.inc b/src/plugins/LdapPlugin/Makefile.inc deleted file mode 100644 index b21cf15..0000000 --- a/src/plugins/LdapPlugin/Makefile.inc +++ /dev/null @@ -1,7 +0,0 @@ -all: $(BUILDDIR)ldapauth$(DLSUFFICS) - -ldapauth$(OBJSUFFICS): ldapauth.c - $(CC) $(DCFLAGS) $(CFLAGS) ldapauth.c - -$(BUILDDIR)ldapauth$(DLSUFFICS): ldapauth$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)ldapauth$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) $(LIBSPREFIX)ladp$(LIBSSUFFIX) ldapauth$(OBJSUFFICS) diff --git a/src/plugins/LdapPlugin/com-unix.sh b/src/plugins/LdapPlugin/com-unix.sh deleted file mode 100644 index 41ec9f0..0000000 --- a/src/plugins/LdapPlugin/com-unix.sh +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh -gcc -shared -o libldapauth.so ldapauth_new.c -DNOODBC -I/usr/include -L/usr/lib -lldap - diff --git a/src/plugins/LdapPlugin/com-win32.bat b/src/plugins/LdapPlugin/com-win32.bat deleted file mode 100644 index a19ebf0..0000000 --- a/src/plugins/LdapPlugin/com-win32.bat +++ /dev/null @@ -1,4 +0,0 @@ -del ldapauth.dll -gcc -o getldapuser getldapuser.c -DWIN32 -I"./ldapwindev" -L"./ldapwindev" -lldap -gcc -shared -o ldapauth.dll ldapauth.c -DWIN32 -I"./ldapwindev" -L"./ldapwindev" -lldap - diff --git a/src/plugins/LdapPlugin/getldapuser.c b/src/plugins/LdapPlugin/getldapuser.c deleted file mode 100644 index e5e0904..0000000 --- a/src/plugins/LdapPlugin/getldapuser.c +++ /dev/null @@ -1,105 +0,0 @@ -/* Create list user for 3proxy ACL from LDAP server - (c) Kirill Lopuchov lopuchov@mail.ru -*/ -#include -#include - -/*Create list user for 3proxy ACL from LDAP server*/ - -/* argv[1] = server - argv[2] = basedn - argv[3] = user_attribute - argv[4] = filter - argv[5] = user - argv[6] = password -*/ - -main(int argc, char *argv[]) - -{ - LDAP *ld = NULL; - LDAPMessage *res = NULL; - LDAPMessage *msg = NULL; - BerElement *ber; - char *getattr,**vals; - - - char *attrs[] = { NULL, NULL }; - int i, rc = -1; - int lderrno; - unsigned char tmpbuf[1000]; - - if ( argc < 6 ) - { - printf ("Create 3proxy ACL userlist from ldap server.\ngetldapuser < ldapserver sbasedn user_attribute filter user password > \n"); - printf ("Example: getldapuser 192.168.0.1 dc=domain,dc=com cn (memberOf=cn=internet,cn=Users,dc=domain,dc=com) cn=admin,cn=users,dc=domain,dc=com password \n"); - } - - else - { - attrs[0]=strdup(argv[3]); - - /* init ldap ------------------------ */ - ld = ldap_init( argv[1] , 389 ); - - if ( ld == NULL ) - { - /*perror( "ldap_init" );*/ - printf("Error init ldap") ; - exit(1); - } - - - - /* connect ------------------------ */ - - rc = ldap_bind_s( ld, argv[5], argv[6], LDAP_AUTH_SIMPLE ); - - if ( rc != LDAP_SUCCESS ) - { - ldap_perror( ld, "Error ldap_bind" ); - } - - - - /* search ------------------------ */ - - rc = ldap_search_s( ld,argv[2], LDAP_SCOPE_SUBTREE, - argv[4], attrs, 0, &res ); - - /* get val ------------------------*/ - rc=ldap_count_entries(ld,res); - - if (rc > 0) - { - - msg=ldap_first_entry(ld, res); - getattr=ldap_first_attribute(ld, msg, &ber); - while (rc > 0) - { - vals=ldap_get_values(ld, msg, getattr); - if (vals != NULL && vals[0] != NULL ) - { - i=ldap_count_values(vals); - while(i>0) - { - printf("%s",vals[0]); - i--; - if (rc > 1) { printf(",",vals[0]); } - } - ldap_value_free(vals); - } - - msg=ldap_next_entry(ld, msg); - rc--; - } - - } //end if (rc>0) - - ldap_memfree(res); - - ldap_unbind(ld); - - }/*end else*/ - -} diff --git a/src/plugins/LdapPlugin/ldapauth.c b/src/plugins/LdapPlugin/ldapauth.c deleted file mode 100644 index 5b8231c..0000000 --- a/src/plugins/LdapPlugin/ldapauth.c +++ /dev/null @@ -1,576 +0,0 @@ -#include -#include -#include -#include -#include - -#ifndef _WIN32 - -#include -#endif - -#include "../../proxy.h" -#include "../../structures.h" - -struct counter_record -{ - unsigned long traf; - unsigned long trafgb; - time_t cleared; - time_t updated; -}; - - -int already_loaded = 0; - -static struct auth myalwaysauth; -static struct commands ldap_serv_auth_handler; -static struct commands ldap_access_handler; -static struct commands ldap_sbase_handler; -static struct commands ldap_userenv_handler; -static struct commands ldap_trafgroup_handler; -static struct commands ldap_attrsgroup_handler; -static struct commands ldap_dircount_handler; - -static char *attrs[] = { NULL, NULL}; -static char *ldap_group_attr; -static char *ldap_access; -static char *ldap_sbase; -static char *ldap_serv; -static char *ldap_user; -static char *ldap_pass; -static char *ldap_userenv; - int ldap_userenv_size; -static char *ldap_trafgroup; -static char *ldap_dircount; -static int usercaselow = 0; - -struct pluginlink * mypluginlink; -struct schedule myschedule; - -#ifndef _WIN32 -void lower (char *string) -{ - int length, i; - - length = strlen(string); - for (i=0; iconf->trafcounter; - struct trafcount *tcd; - struct counter_record wcounter; - FILE *f; - unsigned char *tmpbuf,pat_file[]="%s%s.lc"; - - - /* timetoexit !=0 - будем завершаться.*/ - while (tc != NULL) - { - tcd = tc; - tc = tc->next; - f=NULL; - if(strcmp(tcd->comment,"ldapcounters")==0) { - tmpbuf=mypluginlink->myalloc(strlen(pat_file)+strlen(ldap_dircount)+strlen(tcd->ace->users->user)); - sprintf(tmpbuf,pat_file,ldap_dircount,tcd->ace->users->user); - f=fopen(tmpbuf,"w+b"); - fseek(f,0,SEEK_SET); - fprintf(f,"%10lu %10lu %lu %lu\n",tcd->trafgb,tcd->traf, - tcd->cleared,tcd->updated); - - fclose(f); - mypluginlink->myfree(tmpbuf); - - } - } - - - /*return 1 delete job , return 0 no delete job*/ - if (mypluginlink->conf->needreload !=0 ) - { - return (0); - } - - return (0); -} -/*--------------------------------------------------------------------------*/ - -#ifdef _WIN32 -__declspec(dllexport) int start(struct pluginlink * pluginlink, - int argc, char** argv); -#else - -int start(struct pluginlink * pluginlink, - int argc, char** argv); - -#endif - -/* --------------------------------------------------------------------------*/ -static int ldapfunc(struct clientparam *param) - { - - LDAP *ld = NULL; - LDAPMessage *res = NULL; - int rc = -1; - char tmpbuf[1024]; - - /* test proxy user auth ------------------------*/ - if(!param->username || !param->password) return 4; - if(strlen(param->password)==0) return 4; - - /* init ldap ---------------------- */ - ld = ldap_init( ldap_serv, 389 ); - if ( ld == NULL ) - { - param->srv->logfunc(param,"Error ldap_init: No init lib ldap"); - /*ldap_perror( ld, "Error ldap_init" ); */ - return 7; - } - - - /* this code for Active Directory LDAP catalog :( - detail see documentation for plugin */ - if (usercaselow > 0) - #ifdef _WIN32 - { CharLower(param->username); } - #else - { lower(param->username); } - #endif - - - /* create user for test auth */ - sprintf(tmpbuf,"%.200s=%.200s,%.200s",attrs[0],param->username,ldap_userenv); - - rc = ldap_bind_s( ld, tmpbuf, param->password, LDAP_AUTH_SIMPLE ); - - - if ( rc != LDAP_SUCCESS ) - { - param->srv->logfunc(param,"Error ldap_bind: No connect ldap catalog"); - ldap_unbind_s(ld); - return 7; - } - - ldap_unbind_s(ld); - - ld = ldap_init( ldap_serv, 389 ); - - if ( ld == NULL ) - { - param->srv->logfunc(param,"Error ldap_init: No init lib ldap"); - /*ldap_perror( ld, "Error ldap_init" ); */ - return 7; - } - - rc = ldap_bind_s( ld, ldap_user, ldap_pass, LDAP_AUTH_SIMPLE ); - - if ( rc != LDAP_SUCCESS ) - { - param->srv->logfunc(param, "Error ldap_bind: Not authorize in ldap\ - catalog, checked option \'ldapconnect\' "); - ldap_unbind_s(ld); - return 7; - } - - /* test enter user in filter ------------------------------ - create filter for search*/ - - sprintf(tmpbuf,"(&(%.200s=%.200s)(%.200s=%.200s))",attrs[0],param->username, - ldap_group_attr,ldap_access); - - - /* search */ - rc = ldap_search_s( ld, ldap_sbase, LDAP_SCOPE_SUBTREE, - tmpbuf, attrs, 0, &res ); - - rc=ldap_count_entries(ld,res); - - ldap_msgfree(res); - ldap_unbind_s(ld); - - /* user not found */ - if (rc == 0) - { return 5; } - - return 0; - } - -/* -------------------------------------------------------------------------- - handle command ldapserv */ -int h_ldapconnect(int argc, unsigned char ** argv) -{ - LDAP *ld = NULL; - - if (argc < 2) - { - fprintf(stderr, "Error in ldapconnect: See documentation of ldapauth plugin.\n"); - return 1; - } - - ldap_serv=mypluginlink->mystrdup(argv[1]); - ldap_user=mypluginlink->mystrdup(argv[2]); - - ld = ldap_init( ldap_serv, 389 ); - ldap_unbind_s(ld); - - if (argc == 4) - { - ldap_pass= mypluginlink->mystrdup(argv[3]); - } - else - { - ldap_pass=NULL; - } - - return 0; -} -/* -------------------------------------------------------------------------- - handle command ldapaccess */ -int h_access(int argc, unsigned char ** argv) -{ - if (argc < 1) - { - fprintf(stderr, "Error in ldapaccess: See documentation of ldapauth plugin.\n"); - return 1; - } - ldap_access=mypluginlink->mystrdup(argv[1]); - return 0; -} -/* -------------------------------------------------------------------------- - handle command ldapsbase - searching base */ -int h_sbase(int argc, unsigned char ** argv) -{ - if (argc < 1) - { - fprintf(stderr, "Error in ldapsbase: See documentation of ldapauth plugin.\n"); - return 1; - } - ldap_sbase=mypluginlink->mystrdup(argv[1]); - return 0; -} -/* -------------------------------------------------------------------------- - handle command ldapuserenv */ -int h_userenv(int argc, unsigned char ** argv) -{ - if (argc < 1) - { - fprintf(stderr, "Error in ldapsbase: See documentation of ldapauth plugin.\n"); - return 1; - } - ldap_userenv=mypluginlink->mystrdup(argv[1]); - return 0; -} -/* -------------------------------------------------------------------------- - handle command ldaptrafgroup */ -int h_trafgroup(int argc, unsigned char ** argv) -{ - struct trafcount *newtrafcount; - struct bandlim *newbandlim; - static struct ace *newace; - static struct userlist *newuserlist; - struct counter_record rcounter; - - LDAP *ld = NULL; - LDAPMessage *res = NULL; - LDAPMessage *msg = NULL; - BerElement *ber = NULL; - int rc = -1; - char *tmpbuf,pat_file[]="%s%s.lc",pat_group[]="(%s=%s)"; - char *getattr,**vals,buf[256]; - ROTATION rtype; - unsigned long traflimit; - int bandwidth ; - - FILE *f; - - if (argc < 3) - { - fprintf(stderr, "Error in ldaptrafgroup: See documentation of ldapauth plugin.\n"); - return 1; - } - - ld = ldap_init( ldap_serv, 389 ); - - if ( ld == NULL ) - { - fprintf(stderr,"Error in ldaptrafgroup: ldap_init: No init lib ldap"); - return 7; - } - - rc = ldap_bind_s( ld, ldap_user, ldap_pass, LDAP_AUTH_SIMPLE ); - - if ( rc != LDAP_SUCCESS ) - { - fprintf(stderr, "Error in ldaptrafgroup: ldap_bind: Not authorize in ldap\ - catalog, checked option \'ldapconnect\' "); - ldap_unbind_s(ld); - return 7; - } - - /* type traf limit */ - if(strcmp(argv[2],"MONTHLY")==0||strcmp(argv[2],"monthly")==0) - {rtype=MONTHLY;} - - if(strcmp(argv[2],"DAILY")==0||strcmp(argv[2],"daily")==0) - {rtype=DAILY;} - - if(strcmp(argv[2],"WEEKLY")==0||strcmp(argv[2],"weekly")==0) - {rtype=WEEKLY;} - - traflimit = atol((char *)argv[3]); - bandwidth = atoi((char *)argv[4]); - - /* name ldap group */ - tmpbuf=mypluginlink->myalloc(strlen(pat_group)+strlen(ldap_group_attr)+strlen(argv[1])); - sprintf(tmpbuf,pat_group,ldap_group_attr,argv[1]); - rc = ldap_search_s( ld, ldap_sbase, LDAP_SCOPE_SUBTREE, - tmpbuf, attrs, 0, &res ); - mypluginlink->myfree(tmpbuf); - - rc=ldap_count_entries(ld,res); - - /* users found */ - if (rc > 0) - { - msg=ldap_first_entry(ld, res); - getattr=ldap_first_attribute(ld, msg, &ber); - - while (rc > 0) - { - vals=ldap_get_values(ld, msg, getattr); - if (vals != NULL && vals[0] != NULL ) - { - - /* -------------bandlim---------- - create user list */ - newuserlist = (*mypluginlink->myalloc)(sizeof (struct userlist)); - if (usercaselow > 0) - #ifdef _WIN32 - { CharLower(vals[0]); } - #else - { lower(vals[0]); } - #endif - - newuserlist->user = (*mypluginlink->mystrdup)(vals[0]); - newuserlist->next = NULL; - /*create user rule */ - newace = (*mypluginlink->myalloc)(sizeof (struct ace)); - memset(newace, 0, sizeof(struct ace)); - newace->users = newuserlist; - newace->action = BANDLIM; - /*create user bandlim */ - newbandlim =(*mypluginlink->myalloc)(sizeof (struct bandlim)); - memset(newbandlim, 0, sizeof(struct bandlim)); - newbandlim->rate = bandwidth; - newbandlim->ace = newace; - newbandlim->next = mypluginlink->conf->bandlimiter; - mypluginlink->conf->bandlimiter = newbandlim; - - /* -------------counters---------- - create user list */ - newuserlist = (*mypluginlink->myalloc)(sizeof (struct userlist)); - if (usercaselow > 0) - #ifdef _WIN32 - { CharLower(vals[0]); } - #else - { lower(vals[0]); } - #endif - newuserlist->user = (*mypluginlink->mystrdup)(vals[0]); - newuserlist->next = NULL; - /*create user rule */ - newace = (*mypluginlink->myalloc)(sizeof (struct ace)); - memset(newace, 0, sizeof(struct ace)); - newace->users = newuserlist; - newace->action = COUNTIN; - /*create user counter */ - newtrafcount =(*mypluginlink->myalloc)(sizeof (struct trafcount)); - memset(newtrafcount, 0, sizeof(struct trafcount)); - newtrafcount->ace = newace; - newtrafcount->type=rtype; - newtrafcount->traflimgb =(traflimit/(1024*4)); - newtrafcount->traflim = ((traflimit - (newtrafcount->traflimgb*(1024*4)))*(1024*1024)); - newtrafcount->comment=(*mypluginlink->mystrdup)("ldapcounters"); - newtrafcount->number=0; - tmpbuf=(*mypluginlink->myalloc)(strlen(pat_file)+strlen(ldap_dircount)+strlen(vals[0])); - sprintf(tmpbuf,pat_file,ldap_dircount,vals[0]); - f=NULL; - f=fopen(tmpbuf,"rb"); - if(f!=NULL) - { - - fseek(f,0,SEEK_SET); - fgets(buf, 256, f); - sscanf(buf,"%10lu %10lu %lu %lu\n",&rcounter.trafgb, &rcounter.traf, - &rcounter.cleared, &rcounter.updated); - - - newtrafcount->trafgb=rcounter.trafgb; - newtrafcount->traf=rcounter.traf; - newtrafcount->cleared=rcounter.cleared; - newtrafcount->updated=rcounter.updated; - fclose(f); - } - mypluginlink->myfree(tmpbuf); - - newtrafcount->next = mypluginlink->conf->trafcounter; - mypluginlink->conf->trafcounter = newtrafcount; - - ldap_value_free(vals); - } - msg=ldap_next_entry(ld, msg); - rc--; - } - - }/* end if (rc > 0) */ - - ldap_unbind_s(ld); - - return 0; -} -/* -------------------------------------------------------------------------- - handle command ldapattrsgroup */ -int h_attrsgroup(int argc, unsigned char ** argv) -{ - if (argc < 1) - { - fprintf(stderr, "Error in ldapattr: See documentation of ldapauth plugin.\n"); - return 1; - } - attrs[0]=mypluginlink->mystrdup(argv[1]); - ldap_group_attr=mypluginlink->mystrdup(argv[2]); - - if(argc == 4) - { usercaselow=atoi(argv[3]); } - - return 0; -} -/* -------------------------------------------------------------------------- - handle command ldapdircount */ -int h_dircount(int argc, unsigned char ** argv) -{ - if (argc < 1) - { - fprintf(stderr, "Error in ldapdircount: See documentation of ldapauth plugin.\n"); - return 1; - } - ldap_dircount=mypluginlink->mystrdup(argv[1]); - return 0; -} - -/*------------------------------- MAIN -------------------------------------- - start plugin init */ -int start(struct pluginlink * pluginlink, int argc, char** argv) -{ - - - if (already_loaded != 0) - { - pluginlink->myfree(ldap_access); - pluginlink->myfree(ldap_sbase); - pluginlink->myfree(ldap_serv); - pluginlink->myfree(ldap_user); - pluginlink->myfree(ldap_pass); - pluginlink->myfree(ldap_userenv); - pluginlink->myfree(ldap_dircount); - pluginlink->myfree(ldap_group_attr); - pluginlink->myfree(attrs[0]); - return (0); - } - - already_loaded = 1; - - mypluginlink=pluginlink; - - ldap_access=NULL; - ldap_sbase=NULL; - ldap_serv=NULL; - ldap_user=NULL; - ldap_pass=NULL; - ldap_userenv=NULL; - ldap_trafgroup=NULL; - ldap_dircount=NULL; - ldap_group_attr=NULL; - - - - myalwaysauth.authenticate = ldapfunc; - myalwaysauth.authorize = pluginlink->checkACL; - myalwaysauth.desc = "ldap"; - myalwaysauth.next = pluginlink->authfuncs->next; - pluginlink->authfuncs->next = &myalwaysauth; - - /* add command: ldapconnect ipserv user_serv pass_serv */ - ldap_serv_auth_handler.minargs = 3; - ldap_serv_auth_handler.maxargs = 4; - ldap_serv_auth_handler.command = "ldapconnect"; - ldap_serv_auth_handler.handler = h_ldapconnect; - ldap_serv_auth_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_serv_auth_handler; - - /* add command: ldapaccess cn=internet,cn=users,dc=domain,dc=ru */ - ldap_access_handler.minargs = 2; - ldap_access_handler.maxargs = 2; - ldap_access_handler.command = "ldapaccess"; - ldap_access_handler.handler = h_access; - ldap_access_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_access_handler; - - /* add command: ldapsbase cn=users,dc=domain,dc=ru */ - ldap_sbase_handler.minargs = 2; - ldap_sbase_handler.maxargs = 2; - ldap_sbase_handler.command = "ldapsbase"; - ldap_sbase_handler.handler = h_sbase; - ldap_sbase_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_sbase_handler; - - /* add command: ldapuserenv (cn=users,dc=domain,dc=ru) */ - ldap_userenv_handler.minargs = 2; - ldap_userenv_handler.maxargs = 2; - ldap_userenv_handler.command = "ldapuserenv"; - ldap_userenv_handler.handler = h_userenv; - ldap_userenv_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_userenv_handler; - - /* add command: ldaptrafgroup cn=traf500,cn=users,dc=domain,dc=ru M 500 333 */ - ldap_trafgroup_handler.minargs = 5; - ldap_trafgroup_handler.maxargs = 5; - ldap_trafgroup_handler.command = "ldaptrafgroup"; - ldap_trafgroup_handler.handler = h_trafgroup; - ldap_trafgroup_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_trafgroup_handler; - - /* add command: ldapattr cn memberOf usercaselow=1 */ - ldap_attrsgroup_handler.minargs = 3; - ldap_attrsgroup_handler.maxargs = 4; - ldap_attrsgroup_handler.command = "ldapattr"; - ldap_attrsgroup_handler.handler = h_attrsgroup; - ldap_attrsgroup_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_attrsgroup_handler; - - /* add command: ldapdircount c:\3proxy\ */ - ldap_dircount_handler.minargs = 2; - ldap_dircount_handler.maxargs = 2; - ldap_dircount_handler.command = "ldapdircount"; - ldap_dircount_handler.handler = h_dircount; - ldap_dircount_handler.next = pluginlink->commandhandlers->next; - pluginlink->commandhandlers->next = &ldap_dircount_handler; - - /*create job shedule for processing reload, save counters to file */ - memset(&myschedule,0,sizeof(struct schedule)); - myschedule.type=MINUTELY; - myschedule.function=savecouters; - myschedule.next = *pluginlink->schedule; - *pluginlink->schedule=&myschedule; - - return 0; -} - - diff --git a/src/plugins/LdapPlugin/ldapauth.txt b/src/plugins/LdapPlugin/ldapauth.txt deleted file mode 100644 index 89f04d5..0000000 --- a/src/plugins/LdapPlugin/ldapauth.txt +++ /dev/null @@ -1,592 +0,0 @@ -----------------------------win1251------------------------------ -Плагин аутентификации в LDAP для сервера 3proxу (ОС windows,unix) -(c) Lopuchov Kirill lopuchov@mail.ru - - 1. Краткое описание - -* Поддерживается только аутентификация открытым текстом (basic) -* Поддерживается создание лимитов по трафику для групп пользователей - (в день,месяц,неделю) -* Поддерживается создание лимитов по скорости для групп пользователей - (пока лимиты только на входящий трафик) - -* Отсутcтвует кеширование имен пользователей. - - В качестве интерфейса доступа к ldap используется библиотека openldap, -поэтому плагин может компилироваться и работать как на Windows 98/2000/XP -так и на различных unix подобных системах например Linux,FreeBSD. -Все тесты работоспособности проводились на сервере с Active Directory в -ее реализации ldap но в принципе должно работать и на других ldap системах. - -Для компиляции и тестирования под ОС Windows использовался пакет Dev-C++ -http://www.bloodshed.net/dev/ и часть библиотек OpenLDAP for Windows -http://lucas.bergmans.us/hacks/openldap/ -версия openldap-2.2.29-db-4.3.29-openssl-0.9.8a-win32_Setup.exe, -версия этой же библиотеки идет в комплекте к плагину. - -под unix подобной ОС (Freebsd) использовался стандартный gcc. -и библиотеки openldap-client. - - - - 2. Настройка плагина. - - 2.1 Для подключения к LDAP серверу используется комманда ldapconnect . -Первый параметр определят ip адрес или host имя LDAP сервера , -второй параметр имя пользователя от имени корого будут совершиться -вся дальнейшая работа с ldap каталогом такая как поиск пользователей -и проверка их принадлежности к той или иной группе, третий параметр это -пароль для этого пользователя. - -У такого пользовате в контекстет Active Directory могут отсутсвовать -права администратора для нормальной работы плагина. В классических Open Ldap -серверах под xNIX таким пользователем может выступать anonymous. - -Пример: -ldapconnect 192.160.0.1 cn=ldap,cn=users,dc=domain,dc=ru ldap - - 2.2 Для определения в каком контексте искать пользователей и группы -служит комманда ldapsbase -Пример: -ldapsbase cn=users,dc=domain,dc=ru - - 2.3 Комманда ldapattr служит для определния различных параметров плагина. -a)первый параметр определяет атрибут "пользователь" в контексте ldap каталога - в Active Directory это как правило "cn" , в других ldap серверах "uid". -b)второй параметр опеределяет атрибут "группа" в контексте ldap каталога - в Active Directory это как правило "memberof" , в других ldap серверах "ou". -c)третий параметр может не обязательный и может содержать 0 или 1 - 1 - означает, что при авторизации пользователя или создании для него - орграничения по трафику его имя будет приводится к нижнему регистру - (примечание: только для имен пользователей на английском) . - Этот параметр создан для исключения случаев когда LDAP каталог при - авторизации не отличает имен пользователей в регистрах. - -Пример: -ldapattr cn memberof 1 - - 2.4 Комманда ldapaccess служит для определения "признака" доступности -пользователю вообще пройти авторизацию на proxy сервере. В контексте -ldap каталога это ЗНАЧЕНИЕ атрибута "группы" описанной в комманде ldapattr. - -Пример: -ldapaccess CN=internet,CN=Users,DC=domain,DC=ru - -Например: для Active Directory это будет пользователь входящий в группу -internet. Тоесть при проверке можно ли пользователю работать с proxy -формируется фильтр он должен попасть в следующий фильтр: -(&(cn=имяпользователя)(memberof=CN=internet,CN=Users,DC=domain,DC=ru)) - - 2.5 Комманда ldapuserenv служит для формирования строки имени пользователя -который пытается пройти авторизацию в ldap. Тоесть фактически это base DN -для пользователя. - -Пример: -ldapuserenv cn=users,dc=domain,dc=ru - - - 2.7 Комманда ldaptrafgroup служит для создания лимитов -ОНИ ОБЯЗАТЕЛЬНО ДОЛЖНА ИДТИ ПОСЛЕ ВСЕХ остальных комманд плагина. -a) первый параметр это название группы (значение ldap атрибута ) в которую - входит пользователь. -b) второй параметр на какой период накладывается ограничение по объему -трафика . Может иметь одно из следующих значений "MONTHLY","DAILY","WEEKLY". -с) третий параметр это размер лимита в мегабайтах . -в) четвертый параметр это ограничение по скорости в бит/сек. - -Лимиты накладываются персонально на пользователя входящего в группу, -а не НА группу в целом. -В данном примере в Active Directory создана группа с именем traf200m -куда ключенны все пользователи кторым необходим данный лимит 200 Мбайт, -в месяц с входящей полосой 60000 бит/сек НА КАЖДОГО ПОЛЬЗОВАТЕЛЯ. - -Пример: -ldaptrafgroup CN=traf200m,CN=Users,DC=domain,DC=ru MONTHLY 200 60000 - - -Счетчики храняться для каждого пользователя в отдельном файле,имя которых -формируется, как имя пользователя и расширение lc. Сохранение счетчиков -происходит раз в минуту. - - 2.6 Комманда ldapdircount служит для указания директории куда будут -сохраняться файлы с пользовательскими счетчиками. Путь к директории -надо заканчивать слэшем, прямой или обратный в зависимости от ОС. - -Пример: -ldapdircount c:\3proxy\counter\ -ldapdircount /usr/3proxy/counter/ - - -Настройка 3proxy ---------------------- -# ВНИМАНИЕ ! Не забывайте что daemon или service должен идти первой строкой -# конфигурационного файла,то есть до загрузки любых плагинов -daemon - -# для win32 -plugin "с:\3proxy\ldapauth.dll" start -# для unix -plugin "/3proxy/libldapauth.so" start - -ldapconnect 192.160.0.1 cn=ldap,cn=users,dc=domain,dc=ru ldap -ldapsbase cn=users,dc=domain,dc=ru -ldapaccess CN=internet,CN=Users,DC=domain,DC=ru -ldapuserenv cn=users,dc=domain,dc=ru -ldapdircount /3proxy/counter/ -ldapattr cn memberof 1 - -ldaptrafgroup CN=traf200m,CN=Users,DC=domain,DC=ru MONTHLY 200 60000 -ldaptrafgroup CN=traf60d,CN=Users,DC=domain,DC=ru DAILY 60 80000 -ldaptrafgroup CN=traf100w,CN=Users,DC=domain,DC=ru WEEKLY 100 80000 - -auth ldap -allow * * * * -proxy -p3128 -n --------------------- - -Так же возможна следующая конфигурация без учета трафика и ограничений -по скорости. ---------------------- -service - -plugin "с:\3proxy\ldapauth.dll" start -ldapconnect 192.160.0.1 cn=ldap,cn=users,dc=domain,dc=ru ldap -ldapsbase cn=users,dc=domain,dc=ru -ldapaccess CN=internet,CN=Users,DC=domain,DC=ru -ldapuserenv cn=users,dc=domain,dc=ru -ldapattr cn memberof 1 -auth ldap -allow * * * * -proxy -p3128 -n ---------------------- - - Создание списков доступа - -Чтобы можно было создавать ACL на основе списков пользователей входящих -в различные группы каталога ldap существует утилита getldapuser -Данной утилите могут переданы 5 параметров : - -getldapuser < ldapserver basedn user_attribute filter user password > - -ldapserver - имя или ip адрес LDAP сервера -basedn - контекст подключения к LDAP (например: cn=users,dc=domain,dc=com) -user_attribute - название пользовательского атрибута (например: - в Active Directory это cn в других LDAP каталогах он может - быт ou) -filter - фильтр по какому пользователи будут отбираться из LDAP (например: - для Active Directory вывести всех пользователей входящих в группу - internet будет следующая строка - (memberOf=cn=internet,cn=Users,dc=domain,dc=com) ) - -user - имя пользователя для подключения к серверу -password - пароль (если есть) - - Пример использования getldapuser в 3proxy. - -Необходимо дать доступ к icq только определенным пользоватлям . Cоздаем -в AD группу icquser заносим туда нужных пользователей. -Создаем bat файл следующего содержания который будет формировать файл -c:\3proxy\icquser со списком пользователей: -------------------------------------------- -getldapuser 192.168.0.1 dc=domain,dc=com cn (memberOf=cn=icquser,cn=Users,dc=domain,dc=com) -cn=admin,cn=users,dc=domain,dc=com password > c:\3proxy\icquser -------------------------------------------- -Вставляем данный bat файл на периодическое выполнение. - -Далее прописываем 3proxy.cfg след строки -------------------------------------------------- -monitor "c:\3proxy\icquser" - -auth ldap -allow $"c:\3proxy\icquser" * *icq.com -deny * * *icq.com -allow * -proxy -n -------------------------------------------------- - - - Компиляция плагина на различных ОС - - 1) Win32 (windows 98/NT/XP/2000/2003) -Для сборки и работы плагина в архиве с ним уже идут в каталоге ldapwindev -следующие библиотеки (версия 2.2.29). - - libcrypto.dll - liblber.dll - libldap.dll - libssl.dll -и заголовочные файлы - lber.h - lber_types.h - ldap.h - ldap_cdefs.h - ldap_features.h - ldap_schema.h - ldap_utf8.h - -Далее вам необходимо скачать и установить компилятор Dev-Cpp с сайта -http://www.bloodshed.net/dev/ - -Далее скачать исходные тексты 3proxy отсюда: -http://3proxy.ru/current/3proxy-0.6-devel.tgz и распаковать. -В каталог \src\plugins скопировать каталог с исходными текстами -плагина. Скорректировать com-win32.bat файл с учетом того где у Вас установлен -компилятор gcc , например: --------------com-win32.bat---------------- -c:\Dev-Cpp\bin\gcc -shared -o ldapauth.dll ldapauth.c -DWIN32 -I"./ldapwindev" -L"./ldapwindev" -lldap ------------------------------------------- -И запустить на выполнение com-win32.bat после этого у Вас должна появится -библиотека ldapauth.dll и исполняемый файл getldapuser.exe . -Для дальнейшей работы получившиеся файлы и все библиотеки dll из каталога -ldapwindev скопировать в каталог с 3proxy. - - 2) xNIX (linux,freebsd и т.п. ) - -Перед компиляцией нужно проверить чтобы в системе был уcтановлен -OpenLDAP client. В системе должны присутвовать следующие -библиотеки: - - liblber.a - libldap.a - liblber.so - libldap.so - -и заголовочные файлы - lber.h - lber_types.h - ldap.h - ldap_cdefs.h - ldap_features.h - ldap_schema.h - ldap_utf8.h - -Установка клиента под разными ОС это делается либо инсталяцией готового пакета -либо самостоятельная сборка данного клиента из исходных текстов которые -расположенны тут ftp://ftp.openldap.org/pub/OpenLDAP/openldap-release/ - -Чтобы собрать пакет, необходимо скачать архив -wget ftp://ftp.openldap.org/pub/OpenLDAP/openldap-release/openldap-2.3.9.tgz - -распаковываем архив -tar xvzf openldap-2.3.9.tgz - -и запускаем скрипт автоконфигурации со следующими -параметрами: -./configure --enable-backends=no --enable-slapd=no - -далее - -make -make install - -Далее скачать исходные тексты 3proxy отсюда: -http://3proxy.ru/current/3proxy-0.6-devel.tgz и распаковать. -В каталог \src\plugins скопировать каталог с исходными текстами -плагина. Изменить пути в файле com-unix.sh параметрах компиляции -I и -L -к заголовочным и библиотечным файлам ldap для Вашей системы. - -Выполнить следующие комманды: -chmod +x com-unix.sh -com-unix.sh - -И запустить на выполнение com-unix.sh после этого у Вас должна появится -библиотека ldapauth.so и исполняемый файл getldapuser. - -Получившиеся файлы скопировать в каталог с 3proxy. -----------------------------win1251------------------------------ -----------------------------KOI8-R------------------------------ -рМБЗЙО БХФЕОФЙЖЙЛБГЙЙ Ч LDAP ДМС УЕТЧЕТБ 3proxХ (пу windows,unix) -(c) Lopuchov Kirill lopuchov@mail.ru - - 1. лТБФЛПЕ ПРЙУБОЙЕ - -* рПДДЕТЦЙЧБЕФУС ФПМШЛП БХФЕОФЙЖЙЛБГЙС ПФЛТЩФЩН ФЕЛУФПН (basic) -* рПДДЕТЦЙЧБЕФУС УПЪДБОЙЕ МЙНЙФПЧ РП ФТБЖЙЛХ ДМС ЗТХРР РПМШЪПЧБФЕМЕК - (Ч ДЕОШ,НЕУСГ,ОЕДЕМА) -* рПДДЕТЦЙЧБЕФУС УПЪДБОЙЕ МЙНЙФПЧ РП УЛПТПУФЙ ДМС ЗТХРР РПМШЪПЧБФЕМЕК - (РПЛБ МЙНЙФЩ ФПМШЛП ОБ ЧИПДСЭЙК ФТБЖЙЛ) - -* пФУХФcФЧХЕФ ЛЕЫЙТПЧБОЙЕ ЙНЕО РПМШЪПЧБФЕМЕК. - - ч ЛБЮЕУФЧЕ ЙОФЕТЖЕКУБ ДПУФХРБ Л ldap ЙУРПМШЪХЕФУС ВЙВМЙПФЕЛБ openldap, -РПЬФПНХ РМБЗЙО НПЦЕФ ЛПНРЙМЙТПЧБФШУС Й ТБВПФБФШ ЛБЛ ОБ Windows 98/2000/XP -ФБЛ Й ОБ ТБЪМЙЮОЩИ unix РПДПВОЩИ УЙУФЕНБИ ОБРТЙНЕТ Linux,FreeBSD. -чУЕ ФЕУФЩ ТБВПФПУРПУПВОПУФЙ РТПЧПДЙМЙУШ ОБ УЕТЧЕТЕ У Active Directory Ч -ЕЕ ТЕБМЙЪБГЙЙ ldap ОП Ч РТЙОГЙРЕ ДПМЦОП ТБВПФБФШ Й ОБ ДТХЗЙИ ldap УЙУФЕНБИ. - -дМС ЛПНРЙМСГЙЙ Й ФЕУФЙТПЧБОЙС РПД пу Windows ЙУРПМШЪПЧБМУС РБЛЕФ Dev-C++ -http://www.bloodshed.net/dev/ Й ЮБУФШ ВЙВМЙПФЕЛ OpenLDAP for Windows -http://lucas.bergmans.us/hacks/openldap/ -ЧЕТУЙС openldap-2.2.29-db-4.3.29-openssl-0.9.8a-win32_Setup.exe, -ЧЕТУЙС ЬФПК ЦЕ ВЙВМЙПФЕЛЙ ЙДЕФ Ч ЛПНРМЕЛФЕ Л РМБЗЙОХ. - -РПД unix РПДПВОПК пу (Freebsd) ЙУРПМШЪПЧБМУС УФБОДБТФОЩК gcc. -Й ВЙВМЙПФЕЛЙ openldap-client. - - - - 2. оБУФТПКЛБ РМБЗЙОБ. - - 2.1 дМС РПДЛМАЮЕОЙС Л LDAP УЕТЧЕТХ ЙУРПМШЪХЕФУС ЛПННБОДБ ldapconnect . -рЕТЧЩК РБТБНЕФТ ПРТЕДЕМСФ ip БДТЕУ ЙМЙ host ЙНС LDAP УЕТЧЕТБ , -ЧФПТПК РБТБНЕФТ ЙНС РПМШЪПЧБФЕМС ПФ ЙНЕОЙ ЛПТПЗП ВХДХФ УПЧЕТЫЙФШУС -ЧУС ДБМШОЕКЫБС ТБВПФБ У ldap ЛБФБМПЗПН ФБЛБС ЛБЛ РПЙУЛ РПМШЪПЧБФЕМЕК -Й РТПЧЕТЛБ ЙИ РТЙОБДМЕЦОПУФЙ Л ФПК ЙМЙ ЙОПК ЗТХРРЕ, ФТЕФЙК РБТБНЕФТ ЬФП -РБТПМШ ДМС ЬФПЗП РПМШЪПЧБФЕМС. - -х ФБЛПЗП РПМШЪПЧБФЕ Ч ЛПОФЕЛУФЕФ Active Directory НПЗХФ ПФУХФУЧПЧБФШ -РТБЧБ БДНЙОЙУФТБФПТБ ДМС ОПТНБМШОПК ТБВПФЩ РМБЗЙОБ. ч ЛМБУУЙЮЕУЛЙИ Open Ldap -УЕТЧЕТБИ РПД xNIX ФБЛЙН РПМШЪПЧБФЕМЕН НПЦЕФ ЧЩУФХРБФШ anonymous. - -рТЙНЕТ: -ldapconnect 192.160.0.1 cn=ldap,cn=users,dc=domain,dc=ru ldap - - 2.2 дМС ПРТЕДЕМЕОЙС Ч ЛБЛПН ЛПОФЕЛУФЕ ЙУЛБФШ РПМШЪПЧБФЕМЕК Й ЗТХРРЩ -УМХЦЙФ ЛПННБОДБ ldapsbase -рТЙНЕТ: -ldapsbase cn=users,dc=domain,dc=ru - - 2.3 лПННБОДБ ldapattr УМХЦЙФ ДМС ПРТЕДЕМОЙС ТБЪМЙЮОЩИ РБТБНЕФТПЧ РМБЗЙОБ. -a)РЕТЧЩК РБТБНЕФТ ПРТЕДЕМСЕФ БФТЙВХФ "РПМШЪПЧБФЕМШ" Ч ЛПОФЕЛУФЕ ldap ЛБФБМПЗБ - Ч Active Directory ЬФП ЛБЛ РТБЧЙМП "cn" , Ч ДТХЗЙИ ldap УЕТЧЕТБИ "uid". -b)ЧФПТПК РБТБНЕФТ ПРЕТЕДЕМСЕФ БФТЙВХФ "ЗТХРРБ" Ч ЛПОФЕЛУФЕ ldap ЛБФБМПЗБ - Ч Active Directory ЬФП ЛБЛ РТБЧЙМП "memberof" , Ч ДТХЗЙИ ldap УЕТЧЕТБИ "ou". -c)ФТЕФЙК РБТБНЕФТ НПЦЕФ ОЕ ПВСЪБФЕМШОЩК Й НПЦЕФ УПДЕТЦБФШ 0 ЙМЙ 1 - 1 - ПЪОБЮБЕФ, ЮФП РТЙ БЧФПТЙЪБГЙЙ РПМШЪПЧБФЕМС ЙМЙ УПЪДБОЙЙ ДМС ОЕЗП - ПТЗТБОЙЮЕОЙС РП ФТБЖЙЛХ ЕЗП ЙНС ВХДЕФ РТЙЧПДЙФУС Л ОЙЦОЕНХ ТЕЗЙУФТХ - (РТЙНЕЮБОЙЕ: ФПМШЛП ДМС ЙНЕО РПМШЪПЧБФЕМЕК ОБ БОЗМЙКУЛПН) . - ьФПФ РБТБНЕФТ УПЪДБО ДМС ЙУЛМАЮЕОЙС УМХЮБЕЧ ЛПЗДБ LDAP ЛБФБМПЗ РТЙ - БЧФПТЙЪБГЙЙ ОЕ ПФМЙЮБЕФ ЙНЕО РПМШЪПЧБФЕМЕК Ч ТЕЗЙУФТБИ. - -рТЙНЕТ: -ldapattr cn memberof 1 - - 2.4 лПННБОДБ ldapaccess УМХЦЙФ ДМС ПРТЕДЕМЕОЙС "РТЙЪОБЛБ" ДПУФХРОПУФЙ -РПМШЪПЧБФЕМА ЧППВЭЕ РТПКФЙ БЧФПТЙЪБГЙА ОБ proxy УЕТЧЕТЕ. ч ЛПОФЕЛУФЕ -ldap ЛБФБМПЗБ ЬФП ъобюеойе БФТЙВХФБ "ЗТХРРЩ" ПРЙУБООПК Ч ЛПННБОДЕ ldapattr. - -рТЙНЕТ: -ldapaccess CN=internet,CN=Users,DC=domain,DC=ru - -оБРТЙНЕТ: ДМС Active Directory ЬФП ВХДЕФ РПМШЪПЧБФЕМШ ЧИПДСЭЙК Ч ЗТХРРХ -internet. фПЕУФШ РТЙ РТПЧЕТЛЕ НПЦОП МЙ РПМШЪПЧБФЕМА ТБВПФБФШ У proxy -ЖПТНЙТХЕФУС ЖЙМШФТ ПО ДПМЦЕО РПРБУФШ Ч УМЕДХАЭЙК ЖЙМШФТ: -(&(cn=ЙНСРПМШЪПЧБФЕМС)(memberof=CN=internet,CN=Users,DC=domain,DC=ru)) - - 2.5 лПННБОДБ ldapuserenv УМХЦЙФ ДМС ЖПТНЙТПЧБОЙС УФТПЛЙ ЙНЕОЙ РПМШЪПЧБФЕМС -ЛПФПТЩК РЩФБЕФУС РТПКФЙ БЧФПТЙЪБГЙА Ч ldap. фПЕУФШ ЖБЛФЙЮЕУЛЙ ЬФП base DN -ДМС РПМШЪПЧБФЕМС. - -рТЙНЕТ: -ldapuserenv cn=users,dc=domain,dc=ru - - - 2.7 лПННБОДБ ldaptrafgroup УМХЦЙФ ДМС УПЪДБОЙС МЙНЙФПЧ -пой пвсъбфемшоп дпмцоб йдфй рпуме чуеи ПУФБМШОЩИ ЛПННБОД РМБЗЙОБ. -a) РЕТЧЩК РБТБНЕФТ ЬФП ОБЪЧБОЙЕ ЗТХРРЩ (ЪОБЮЕОЙЕ ldap БФТЙВХФБ ) Ч ЛПФПТХА - ЧИПДЙФ РПМШЪПЧБФЕМШ. -b) ЧФПТПК РБТБНЕФТ ОБ ЛБЛПК РЕТЙПД ОБЛМБДЩЧБЕФУС ПЗТБОЙЮЕОЙЕ РП ПВЯЕНХ -ФТБЖЙЛБ . нПЦЕФ ЙНЕФШ ПДОП ЙЪ УМЕДХАЭЙИ ЪОБЮЕОЙК "MONTHLY","DAILY","WEEKLY". -У) ФТЕФЙК РБТБНЕФТ ЬФП ТБЪНЕТ МЙНЙФБ Ч НЕЗБВБКФБИ . -Ч) ЮЕФЧЕТФЩК РБТБНЕФТ ЬФП ПЗТБОЙЮЕОЙЕ РП УЛПТПУФЙ Ч ВЙФ/УЕЛ. - -мЙНЙФЩ ОБЛМБДЩЧБАФУС РЕТУПОБМШОП ОБ РПМШЪПЧБФЕМС ЧИПДСЭЕЗП Ч ЗТХРРХ, -Б ОЕ об ЗТХРРХ Ч ГЕМПН. -ч ДБООПН РТЙНЕТЕ Ч Active Directory УПЪДБОБ ЗТХРРБ У ЙНЕОЕН traf200m -ЛХДБ ЛМАЮЕООЩ ЧУЕ РПМШЪПЧБФЕМЙ ЛФПТЩН ОЕПВИПДЙН ДБООЩК МЙНЙФ 200 нВБКФ, -Ч НЕУСГ У ЧИПДСЭЕК РПМПУПК 60000 ВЙФ/УЕЛ об лбцдпзп рпмшъпчбфемс. - -рТЙНЕТ: -ldaptrafgroup CN=traf200m,CN=Users,DC=domain,DC=ru MONTHLY 200 60000 - - -уЮЕФЮЙЛЙ ИТБОСФШУС ДМС ЛБЦДПЗП РПМШЪПЧБФЕМС Ч ПФДЕМШОПН ЖБКМЕ,ЙНС ЛПФПТЩИ -ЖПТНЙТХЕФУС, ЛБЛ ЙНС РПМШЪПЧБФЕМС Й ТБУЫЙТЕОЙЕ lc. уПИТБОЕОЙЕ УЮЕФЮЙЛПЧ -РТПЙУИПДЙФ ТБЪ Ч НЙОХФХ. - - 2.6 лПННБОДБ ldapdircount УМХЦЙФ ДМС ХЛБЪБОЙС ДЙТЕЛФПТЙЙ ЛХДБ ВХДХФ -УПИТБОСФШУС ЖБКМЩ У РПМШЪПЧБФЕМШУЛЙНЙ УЮЕФЮЙЛБНЙ. рХФШ Л ДЙТЕЛФПТЙЙ -ОБДП ЪБЛБОЮЙЧБФШ УМЬЫЕН, РТСНПК ЙМЙ ПВТБФОЩК Ч ЪБЧЙУЙНПУФЙ ПФ пу. - -рТЙНЕТ: -ldapdircount c:\3proxy\counter\ -ldapdircount /usr/3proxy/counter/ - - -оБУФТПКЛБ 3proxy ---------------------- -# чойнбойе ! оЕ ЪБВЩЧБКФЕ ЮФП daemon ЙМЙ service ДПМЦЕО ЙДФЙ РЕТЧПК УФТПЛПК -# ЛПОЖЙЗХТБГЙПООПЗП ЖБКМБ,ФП ЕУФШ ДП ЪБЗТХЪЛЙ МАВЩИ РМБЗЙОПЧ -daemon - -# ДМС win32 -plugin "У:\3proxy\ldapauth.dll" start -# ДМС unix -plugin "/3proxy/libldapauth.so" start - -ldapconnect 192.160.0.1 cn=ldap,cn=users,dc=domain,dc=ru ldap -ldapsbase cn=users,dc=domain,dc=ru -ldapaccess CN=internet,CN=Users,DC=domain,DC=ru -ldapuserenv cn=users,dc=domain,dc=ru -ldapdircount /3proxy/counter/ -ldapattr cn memberof 1 - -ldaptrafgroup CN=traf200m,CN=Users,DC=domain,DC=ru MONTHLY 200 60000 -ldaptrafgroup CN=traf60d,CN=Users,DC=domain,DC=ru DAILY 60 80000 -ldaptrafgroup CN=traf100w,CN=Users,DC=domain,DC=ru WEEKLY 100 80000 - -auth ldap -allow * * * * -proxy -p3128 -n --------------------- - -фБЛ ЦЕ ЧПЪНПЦОБ УМЕДХАЭБС ЛПОЖЙЗХТБГЙС ВЕЪ ХЮЕФБ ФТБЖЙЛБ Й ПЗТБОЙЮЕОЙК -РП УЛПТПУФЙ. ---------------------- -service - -plugin "У:\3proxy\ldapauth.dll" start -ldapconnect 192.160.0.1 cn=ldap,cn=users,dc=domain,dc=ru ldap -ldapsbase cn=users,dc=domain,dc=ru -ldapaccess CN=internet,CN=Users,DC=domain,DC=ru -ldapuserenv cn=users,dc=domain,dc=ru -ldapattr cn memberof 1 -auth ldap -allow * * * * -proxy -p3128 -n ---------------------- - - уПЪДБОЙЕ УРЙУЛПЧ ДПУФХРБ - -юФПВЩ НПЦОП ВЩМП УПЪДБЧБФШ ACL ОБ ПУОПЧЕ УРЙУЛПЧ РПМШЪПЧБФЕМЕК ЧИПДСЭЙИ -Ч ТБЪМЙЮОЩЕ ЗТХРРЩ ЛБФБМПЗБ ldap УХЭЕУФЧХЕФ ХФЙМЙФБ getldapuser -дБООПК ХФЙМЙФЕ НПЗХФ РЕТЕДБОЩ 5 РБТБНЕФТПЧ : - -getldapuser < ldapserver basedn user_attribute filter user password > - -ldapserver - ЙНС ЙМЙ ip БДТЕУ LDAP УЕТЧЕТБ -basedn - ЛПОФЕЛУФ РПДЛМАЮЕОЙС Л LDAP (ОБРТЙНЕТ: cn=users,dc=domain,dc=com) -user_attribute - ОБЪЧБОЙЕ РПМШЪПЧБФЕМШУЛПЗП БФТЙВХФБ (ОБРТЙНЕТ: - Ч Active Directory ЬФП cn Ч ДТХЗЙИ LDAP ЛБФБМПЗБИ ПО НПЦЕФ - ВЩФ ou) -filter - ЖЙМШФТ РП ЛБЛПНХ РПМШЪПЧБФЕМЙ ВХДХФ ПФВЙТБФШУС ЙЪ LDAP (ОБРТЙНЕТ: - ДМС Active Directory ЧЩЧЕУФЙ ЧУЕИ РПМШЪПЧБФЕМЕК ЧИПДСЭЙИ Ч ЗТХРРХ - internet ВХДЕФ УМЕДХАЭБС УФТПЛБ - (memberOf=cn=internet,cn=Users,dc=domain,dc=com) ) - -user - ЙНС РПМШЪПЧБФЕМС ДМС РПДЛМАЮЕОЙС Л УЕТЧЕТХ -password - РБТПМШ (ЕУМЙ ЕУФШ) - - рТЙНЕТ ЙУРПМШЪПЧБОЙС getldapuser Ч 3proxy. - -оЕПВИПДЙНП ДБФШ ДПУФХР Л icq ФПМШЛП ПРТЕДЕМЕООЩН РПМШЪПЧБФМСН . CПЪДБЕН -Ч AD ЗТХРРХ icquser ЪБОПУЙН ФХДБ ОХЦОЩИ РПМШЪПЧБФЕМЕК. -уПЪДБЕН bat ЖБКМ УМЕДХАЭЕЗП УПДЕТЦБОЙС ЛПФПТЩК ВХДЕФ ЖПТНЙТПЧБФШ ЖБКМ -c:\3proxy\icquser УП УРЙУЛПН РПМШЪПЧБФЕМЕК: -------------------------------------------- -getldapuser 192.168.0.1 dc=domain,dc=com cn (memberOf=cn=icquser,cn=Users,dc=domain,dc=com) -cn=admin,cn=users,dc=domain,dc=com password > c:\3proxy\icquser -------------------------------------------- -чУФБЧМСЕН ДБООЩК bat ЖБКМ ОБ РЕТЙПДЙЮЕУЛПЕ ЧЩРПМОЕОЙЕ. - -дБМЕЕ РТПРЙУЩЧБЕН 3proxy.cfg УМЕД УФТПЛЙ -------------------------------------------------- -monitor "c:\3proxy\icquser" - -auth ldap -allow $"c:\3proxy\icquser" * *icq.com -deny * * *icq.com -allow * -proxy -n -------------------------------------------------- - - - лПНРЙМСГЙС РМБЗЙОБ ОБ ТБЪМЙЮОЩИ пу - - 1) Win32 (windows 98/NT/XP/2000/2003) -дМС УВПТЛЙ Й ТБВПФЩ РМБЗЙОБ Ч БТИЙЧЕ У ОЙН ХЦЕ ЙДХФ Ч ЛБФБМПЗЕ ldapwindev -УМЕДХАЭЙЕ ВЙВМЙПФЕЛЙ (ЧЕТУЙС 2.2.29). - - libcrypto.dll - liblber.dll - libldap.dll - libssl.dll -Й ЪБЗПМПЧПЮОЩЕ ЖБКМЩ - lber.h - lber_types.h - ldap.h - ldap_cdefs.h - ldap_features.h - ldap_schema.h - ldap_utf8.h - -дБМЕЕ ЧБН ОЕПВИПДЙНП УЛБЮБФШ Й ХУФБОПЧЙФШ ЛПНРЙМСФПТ Dev-Cpp У УБКФБ -http://www.bloodshed.net/dev/ - -дБМЕЕ УЛБЮБФШ ЙУИПДОЩЕ ФЕЛУФЩ 3proxy ПФУАДБ: -http://3proxy.ru/current/3proxy-0.6-devel.tgz Й ТБУРБЛПЧБФШ. -ч ЛБФБМПЗ \src\plugins УЛПРЙТПЧБФШ ЛБФБМПЗ У ЙУИПДОЩНЙ ФЕЛУФБНЙ -РМБЗЙОБ. уЛПТТЕЛФЙТПЧБФШ com-win32.bat ЖБКМ У ХЮЕФПН ФПЗП ЗДЕ Х чБУ ХУФБОПЧМЕО -ЛПНРЙМСФПТ gcc , ОБРТЙНЕТ: --------------com-win32.bat---------------- -c:\Dev-Cpp\bin\gcc -shared -o ldapauth.dll ldapauth.c -DWIN32 -I"./ldapwindev" -L"./ldapwindev" -lldap ------------------------------------------- -й ЪБРХУФЙФШ ОБ ЧЩРПМОЕОЙЕ com-win32.bat РПУМЕ ЬФПЗП Х чБУ ДПМЦОБ РПСЧЙФУС -ВЙВМЙПФЕЛБ ldapauth.dll Й ЙУРПМОСЕНЩК ЖБКМ getldapuser.exe . -дМС ДБМШОЕКЫЕК ТБВПФЩ РПМХЮЙЧЫЙЕУС ЖБКМЩ Й ЧУЕ ВЙВМЙПФЕЛЙ dll ЙЪ ЛБФБМПЗБ -ldapwindev УЛПРЙТПЧБФШ Ч ЛБФБМПЗ У 3proxy. - - 2) xNIX (linux,freebsd Й Ф.Р. ) - -рЕТЕД ЛПНРЙМСГЙЕК ОХЦОП РТПЧЕТЙФШ ЮФПВЩ Ч УЙУФЕНЕ ВЩМ ХcФБОПЧМЕО -OpenLDAP client. ч УЙУФЕНЕ ДПМЦОЩ РТЙУХФЧПЧБФШ УМЕДХАЭЙЕ -ВЙВМЙПФЕЛЙ: - - liblber.a - libldap.a - liblber.so - libldap.so - -Й ЪБЗПМПЧПЮОЩЕ ЖБКМЩ - lber.h - lber_types.h - ldap.h - ldap_cdefs.h - ldap_features.h - ldap_schema.h - ldap_utf8.h - -хУФБОПЧЛБ ЛМЙЕОФБ РПД ТБЪОЩНЙ пу ЬФП ДЕМБЕФУС МЙВП ЙОУФБМСГЙЕК ЗПФПЧПЗП РБЛЕФБ -МЙВП УБНПУФПСФЕМШОБС УВПТЛБ ДБООПЗП ЛМЙЕОФБ ЙЪ ЙУИПДОЩИ ФЕЛУФПЧ ЛПФПТЩЕ -ТБУРПМПЦЕООЩ ФХФ ftp://ftp.openldap.org/pub/OpenLDAP/openldap-release/ - -юФПВЩ УПВТБФШ РБЛЕФ, ОЕПВИПДЙНП УЛБЮБФШ БТИЙЧ -wget ftp://ftp.openldap.org/pub/OpenLDAP/openldap-release/openldap-2.3.9.tgz - -ТБУРБЛПЧЩЧБЕН БТИЙЧ -tar xvzf openldap-2.3.9.tgz - -Й ЪБРХУЛБЕН УЛТЙРФ БЧФПЛПОЖЙЗХТБГЙЙ УП УМЕДХАЭЙНЙ -РБТБНЕФТБНЙ: -./configure --enable-backends=no --enable-slapd=no - -ДБМЕЕ - -make -make install - -дБМЕЕ УЛБЮБФШ ЙУИПДОЩЕ ФЕЛУФЩ 3proxy ПФУАДБ: -http://3proxy.ru/current/3proxy-0.6-devel.tgz Й ТБУРБЛПЧБФШ. -ч ЛБФБМПЗ \src\plugins УЛПРЙТПЧБФШ ЛБФБМПЗ У ЙУИПДОЩНЙ ФЕЛУФБНЙ -РМБЗЙОБ. йЪНЕОЙФШ РХФЙ Ч ЖБКМЕ com-unix.sh РБТБНЕФТБИ ЛПНРЙМСГЙЙ -I Й -L -Л ЪБЗПМПЧПЮОЩН Й ВЙВМЙПФЕЮОЩН ЖБКМБН ldap ДМС чБЫЕК УЙУФЕНЩ. - -чЩРПМОЙФШ УМЕДХАЭЙЕ ЛПННБОДЩ: -chmod +x com-unix.sh -com-unix.sh - -й ЪБРХУФЙФШ ОБ ЧЩРПМОЕОЙЕ com-unix.sh РПУМЕ ЬФПЗП Х чБУ ДПМЦОБ РПСЧЙФУС -ВЙВМЙПФЕЛБ ldapauth.so Й ЙУРПМОСЕНЩК ЖБКМ getldapuser. - -рПМХЮЙЧЫЙЕУС ЖБКМЩ УЛПРЙТПЧБФШ Ч ЛБФБМПЗ У 3proxy. -----------------------------KOI8-R------------------------------ \ No newline at end of file diff --git a/src/plugins/PCREPlugin/Makefile b/src/plugins/PCREPlugin/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/PCREPlugin/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/PCREPlugin/Makefile.inc b/src/plugins/PCREPlugin/Makefile.inc deleted file mode 100644 index 7dd3d4f..0000000 --- a/src/plugins/PCREPlugin/Makefile.inc +++ /dev/null @@ -1,71 +0,0 @@ -all: $(BUILDDIR)PCREPlugin$(DLSUFFICS) - - -pcre_compile$(OBJSUFFICS): pcre_compile.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_compile.c - -pcre_config$(OBJSUFFICS): pcre_config.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_config.c - -pcre_dfa_exec$(OBJSUFFICS): pcre_dfa_exec.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_dfa_exec.c - -pcre_exec$(OBJSUFFICS): pcre_exec.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_exec.c - -pcre_fullinfo$(OBJSUFFICS): pcre_fullinfo.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_fullinfo.c - -pcre_get$(OBJSUFFICS): pcre_get.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_get.c - -pcre_globals$(OBJSUFFICS): pcre_globals.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_globals.c - -pcre_info$(OBJSUFFICS): pcre_info.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_info.c - -pcre_maketables$(OBJSUFFICS): pcre_maketables.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_maketables.c - -pcre_newline$(OBJSUFFICS): pcre_newline.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_newline.c - -pcre_ord2utf8$(OBJSUFFICS): pcre_ord2utf8.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_ord2utf8.c - -pcre_refcount$(OBJSUFFICS): pcre_refcount.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_refcount.c - -pcre_study$(OBJSUFFICS): pcre_study.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_study.c - -pcre_tables$(OBJSUFFICS): pcre_tables.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_tables.c - -pcre_try_flipped$(OBJSUFFICS): pcre_try_flipped.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_try_flipped.c - -pcre_ucp_searchfuncs$(OBJSUFFICS): pcre_ucp_searchfuncs.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_ucp_searchfuncs.c - -pcre_valid_utf8$(OBJSUFFICS): pcre_valid_utf8.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_valid_utf8.c - -pcre_version$(OBJSUFFICS): pcre_version.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_version.c - -pcre_xclass$(OBJSUFFICS): pcre_xclass.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_xclass.c - -pcre_dftables$(OBJSUFFICS): pcre_dftables.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_dftables.c - -pcre_plugin$(OBJSUFFICS): pcre_plugin.c - $(CC) $(DCFLAGS) $(CFLAGS) pcre_plugin.c - -pcreposix$(OBJSUFFICS): pcreposix.c - $(CC) $(DCFLAGS) $(CFLAGS) pcreposix.c - -$(BUILDDIR)PCREPlugin$(DLSUFFICS): pcre_compile$(OBJSUFFICS) pcre_config$(OBJSUFFICS) pcre_dfa_exec$(OBJSUFFICS) pcre_exec$(OBJSUFFICS) pcre_fullinfo$(OBJSUFFICS) pcre_get$(OBJSUFFICS) pcre_globals$(OBJSUFFICS) pcre_info$(OBJSUFFICS) pcre_maketables$(OBJSUFFICS) pcre_newline$(OBJSUFFICS) pcre_ord2utf8$(OBJSUFFICS) pcre_refcount$(OBJSUFFICS) pcre_study$(OBJSUFFICS) pcre_tables$(OBJSUFFICS) pcre_try_flipped$(OBJSUFFICS) pcre_ucp_searchfuncs$(OBJSUFFICS) pcre_valid_utf8$(OBJSUFFICS) pcre_version$(OBJSUFFICS) pcre_xclass$(OBJSUFFICS) pcre_dftables$(OBJSUFFICS) pcre_plugin$(OBJSUFFICS) pcreposix$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)PCREPlugin$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) pcre_compile$(OBJSUFFICS) pcre_config$(OBJSUFFICS) pcre_dfa_exec$(OBJSUFFICS) pcre_exec$(OBJSUFFICS) pcre_fullinfo$(OBJSUFFICS) pcre_get$(OBJSUFFICS) pcre_globals$(OBJSUFFICS) pcre_info$(OBJSUFFICS) pcre_maketables$(OBJSUFFICS) pcre_newline$(OBJSUFFICS) pcre_ord2utf8$(OBJSUFFICS) pcre_refcount$(OBJSUFFICS) pcre_study$(OBJSUFFICS) pcre_tables$(OBJSUFFICS) pcre_try_flipped$(OBJSUFFICS) pcre_ucp_searchfuncs$(OBJSUFFICS) pcre_valid_utf8$(OBJSUFFICS) pcre_version$(OBJSUFFICS) pcre_xclass$(OBJSUFFICS) pcre_dftables$(OBJSUFFICS) pcre_plugin$(OBJSUFFICS) pcreposix$(OBJSUFFICS) diff --git a/src/plugins/PCREPlugin/config.h b/src/plugins/PCREPlugin/config.h deleted file mode 100644 index a149626..0000000 --- a/src/plugins/PCREPlugin/config.h +++ /dev/null @@ -1,145 +0,0 @@ - -/* On Unix-like systems config.in is converted by "configure" into config.h. -Some other environments also support the use of "configure". PCRE is written in -Standard C, but there are a few non-standard things it can cope with, allowing -it to run on SunOS4 and other "close to standard" systems. - -On a non-Unix-like system you should just copy this file into config.h, and set -up the macros the way you need them. You should normally change the definitions -of HAVE_STRERROR and HAVE_MEMMOVE to 1. Unfortunately, because of the way -autoconf works, these cannot be made the defaults. If your system has bcopy() -and not memmove(), change the definition of HAVE_BCOPY instead of HAVE_MEMMOVE. -If your system has neither bcopy() nor memmove(), leave them both as 0; an -emulation function will be used. */ - -/* If you are compiling for a system that uses EBCDIC instead of ASCII -character codes, define this macro as 1. On systems that can use "configure", -this can be done via --enable-ebcdic. */ - -#ifndef EBCDIC -#define EBCDIC 0 -#endif - -#define PCRE_STATIC - -/* If you are compiling for a system other than a Unix-like system or Win32, -and it needs some magic to be inserted before the definition of a function that -is exported by the library, define this macro to contain the relevant magic. If -you do not define this macro, it defaults to "extern" for a C compiler and -"extern C" for a C++ compiler on non-Win32 systems. This macro apears at the -start of every exported function that is part of the external API. It does not -appear on functions that are "external" in the C sense, but which are internal -to the library. */ - -/* #define PCRE_DATA_SCOPE */ - -/* Define the following macro to empty if the "const" keyword does not work. */ - -#undef const - -/* Define the following macro to "unsigned" if does not define -size_t. */ - -#undef size_t - -/* The following two definitions are mainly for the benefit of SunOS4, which -does not have the strerror() or memmove() functions that should be present in -all Standard C libraries. The macros HAVE_STRERROR and HAVE_MEMMOVE should -normally be defined with the value 1 for other systems, but unfortunately we -cannot make this the default because "configure" files generated by autoconf -will only change 0 to 1; they won't change 1 to 0 if the functions are not -found. */ - -#define HAVE_STRERROR 0 -#define HAVE_MEMMOVE 0 - -/* There are some non-Unix-like systems that don't even have bcopy(). If this -macro is false, an emulation is used. If HAVE_MEMMOVE is set to 1, the value of -HAVE_BCOPY is not relevant. */ - -#define HAVE_BCOPY 0 - -/* The value of NEWLINE determines the newline character. The default is to -leave it up to the compiler, but some sites want to force a particular value. -On Unix-like systems, "configure" can be used to override this default. */ - -#ifndef NEWLINE -#define NEWLINE '\n' -#endif - -/* The value of LINK_SIZE determines the number of bytes used to store links as -offsets within the compiled regex. The default is 2, which allows for compiled -patterns up to 64K long. This covers the vast majority of cases. However, PCRE -can also be compiled to use 3 or 4 bytes instead. This allows for longer -patterns in extreme cases. On systems that support it, "configure" can be used -to override this default. */ - -#ifndef LINK_SIZE -#define LINK_SIZE 2 -#endif - -/* When calling PCRE via the POSIX interface, additional working storage is -required for holding the pointers to capturing substrings because PCRE requires -three integers per substring, whereas the POSIX interface provides only two. If -the number of expected substrings is small, the wrapper function uses space on -the stack, because this is faster than using malloc() for each call. The -threshold above which the stack is no longer used is defined by POSIX_MALLOC_ -THRESHOLD. On systems that support it, "configure" can be used to override this -default. */ - -#ifndef POSIX_MALLOC_THRESHOLD -#define POSIX_MALLOC_THRESHOLD 10 -#endif - -/* PCRE uses recursive function calls to handle backtracking while matching. -This can sometimes be a problem on systems that have stacks of limited size. -Define NO_RECURSE to get a version that doesn't use recursion in the match() -function; instead it creates its own stack by steam using pcre_recurse_malloc() -to obtain memory from the heap. For more detail, see the comments and other -stuff just above the match() function. On systems that support it, "configure" -can be used to set this in the Makefile (use --disable-stack-for-recursion). */ - -/* #define NO_RECURSE */ - -/* The value of MATCH_LIMIT determines the default number of times the internal -match() function can be called during a single execution of pcre_exec(). There -is a runtime interface for setting a different limit. The limit exists in order -to catch runaway regular expressions that take for ever to determine that they -do not match. The default is set very large so that it does not accidentally -catch legitimate cases. On systems that support it, "configure" can be used to -override this default default. */ - -#ifndef MATCH_LIMIT -#define MATCH_LIMIT 10000000 -#endif - -/* The above limit applies to all calls of match(), whether or not they -increase the recursion depth. In some environments it is desirable to limit the -depth of recursive calls of match() more strictly, in order to restrict the -maximum amount of stack (or heap, if NO_RECURSE is defined) that is used. The -value of MATCH_LIMIT_RECURSION applies only to recursive calls of match(). To -have any useful effect, it must be less than the value of MATCH_LIMIT. There is -a runtime method for setting a different limit. On systems that support it, -"configure" can be used to override this default default. */ - -#ifndef MATCH_LIMIT_RECURSION -#define MATCH_LIMIT_RECURSION MATCH_LIMIT -#endif - -/* These three limits are parameterized just in case anybody ever wants to -change them. Care must be taken if they are increased, because they guard -against integer overflow caused by enormously large patterns. */ - -#ifndef MAX_NAME_SIZE -#define MAX_NAME_SIZE 32 -#endif - -#ifndef MAX_NAME_COUNT -#define MAX_NAME_COUNT 10000 -#endif - -#ifndef MAX_DUPLENGTH -#define MAX_DUPLENGTH 30000 -#endif - -/* End */ diff --git a/src/plugins/PCREPlugin/pcre.h b/src/plugins/PCREPlugin/pcre.h deleted file mode 100644 index 9064ee0..0000000 --- a/src/plugins/PCREPlugin/pcre.h +++ /dev/null @@ -1,304 +0,0 @@ -#include "config.h" -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* This is the public header file for the PCRE library, to be #included by -applications that call the PCRE functions. - - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - -#ifndef _PCRE_H -#define _PCRE_H - -/* The current PCRE version information. */ - -#define PCRE_MAJOR 7 -#define PCRE_MINOR 4 -#define PCRE_PRERELEASE -#define PCRE_DATE 2007-09-21 - -/* When an application links to a PCRE DLL in Windows, the symbols that are -imported have to be identified as such. When building PCRE, the appropriate -export setting is defined in pcre_internal.h, which includes this file. So we -don't change existing definitions of PCRE_EXP_DECL and PCRECPP_EXP_DECL. */ - -#if defined(_WIN32) && !defined(PCRE_STATIC) -# ifndef PCRE_EXP_DECL -# define PCRE_EXP_DECL extern __declspec(dllimport) -# endif -# ifdef __cplusplus -# ifndef PCRECPP_EXP_DECL -# define PCRECPP_EXP_DECL extern __declspec(dllimport) -# endif -# ifndef PCRECPP_EXP_DEFN -# define PCRECPP_EXP_DEFN __declspec(dllimport) -# endif -# endif -#endif - -/* By default, we use the standard "extern" declarations. */ - -#ifndef PCRE_EXP_DECL -# ifdef __cplusplus -# define PCRE_EXP_DECL extern "C" -# else -# define PCRE_EXP_DECL extern -# endif -#endif - -#ifdef __cplusplus -# ifndef PCRECPP_EXP_DECL -# define PCRECPP_EXP_DECL extern -# endif -# ifndef PCRECPP_EXP_DEFN -# define PCRECPP_EXP_DEFN -# endif -#endif - -/* Have to include stdlib.h in order to ensure that size_t is defined; -it is needed here for malloc. */ - -#include - -/* Allow for C++ users */ - -#ifdef __cplusplus -extern "C" { -#endif - -/* Options */ - -#define PCRE_CASELESS 0x00000001 -#define PCRE_MULTILINE 0x00000002 -#define PCRE_DOTALL 0x00000004 -#define PCRE_EXTENDED 0x00000008 -#define PCRE_ANCHORED 0x00000010 -#define PCRE_DOLLAR_ENDONLY 0x00000020 -#define PCRE_EXTRA 0x00000040 -#define PCRE_NOTBOL 0x00000080 -#define PCRE_NOTEOL 0x00000100 -#define PCRE_UNGREEDY 0x00000200 -#define PCRE_NOTEMPTY 0x00000400 -#define PCRE_UTF8 0x00000800 -#define PCRE_NO_AUTO_CAPTURE 0x00001000 -#define PCRE_NO_UTF8_CHECK 0x00002000 -#define PCRE_AUTO_CALLOUT 0x00004000 -#define PCRE_PARTIAL 0x00008000 -#define PCRE_DFA_SHORTEST 0x00010000 -#define PCRE_DFA_RESTART 0x00020000 -#define PCRE_FIRSTLINE 0x00040000 -#define PCRE_DUPNAMES 0x00080000 -#define PCRE_NEWLINE_CR 0x00100000 -#define PCRE_NEWLINE_LF 0x00200000 -#define PCRE_NEWLINE_CRLF 0x00300000 -#define PCRE_NEWLINE_ANY 0x00400000 -#define PCRE_NEWLINE_ANYCRLF 0x00500000 -#define PCRE_BSR_ANYCRLF 0x00800000 -#define PCRE_BSR_UNICODE 0x01000000 - -/* Exec-time and get/set-time error codes */ - -#define PCRE_ERROR_NOMATCH (-1) -#define PCRE_ERROR_NULL (-2) -#define PCRE_ERROR_BADOPTION (-3) -#define PCRE_ERROR_BADMAGIC (-4) -#define PCRE_ERROR_UNKNOWN_OPCODE (-5) -#define PCRE_ERROR_UNKNOWN_NODE (-5) /* For backward compatibility */ -#define PCRE_ERROR_NOMEMORY (-6) -#define PCRE_ERROR_NOSUBSTRING (-7) -#define PCRE_ERROR_MATCHLIMIT (-8) -#define PCRE_ERROR_CALLOUT (-9) /* Never used by PCRE itself */ -#define PCRE_ERROR_BADUTF8 (-10) -#define PCRE_ERROR_BADUTF8_OFFSET (-11) -#define PCRE_ERROR_PARTIAL (-12) -#define PCRE_ERROR_BADPARTIAL (-13) -#define PCRE_ERROR_INTERNAL (-14) -#define PCRE_ERROR_BADCOUNT (-15) -#define PCRE_ERROR_DFA_UITEM (-16) -#define PCRE_ERROR_DFA_UCOND (-17) -#define PCRE_ERROR_DFA_UMLIMIT (-18) -#define PCRE_ERROR_DFA_WSSIZE (-19) -#define PCRE_ERROR_DFA_RECURSE (-20) -#define PCRE_ERROR_RECURSIONLIMIT (-21) -#define PCRE_ERROR_NULLWSLIMIT (-22) /* No longer actually used */ -#define PCRE_ERROR_BADNEWLINE (-23) - -/* Request types for pcre_fullinfo() */ - -#define PCRE_INFO_OPTIONS 0 -#define PCRE_INFO_SIZE 1 -#define PCRE_INFO_CAPTURECOUNT 2 -#define PCRE_INFO_BACKREFMAX 3 -#define PCRE_INFO_FIRSTBYTE 4 -#define PCRE_INFO_FIRSTCHAR 4 /* For backwards compatibility */ -#define PCRE_INFO_FIRSTTABLE 5 -#define PCRE_INFO_LASTLITERAL 6 -#define PCRE_INFO_NAMEENTRYSIZE 7 -#define PCRE_INFO_NAMECOUNT 8 -#define PCRE_INFO_NAMETABLE 9 -#define PCRE_INFO_STUDYSIZE 10 -#define PCRE_INFO_DEFAULT_TABLES 11 -#define PCRE_INFO_OKPARTIAL 12 -#define PCRE_INFO_JCHANGED 13 -#define PCRE_INFO_HASCRORLF 14 - -/* Request types for pcre_config(). Do not re-arrange, in order to remain -compatible. */ - -#define PCRE_CONFIG_UTF8 0 -#define PCRE_CONFIG_NEWLINE 1 -#define PCRE_CONFIG_LINK_SIZE 2 -#define PCRE_CONFIG_POSIX_MALLOC_THRESHOLD 3 -#define PCRE_CONFIG_MATCH_LIMIT 4 -#define PCRE_CONFIG_STACKRECURSE 5 -#define PCRE_CONFIG_UNICODE_PROPERTIES 6 -#define PCRE_CONFIG_MATCH_LIMIT_RECURSION 7 -#define PCRE_CONFIG_BSR 8 - -/* Bit flags for the pcre_extra structure. Do not re-arrange or redefine -these bits, just add new ones on the end, in order to remain compatible. */ - -#define PCRE_EXTRA_STUDY_DATA 0x0001 -#define PCRE_EXTRA_MATCH_LIMIT 0x0002 -#define PCRE_EXTRA_CALLOUT_DATA 0x0004 -#define PCRE_EXTRA_TABLES 0x0008 -#define PCRE_EXTRA_MATCH_LIMIT_RECURSION 0x0010 - -/* Types */ - -struct real_pcre; /* declaration; the definition is private */ -typedef struct real_pcre pcre; - -/* When PCRE is compiled as a C++ library, the subject pointer type can be -replaced with a custom type. For conventional use, the public interface is a -const char *. */ - -#ifndef PCRE_SPTR -#define PCRE_SPTR const char * -#endif - -/* The structure for passing additional data to pcre_exec(). This is defined in -such as way as to be extensible. Always add new fields at the end, in order to -remain compatible. */ - -typedef struct pcre_extra { - unsigned long int flags; /* Bits for which fields are set */ - void *study_data; /* Opaque data from pcre_study() */ - unsigned long int match_limit; /* Maximum number of calls to match() */ - void *callout_data; /* Data passed back in callouts */ - const unsigned char *tables; /* Pointer to character tables */ - unsigned long int match_limit_recursion; /* Max recursive calls to match() */ -} pcre_extra; - -/* The structure for passing out data via the pcre_callout_function. We use a -structure so that new fields can be added on the end in future versions, -without changing the API of the function, thereby allowing old clients to work -without modification. */ - -typedef struct pcre_callout_block { - int version; /* Identifies version of block */ - /* ------------------------ Version 0 ------------------------------- */ - int callout_number; /* Number compiled into pattern */ - int *offset_vector; /* The offset vector */ - PCRE_SPTR subject; /* The subject being matched */ - int subject_length; /* The length of the subject */ - int start_match; /* Offset to start of this match attempt */ - int current_position; /* Where we currently are in the subject */ - int capture_top; /* Max current capture */ - int capture_last; /* Most recently closed capture */ - void *callout_data; /* Data passed in with the call */ - /* ------------------- Added for Version 1 -------------------------- */ - int pattern_position; /* Offset to next item in the pattern */ - int next_item_length; /* Length of next item in the pattern */ - /* ------------------------------------------------------------------ */ -} pcre_callout_block; - -/* Indirection for store get and free functions. These can be set to -alternative malloc/free functions if required. Special ones are used in the -non-recursive case for "frames". There is also an optional callout function -that is triggered by the (?) regex item. For Virtual Pascal, these definitions -have to take another form. */ - -#ifndef VPCOMPAT -PCRE_EXP_DECL void *(*pcre_malloc)(size_t); -PCRE_EXP_DECL void (*pcre_free)(void *); -PCRE_EXP_DECL void *(*pcre_stack_malloc)(size_t); -PCRE_EXP_DECL void (*pcre_stack_free)(void *); -PCRE_EXP_DECL int (*pcre_callout)(pcre_callout_block *); -#else /* VPCOMPAT */ -PCRE_EXP_DECL void *pcre_malloc(size_t); -PCRE_EXP_DECL void pcre_free(void *); -PCRE_EXP_DECL void *pcre_stack_malloc(size_t); -PCRE_EXP_DECL void pcre_stack_free(void *); -PCRE_EXP_DECL int pcre_callout(pcre_callout_block *); -#endif /* VPCOMPAT */ - -/* Exported PCRE functions */ - -PCRE_EXP_DECL pcre *pcre_compile(const char *, int, const char **, int *, - const unsigned char *); -PCRE_EXP_DECL pcre *pcre_compile2(const char *, int, int *, const char **, - int *, const unsigned char *); -PCRE_EXP_DECL int pcre_config(int, void *); -PCRE_EXP_DECL int pcre_copy_named_substring(const pcre *, const char *, - int *, int, const char *, char *, int); -PCRE_EXP_DECL int pcre_copy_substring(const char *, int *, int, int, char *, - int); -PCRE_EXP_DECL int pcre_dfa_exec(const pcre *, const pcre_extra *, - const char *, int, int, int, int *, int , int *, int); -PCRE_EXP_DECL int pcre_exec(const pcre *, const pcre_extra *, PCRE_SPTR, - int, int, int, int *, int); -PCRE_EXP_DECL void pcre_free_substring(const char *); -PCRE_EXP_DECL void pcre_free_substring_list(const char **); -PCRE_EXP_DECL int pcre_fullinfo(const pcre *, const pcre_extra *, int, - void *); -PCRE_EXP_DECL int pcre_get_named_substring(const pcre *, const char *, - int *, int, const char *, const char **); -PCRE_EXP_DECL int pcre_get_stringnumber(const pcre *, const char *); -PCRE_EXP_DECL int pcre_get_stringtable_entries(const pcre *, const char *, - char **, char **); -PCRE_EXP_DECL int pcre_get_substring(const char *, int *, int, int, - const char **); -PCRE_EXP_DECL int pcre_get_substring_list(const char *, int *, int, - const char ***); -PCRE_EXP_DECL int pcre_info(const pcre *, int *, int *); -PCRE_EXP_DECL const unsigned char *pcre_maketables(void); -PCRE_EXP_DECL int pcre_refcount(pcre *, int); -PCRE_EXP_DECL pcre_extra *pcre_study(const pcre *, int, const char **); -PCRE_EXP_DECL const char *pcre_version(void); - -#ifdef __cplusplus -} /* extern "C" */ -#endif - -#endif /* End of pcre.h */ diff --git a/src/plugins/PCREPlugin/pcre_compile.c b/src/plugins/PCREPlugin/pcre_compile.c deleted file mode 100644 index 3994781..0000000 --- a/src/plugins/PCREPlugin/pcre_compile.c +++ /dev/null @@ -1,6145 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_compile(), along with -supporting internal functions that are not used by other modules. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#define NLBLOCK cd /* Block containing newline information */ -#define PSSTART start_pattern /* Field containing processed string start */ -#define PSEND end_pattern /* Field containing processed string end */ - -#include "pcre_internal.h" - - -/* When DEBUG is defined, we need the pcre_printint() function, which is also -used by pcretest. DEBUG is not defined when building a production library. */ - -#ifdef DEBUG -#include "pcre_printint.src" -#endif - - -/* Macro for setting individual bits in class bitmaps. */ - -#define SETBIT(a,b) a[b/8] |= (1 << (b%8)) - -/* Maximum length value to check against when making sure that the integer that -holds the compiled pattern length does not overflow. We make it a bit less than -INT_MAX to allow for adding in group terminating bytes, so that we don't have -to check them every time. */ - -#define OFLOW_MAX (INT_MAX - 20) - - -/************************************************* -* Code parameters and static tables * -*************************************************/ - -/* This value specifies the size of stack workspace that is used during the -first pre-compile phase that determines how much memory is required. The regex -is partly compiled into this space, but the compiled parts are discarded as -soon as they can be, so that hopefully there will never be an overrun. The code -does, however, check for an overrun. The largest amount I've seen used is 218, -so this number is very generous. - -The same workspace is used during the second, actual compile phase for -remembering forward references to groups so that they can be filled in at the -end. Each entry in this list occupies LINK_SIZE bytes, so even when LINK_SIZE -is 4 there is plenty of room. */ - -#define COMPILE_WORK_SIZE (4096) - - -/* Table for handling escaped characters in the range '0'-'z'. Positive returns -are simple data values; negative values are for special things like \d and so -on. Zero means further processing is needed (for things like \x), or the escape -is invalid. */ - -#ifndef EBCDIC /* This is the "normal" table for ASCII systems */ -static const short int escapes[] = { - 0, 0, 0, 0, 0, 0, 0, 0, /* 0 - 7 */ - 0, 0, ':', ';', '<', '=', '>', '?', /* 8 - ? */ - '@', -ESC_A, -ESC_B, -ESC_C, -ESC_D, -ESC_E, 0, -ESC_G, /* @ - G */ --ESC_H, 0, 0, -ESC_K, 0, 0, 0, 0, /* H - O */ --ESC_P, -ESC_Q, -ESC_R, -ESC_S, 0, 0, -ESC_V, -ESC_W, /* P - W */ --ESC_X, 0, -ESC_Z, '[', '\\', ']', '^', '_', /* X - _ */ - '`', 7, -ESC_b, 0, -ESC_d, ESC_e, ESC_f, 0, /* ` - g */ --ESC_h, 0, 0, -ESC_k, 0, 0, ESC_n, 0, /* h - o */ --ESC_p, 0, ESC_r, -ESC_s, ESC_tee, 0, -ESC_v, -ESC_w, /* p - w */ - 0, 0, -ESC_z /* x - z */ -}; - -#else /* This is the "abnormal" table for EBCDIC systems */ -static const short int escapes[] = { -/* 48 */ 0, 0, 0, '.', '<', '(', '+', '|', -/* 50 */ '&', 0, 0, 0, 0, 0, 0, 0, -/* 58 */ 0, 0, '!', '$', '*', ')', ';', '~', -/* 60 */ '-', '/', 0, 0, 0, 0, 0, 0, -/* 68 */ 0, 0, '|', ',', '%', '_', '>', '?', -/* 70 */ 0, 0, 0, 0, 0, 0, 0, 0, -/* 78 */ 0, '`', ':', '#', '@', '\'', '=', '"', -/* 80 */ 0, 7, -ESC_b, 0, -ESC_d, ESC_e, ESC_f, 0, -/* 88 */-ESC_h, 0, 0, '{', 0, 0, 0, 0, -/* 90 */ 0, 0, -ESC_k, 'l', 0, ESC_n, 0, -ESC_p, -/* 98 */ 0, ESC_r, 0, '}', 0, 0, 0, 0, -/* A0 */ 0, '~', -ESC_s, ESC_tee, 0,-ESC_v, -ESC_w, 0, -/* A8 */ 0,-ESC_z, 0, 0, 0, '[', 0, 0, -/* B0 */ 0, 0, 0, 0, 0, 0, 0, 0, -/* B8 */ 0, 0, 0, 0, 0, ']', '=', '-', -/* C0 */ '{',-ESC_A, -ESC_B, -ESC_C, -ESC_D,-ESC_E, 0, -ESC_G, -/* C8 */-ESC_H, 0, 0, 0, 0, 0, 0, 0, -/* D0 */ '}', 0, -ESC_K, 0, 0, 0, 0, -ESC_P, -/* D8 */-ESC_Q,-ESC_R, 0, 0, 0, 0, 0, 0, -/* E0 */ '\\', 0, -ESC_S, 0, 0,-ESC_V, -ESC_W, -ESC_X, -/* E8 */ 0,-ESC_Z, 0, 0, 0, 0, 0, 0, -/* F0 */ 0, 0, 0, 0, 0, 0, 0, 0, -/* F8 */ 0, 0, 0, 0, 0, 0, 0, 0 -}; -#endif - - -/* Table of special "verbs" like (*PRUNE). This is a short table, so it is -searched linearly. Put all the names into a single string, in order to reduce -the number of relocations when a shared library is dynamically linked. */ - -typedef struct verbitem { - int len; - int op; -} verbitem; - -static const char verbnames[] = - "ACCEPT\0" - "COMMIT\0" - "F\0" - "FAIL\0" - "PRUNE\0" - "SKIP\0" - "THEN"; - -static verbitem verbs[] = { - { 6, OP_ACCEPT }, - { 6, OP_COMMIT }, - { 1, OP_FAIL }, - { 4, OP_FAIL }, - { 5, OP_PRUNE }, - { 4, OP_SKIP }, - { 4, OP_THEN } -}; - -static int verbcount = sizeof(verbs)/sizeof(verbitem); - - -/* Tables of names of POSIX character classes and their lengths. The names are -now all in a single string, to reduce the number of relocations when a shared -library is dynamically loaded. The list of lengths is terminated by a zero -length entry. The first three must be alpha, lower, upper, as this is assumed -for handling case independence. */ - -static const char posix_names[] = - "alpha\0" "lower\0" "upper\0" "alnum\0" "ascii\0" "blank\0" - "cntrl\0" "digit\0" "graph\0" "print\0" "punct\0" "space\0" - "word\0" "xdigit"; - -static const uschar posix_name_lengths[] = { - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 4, 6, 0 }; - -/* Table of class bit maps for each POSIX class. Each class is formed from a -base map, with an optional addition or removal of another map. Then, for some -classes, there is some additional tweaking: for [:blank:] the vertical space -characters are removed, and for [:alpha:] and [:alnum:] the underscore -character is removed. The triples in the table consist of the base map offset, -second map offset or -1 if no second map, and a non-negative value for map -addition or a negative value for map subtraction (if there are two maps). The -absolute value of the third field has these meanings: 0 => no tweaking, 1 => -remove vertical space characters, 2 => remove underscore. */ - -static const int posix_class_maps[] = { - cbit_word, cbit_digit, -2, /* alpha */ - cbit_lower, -1, 0, /* lower */ - cbit_upper, -1, 0, /* upper */ - cbit_word, -1, 2, /* alnum - word without underscore */ - cbit_print, cbit_cntrl, 0, /* ascii */ - cbit_space, -1, 1, /* blank - a GNU extension */ - cbit_cntrl, -1, 0, /* cntrl */ - cbit_digit, -1, 0, /* digit */ - cbit_graph, -1, 0, /* graph */ - cbit_print, -1, 0, /* print */ - cbit_punct, -1, 0, /* punct */ - cbit_space, -1, 0, /* space */ - cbit_word, -1, 0, /* word - a Perl extension */ - cbit_xdigit,-1, 0 /* xdigit */ -}; - - -#define STRING(a) # a -#define XSTRING(s) STRING(s) - -/* The texts of compile-time error messages. These are "char *" because they -are passed to the outside world. Do not ever re-use any error number, because -they are documented. Always add a new error instead. Messages marked DEAD below -are no longer used. This used to be a table of strings, but in order to reduce -the number of relocations needed when a shared library is loaded dynamically, -it is now one long string. We cannot use a table of offsets, because the -lengths of inserts such as XSTRING(MAX_NAME_SIZE) are not known. Instead, we -simply count through to the one we want - this isn't a performance issue -because these strings are used only when there is a compilation error. */ - -static const char error_texts[] = - "no error\0" - "\\ at end of pattern\0" - "\\c at end of pattern\0" - "unrecognized character follows \\\0" - "numbers out of order in {} quantifier\0" - /* 5 */ - "number too big in {} quantifier\0" - "missing terminating ] for character class\0" - "invalid escape sequence in character class\0" - "range out of order in character class\0" - "nothing to repeat\0" - /* 10 */ - "operand of unlimited repeat could match the empty string\0" /** DEAD **/ - "internal error: unexpected repeat\0" - "unrecognized character after (?\0" - "POSIX named classes are supported only within a class\0" - "missing )\0" - /* 15 */ - "reference to non-existent subpattern\0" - "erroffset passed as NULL\0" - "unknown option bit(s) set\0" - "missing ) after comment\0" - "parentheses nested too deeply\0" /** DEAD **/ - /* 20 */ - "regular expression is too large\0" - "failed to get memory\0" - "unmatched parentheses\0" - "internal error: code overflow\0" - "unrecognized character after (?<\0" - /* 25 */ - "lookbehind assertion is not fixed length\0" - "malformed number or name after (?(\0" - "conditional group contains more than two branches\0" - "assertion expected after (?(\0" - "(?R or (?[+-]digits must be followed by )\0" - /* 30 */ - "unknown POSIX class name\0" - "POSIX collating elements are not supported\0" - "this version of PCRE is not compiled with PCRE_UTF8 support\0" - "spare error\0" /** DEAD **/ - "character value in \\x{...} sequence is too large\0" - /* 35 */ - "invalid condition (?(0)\0" - "\\C not allowed in lookbehind assertion\0" - "PCRE does not support \\L, \\l, \\N, \\U, or \\u\0" - "number after (?C is > 255\0" - "closing ) for (?C expected\0" - /* 40 */ - "recursive call could loop indefinitely\0" - "unrecognized character after (?P\0" - "syntax error in subpattern name (missing terminator)\0" - "two named subpatterns have the same name\0" - "invalid UTF-8 string\0" - /* 45 */ - "support for \\P, \\p, and \\X has not been compiled\0" - "malformed \\P or \\p sequence\0" - "unknown property name after \\P or \\p\0" - "subpattern name is too long (maximum " XSTRING(MAX_NAME_SIZE) " characters)\0" - "too many named subpatterns (maximum " XSTRING(MAX_NAME_COUNT) ")\0" - /* 50 */ - "repeated subpattern is too long\0" /** DEAD **/ - "octal value is greater than \\377 (not in UTF-8 mode)\0" - "internal error: overran compiling workspace\0" - "internal error: previously-checked referenced subpattern not found\0" - "DEFINE group contains more than one branch\0" - /* 55 */ - "repeating a DEFINE group is not allowed\0" - "inconsistent NEWLINE options\0" - "\\g is not followed by a braced name or an optionally braced non-zero number\0" - "(?+ or (?- or (?(+ or (?(- must be followed by a non-zero number\0" - "(*VERB) with an argument is not supported\0" - /* 60 */ - "(*VERB) not recognized\0" - "number is too big"; - - -/* Table to identify digits and hex digits. This is used when compiling -patterns. Note that the tables in chartables are dependent on the locale, and -may mark arbitrary characters as digits - but the PCRE compiling code expects -to handle only 0-9, a-z, and A-Z as digits when compiling. That is why we have -a private table here. It costs 256 bytes, but it is a lot faster than doing -character value tests (at least in some simple cases I timed), and in some -applications one wants PCRE to compile efficiently as well as match -efficiently. - -For convenience, we use the same bit definitions as in chartables: - - 0x04 decimal digit - 0x08 hexadecimal digit - -Then we can use ctype_digit and ctype_xdigit in the code. */ - -#ifndef EBCDIC /* This is the "normal" case, for ASCII systems */ -static const unsigned char digitab[] = - { - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 0- 7 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 8- 15 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 16- 23 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 24- 31 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* - ' */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* ( - / */ - 0x0c,0x0c,0x0c,0x0c,0x0c,0x0c,0x0c,0x0c, /* 0 - 7 */ - 0x0c,0x0c,0x00,0x00,0x00,0x00,0x00,0x00, /* 8 - ? */ - 0x00,0x08,0x08,0x08,0x08,0x08,0x08,0x00, /* @ - G */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* H - O */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* P - W */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* X - _ */ - 0x00,0x08,0x08,0x08,0x08,0x08,0x08,0x00, /* ` - g */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* h - o */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* p - w */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* x -127 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 128-135 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 136-143 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 144-151 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 152-159 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 160-167 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 168-175 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 176-183 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 184-191 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 192-199 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 200-207 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 208-215 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 216-223 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 224-231 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 232-239 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 240-247 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};/* 248-255 */ - -#else /* This is the "abnormal" case, for EBCDIC systems */ -static const unsigned char digitab[] = - { - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 0- 7 0 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 8- 15 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 16- 23 10 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 24- 31 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 32- 39 20 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 40- 47 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 48- 55 30 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 56- 63 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* - 71 40 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 72- | */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* & - 87 50 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 88- 95 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* - -103 60 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 104- ? */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 112-119 70 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 120- " */ - 0x00,0x08,0x08,0x08,0x08,0x08,0x08,0x00, /* 128- g 80 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* h -143 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 144- p 90 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* q -159 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 160- x A0 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* y -175 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* ^ -183 B0 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 184-191 */ - 0x00,0x08,0x08,0x08,0x08,0x08,0x08,0x00, /* { - G C0 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* H -207 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* } - P D0 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* Q -223 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* \ - X E0 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* Y -239 */ - 0x0c,0x0c,0x0c,0x0c,0x0c,0x0c,0x0c,0x0c, /* 0 - 7 F0 */ - 0x0c,0x0c,0x00,0x00,0x00,0x00,0x00,0x00};/* 8 -255 */ - -static const unsigned char ebcdic_chartab[] = { /* chartable partial dup */ - 0x80,0x00,0x00,0x00,0x00,0x01,0x00,0x00, /* 0- 7 */ - 0x00,0x00,0x00,0x00,0x01,0x01,0x00,0x00, /* 8- 15 */ - 0x00,0x00,0x00,0x00,0x00,0x01,0x00,0x00, /* 16- 23 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 24- 31 */ - 0x00,0x00,0x00,0x00,0x00,0x01,0x00,0x00, /* 32- 39 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 40- 47 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 48- 55 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 56- 63 */ - 0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* - 71 */ - 0x00,0x00,0x00,0x80,0x00,0x80,0x80,0x80, /* 72- | */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* & - 87 */ - 0x00,0x00,0x00,0x80,0x80,0x80,0x00,0x00, /* 88- 95 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* - -103 */ - 0x00,0x00,0x00,0x00,0x00,0x10,0x00,0x80, /* 104- ? */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 112-119 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 120- " */ - 0x00,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x12, /* 128- g */ - 0x12,0x12,0x00,0x00,0x00,0x00,0x00,0x00, /* h -143 */ - 0x00,0x12,0x12,0x12,0x12,0x12,0x12,0x12, /* 144- p */ - 0x12,0x12,0x00,0x00,0x00,0x00,0x00,0x00, /* q -159 */ - 0x00,0x00,0x12,0x12,0x12,0x12,0x12,0x12, /* 160- x */ - 0x12,0x12,0x00,0x00,0x00,0x00,0x00,0x00, /* y -175 */ - 0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* ^ -183 */ - 0x00,0x00,0x80,0x00,0x00,0x00,0x00,0x00, /* 184-191 */ - 0x80,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x12, /* { - G */ - 0x12,0x12,0x00,0x00,0x00,0x00,0x00,0x00, /* H -207 */ - 0x00,0x12,0x12,0x12,0x12,0x12,0x12,0x12, /* } - P */ - 0x12,0x12,0x00,0x00,0x00,0x00,0x00,0x00, /* Q -223 */ - 0x00,0x00,0x12,0x12,0x12,0x12,0x12,0x12, /* \ - X */ - 0x12,0x12,0x00,0x00,0x00,0x00,0x00,0x00, /* Y -239 */ - 0x1c,0x1c,0x1c,0x1c,0x1c,0x1c,0x1c,0x1c, /* 0 - 7 */ - 0x1c,0x1c,0x00,0x00,0x00,0x00,0x00,0x00};/* 8 -255 */ -#endif - - -/* Definition to allow mutual recursion */ - -static BOOL - compile_regex(int, int, uschar **, const uschar **, int *, BOOL, BOOL, int, - int *, int *, branch_chain *, compile_data *, int *); - - - -/************************************************* -* Find an error text * -*************************************************/ - -/* The error texts are now all in one long string, to save on relocations. As -some of the text is of unknown length, we can't use a table of offsets. -Instead, just count through the strings. This is not a performance issue -because it happens only when there has been a compilation error. - -Argument: the error number -Returns: pointer to the error string -*/ - -static const char * -find_error_text(int n) -{ -const char *s = error_texts; -for (; n > 0; n--) while (*s++ != 0); -return s; -} - - -/************************************************* -* Handle escapes * -*************************************************/ - -/* This function is called when a \ has been encountered. It either returns a -positive value for a simple escape such as \n, or a negative value which -encodes one of the more complicated things such as \d. A backreference to group -n is returned as -(ESC_REF + n); ESC_REF is the highest ESC_xxx macro. When -UTF-8 is enabled, a positive value greater than 255 may be returned. On entry, -ptr is pointing at the \. On exit, it is on the final character of the escape -sequence. - -Arguments: - ptrptr points to the pattern position pointer - errorcodeptr points to the errorcode variable - bracount number of previous extracting brackets - options the options bits - isclass TRUE if inside a character class - -Returns: zero or positive => a data character - negative => a special escape sequence - on error, errorcodeptr is set -*/ - -static int -check_escape(const uschar **ptrptr, int *errorcodeptr, int bracount, - int options, BOOL isclass) -{ -BOOL utf8 = (options & PCRE_UTF8) != 0; -const uschar *ptr = *ptrptr + 1; -int c, i; - -GETCHARINCTEST(c, ptr); /* Get character value, increment pointer */ -ptr--; /* Set pointer back to the last byte */ - -/* If backslash is at the end of the pattern, it's an error. */ - -if (c == 0) *errorcodeptr = ERR1; - -/* Non-alphamerics are literals. For digits or letters, do an initial lookup in -a table. A non-zero result is something that can be returned immediately. -Otherwise further processing may be required. */ - -#ifndef EBCDIC /* ASCII coding */ -else if (c < '0' || c > 'z') {} /* Not alphameric */ -else if ((i = escapes[c - '0']) != 0) c = i; - -#else /* EBCDIC coding */ -else if (c < 'a' || (ebcdic_chartab[c] & 0x0E) == 0) {} /* Not alphameric */ -else if ((i = escapes[c - 0x48]) != 0) c = i; -#endif - -/* Escapes that need further processing, or are illegal. */ - -else - { - const uschar *oldptr; - BOOL braced, negated; - - switch (c) - { - /* A number of Perl escapes are not handled by PCRE. We give an explicit - error. */ - - case 'l': - case 'L': - case 'N': - case 'u': - case 'U': - *errorcodeptr = ERR37; - break; - - /* \g must be followed by a number, either plain or braced. If positive, it - is an absolute backreference. If negative, it is a relative backreference. - This is a Perl 5.10 feature. Perl 5.10 also supports \g{name} as a - reference to a named group. This is part of Perl's movement towards a - unified syntax for back references. As this is synonymous with \k{name}, we - fudge it up by pretending it really was \k. */ - - case 'g': - if (ptr[1] == '{') - { - const uschar *p; - for (p = ptr+2; *p != 0 && *p != '}'; p++) - if (*p != '-' && (digitab[*p] & ctype_digit) == 0) break; - if (*p != 0 && *p != '}') - { - c = -ESC_k; - break; - } - braced = TRUE; - ptr++; - } - else braced = FALSE; - - if (ptr[1] == '-') - { - negated = TRUE; - ptr++; - } - else negated = FALSE; - - c = 0; - while ((digitab[ptr[1]] & ctype_digit) != 0) - c = c * 10 + *(++ptr) - '0'; - - if (c < 0) - { - *errorcodeptr = ERR61; - break; - } - - if (c == 0 || (braced && *(++ptr) != '}')) - { - *errorcodeptr = ERR57; - break; - } - - if (negated) - { - if (c > bracount) - { - *errorcodeptr = ERR15; - break; - } - c = bracount - (c - 1); - } - - c = -(ESC_REF + c); - break; - - /* The handling of escape sequences consisting of a string of digits - starting with one that is not zero is not straightforward. By experiment, - the way Perl works seems to be as follows: - - Outside a character class, the digits are read as a decimal number. If the - number is less than 10, or if there are that many previous extracting - left brackets, then it is a back reference. Otherwise, up to three octal - digits are read to form an escaped byte. Thus \123 is likely to be octal - 123 (cf \0123, which is octal 012 followed by the literal 3). If the octal - value is greater than 377, the least significant 8 bits are taken. Inside a - character class, \ followed by a digit is always an octal number. */ - - case '1': case '2': case '3': case '4': case '5': - case '6': case '7': case '8': case '9': - - if (!isclass) - { - oldptr = ptr; - c -= '0'; - while ((digitab[ptr[1]] & ctype_digit) != 0) - c = c * 10 + *(++ptr) - '0'; - if (c < 0) - { - *errorcodeptr = ERR61; - break; - } - if (c < 10 || c <= bracount) - { - c = -(ESC_REF + c); - break; - } - ptr = oldptr; /* Put the pointer back and fall through */ - } - - /* Handle an octal number following \. If the first digit is 8 or 9, Perl - generates a binary zero byte and treats the digit as a following literal. - Thus we have to pull back the pointer by one. */ - - if ((c = *ptr) >= '8') - { - ptr--; - c = 0; - break; - } - - /* \0 always starts an octal number, but we may drop through to here with a - larger first octal digit. The original code used just to take the least - significant 8 bits of octal numbers (I think this is what early Perls used - to do). Nowadays we allow for larger numbers in UTF-8 mode, but no more - than 3 octal digits. */ - - case '0': - c -= '0'; - while(i++ < 2 && ptr[1] >= '0' && ptr[1] <= '7') - c = c * 8 + *(++ptr) - '0'; - if (!utf8 && c > 255) *errorcodeptr = ERR51; - break; - - /* \x is complicated. \x{ddd} is a character number which can be greater - than 0xff in utf8 mode, but only if the ddd are hex digits. If not, { is - treated as a data character. */ - - case 'x': - if (ptr[1] == '{') - { - const uschar *pt = ptr + 2; - int count = 0; - - c = 0; - while ((digitab[*pt] & ctype_xdigit) != 0) - { - register int cc = *pt++; - if (c == 0 && cc == '0') continue; /* Leading zeroes */ - count++; - -#ifndef EBCDIC /* ASCII coding */ - if (cc >= 'a') cc -= 32; /* Convert to upper case */ - c = (c << 4) + cc - ((cc < 'A')? '0' : ('A' - 10)); -#else /* EBCDIC coding */ - if (cc >= 'a' && cc <= 'z') cc += 64; /* Convert to upper case */ - c = (c << 4) + cc - ((cc >= '0')? '0' : ('A' - 10)); -#endif - } - - if (*pt == '}') - { - if (c < 0 || count > (utf8? 8 : 2)) *errorcodeptr = ERR34; - ptr = pt; - break; - } - - /* If the sequence of hex digits does not end with '}', then we don't - recognize this construct; fall through to the normal \x handling. */ - } - - /* Read just a single-byte hex-defined char */ - - c = 0; - while (i++ < 2 && (digitab[ptr[1]] & ctype_xdigit) != 0) - { - int cc; /* Some compilers don't like ++ */ - cc = *(++ptr); /* in initializers */ -#ifndef EBCDIC /* ASCII coding */ - if (cc >= 'a') cc -= 32; /* Convert to upper case */ - c = c * 16 + cc - ((cc < 'A')? '0' : ('A' - 10)); -#else /* EBCDIC coding */ - if (cc <= 'z') cc += 64; /* Convert to upper case */ - c = c * 16 + cc - ((cc >= '0')? '0' : ('A' - 10)); -#endif - } - break; - - /* For \c, a following letter is upper-cased; then the 0x40 bit is flipped. - This coding is ASCII-specific, but then the whole concept of \cx is - ASCII-specific. (However, an EBCDIC equivalent has now been added.) */ - - case 'c': - c = *(++ptr); - if (c == 0) - { - *errorcodeptr = ERR2; - break; - } - -#ifndef EBCDIC /* ASCII coding */ - if (c >= 'a' && c <= 'z') c -= 32; - c ^= 0x40; -#else /* EBCDIC coding */ - if (c >= 'a' && c <= 'z') c += 64; - c ^= 0xC0; -#endif - break; - - /* PCRE_EXTRA enables extensions to Perl in the matter of escapes. Any - other alphameric following \ is an error if PCRE_EXTRA was set; otherwise, - for Perl compatibility, it is a literal. This code looks a bit odd, but - there used to be some cases other than the default, and there may be again - in future, so I haven't "optimized" it. */ - - default: - if ((options & PCRE_EXTRA) != 0) switch(c) - { - default: - *errorcodeptr = ERR3; - break; - } - break; - } - } - -*ptrptr = ptr; -return c; -} - - - -#ifdef SUPPORT_UCP -/************************************************* -* Handle \P and \p * -*************************************************/ - -/* This function is called after \P or \p has been encountered, provided that -PCRE is compiled with support for Unicode properties. On entry, ptrptr is -pointing at the P or p. On exit, it is pointing at the final character of the -escape sequence. - -Argument: - ptrptr points to the pattern position pointer - negptr points to a boolean that is set TRUE for negation else FALSE - dptr points to an int that is set to the detailed property value - errorcodeptr points to the error code variable - -Returns: type value from ucp_type_table, or -1 for an invalid type -*/ - -static int -get_ucp(const uschar **ptrptr, BOOL *negptr, int *dptr, int *errorcodeptr) -{ -int c, i, bot, top; -const uschar *ptr = *ptrptr; -char name[32]; - -c = *(++ptr); -if (c == 0) goto ERROR_RETURN; - -*negptr = FALSE; - -/* \P or \p can be followed by a name in {}, optionally preceded by ^ for -negation. */ - -if (c == '{') - { - if (ptr[1] == '^') - { - *negptr = TRUE; - ptr++; - } - for (i = 0; i < (int)sizeof(name) - 1; i++) - { - c = *(++ptr); - if (c == 0) goto ERROR_RETURN; - if (c == '}') break; - name[i] = c; - } - if (c !='}') goto ERROR_RETURN; - name[i] = 0; - } - -/* Otherwise there is just one following character */ - -else - { - name[0] = c; - name[1] = 0; - } - -*ptrptr = ptr; - -/* Search for a recognized property name using binary chop */ - -bot = 0; -top = _pcre_utt_size; - -while (bot < top) - { - i = (bot + top) >> 1; - c = strcmp(name, _pcre_utt_names + _pcre_utt[i].name_offset); - if (c == 0) - { - *dptr = _pcre_utt[i].value; - return _pcre_utt[i].type; - } - if (c > 0) bot = i + 1; else top = i; - } - -*errorcodeptr = ERR47; -*ptrptr = ptr; -return -1; - -ERROR_RETURN: -*errorcodeptr = ERR46; -*ptrptr = ptr; -return -1; -} -#endif - - - - -/************************************************* -* Check for counted repeat * -*************************************************/ - -/* This function is called when a '{' is encountered in a place where it might -start a quantifier. It looks ahead to see if it really is a quantifier or not. -It is only a quantifier if it is one of the forms {ddd} {ddd,} or {ddd,ddd} -where the ddds are digits. - -Arguments: - p pointer to the first char after '{' - -Returns: TRUE or FALSE -*/ - -static BOOL -is_counted_repeat(const uschar *p) -{ -if ((digitab[*p++] & ctype_digit) == 0) return FALSE; -while ((digitab[*p] & ctype_digit) != 0) p++; -if (*p == '}') return TRUE; - -if (*p++ != ',') return FALSE; -if (*p == '}') return TRUE; - -if ((digitab[*p++] & ctype_digit) == 0) return FALSE; -while ((digitab[*p] & ctype_digit) != 0) p++; - -return (*p == '}'); -} - - - -/************************************************* -* Read repeat counts * -*************************************************/ - -/* Read an item of the form {n,m} and return the values. This is called only -after is_counted_repeat() has confirmed that a repeat-count quantifier exists, -so the syntax is guaranteed to be correct, but we need to check the values. - -Arguments: - p pointer to first char after '{' - minp pointer to int for min - maxp pointer to int for max - returned as -1 if no max - errorcodeptr points to error code variable - -Returns: pointer to '}' on success; - current ptr on error, with errorcodeptr set non-zero -*/ - -static const uschar * -read_repeat_counts(const uschar *p, int *minp, int *maxp, int *errorcodeptr) -{ -int min = 0; -int max = -1; - -/* Read the minimum value and do a paranoid check: a negative value indicates -an integer overflow. */ - -while ((digitab[*p] & ctype_digit) != 0) min = min * 10 + *p++ - '0'; -if (min < 0 || min > 65535) - { - *errorcodeptr = ERR5; - return p; - } - -/* Read the maximum value if there is one, and again do a paranoid on its size. -Also, max must not be less than min. */ - -if (*p == '}') max = min; else - { - if (*(++p) != '}') - { - max = 0; - while((digitab[*p] & ctype_digit) != 0) max = max * 10 + *p++ - '0'; - if (max < 0 || max > 65535) - { - *errorcodeptr = ERR5; - return p; - } - if (max < min) - { - *errorcodeptr = ERR4; - return p; - } - } - } - -/* Fill in the required variables, and pass back the pointer to the terminating -'}'. */ - -*minp = min; -*maxp = max; -return p; -} - - - -/************************************************* -* Find forward referenced subpattern * -*************************************************/ - -/* This function scans along a pattern's text looking for capturing -subpatterns, and counting them. If it finds a named pattern that matches the -name it is given, it returns its number. Alternatively, if the name is NULL, it -returns when it reaches a given numbered subpattern. This is used for forward -references to subpatterns. We know that if (?P< is encountered, the name will -be terminated by '>' because that is checked in the first pass. - -Arguments: - ptr current position in the pattern - count current count of capturing parens so far encountered - name name to seek, or NULL if seeking a numbered subpattern - lorn name length, or subpattern number if name is NULL - xmode TRUE if we are in /x mode - -Returns: the number of the named subpattern, or -1 if not found -*/ - -static int -find_parens(const uschar *ptr, int count, const uschar *name, int lorn, - BOOL xmode) -{ -const uschar *thisname; - -for (; *ptr != 0; ptr++) - { - int term; - - /* Skip over backslashed characters and also entire \Q...\E */ - - if (*ptr == '\\') - { - if (*(++ptr) == 0) return -1; - if (*ptr == 'Q') for (;;) - { - while (*(++ptr) != 0 && *ptr != '\\'); - if (*ptr == 0) return -1; - if (*(++ptr) == 'E') break; - } - continue; - } - - /* Skip over character classes */ - - if (*ptr == '[') - { - while (*(++ptr) != ']') - { - if (*ptr == 0) return -1; - if (*ptr == '\\') - { - if (*(++ptr) == 0) return -1; - if (*ptr == 'Q') for (;;) - { - while (*(++ptr) != 0 && *ptr != '\\'); - if (*ptr == 0) return -1; - if (*(++ptr) == 'E') break; - } - continue; - } - } - continue; - } - - /* Skip comments in /x mode */ - - if (xmode && *ptr == '#') - { - while (*(++ptr) != 0 && *ptr != '\n'); - if (*ptr == 0) return -1; - continue; - } - - /* An opening parens must now be a real metacharacter */ - - if (*ptr != '(') continue; - if (ptr[1] != '?' && ptr[1] != '*') - { - count++; - if (name == NULL && count == lorn) return count; - continue; - } - - ptr += 2; - if (*ptr == 'P') ptr++; /* Allow optional P */ - - /* We have to disambiguate (? */ - - if ((*ptr != '<' || ptr[1] == '!' || ptr[1] == '=') && - *ptr != '\'') - continue; - - count++; - - if (name == NULL && count == lorn) return count; - term = *ptr++; - if (term == '<') term = '>'; - thisname = ptr; - while (*ptr != term) ptr++; - if (name != NULL && lorn == ptr - thisname && - strncmp((const char *)name, (const char *)thisname, lorn) == 0) - return count; - } - -return -1; -} - - - -/************************************************* -* Find first significant op code * -*************************************************/ - -/* This is called by several functions that scan a compiled expression looking -for a fixed first character, or an anchoring op code etc. It skips over things -that do not influence this. For some calls, a change of option is important. -For some calls, it makes sense to skip negative forward and all backward -assertions, and also the \b assertion; for others it does not. - -Arguments: - code pointer to the start of the group - options pointer to external options - optbit the option bit whose changing is significant, or - zero if none are - skipassert TRUE if certain assertions are to be skipped - -Returns: pointer to the first significant opcode -*/ - -static const uschar* -first_significant_code(const uschar *code, int *options, int optbit, - BOOL skipassert) -{ -for (;;) - { - switch ((int)*code) - { - case OP_OPT: - if (optbit > 0 && ((int)code[1] & optbit) != (*options & optbit)) - *options = (int)code[1]; - code += 2; - break; - - case OP_ASSERT_NOT: - case OP_ASSERTBACK: - case OP_ASSERTBACK_NOT: - if (!skipassert) return code; - do code += GET(code, 1); while (*code == OP_ALT); - code += _pcre_OP_lengths[*code]; - break; - - case OP_WORD_BOUNDARY: - case OP_NOT_WORD_BOUNDARY: - if (!skipassert) return code; - /* Fall through */ - - case OP_CALLOUT: - case OP_CREF: - case OP_RREF: - case OP_DEF: - code += _pcre_OP_lengths[*code]; - break; - - default: - return code; - } - } -/* Control never reaches here */ -} - - - - -/************************************************* -* Find the fixed length of a pattern * -*************************************************/ - -/* Scan a pattern and compute the fixed length of subject that will match it, -if the length is fixed. This is needed for dealing with backward assertions. -In UTF8 mode, the result is in characters rather than bytes. - -Arguments: - code points to the start of the pattern (the bracket) - options the compiling options - -Returns: the fixed length, or -1 if there is no fixed length, - or -2 if \C was encountered -*/ - -static int -find_fixedlength(uschar *code, int options) -{ -int length = -1; - -register int branchlength = 0; -register uschar *cc = code + 1 + LINK_SIZE; - -/* Scan along the opcodes for this branch. If we get to the end of the -branch, check the length against that of the other branches. */ - -for (;;) - { - int d; - register int op = *cc; - switch (op) - { - case OP_CBRA: - case OP_BRA: - case OP_ONCE: - case OP_COND: - d = find_fixedlength(cc + ((op == OP_CBRA)? 2:0), options); - if (d < 0) return d; - branchlength += d; - do cc += GET(cc, 1); while (*cc == OP_ALT); - cc += 1 + LINK_SIZE; - break; - - /* Reached end of a branch; if it's a ket it is the end of a nested - call. If it's ALT it is an alternation in a nested call. If it is - END it's the end of the outer call. All can be handled by the same code. */ - - case OP_ALT: - case OP_KET: - case OP_KETRMAX: - case OP_KETRMIN: - case OP_END: - if (length < 0) length = branchlength; - else if (length != branchlength) return -1; - if (*cc != OP_ALT) return length; - cc += 1 + LINK_SIZE; - branchlength = 0; - break; - - /* Skip over assertive subpatterns */ - - case OP_ASSERT: - case OP_ASSERT_NOT: - case OP_ASSERTBACK: - case OP_ASSERTBACK_NOT: - do cc += GET(cc, 1); while (*cc == OP_ALT); - /* Fall through */ - - /* Skip over things that don't match chars */ - - case OP_REVERSE: - case OP_CREF: - case OP_RREF: - case OP_DEF: - case OP_OPT: - case OP_CALLOUT: - case OP_SOD: - case OP_SOM: - case OP_EOD: - case OP_EODN: - case OP_CIRC: - case OP_DOLL: - case OP_NOT_WORD_BOUNDARY: - case OP_WORD_BOUNDARY: - cc += _pcre_OP_lengths[*cc]; - break; - - /* Handle literal characters */ - - case OP_CHAR: - case OP_CHARNC: - case OP_NOT: - branchlength++; - cc += 2; -#ifdef SUPPORT_UTF8 - if ((options & PCRE_UTF8) != 0) - { - while ((*cc & 0xc0) == 0x80) cc++; - } -#endif - break; - - /* Handle exact repetitions. The count is already in characters, but we - need to skip over a multibyte character in UTF8 mode. */ - - case OP_EXACT: - branchlength += GET2(cc,1); - cc += 4; -#ifdef SUPPORT_UTF8 - if ((options & PCRE_UTF8) != 0) - { - while((*cc & 0x80) == 0x80) cc++; - } -#endif - break; - - case OP_TYPEEXACT: - branchlength += GET2(cc,1); - if (cc[3] == OP_PROP || cc[3] == OP_NOTPROP) cc += 2; - cc += 4; - break; - - /* Handle single-char matchers */ - - case OP_PROP: - case OP_NOTPROP: - cc += 2; - /* Fall through */ - - case OP_NOT_DIGIT: - case OP_DIGIT: - case OP_NOT_WHITESPACE: - case OP_WHITESPACE: - case OP_NOT_WORDCHAR: - case OP_WORDCHAR: - case OP_ANY: - branchlength++; - cc++; - break; - - /* The single-byte matcher isn't allowed */ - - case OP_ANYBYTE: - return -2; - - /* Check a class for variable quantification */ - -#ifdef SUPPORT_UTF8 - case OP_XCLASS: - cc += GET(cc, 1) - 33; - /* Fall through */ -#endif - - case OP_CLASS: - case OP_NCLASS: - cc += 33; - - switch (*cc) - { - case OP_CRSTAR: - case OP_CRMINSTAR: - case OP_CRQUERY: - case OP_CRMINQUERY: - return -1; - - case OP_CRRANGE: - case OP_CRMINRANGE: - if (GET2(cc,1) != GET2(cc,3)) return -1; - branchlength += GET2(cc,1); - cc += 5; - break; - - default: - branchlength++; - } - break; - - /* Anything else is variable length */ - - default: - return -1; - } - } -/* Control never gets here */ -} - - - - -/************************************************* -* Scan compiled regex for numbered bracket * -*************************************************/ - -/* This little function scans through a compiled pattern until it finds a -capturing bracket with the given number. - -Arguments: - code points to start of expression - utf8 TRUE in UTF-8 mode - number the required bracket number - -Returns: pointer to the opcode for the bracket, or NULL if not found -*/ - -static const uschar * -find_bracket(const uschar *code, BOOL utf8, int number) -{ -for (;;) - { - register int c = *code; - if (c == OP_END) return NULL; - - /* XCLASS is used for classes that cannot be represented just by a bit - map. This includes negated single high-valued characters. The length in - the table is zero; the actual length is stored in the compiled code. */ - - if (c == OP_XCLASS) code += GET(code, 1); - - /* Handle capturing bracket */ - - else if (c == OP_CBRA) - { - int n = GET2(code, 1+LINK_SIZE); - if (n == number) return (uschar *)code; - code += _pcre_OP_lengths[c]; - } - - /* Otherwise, we can get the item's length from the table, except that for - repeated character types, we have to test for \p and \P, which have an extra - two bytes of parameters. */ - - else - { - switch(c) - { - case OP_TYPESTAR: - case OP_TYPEMINSTAR: - case OP_TYPEPLUS: - case OP_TYPEMINPLUS: - case OP_TYPEQUERY: - case OP_TYPEMINQUERY: - case OP_TYPEPOSSTAR: - case OP_TYPEPOSPLUS: - case OP_TYPEPOSQUERY: - if (code[1] == OP_PROP || code[1] == OP_NOTPROP) code += 2; - break; - - case OP_TYPEUPTO: - case OP_TYPEMINUPTO: - case OP_TYPEEXACT: - case OP_TYPEPOSUPTO: - if (code[3] == OP_PROP || code[3] == OP_NOTPROP) code += 2; - break; - } - - /* Add in the fixed length from the table */ - - code += _pcre_OP_lengths[c]; - - /* In UTF-8 mode, opcodes that are followed by a character may be followed by - a multi-byte character. The length in the table is a minimum, so we have to - arrange to skip the extra bytes. */ - -#ifdef SUPPORT_UTF8 - if (utf8) switch(c) - { - case OP_CHAR: - case OP_CHARNC: - case OP_EXACT: - case OP_UPTO: - case OP_MINUPTO: - case OP_POSUPTO: - case OP_STAR: - case OP_MINSTAR: - case OP_POSSTAR: - case OP_PLUS: - case OP_MINPLUS: - case OP_POSPLUS: - case OP_QUERY: - case OP_MINQUERY: - case OP_POSQUERY: - if (code[-1] >= 0xc0) code += _pcre_utf8_table4[code[-1] & 0x3f]; - break; - } -#endif - } - } -} - - - -/************************************************* -* Scan compiled regex for recursion reference * -*************************************************/ - -/* This little function scans through a compiled pattern until it finds an -instance of OP_RECURSE. - -Arguments: - code points to start of expression - utf8 TRUE in UTF-8 mode - -Returns: pointer to the opcode for OP_RECURSE, or NULL if not found -*/ - -static const uschar * -find_recurse(const uschar *code, BOOL utf8) -{ -for (;;) - { - register int c = *code; - if (c == OP_END) return NULL; - if (c == OP_RECURSE) return code; - - /* XCLASS is used for classes that cannot be represented just by a bit - map. This includes negated single high-valued characters. The length in - the table is zero; the actual length is stored in the compiled code. */ - - if (c == OP_XCLASS) code += GET(code, 1); - - /* Otherwise, we can get the item's length from the table, except that for - repeated character types, we have to test for \p and \P, which have an extra - two bytes of parameters. */ - - else - { - switch(c) - { - case OP_TYPESTAR: - case OP_TYPEMINSTAR: - case OP_TYPEPLUS: - case OP_TYPEMINPLUS: - case OP_TYPEQUERY: - case OP_TYPEMINQUERY: - case OP_TYPEPOSSTAR: - case OP_TYPEPOSPLUS: - case OP_TYPEPOSQUERY: - if (code[1] == OP_PROP || code[1] == OP_NOTPROP) code += 2; - break; - - case OP_TYPEPOSUPTO: - case OP_TYPEUPTO: - case OP_TYPEMINUPTO: - case OP_TYPEEXACT: - if (code[3] == OP_PROP || code[3] == OP_NOTPROP) code += 2; - break; - } - - /* Add in the fixed length from the table */ - - code += _pcre_OP_lengths[c]; - - /* In UTF-8 mode, opcodes that are followed by a character may be followed - by a multi-byte character. The length in the table is a minimum, so we have - to arrange to skip the extra bytes. */ - -#ifdef SUPPORT_UTF8 - if (utf8) switch(c) - { - case OP_CHAR: - case OP_CHARNC: - case OP_EXACT: - case OP_UPTO: - case OP_MINUPTO: - case OP_POSUPTO: - case OP_STAR: - case OP_MINSTAR: - case OP_POSSTAR: - case OP_PLUS: - case OP_MINPLUS: - case OP_POSPLUS: - case OP_QUERY: - case OP_MINQUERY: - case OP_POSQUERY: - if (code[-1] >= 0xc0) code += _pcre_utf8_table4[code[-1] & 0x3f]; - break; - } -#endif - } - } -} - - - -/************************************************* -* Scan compiled branch for non-emptiness * -*************************************************/ - -/* This function scans through a branch of a compiled pattern to see whether it -can match the empty string or not. It is called from could_be_empty() -below and from compile_branch() when checking for an unlimited repeat of a -group that can match nothing. Note that first_significant_code() skips over -assertions. If we hit an unclosed bracket, we return "empty" - this means we've -struck an inner bracket whose current branch will already have been scanned. - -Arguments: - code points to start of search - endcode points to where to stop - utf8 TRUE if in UTF8 mode - -Returns: TRUE if what is matched could be empty -*/ - -static BOOL -could_be_empty_branch(const uschar *code, const uschar *endcode, BOOL utf8) -{ -register int c; -for (code = first_significant_code(code + _pcre_OP_lengths[*code], NULL, 0, TRUE); - code < endcode; - code = first_significant_code(code + _pcre_OP_lengths[c], NULL, 0, TRUE)) - { - const uschar *ccode; - - c = *code; - - /* Groups with zero repeats can of course be empty; skip them. */ - - if (c == OP_BRAZERO || c == OP_BRAMINZERO) - { - code += _pcre_OP_lengths[c]; - do code += GET(code, 1); while (*code == OP_ALT); - c = *code; - continue; - } - - /* For other groups, scan the branches. */ - - if (c == OP_BRA || c == OP_CBRA || c == OP_ONCE || c == OP_COND) - { - BOOL empty_branch; - if (GET(code, 1) == 0) return TRUE; /* Hit unclosed bracket */ - - /* Scan a closed bracket */ - - empty_branch = FALSE; - do - { - if (!empty_branch && could_be_empty_branch(code, endcode, utf8)) - empty_branch = TRUE; - code += GET(code, 1); - } - while (*code == OP_ALT); - if (!empty_branch) return FALSE; /* All branches are non-empty */ - c = *code; - continue; - } - - /* Handle the other opcodes */ - - switch (c) - { - /* Check for quantifiers after a class. XCLASS is used for classes that - cannot be represented just by a bit map. This includes negated single - high-valued characters. The length in _pcre_OP_lengths[] is zero; the - actual length is stored in the compiled code, so we must update "code" - here. */ - -#ifdef SUPPORT_UTF8 - case OP_XCLASS: - ccode = code += GET(code, 1); - goto CHECK_CLASS_REPEAT; -#endif - - case OP_CLASS: - case OP_NCLASS: - ccode = code + 33; - -#ifdef SUPPORT_UTF8 - CHECK_CLASS_REPEAT: -#endif - - switch (*ccode) - { - case OP_CRSTAR: /* These could be empty; continue */ - case OP_CRMINSTAR: - case OP_CRQUERY: - case OP_CRMINQUERY: - break; - - default: /* Non-repeat => class must match */ - case OP_CRPLUS: /* These repeats aren't empty */ - case OP_CRMINPLUS: - return FALSE; - - case OP_CRRANGE: - case OP_CRMINRANGE: - if (GET2(ccode, 1) > 0) return FALSE; /* Minimum > 0 */ - break; - } - break; - - /* Opcodes that must match a character */ - - case OP_PROP: - case OP_NOTPROP: - case OP_EXTUNI: - case OP_NOT_DIGIT: - case OP_DIGIT: - case OP_NOT_WHITESPACE: - case OP_WHITESPACE: - case OP_NOT_WORDCHAR: - case OP_WORDCHAR: - case OP_ANY: - case OP_ANYBYTE: - case OP_CHAR: - case OP_CHARNC: - case OP_NOT: - case OP_PLUS: - case OP_MINPLUS: - case OP_POSPLUS: - case OP_EXACT: - case OP_NOTPLUS: - case OP_NOTMINPLUS: - case OP_NOTPOSPLUS: - case OP_NOTEXACT: - case OP_TYPEPLUS: - case OP_TYPEMINPLUS: - case OP_TYPEPOSPLUS: - case OP_TYPEEXACT: - return FALSE; - - /* These are going to continue, as they may be empty, but we have to - fudge the length for the \p and \P cases. */ - - case OP_TYPESTAR: - case OP_TYPEMINSTAR: - case OP_TYPEPOSSTAR: - case OP_TYPEQUERY: - case OP_TYPEMINQUERY: - case OP_TYPEPOSQUERY: - if (code[1] == OP_PROP || code[1] == OP_NOTPROP) code += 2; - break; - - /* Same for these */ - - case OP_TYPEUPTO: - case OP_TYPEMINUPTO: - case OP_TYPEPOSUPTO: - if (code[3] == OP_PROP || code[3] == OP_NOTPROP) code += 2; - break; - - /* End of branch */ - - case OP_KET: - case OP_KETRMAX: - case OP_KETRMIN: - case OP_ALT: - return TRUE; - - /* In UTF-8 mode, STAR, MINSTAR, POSSTAR, QUERY, MINQUERY, POSQUERY, UPTO, - MINUPTO, and POSUPTO may be followed by a multibyte character */ - -#ifdef SUPPORT_UTF8 - case OP_STAR: - case OP_MINSTAR: - case OP_POSSTAR: - case OP_QUERY: - case OP_MINQUERY: - case OP_POSQUERY: - case OP_UPTO: - case OP_MINUPTO: - case OP_POSUPTO: - if (utf8) while ((code[2] & 0xc0) == 0x80) code++; - break; -#endif - } - } - -return TRUE; -} - - - -/************************************************* -* Scan compiled regex for non-emptiness * -*************************************************/ - -/* This function is called to check for left recursive calls. We want to check -the current branch of the current pattern to see if it could match the empty -string. If it could, we must look outwards for branches at other levels, -stopping when we pass beyond the bracket which is the subject of the recursion. - -Arguments: - code points to start of the recursion - endcode points to where to stop (current RECURSE item) - bcptr points to the chain of current (unclosed) branch starts - utf8 TRUE if in UTF-8 mode - -Returns: TRUE if what is matched could be empty -*/ - -static BOOL -could_be_empty(const uschar *code, const uschar *endcode, branch_chain *bcptr, - BOOL utf8) -{ -while (bcptr != NULL && bcptr->current >= code) - { - if (!could_be_empty_branch(bcptr->current, endcode, utf8)) return FALSE; - bcptr = bcptr->outer; - } -return TRUE; -} - - - -/************************************************* -* Check for POSIX class syntax * -*************************************************/ - -/* This function is called when the sequence "[:" or "[." or "[=" is -encountered in a character class. It checks whether this is followed by an -optional ^ and then a sequence of letters, terminated by a matching ":]" or -".]" or "=]". - -Argument: - ptr pointer to the initial [ - endptr where to return the end pointer - cd pointer to compile data - -Returns: TRUE or FALSE -*/ - -static BOOL -check_posix_syntax(const uschar *ptr, const uschar **endptr, compile_data *cd) -{ -int terminator; /* Don't combine these lines; the Solaris cc */ -terminator = *(++ptr); /* compiler warns about "non-constant" initializer. */ -if (*(++ptr) == '^') ptr++; -while ((cd->ctypes[*ptr] & ctype_letter) != 0) ptr++; -if (*ptr == terminator && ptr[1] == ']') - { - *endptr = ptr; - return TRUE; - } -return FALSE; -} - - - - -/************************************************* -* Check POSIX class name * -*************************************************/ - -/* This function is called to check the name given in a POSIX-style class entry -such as [:alnum:]. - -Arguments: - ptr points to the first letter - len the length of the name - -Returns: a value representing the name, or -1 if unknown -*/ - -static int -check_posix_name(const uschar *ptr, int len) -{ -const char *pn = posix_names; -register int yield = 0; -while (posix_name_lengths[yield] != 0) - { - if (len == posix_name_lengths[yield] && - strncmp((const char *)ptr, pn, len) == 0) return yield; - pn += posix_name_lengths[yield] + 1; - yield++; - } -return -1; -} - - -/************************************************* -* Adjust OP_RECURSE items in repeated group * -*************************************************/ - -/* OP_RECURSE items contain an offset from the start of the regex to the group -that is referenced. This means that groups can be replicated for fixed -repetition simply by copying (because the recursion is allowed to refer to -earlier groups that are outside the current group). However, when a group is -optional (i.e. the minimum quantifier is zero), OP_BRAZERO is inserted before -it, after it has been compiled. This means that any OP_RECURSE items within it -that refer to the group itself or any contained groups have to have their -offsets adjusted. That one of the jobs of this function. Before it is called, -the partially compiled regex must be temporarily terminated with OP_END. - -This function has been extended with the possibility of forward references for -recursions and subroutine calls. It must also check the list of such references -for the group we are dealing with. If it finds that one of the recursions in -the current group is on this list, it adjusts the offset in the list, not the -value in the reference (which is a group number). - -Arguments: - group points to the start of the group - adjust the amount by which the group is to be moved - utf8 TRUE in UTF-8 mode - cd contains pointers to tables etc. - save_hwm the hwm forward reference pointer at the start of the group - -Returns: nothing -*/ - -static void -adjust_recurse(uschar *group, int adjust, BOOL utf8, compile_data *cd, - uschar *save_hwm) -{ -uschar *ptr = group; - -while ((ptr = (uschar *)find_recurse(ptr, utf8)) != NULL) - { - int offset; - uschar *hc; - - /* See if this recursion is on the forward reference list. If so, adjust the - reference. */ - - for (hc = save_hwm; hc < cd->hwm; hc += LINK_SIZE) - { - offset = GET(hc, 0); - if (cd->start_code + offset == ptr + 1) - { - PUT(hc, 0, offset + adjust); - break; - } - } - - /* Otherwise, adjust the recursion offset if it's after the start of this - group. */ - - if (hc >= cd->hwm) - { - offset = GET(ptr, 1); - if (cd->start_code + offset >= group) PUT(ptr, 1, offset + adjust); - } - - ptr += 1 + LINK_SIZE; - } -} - - - -/************************************************* -* Insert an automatic callout point * -*************************************************/ - -/* This function is called when the PCRE_AUTO_CALLOUT option is set, to insert -callout points before each pattern item. - -Arguments: - code current code pointer - ptr current pattern pointer - cd pointers to tables etc - -Returns: new code pointer -*/ - -static uschar * -auto_callout(uschar *code, const uschar *ptr, compile_data *cd) -{ -*code++ = OP_CALLOUT; -*code++ = 255; -PUT(code, 0, ptr - cd->start_pattern); /* Pattern offset */ -PUT(code, LINK_SIZE, 0); /* Default length */ -return code + 2*LINK_SIZE; -} - - - -/************************************************* -* Complete a callout item * -*************************************************/ - -/* A callout item contains the length of the next item in the pattern, which -we can't fill in till after we have reached the relevant point. This is used -for both automatic and manual callouts. - -Arguments: - previous_callout points to previous callout item - ptr current pattern pointer - cd pointers to tables etc - -Returns: nothing -*/ - -static void -complete_callout(uschar *previous_callout, const uschar *ptr, compile_data *cd) -{ -int length = ptr - cd->start_pattern - GET(previous_callout, 2); -PUT(previous_callout, 2 + LINK_SIZE, length); -} - - - -#ifdef SUPPORT_UCP -/************************************************* -* Get othercase range * -*************************************************/ - -/* This function is passed the start and end of a class range, in UTF-8 mode -with UCP support. It searches up the characters, looking for internal ranges of -characters in the "other" case. Each call returns the next one, updating the -start address. - -Arguments: - cptr points to starting character value; updated - d end value - ocptr where to put start of othercase range - odptr where to put end of othercase range - -Yield: TRUE when range returned; FALSE when no more -*/ - -static BOOL -get_othercase_range(unsigned int *cptr, unsigned int d, unsigned int *ocptr, - unsigned int *odptr) -{ -unsigned int c, othercase, next; - -for (c = *cptr; c <= d; c++) - { if ((othercase = _pcre_ucp_othercase(c)) != NOTACHAR) break; } - -if (c > d) return FALSE; - -*ocptr = othercase; -next = othercase + 1; - -for (++c; c <= d; c++) - { - if (_pcre_ucp_othercase(c) != next) break; - next++; - } - -*odptr = next - 1; -*cptr = c; - -return TRUE; -} -#endif /* SUPPORT_UCP */ - - - -/************************************************* -* Check if auto-possessifying is possible * -*************************************************/ - -/* This function is called for unlimited repeats of certain items, to see -whether the next thing could possibly match the repeated item. If not, it makes -sense to automatically possessify the repeated item. - -Arguments: - op_code the repeated op code - this data for this item, depends on the opcode - utf8 TRUE in UTF-8 mode - utf8_char used for utf8 character bytes, NULL if not relevant - ptr next character in pattern - options options bits - cd contains pointers to tables etc. - -Returns: TRUE if possessifying is wanted -*/ - -static BOOL -check_auto_possessive(int op_code, int item, BOOL utf8, uschar *utf8_char, - const uschar *ptr, int options, compile_data *cd) -{ -int next; - -/* Skip whitespace and comments in extended mode */ - -if ((options & PCRE_EXTENDED) != 0) - { - for (;;) - { - while ((cd->ctypes[*ptr] & ctype_space) != 0) ptr++; - if (*ptr == '#') - { - while (*(++ptr) != 0) - if (IS_NEWLINE(ptr)) { ptr += cd->nllen; break; } - } - else break; - } - } - -/* If the next item is one that we can handle, get its value. A non-negative -value is a character, a negative value is an escape value. */ - -if (*ptr == '\\') - { - int temperrorcode = 0; - next = check_escape(&ptr, &temperrorcode, cd->bracount, options, FALSE); - if (temperrorcode != 0) return FALSE; - ptr++; /* Point after the escape sequence */ - } - -else if ((cd->ctypes[*ptr] & ctype_meta) == 0) - { -#ifdef SUPPORT_UTF8 - if (utf8) { GETCHARINC(next, ptr); } else -#endif - next = *ptr++; - } - -else return FALSE; - -/* Skip whitespace and comments in extended mode */ - -if ((options & PCRE_EXTENDED) != 0) - { - for (;;) - { - while ((cd->ctypes[*ptr] & ctype_space) != 0) ptr++; - if (*ptr == '#') - { - while (*(++ptr) != 0) - if (IS_NEWLINE(ptr)) { ptr += cd->nllen; break; } - } - else break; - } - } - -/* If the next thing is itself optional, we have to give up. */ - -if (*ptr == '*' || *ptr == '?' || strncmp((char *)ptr, "{0,", 3) == 0) - return FALSE; - -/* Now compare the next item with the previous opcode. If the previous is a -positive single character match, "item" either contains the character or, if -"item" is greater than 127 in utf8 mode, the character's bytes are in -utf8_char. */ - - -/* Handle cases when the next item is a character. */ - -if (next >= 0) switch(op_code) - { - case OP_CHAR: -#ifdef SUPPORT_UTF8 - if (utf8 && item > 127) { GETCHAR(item, utf8_char); } -#endif - return item != next; - - /* For CHARNC (caseless character) we must check the other case. If we have - Unicode property support, we can use it to test the other case of - high-valued characters. */ - - case OP_CHARNC: -#ifdef SUPPORT_UTF8 - if (utf8 && item > 127) { GETCHAR(item, utf8_char); } -#endif - if (item == next) return FALSE; -#ifdef SUPPORT_UTF8 - if (utf8) - { - unsigned int othercase; - if (next < 128) othercase = cd->fcc[next]; else -#ifdef SUPPORT_UCP - othercase = _pcre_ucp_othercase((unsigned int)next); -#else - othercase = NOTACHAR; -#endif - return (unsigned int)item != othercase; - } - else -#endif /* SUPPORT_UTF8 */ - return (item != cd->fcc[next]); /* Non-UTF-8 mode */ - - /* For OP_NOT, "item" must be a single-byte character. */ - - case OP_NOT: - if (next < 0) return FALSE; /* Not a character */ - if (item == next) return TRUE; - if ((options & PCRE_CASELESS) == 0) return FALSE; -#ifdef SUPPORT_UTF8 - if (utf8) - { - unsigned int othercase; - if (next < 128) othercase = cd->fcc[next]; else -#ifdef SUPPORT_UCP - othercase = _pcre_ucp_othercase(next); -#else - othercase = NOTACHAR; -#endif - return (unsigned int)item == othercase; - } - else -#endif /* SUPPORT_UTF8 */ - return (item == cd->fcc[next]); /* Non-UTF-8 mode */ - - case OP_DIGIT: - return next > 127 || (cd->ctypes[next] & ctype_digit) == 0; - - case OP_NOT_DIGIT: - return next <= 127 && (cd->ctypes[next] & ctype_digit) != 0; - - case OP_WHITESPACE: - return next > 127 || (cd->ctypes[next] & ctype_space) == 0; - - case OP_NOT_WHITESPACE: - return next <= 127 && (cd->ctypes[next] & ctype_space) != 0; - - case OP_WORDCHAR: - return next > 127 || (cd->ctypes[next] & ctype_word) == 0; - - case OP_NOT_WORDCHAR: - return next <= 127 && (cd->ctypes[next] & ctype_word) != 0; - - case OP_HSPACE: - case OP_NOT_HSPACE: - switch(next) - { - case 0x09: - case 0x20: - case 0xa0: - case 0x1680: - case 0x180e: - case 0x2000: - case 0x2001: - case 0x2002: - case 0x2003: - case 0x2004: - case 0x2005: - case 0x2006: - case 0x2007: - case 0x2008: - case 0x2009: - case 0x200A: - case 0x202f: - case 0x205f: - case 0x3000: - return op_code != OP_HSPACE; - default: - return op_code == OP_HSPACE; - } - - case OP_VSPACE: - case OP_NOT_VSPACE: - switch(next) - { - case 0x0a: - case 0x0b: - case 0x0c: - case 0x0d: - case 0x85: - case 0x2028: - case 0x2029: - return op_code != OP_VSPACE; - default: - return op_code == OP_VSPACE; - } - - default: - return FALSE; - } - - -/* Handle the case when the next item is \d, \s, etc. */ - -switch(op_code) - { - case OP_CHAR: - case OP_CHARNC: -#ifdef SUPPORT_UTF8 - if (utf8 && item > 127) { GETCHAR(item, utf8_char); } -#endif - switch(-next) - { - case ESC_d: - return item > 127 || (cd->ctypes[item] & ctype_digit) == 0; - - case ESC_D: - return item <= 127 && (cd->ctypes[item] & ctype_digit) != 0; - - case ESC_s: - return item > 127 || (cd->ctypes[item] & ctype_space) == 0; - - case ESC_S: - return item <= 127 && (cd->ctypes[item] & ctype_space) != 0; - - case ESC_w: - return item > 127 || (cd->ctypes[item] & ctype_word) == 0; - - case ESC_W: - return item <= 127 && (cd->ctypes[item] & ctype_word) != 0; - - case ESC_h: - case ESC_H: - switch(item) - { - case 0x09: - case 0x20: - case 0xa0: - case 0x1680: - case 0x180e: - case 0x2000: - case 0x2001: - case 0x2002: - case 0x2003: - case 0x2004: - case 0x2005: - case 0x2006: - case 0x2007: - case 0x2008: - case 0x2009: - case 0x200A: - case 0x202f: - case 0x205f: - case 0x3000: - return -next != ESC_h; - default: - return -next == ESC_h; - } - - case ESC_v: - case ESC_V: - switch(item) - { - case 0x0a: - case 0x0b: - case 0x0c: - case 0x0d: - case 0x85: - case 0x2028: - case 0x2029: - return -next != ESC_v; - default: - return -next == ESC_v; - } - - default: - return FALSE; - } - - case OP_DIGIT: - return next == -ESC_D || next == -ESC_s || next == -ESC_W || - next == -ESC_h || next == -ESC_v; - - case OP_NOT_DIGIT: - return next == -ESC_d; - - case OP_WHITESPACE: - return next == -ESC_S || next == -ESC_d || next == -ESC_w; - - case OP_NOT_WHITESPACE: - return next == -ESC_s || next == -ESC_h || next == -ESC_v; - - case OP_HSPACE: - return next == -ESC_S || next == -ESC_H || next == -ESC_d || next == -ESC_w; - - case OP_NOT_HSPACE: - return next == -ESC_h; - - /* Can't have \S in here because VT matches \S (Perl anomaly) */ - case OP_VSPACE: - return next == -ESC_V || next == -ESC_d || next == -ESC_w; - - case OP_NOT_VSPACE: - return next == -ESC_v; - - case OP_WORDCHAR: - return next == -ESC_W || next == -ESC_s || next == -ESC_h || next == -ESC_v; - - case OP_NOT_WORDCHAR: - return next == -ESC_w || next == -ESC_d; - - default: - return FALSE; - } - -/* Control does not reach here */ -} - - - -/************************************************* -* Compile one branch * -*************************************************/ - -/* Scan the pattern, compiling it into the a vector. If the options are -changed during the branch, the pointer is used to change the external options -bits. This function is used during the pre-compile phase when we are trying -to find out the amount of memory needed, as well as during the real compile -phase. The value of lengthptr distinguishes the two phases. - -Arguments: - optionsptr pointer to the option bits - codeptr points to the pointer to the current code point - ptrptr points to the current pattern pointer - errorcodeptr points to error code variable - firstbyteptr set to initial literal character, or < 0 (REQ_UNSET, REQ_NONE) - reqbyteptr set to the last literal character required, else < 0 - bcptr points to current branch chain - cd contains pointers to tables etc. - lengthptr NULL during the real compile phase - points to length accumulator during pre-compile phase - -Returns: TRUE on success - FALSE, with *errorcodeptr set non-zero on error -*/ - -static BOOL -compile_branch(int *optionsptr, uschar **codeptr, const uschar **ptrptr, - int *errorcodeptr, int *firstbyteptr, int *reqbyteptr, branch_chain *bcptr, - compile_data *cd, int *lengthptr) -{ -int repeat_type, op_type; -int repeat_min = 0, repeat_max = 0; /* To please picky compilers */ -int bravalue = 0; -int greedy_default, greedy_non_default; -int firstbyte, reqbyte; -int zeroreqbyte, zerofirstbyte; -int req_caseopt, reqvary, tempreqvary; -int options = *optionsptr; -int after_manual_callout = 0; -int length_prevgroup = 0; -register int c; -register uschar *code = *codeptr; -uschar *last_code = code; -uschar *orig_code = code; -uschar *tempcode; -BOOL inescq = FALSE; -BOOL groupsetfirstbyte = FALSE; -const uschar *ptr = *ptrptr; -const uschar *tempptr; -uschar *previous = NULL; -uschar *previous_callout = NULL; -uschar *save_hwm = NULL; -uschar classbits[32]; - -#ifdef SUPPORT_UTF8 -BOOL class_utf8; -BOOL utf8 = (options & PCRE_UTF8) != 0; -uschar *class_utf8data; -uschar utf8_char[6]; -#else -BOOL utf8 = FALSE; -uschar *utf8_char = NULL; -#endif - -#ifdef DEBUG -if (lengthptr != NULL) DPRINTF((">> start branch\n")); -#endif - -/* Set up the default and non-default settings for greediness */ - -greedy_default = ((options & PCRE_UNGREEDY) != 0); -greedy_non_default = greedy_default ^ 1; - -/* Initialize no first byte, no required byte. REQ_UNSET means "no char -matching encountered yet". It gets changed to REQ_NONE if we hit something that -matches a non-fixed char first char; reqbyte just remains unset if we never -find one. - -When we hit a repeat whose minimum is zero, we may have to adjust these values -to take the zero repeat into account. This is implemented by setting them to -zerofirstbyte and zeroreqbyte when such a repeat is encountered. The individual -item types that can be repeated set these backoff variables appropriately. */ - -firstbyte = reqbyte = zerofirstbyte = zeroreqbyte = REQ_UNSET; - -/* The variable req_caseopt contains either the REQ_CASELESS value or zero, -according to the current setting of the caseless flag. REQ_CASELESS is a bit -value > 255. It is added into the firstbyte or reqbyte variables to record the -case status of the value. This is used only for ASCII characters. */ - -req_caseopt = ((options & PCRE_CASELESS) != 0)? REQ_CASELESS : 0; - -/* Switch on next character until the end of the branch */ - -for (;; ptr++) - { - BOOL negate_class; - BOOL possessive_quantifier; - BOOL is_quantifier; - BOOL is_recurse; - BOOL reset_bracount; - int class_charcount; - int class_lastchar; - int newoptions; - int recno; - int refsign; - int skipbytes; - int subreqbyte; - int subfirstbyte; - int terminator; - int mclength; - uschar mcbuffer[8]; - - /* Get next byte in the pattern */ - - c = *ptr; - - /* If we are in the pre-compile phase, accumulate the length used for the - previous cycle of this loop. */ - - if (lengthptr != NULL) - { -#ifdef DEBUG - if (code > cd->hwm) cd->hwm = code; /* High water info */ -#endif - if (code > cd->start_workspace + COMPILE_WORK_SIZE) /* Check for overrun */ - { - *errorcodeptr = ERR52; - goto FAILED; - } - - /* There is at least one situation where code goes backwards: this is the - case of a zero quantifier after a class (e.g. [ab]{0}). At compile time, - the class is simply eliminated. However, it is created first, so we have to - allow memory for it. Therefore, don't ever reduce the length at this point. - */ - - if (code < last_code) code = last_code; - - /* Paranoid check for integer overflow */ - - if (OFLOW_MAX - *lengthptr < code - last_code) - { - *errorcodeptr = ERR20; - goto FAILED; - } - - *lengthptr += code - last_code; - DPRINTF(("length=%d added %d c=%c\n", *lengthptr, code - last_code, c)); - - /* If "previous" is set and it is not at the start of the work space, move - it back to there, in order to avoid filling up the work space. Otherwise, - if "previous" is NULL, reset the current code pointer to the start. */ - - if (previous != NULL) - { - if (previous > orig_code) - { - memmove(orig_code, previous, code - previous); - code -= previous - orig_code; - previous = orig_code; - } - } - else code = orig_code; - - /* Remember where this code item starts so we can pick up the length - next time round. */ - - last_code = code; - } - - /* In the real compile phase, just check the workspace used by the forward - reference list. */ - - else if (cd->hwm > cd->start_workspace + COMPILE_WORK_SIZE) - { - *errorcodeptr = ERR52; - goto FAILED; - } - - /* If in \Q...\E, check for the end; if not, we have a literal */ - - if (inescq && c != 0) - { - if (c == '\\' && ptr[1] == 'E') - { - inescq = FALSE; - ptr++; - continue; - } - else - { - if (previous_callout != NULL) - { - if (lengthptr == NULL) /* Don't attempt in pre-compile phase */ - complete_callout(previous_callout, ptr, cd); - previous_callout = NULL; - } - if ((options & PCRE_AUTO_CALLOUT) != 0) - { - previous_callout = code; - code = auto_callout(code, ptr, cd); - } - goto NORMAL_CHAR; - } - } - - /* Fill in length of a previous callout, except when the next thing is - a quantifier. */ - - is_quantifier = c == '*' || c == '+' || c == '?' || - (c == '{' && is_counted_repeat(ptr+1)); - - if (!is_quantifier && previous_callout != NULL && - after_manual_callout-- <= 0) - { - if (lengthptr == NULL) /* Don't attempt in pre-compile phase */ - complete_callout(previous_callout, ptr, cd); - previous_callout = NULL; - } - - /* In extended mode, skip white space and comments */ - - if ((options & PCRE_EXTENDED) != 0) - { - if ((cd->ctypes[c] & ctype_space) != 0) continue; - if (c == '#') - { - while (*(++ptr) != 0) - { - if (IS_NEWLINE(ptr)) { ptr += cd->nllen - 1; break; } - } - if (*ptr != 0) continue; - - /* Else fall through to handle end of string */ - c = 0; - } - } - - /* No auto callout for quantifiers. */ - - if ((options & PCRE_AUTO_CALLOUT) != 0 && !is_quantifier) - { - previous_callout = code; - code = auto_callout(code, ptr, cd); - } - - switch(c) - { - /* ===================================================================*/ - case 0: /* The branch terminates at string end */ - case '|': /* or | or ) */ - case ')': - *firstbyteptr = firstbyte; - *reqbyteptr = reqbyte; - *codeptr = code; - *ptrptr = ptr; - if (lengthptr != NULL) - { - if (OFLOW_MAX - *lengthptr < code - last_code) - { - *errorcodeptr = ERR20; - goto FAILED; - } - *lengthptr += code - last_code; /* To include callout length */ - DPRINTF((">> end branch\n")); - } - return TRUE; - - - /* ===================================================================*/ - /* Handle single-character metacharacters. In multiline mode, ^ disables - the setting of any following char as a first character. */ - - case '^': - if ((options & PCRE_MULTILINE) != 0) - { - if (firstbyte == REQ_UNSET) firstbyte = REQ_NONE; - } - previous = NULL; - *code++ = OP_CIRC; - break; - - case '$': - previous = NULL; - *code++ = OP_DOLL; - break; - - /* There can never be a first char if '.' is first, whatever happens about - repeats. The value of reqbyte doesn't change either. */ - - case '.': - if (firstbyte == REQ_UNSET) firstbyte = REQ_NONE; - zerofirstbyte = firstbyte; - zeroreqbyte = reqbyte; - previous = code; - *code++ = OP_ANY; - break; - - - /* ===================================================================*/ - /* Character classes. If the included characters are all < 256, we build a - 32-byte bitmap of the permitted characters, except in the special case - where there is only one such character. For negated classes, we build the - map as usual, then invert it at the end. However, we use a different opcode - so that data characters > 255 can be handled correctly. - - If the class contains characters outside the 0-255 range, a different - opcode is compiled. It may optionally have a bit map for characters < 256, - but those above are are explicitly listed afterwards. A flag byte tells - whether the bitmap is present, and whether this is a negated class or not. - */ - - case '[': - previous = code; - - /* PCRE supports POSIX class stuff inside a class. Perl gives an error if - they are encountered at the top level, so we'll do that too. */ - - if ((ptr[1] == ':' || ptr[1] == '.' || ptr[1] == '=') && - check_posix_syntax(ptr, &tempptr, cd)) - { - *errorcodeptr = (ptr[1] == ':')? ERR13 : ERR31; - goto FAILED; - } - - /* If the first character is '^', set the negation flag and skip it. Also, - if the first few characters (either before or after ^) are \Q\E or \E we - skip them too. This makes for compatibility with Perl. */ - - negate_class = FALSE; - for (;;) - { - c = *(++ptr); - if (c == '\\') - { - if (ptr[1] == 'E') ptr++; - else if (strncmp((const char *)ptr+1, "Q\\E", 3) == 0) ptr += 3; - else break; - } - else if (!negate_class && c == '^') - negate_class = TRUE; - else break; - } - - /* Keep a count of chars with values < 256 so that we can optimize the case - of just a single character (as long as it's < 256). However, For higher - valued UTF-8 characters, we don't yet do any optimization. */ - - class_charcount = 0; - class_lastchar = -1; - - /* Initialize the 32-char bit map to all zeros. We build the map in a - temporary bit of memory, in case the class contains only 1 character (less - than 256), because in that case the compiled code doesn't use the bit map. - */ - - memset(classbits, 0, 32 * sizeof(uschar)); - -#ifdef SUPPORT_UTF8 - class_utf8 = FALSE; /* No chars >= 256 */ - class_utf8data = code + LINK_SIZE + 2; /* For UTF-8 items */ -#endif - - /* Process characters until ] is reached. By writing this as a "do" it - means that an initial ] is taken as a data character. At the start of the - loop, c contains the first byte of the character. */ - - if (c != 0) do - { - const uschar *oldptr; - -#ifdef SUPPORT_UTF8 - if (utf8 && c > 127) - { /* Braces are required because the */ - GETCHARLEN(c, ptr, ptr); /* macro generates multiple statements */ - } -#endif - - /* Inside \Q...\E everything is literal except \E */ - - if (inescq) - { - if (c == '\\' && ptr[1] == 'E') /* If we are at \E */ - { - inescq = FALSE; /* Reset literal state */ - ptr++; /* Skip the 'E' */ - continue; /* Carry on with next */ - } - goto CHECK_RANGE; /* Could be range if \E follows */ - } - - /* Handle POSIX class names. Perl allows a negation extension of the - form [:^name:]. A square bracket that doesn't match the syntax is - treated as a literal. We also recognize the POSIX constructions - [.ch.] and [=ch=] ("collating elements") and fault them, as Perl - 5.6 and 5.8 do. */ - - if (c == '[' && - (ptr[1] == ':' || ptr[1] == '.' || ptr[1] == '=') && - check_posix_syntax(ptr, &tempptr, cd)) - { - BOOL local_negate = FALSE; - int posix_class, taboffset, tabopt; - register const uschar *cbits = cd->cbits; - uschar pbits[32]; - - if (ptr[1] != ':') - { - *errorcodeptr = ERR31; - goto FAILED; - } - - ptr += 2; - if (*ptr == '^') - { - local_negate = TRUE; - ptr++; - } - - posix_class = check_posix_name(ptr, tempptr - ptr); - if (posix_class < 0) - { - *errorcodeptr = ERR30; - goto FAILED; - } - - /* If matching is caseless, upper and lower are converted to - alpha. This relies on the fact that the class table starts with - alpha, lower, upper as the first 3 entries. */ - - if ((options & PCRE_CASELESS) != 0 && posix_class <= 2) - posix_class = 0; - - /* We build the bit map for the POSIX class in a chunk of local store - because we may be adding and subtracting from it, and we don't want to - subtract bits that may be in the main map already. At the end we or the - result into the bit map that is being built. */ - - posix_class *= 3; - - /* Copy in the first table (always present) */ - - memcpy(pbits, cbits + posix_class_maps[posix_class], - 32 * sizeof(uschar)); - - /* If there is a second table, add or remove it as required. */ - - taboffset = posix_class_maps[posix_class + 1]; - tabopt = posix_class_maps[posix_class + 2]; - - if (taboffset >= 0) - { - if (tabopt >= 0) - for (c = 0; c < 32; c++) pbits[c] |= cbits[c + taboffset]; - else - for (c = 0; c < 32; c++) pbits[c] &= ~cbits[c + taboffset]; - } - - /* Not see if we need to remove any special characters. An option - value of 1 removes vertical space and 2 removes underscore. */ - - if (tabopt < 0) tabopt = -tabopt; - if (tabopt == 1) pbits[1] &= ~0x3c; - else if (tabopt == 2) pbits[11] &= 0x7f; - - /* Add the POSIX table or its complement into the main table that is - being built and we are done. */ - - if (local_negate) - for (c = 0; c < 32; c++) classbits[c] |= ~pbits[c]; - else - for (c = 0; c < 32; c++) classbits[c] |= pbits[c]; - - ptr = tempptr + 1; - class_charcount = 10; /* Set > 1; assumes more than 1 per class */ - continue; /* End of POSIX syntax handling */ - } - - /* Backslash may introduce a single character, or it may introduce one - of the specials, which just set a flag. The sequence \b is a special - case. Inside a class (and only there) it is treated as backspace. - Elsewhere it marks a word boundary. Other escapes have preset maps ready - to 'or' into the one we are building. We assume they have more than one - character in them, so set class_charcount bigger than one. */ - - if (c == '\\') - { - c = check_escape(&ptr, errorcodeptr, cd->bracount, options, TRUE); - if (*errorcodeptr != 0) goto FAILED; - - if (-c == ESC_b) c = '\b'; /* \b is backslash in a class */ - else if (-c == ESC_X) c = 'X'; /* \X is literal X in a class */ - else if (-c == ESC_R) c = 'R'; /* \R is literal R in a class */ - else if (-c == ESC_Q) /* Handle start of quoted string */ - { - if (ptr[1] == '\\' && ptr[2] == 'E') - { - ptr += 2; /* avoid empty string */ - } - else inescq = TRUE; - continue; - } - else if (-c == ESC_E) continue; /* Ignore orphan \E */ - - if (c < 0) - { - register const uschar *cbits = cd->cbits; - class_charcount += 2; /* Greater than 1 is what matters */ - - /* Save time by not doing this in the pre-compile phase. */ - - if (lengthptr == NULL) switch (-c) - { - case ESC_d: - for (c = 0; c < 32; c++) classbits[c] |= cbits[c+cbit_digit]; - continue; - - case ESC_D: - for (c = 0; c < 32; c++) classbits[c] |= ~cbits[c+cbit_digit]; - continue; - - case ESC_w: - for (c = 0; c < 32; c++) classbits[c] |= cbits[c+cbit_word]; - continue; - - case ESC_W: - for (c = 0; c < 32; c++) classbits[c] |= ~cbits[c+cbit_word]; - continue; - - case ESC_s: - for (c = 0; c < 32; c++) classbits[c] |= cbits[c+cbit_space]; - classbits[1] &= ~0x08; /* Perl 5.004 onwards omits VT from \s */ - continue; - - case ESC_S: - for (c = 0; c < 32; c++) classbits[c] |= ~cbits[c+cbit_space]; - classbits[1] |= 0x08; /* Perl 5.004 onwards omits VT from \s */ - continue; - - case ESC_E: /* Perl ignores an orphan \E */ - continue; - - default: /* Not recognized; fall through */ - break; /* Need "default" setting to stop compiler warning. */ - } - - /* In the pre-compile phase, just do the recognition. */ - - else if (c == -ESC_d || c == -ESC_D || c == -ESC_w || - c == -ESC_W || c == -ESC_s || c == -ESC_S) continue; - - /* We need to deal with \H, \h, \V, and \v in both phases because - they use extra memory. */ - - if (-c == ESC_h) - { - SETBIT(classbits, 0x09); /* VT */ - SETBIT(classbits, 0x20); /* SPACE */ - SETBIT(classbits, 0xa0); /* NSBP */ -#ifdef SUPPORT_UTF8 - if (utf8) - { - class_utf8 = TRUE; - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(0x1680, class_utf8data); - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(0x180e, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x2000, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x200A, class_utf8data); - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(0x202f, class_utf8data); - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(0x205f, class_utf8data); - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(0x3000, class_utf8data); - } -#endif - continue; - } - - if (-c == ESC_H) - { - for (c = 0; c < 32; c++) - { - int x = 0xff; - switch (c) - { - case 0x09/8: x ^= 1 << (0x09%8); break; - case 0x20/8: x ^= 1 << (0x20%8); break; - case 0xa0/8: x ^= 1 << (0xa0%8); break; - default: break; - } - classbits[c] |= x; - } - -#ifdef SUPPORT_UTF8 - if (utf8) - { - class_utf8 = TRUE; - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x0100, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x167f, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x1681, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x180d, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x180f, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x1fff, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x200B, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x202e, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x2030, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x205e, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x2060, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x2fff, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x3001, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x7fffffff, class_utf8data); - } -#endif - continue; - } - - if (-c == ESC_v) - { - SETBIT(classbits, 0x0a); /* LF */ - SETBIT(classbits, 0x0b); /* VT */ - SETBIT(classbits, 0x0c); /* FF */ - SETBIT(classbits, 0x0d); /* CR */ - SETBIT(classbits, 0x85); /* NEL */ -#ifdef SUPPORT_UTF8 - if (utf8) - { - class_utf8 = TRUE; - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x2028, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x2029, class_utf8data); - } -#endif - continue; - } - - if (-c == ESC_V) - { - for (c = 0; c < 32; c++) - { - int x = 0xff; - switch (c) - { - case 0x0a/8: x ^= 1 << (0x0a%8); - x ^= 1 << (0x0b%8); - x ^= 1 << (0x0c%8); - x ^= 1 << (0x0d%8); - break; - case 0x85/8: x ^= 1 << (0x85%8); break; - default: break; - } - classbits[c] |= x; - } - -#ifdef SUPPORT_UTF8 - if (utf8) - { - class_utf8 = TRUE; - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x0100, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x2027, class_utf8data); - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(0x2029, class_utf8data); - class_utf8data += _pcre_ord2utf8(0x7fffffff, class_utf8data); - } -#endif - continue; - } - - /* We need to deal with \P and \p in both phases. */ - -#ifdef SUPPORT_UCP - if (-c == ESC_p || -c == ESC_P) - { - BOOL negated; - int pdata; - int ptype = get_ucp(&ptr, &negated, &pdata, errorcodeptr); - if (ptype < 0) goto FAILED; - class_utf8 = TRUE; - *class_utf8data++ = ((-c == ESC_p) != negated)? - XCL_PROP : XCL_NOTPROP; - *class_utf8data++ = ptype; - *class_utf8data++ = pdata; - class_charcount -= 2; /* Not a < 256 character */ - continue; - } -#endif - /* Unrecognized escapes are faulted if PCRE is running in its - strict mode. By default, for compatibility with Perl, they are - treated as literals. */ - - if ((options & PCRE_EXTRA) != 0) - { - *errorcodeptr = ERR7; - goto FAILED; - } - - class_charcount -= 2; /* Undo the default count from above */ - c = *ptr; /* Get the final character and fall through */ - } - - /* Fall through if we have a single character (c >= 0). This may be - greater than 256 in UTF-8 mode. */ - - } /* End of backslash handling */ - - /* A single character may be followed by '-' to form a range. However, - Perl does not permit ']' to be the end of the range. A '-' character - at the end is treated as a literal. Perl ignores orphaned \E sequences - entirely. The code for handling \Q and \E is messy. */ - - CHECK_RANGE: - while (ptr[1] == '\\' && ptr[2] == 'E') - { - inescq = FALSE; - ptr += 2; - } - - oldptr = ptr; - - /* Remember \r or \n */ - - if (c == '\r' || c == '\n') cd->external_flags |= PCRE_HASCRORLF; - - /* Check for range */ - - if (!inescq && ptr[1] == '-') - { - int d; - ptr += 2; - while (*ptr == '\\' && ptr[1] == 'E') ptr += 2; - - /* If we hit \Q (not followed by \E) at this point, go into escaped - mode. */ - - while (*ptr == '\\' && ptr[1] == 'Q') - { - ptr += 2; - if (*ptr == '\\' && ptr[1] == 'E') { ptr += 2; continue; } - inescq = TRUE; - break; - } - - if (*ptr == 0 || (!inescq && *ptr == ']')) - { - ptr = oldptr; - goto LONE_SINGLE_CHARACTER; - } - -#ifdef SUPPORT_UTF8 - if (utf8) - { /* Braces are required because the */ - GETCHARLEN(d, ptr, ptr); /* macro generates multiple statements */ - } - else -#endif - d = *ptr; /* Not UTF-8 mode */ - - /* The second part of a range can be a single-character escape, but - not any of the other escapes. Perl 5.6 treats a hyphen as a literal - in such circumstances. */ - - if (!inescq && d == '\\') - { - d = check_escape(&ptr, errorcodeptr, cd->bracount, options, TRUE); - if (*errorcodeptr != 0) goto FAILED; - - /* \b is backslash; \X is literal X; \R is literal R; any other - special means the '-' was literal */ - - if (d < 0) - { - if (d == -ESC_b) d = '\b'; - else if (d == -ESC_X) d = 'X'; - else if (d == -ESC_R) d = 'R'; else - { - ptr = oldptr; - goto LONE_SINGLE_CHARACTER; /* A few lines below */ - } - } - } - - /* Check that the two values are in the correct order. Optimize - one-character ranges */ - - if (d < c) - { - *errorcodeptr = ERR8; - goto FAILED; - } - - if (d == c) goto LONE_SINGLE_CHARACTER; /* A few lines below */ - - /* Remember \r or \n */ - - if (d == '\r' || d == '\n') cd->external_flags |= PCRE_HASCRORLF; - - /* In UTF-8 mode, if the upper limit is > 255, or > 127 for caseless - matching, we have to use an XCLASS with extra data items. Caseless - matching for characters > 127 is available only if UCP support is - available. */ - -#ifdef SUPPORT_UTF8 - if (utf8 && (d > 255 || ((options & PCRE_CASELESS) != 0 && d > 127))) - { - class_utf8 = TRUE; - - /* With UCP support, we can find the other case equivalents of - the relevant characters. There may be several ranges. Optimize how - they fit with the basic range. */ - -#ifdef SUPPORT_UCP - if ((options & PCRE_CASELESS) != 0) - { - unsigned int occ, ocd; - unsigned int cc = c; - unsigned int origd = d; - while (get_othercase_range(&cc, origd, &occ, &ocd)) - { - if (occ >= (unsigned int)c && - ocd <= (unsigned int)d) - continue; /* Skip embedded ranges */ - - if (occ < (unsigned int)c && - ocd >= (unsigned int)c - 1) /* Extend the basic range */ - { /* if there is overlap, */ - c = occ; /* noting that if occ < c */ - continue; /* we can't have ocd > d */ - } /* because a subrange is */ - if (ocd > (unsigned int)d && - occ <= (unsigned int)d + 1) /* always shorter than */ - { /* the basic range. */ - d = ocd; - continue; - } - - if (occ == ocd) - { - *class_utf8data++ = XCL_SINGLE; - } - else - { - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(occ, class_utf8data); - } - class_utf8data += _pcre_ord2utf8(ocd, class_utf8data); - } - } -#endif /* SUPPORT_UCP */ - - /* Now record the original range, possibly modified for UCP caseless - overlapping ranges. */ - - *class_utf8data++ = XCL_RANGE; - class_utf8data += _pcre_ord2utf8(c, class_utf8data); - class_utf8data += _pcre_ord2utf8(d, class_utf8data); - - /* With UCP support, we are done. Without UCP support, there is no - caseless matching for UTF-8 characters > 127; we can use the bit map - for the smaller ones. */ - -#ifdef SUPPORT_UCP - continue; /* With next character in the class */ -#else - if ((options & PCRE_CASELESS) == 0 || c > 127) continue; - - /* Adjust upper limit and fall through to set up the map */ - - d = 127; - -#endif /* SUPPORT_UCP */ - } -#endif /* SUPPORT_UTF8 */ - - /* We use the bit map for all cases when not in UTF-8 mode; else - ranges that lie entirely within 0-127 when there is UCP support; else - for partial ranges without UCP support. */ - - class_charcount += d - c + 1; - class_lastchar = d; - - /* We can save a bit of time by skipping this in the pre-compile. */ - - if (lengthptr == NULL) for (; c <= d; c++) - { - classbits[c/8] |= (1 << (c&7)); - if ((options & PCRE_CASELESS) != 0) - { - int uc = cd->fcc[c]; /* flip case */ - classbits[uc/8] |= (1 << (uc&7)); - } - } - - continue; /* Go get the next char in the class */ - } - - /* Handle a lone single character - we can get here for a normal - non-escape char, or after \ that introduces a single character or for an - apparent range that isn't. */ - - LONE_SINGLE_CHARACTER: - - /* Handle a character that cannot go in the bit map */ - -#ifdef SUPPORT_UTF8 - if (utf8 && (c > 255 || ((options & PCRE_CASELESS) != 0 && c > 127))) - { - class_utf8 = TRUE; - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(c, class_utf8data); - -#ifdef SUPPORT_UCP - if ((options & PCRE_CASELESS) != 0) - { - unsigned int othercase; - if ((othercase = _pcre_ucp_othercase(c)) != NOTACHAR) - { - *class_utf8data++ = XCL_SINGLE; - class_utf8data += _pcre_ord2utf8(othercase, class_utf8data); - } - } -#endif /* SUPPORT_UCP */ - - } - else -#endif /* SUPPORT_UTF8 */ - - /* Handle a single-byte character */ - { - classbits[c/8] |= (1 << (c&7)); - if ((options & PCRE_CASELESS) != 0) - { - c = cd->fcc[c]; /* flip case */ - classbits[c/8] |= (1 << (c&7)); - } - class_charcount++; - class_lastchar = c; - } - } - - /* Loop until ']' reached. This "while" is the end of the "do" above. */ - - while ((c = *(++ptr)) != 0 && (c != ']' || inescq)); - - if (c == 0) /* Missing terminating ']' */ - { - *errorcodeptr = ERR6; - goto FAILED; - } - - -/* This code has been disabled because it would mean that \s counts as -an explicit \r or \n reference, and that's not really what is wanted. Now -we set the flag only if there is a literal "\r" or "\n" in the class. */ - -#if 0 - /* Remember whether \r or \n are in this class */ - - if (negate_class) - { - if ((classbits[1] & 0x24) != 0x24) cd->external_flags |= PCRE_HASCRORLF; - } - else - { - if ((classbits[1] & 0x24) != 0) cd->external_flags |= PCRE_HASCRORLF; - } -#endif - - - /* If class_charcount is 1, we saw precisely one character whose value is - less than 256. As long as there were no characters >= 128 and there was no - use of \p or \P, in other words, no use of any XCLASS features, we can - optimize. - - In UTF-8 mode, we can optimize the negative case only if there were no - characters >= 128 because OP_NOT and the related opcodes like OP_NOTSTAR - operate on single-bytes only. This is an historical hangover. Maybe one day - we can tidy these opcodes to handle multi-byte characters. - - The optimization throws away the bit map. We turn the item into a - 1-character OP_CHAR[NC] if it's positive, or OP_NOT if it's negative. Note - that OP_NOT does not support multibyte characters. In the positive case, it - can cause firstbyte to be set. Otherwise, there can be no first char if - this item is first, whatever repeat count may follow. In the case of - reqbyte, save the previous value for reinstating. */ - -#ifdef SUPPORT_UTF8 - if (class_charcount == 1 && !class_utf8 && - (!utf8 || !negate_class || class_lastchar < 128)) -#else - if (class_charcount == 1) -#endif - { - zeroreqbyte = reqbyte; - - /* The OP_NOT opcode works on one-byte characters only. */ - - if (negate_class) - { - if (firstbyte == REQ_UNSET) firstbyte = REQ_NONE; - zerofirstbyte = firstbyte; - *code++ = OP_NOT; - *code++ = class_lastchar; - break; - } - - /* For a single, positive character, get the value into mcbuffer, and - then we can handle this with the normal one-character code. */ - -#ifdef SUPPORT_UTF8 - if (utf8 && class_lastchar > 127) - mclength = _pcre_ord2utf8(class_lastchar, mcbuffer); - else -#endif - { - mcbuffer[0] = class_lastchar; - mclength = 1; - } - goto ONE_CHAR; - } /* End of 1-char optimization */ - - /* The general case - not the one-char optimization. If this is the first - thing in the branch, there can be no first char setting, whatever the - repeat count. Any reqbyte setting must remain unchanged after any kind of - repeat. */ - - if (firstbyte == REQ_UNSET) firstbyte = REQ_NONE; - zerofirstbyte = firstbyte; - zeroreqbyte = reqbyte; - - /* If there are characters with values > 255, we have to compile an - extended class, with its own opcode. If there are no characters < 256, - we can omit the bitmap in the actual compiled code. */ - -#ifdef SUPPORT_UTF8 - if (class_utf8) - { - *class_utf8data++ = XCL_END; /* Marks the end of extra data */ - *code++ = OP_XCLASS; - code += LINK_SIZE; - *code = negate_class? XCL_NOT : 0; - - /* If the map is required, move up the extra data to make room for it; - otherwise just move the code pointer to the end of the extra data. */ - - if (class_charcount > 0) - { - *code++ |= XCL_MAP; - memmove(code + 32, code, class_utf8data - code); - memcpy(code, classbits, 32); - code = class_utf8data + 32; - } - else code = class_utf8data; - - /* Now fill in the complete length of the item */ - - PUT(previous, 1, code - previous); - break; /* End of class handling */ - } -#endif - - /* If there are no characters > 255, negate the 32-byte map if necessary, - and copy it into the code vector. If this is the first thing in the branch, - there can be no first char setting, whatever the repeat count. Any reqbyte - setting must remain unchanged after any kind of repeat. */ - - if (negate_class) - { - *code++ = OP_NCLASS; - if (lengthptr == NULL) /* Save time in the pre-compile phase */ - for (c = 0; c < 32; c++) code[c] = ~classbits[c]; - } - else - { - *code++ = OP_CLASS; - memcpy(code, classbits, 32); - } - code += 32; - break; - - - /* ===================================================================*/ - /* Various kinds of repeat; '{' is not necessarily a quantifier, but this - has been tested above. */ - - case '{': - if (!is_quantifier) goto NORMAL_CHAR; - ptr = read_repeat_counts(ptr+1, &repeat_min, &repeat_max, errorcodeptr); - if (*errorcodeptr != 0) goto FAILED; - goto REPEAT; - - case '*': - repeat_min = 0; - repeat_max = -1; - goto REPEAT; - - case '+': - repeat_min = 1; - repeat_max = -1; - goto REPEAT; - - case '?': - repeat_min = 0; - repeat_max = 1; - - REPEAT: - if (previous == NULL) - { - *errorcodeptr = ERR9; - goto FAILED; - } - - if (repeat_min == 0) - { - firstbyte = zerofirstbyte; /* Adjust for zero repeat */ - reqbyte = zeroreqbyte; /* Ditto */ - } - - /* Remember whether this is a variable length repeat */ - - reqvary = (repeat_min == repeat_max)? 0 : REQ_VARY; - - op_type = 0; /* Default single-char op codes */ - possessive_quantifier = FALSE; /* Default not possessive quantifier */ - - /* Save start of previous item, in case we have to move it up to make space - for an inserted OP_ONCE for the additional '+' extension. */ - - tempcode = previous; - - /* If the next character is '+', we have a possessive quantifier. This - implies greediness, whatever the setting of the PCRE_UNGREEDY option. - If the next character is '?' this is a minimizing repeat, by default, - but if PCRE_UNGREEDY is set, it works the other way round. We change the - repeat type to the non-default. */ - - if (ptr[1] == '+') - { - repeat_type = 0; /* Force greedy */ - possessive_quantifier = TRUE; - ptr++; - } - else if (ptr[1] == '?') - { - repeat_type = greedy_non_default; - ptr++; - } - else repeat_type = greedy_default; - - /* If previous was a character match, abolish the item and generate a - repeat item instead. If a char item has a minumum of more than one, ensure - that it is set in reqbyte - it might not be if a sequence such as x{3} is - the first thing in a branch because the x will have gone into firstbyte - instead. */ - - if (*previous == OP_CHAR || *previous == OP_CHARNC) - { - /* Deal with UTF-8 characters that take up more than one byte. It's - easier to write this out separately than try to macrify it. Use c to - hold the length of the character in bytes, plus 0x80 to flag that it's a - length rather than a small character. */ - -#ifdef SUPPORT_UTF8 - if (utf8 && (code[-1] & 0x80) != 0) - { - uschar *lastchar = code - 1; - while((*lastchar & 0xc0) == 0x80) lastchar--; - c = code - lastchar; /* Length of UTF-8 character */ - memcpy(utf8_char, lastchar, c); /* Save the char */ - c |= 0x80; /* Flag c as a length */ - } - else -#endif - - /* Handle the case of a single byte - either with no UTF8 support, or - with UTF-8 disabled, or for a UTF-8 character < 128. */ - - { - c = code[-1]; - if (repeat_min > 1) reqbyte = c | req_caseopt | cd->req_varyopt; - } - - /* If the repetition is unlimited, it pays to see if the next thing on - the line is something that cannot possibly match this character. If so, - automatically possessifying this item gains some performance in the case - where the match fails. */ - - if (!possessive_quantifier && - repeat_max < 0 && - check_auto_possessive(*previous, c, utf8, utf8_char, ptr + 1, - options, cd)) - { - repeat_type = 0; /* Force greedy */ - possessive_quantifier = TRUE; - } - - goto OUTPUT_SINGLE_REPEAT; /* Code shared with single character types */ - } - - /* If previous was a single negated character ([^a] or similar), we use - one of the special opcodes, replacing it. The code is shared with single- - character repeats by setting opt_type to add a suitable offset into - repeat_type. We can also test for auto-possessification. OP_NOT is - currently used only for single-byte chars. */ - - else if (*previous == OP_NOT) - { - op_type = OP_NOTSTAR - OP_STAR; /* Use "not" opcodes */ - c = previous[1]; - if (!possessive_quantifier && - repeat_max < 0 && - check_auto_possessive(OP_NOT, c, utf8, NULL, ptr + 1, options, cd)) - { - repeat_type = 0; /* Force greedy */ - possessive_quantifier = TRUE; - } - goto OUTPUT_SINGLE_REPEAT; - } - - /* If previous was a character type match (\d or similar), abolish it and - create a suitable repeat item. The code is shared with single-character - repeats by setting op_type to add a suitable offset into repeat_type. Note - the the Unicode property types will be present only when SUPPORT_UCP is - defined, but we don't wrap the little bits of code here because it just - makes it horribly messy. */ - - else if (*previous < OP_EODN) - { - uschar *oldcode; - int prop_type, prop_value; - op_type = OP_TYPESTAR - OP_STAR; /* Use type opcodes */ - c = *previous; - - if (!possessive_quantifier && - repeat_max < 0 && - check_auto_possessive(c, 0, utf8, NULL, ptr + 1, options, cd)) - { - repeat_type = 0; /* Force greedy */ - possessive_quantifier = TRUE; - } - - OUTPUT_SINGLE_REPEAT: - if (*previous == OP_PROP || *previous == OP_NOTPROP) - { - prop_type = previous[1]; - prop_value = previous[2]; - } - else prop_type = prop_value = -1; - - oldcode = code; - code = previous; /* Usually overwrite previous item */ - - /* If the maximum is zero then the minimum must also be zero; Perl allows - this case, so we do too - by simply omitting the item altogether. */ - - if (repeat_max == 0) goto END_REPEAT; - - /* All real repeats make it impossible to handle partial matching (maybe - one day we will be able to remove this restriction). */ - - if (repeat_max != 1) cd->external_flags |= PCRE_NOPARTIAL; - - /* Combine the op_type with the repeat_type */ - - repeat_type += op_type; - - /* A minimum of zero is handled either as the special case * or ?, or as - an UPTO, with the maximum given. */ - - if (repeat_min == 0) - { - if (repeat_max == -1) *code++ = OP_STAR + repeat_type; - else if (repeat_max == 1) *code++ = OP_QUERY + repeat_type; - else - { - *code++ = OP_UPTO + repeat_type; - PUT2INC(code, 0, repeat_max); - } - } - - /* A repeat minimum of 1 is optimized into some special cases. If the - maximum is unlimited, we use OP_PLUS. Otherwise, the original item is - left in place and, if the maximum is greater than 1, we use OP_UPTO with - one less than the maximum. */ - - else if (repeat_min == 1) - { - if (repeat_max == -1) - *code++ = OP_PLUS + repeat_type; - else - { - code = oldcode; /* leave previous item in place */ - if (repeat_max == 1) goto END_REPEAT; - *code++ = OP_UPTO + repeat_type; - PUT2INC(code, 0, repeat_max - 1); - } - } - - /* The case {n,n} is just an EXACT, while the general case {n,m} is - handled as an EXACT followed by an UPTO. */ - - else - { - *code++ = OP_EXACT + op_type; /* NB EXACT doesn't have repeat_type */ - PUT2INC(code, 0, repeat_min); - - /* If the maximum is unlimited, insert an OP_STAR. Before doing so, - we have to insert the character for the previous code. For a repeated - Unicode property match, there are two extra bytes that define the - required property. In UTF-8 mode, long characters have their length in - c, with the 0x80 bit as a flag. */ - - if (repeat_max < 0) - { -#ifdef SUPPORT_UTF8 - if (utf8 && c >= 128) - { - memcpy(code, utf8_char, c & 7); - code += c & 7; - } - else -#endif - { - *code++ = c; - if (prop_type >= 0) - { - *code++ = prop_type; - *code++ = prop_value; - } - } - *code++ = OP_STAR + repeat_type; - } - - /* Else insert an UPTO if the max is greater than the min, again - preceded by the character, for the previously inserted code. If the - UPTO is just for 1 instance, we can use QUERY instead. */ - - else if (repeat_max != repeat_min) - { -#ifdef SUPPORT_UTF8 - if (utf8 && c >= 128) - { - memcpy(code, utf8_char, c & 7); - code += c & 7; - } - else -#endif - *code++ = c; - if (prop_type >= 0) - { - *code++ = prop_type; - *code++ = prop_value; - } - repeat_max -= repeat_min; - - if (repeat_max == 1) - { - *code++ = OP_QUERY + repeat_type; - } - else - { - *code++ = OP_UPTO + repeat_type; - PUT2INC(code, 0, repeat_max); - } - } - } - - /* The character or character type itself comes last in all cases. */ - -#ifdef SUPPORT_UTF8 - if (utf8 && c >= 128) - { - memcpy(code, utf8_char, c & 7); - code += c & 7; - } - else -#endif - *code++ = c; - - /* For a repeated Unicode property match, there are two extra bytes that - define the required property. */ - -#ifdef SUPPORT_UCP - if (prop_type >= 0) - { - *code++ = prop_type; - *code++ = prop_value; - } -#endif - } - - /* If previous was a character class or a back reference, we put the repeat - stuff after it, but just skip the item if the repeat was {0,0}. */ - - else if (*previous == OP_CLASS || - *previous == OP_NCLASS || -#ifdef SUPPORT_UTF8 - *previous == OP_XCLASS || -#endif - *previous == OP_REF) - { - if (repeat_max == 0) - { - code = previous; - goto END_REPEAT; - } - - /* All real repeats make it impossible to handle partial matching (maybe - one day we will be able to remove this restriction). */ - - if (repeat_max != 1) cd->external_flags |= PCRE_NOPARTIAL; - - if (repeat_min == 0 && repeat_max == -1) - *code++ = OP_CRSTAR + repeat_type; - else if (repeat_min == 1 && repeat_max == -1) - *code++ = OP_CRPLUS + repeat_type; - else if (repeat_min == 0 && repeat_max == 1) - *code++ = OP_CRQUERY + repeat_type; - else - { - *code++ = OP_CRRANGE + repeat_type; - PUT2INC(code, 0, repeat_min); - if (repeat_max == -1) repeat_max = 0; /* 2-byte encoding for max */ - PUT2INC(code, 0, repeat_max); - } - } - - /* If previous was a bracket group, we may have to replicate it in certain - cases. */ - - else if (*previous == OP_BRA || *previous == OP_CBRA || - *previous == OP_ONCE || *previous == OP_COND) - { - register int i; - int ketoffset = 0; - int len = code - previous; - uschar *bralink = NULL; - - /* Repeating a DEFINE group is pointless */ - - if (*previous == OP_COND && previous[LINK_SIZE+1] == OP_DEF) - { - *errorcodeptr = ERR55; - goto FAILED; - } - - /* If the maximum repeat count is unlimited, find the end of the bracket - by scanning through from the start, and compute the offset back to it - from the current code pointer. There may be an OP_OPT setting following - the final KET, so we can't find the end just by going back from the code - pointer. */ - - if (repeat_max == -1) - { - register uschar *ket = previous; - do ket += GET(ket, 1); while (*ket != OP_KET); - ketoffset = code - ket; - } - - /* The case of a zero minimum is special because of the need to stick - OP_BRAZERO in front of it, and because the group appears once in the - data, whereas in other cases it appears the minimum number of times. For - this reason, it is simplest to treat this case separately, as otherwise - the code gets far too messy. There are several special subcases when the - minimum is zero. */ - - if (repeat_min == 0) - { - /* If the maximum is also zero, we just omit the group from the output - altogether. */ - - if (repeat_max == 0) - { - code = previous; - goto END_REPEAT; - } - - /* If the maximum is 1 or unlimited, we just have to stick in the - BRAZERO and do no more at this point. However, we do need to adjust - any OP_RECURSE calls inside the group that refer to the group itself or - any internal or forward referenced group, because the offset is from - the start of the whole regex. Temporarily terminate the pattern while - doing this. */ - - if (repeat_max <= 1) - { - *code = OP_END; - adjust_recurse(previous, 1, utf8, cd, save_hwm); - memmove(previous+1, previous, len); - code++; - *previous++ = OP_BRAZERO + repeat_type; - } - - /* If the maximum is greater than 1 and limited, we have to replicate - in a nested fashion, sticking OP_BRAZERO before each set of brackets. - The first one has to be handled carefully because it's the original - copy, which has to be moved up. The remainder can be handled by code - that is common with the non-zero minimum case below. We have to - adjust the value or repeat_max, since one less copy is required. Once - again, we may have to adjust any OP_RECURSE calls inside the group. */ - - else - { - int offset; - *code = OP_END; - adjust_recurse(previous, 2 + LINK_SIZE, utf8, cd, save_hwm); - memmove(previous + 2 + LINK_SIZE, previous, len); - code += 2 + LINK_SIZE; - *previous++ = OP_BRAZERO + repeat_type; - *previous++ = OP_BRA; - - /* We chain together the bracket offset fields that have to be - filled in later when the ends of the brackets are reached. */ - - offset = (bralink == NULL)? 0 : previous - bralink; - bralink = previous; - PUTINC(previous, 0, offset); - } - - repeat_max--; - } - - /* If the minimum is greater than zero, replicate the group as many - times as necessary, and adjust the maximum to the number of subsequent - copies that we need. If we set a first char from the group, and didn't - set a required char, copy the latter from the former. If there are any - forward reference subroutine calls in the group, there will be entries on - the workspace list; replicate these with an appropriate increment. */ - - else - { - if (repeat_min > 1) - { - /* In the pre-compile phase, we don't actually do the replication. We - just adjust the length as if we had. Do some paranoid checks for - potential integer overflow. */ - - if (lengthptr != NULL) - { - int delta = (repeat_min - 1)*length_prevgroup; - if ((double)(repeat_min - 1)*(double)length_prevgroup > - (double)INT_MAX || - OFLOW_MAX - *lengthptr < delta) - { - *errorcodeptr = ERR20; - goto FAILED; - } - *lengthptr += delta; - } - - /* This is compiling for real */ - - else - { - if (groupsetfirstbyte && reqbyte < 0) reqbyte = firstbyte; - for (i = 1; i < repeat_min; i++) - { - uschar *hc; - uschar *this_hwm = cd->hwm; - memcpy(code, previous, len); - for (hc = save_hwm; hc < this_hwm; hc += LINK_SIZE) - { - PUT(cd->hwm, 0, GET(hc, 0) + len); - cd->hwm += LINK_SIZE; - } - save_hwm = this_hwm; - code += len; - } - } - } - - if (repeat_max > 0) repeat_max -= repeat_min; - } - - /* This code is common to both the zero and non-zero minimum cases. If - the maximum is limited, it replicates the group in a nested fashion, - remembering the bracket starts on a stack. In the case of a zero minimum, - the first one was set up above. In all cases the repeat_max now specifies - the number of additional copies needed. Again, we must remember to - replicate entries on the forward reference list. */ - - if (repeat_max >= 0) - { - /* In the pre-compile phase, we don't actually do the replication. We - just adjust the length as if we had. For each repetition we must add 1 - to the length for BRAZERO and for all but the last repetition we must - add 2 + 2*LINKSIZE to allow for the nesting that occurs. Do some - paranoid checks to avoid integer overflow. */ - - if (lengthptr != NULL && repeat_max > 0) - { - int delta = repeat_max * (length_prevgroup + 1 + 2 + 2*LINK_SIZE) - - 2 - 2*LINK_SIZE; /* Last one doesn't nest */ - if ((double)repeat_max * - (double)(length_prevgroup + 1 + 2 + 2*LINK_SIZE) - > (double)INT_MAX || - OFLOW_MAX - *lengthptr < delta) - { - *errorcodeptr = ERR20; - goto FAILED; - } - *lengthptr += delta; - } - - /* This is compiling for real */ - - else for (i = repeat_max - 1; i >= 0; i--) - { - uschar *hc; - uschar *this_hwm = cd->hwm; - - *code++ = OP_BRAZERO + repeat_type; - - /* All but the final copy start a new nesting, maintaining the - chain of brackets outstanding. */ - - if (i != 0) - { - int offset; - *code++ = OP_BRA; - offset = (bralink == NULL)? 0 : code - bralink; - bralink = code; - PUTINC(code, 0, offset); - } - - memcpy(code, previous, len); - for (hc = save_hwm; hc < this_hwm; hc += LINK_SIZE) - { - PUT(cd->hwm, 0, GET(hc, 0) + len + ((i != 0)? 2+LINK_SIZE : 1)); - cd->hwm += LINK_SIZE; - } - save_hwm = this_hwm; - code += len; - } - - /* Now chain through the pending brackets, and fill in their length - fields (which are holding the chain links pro tem). */ - - while (bralink != NULL) - { - int oldlinkoffset; - int offset = code - bralink + 1; - uschar *bra = code - offset; - oldlinkoffset = GET(bra, 1); - bralink = (oldlinkoffset == 0)? NULL : bralink - oldlinkoffset; - *code++ = OP_KET; - PUTINC(code, 0, offset); - PUT(bra, 1, offset); - } - } - - /* If the maximum is unlimited, set a repeater in the final copy. We - can't just offset backwards from the current code point, because we - don't know if there's been an options resetting after the ket. The - correct offset was computed above. - - Then, when we are doing the actual compile phase, check to see whether - this group is a non-atomic one that could match an empty string. If so, - convert the initial operator to the S form (e.g. OP_BRA -> OP_SBRA) so - that runtime checking can be done. [This check is also applied to - atomic groups at runtime, but in a different way.] */ - - else - { - uschar *ketcode = code - ketoffset; - uschar *bracode = ketcode - GET(ketcode, 1); - *ketcode = OP_KETRMAX + repeat_type; - if (lengthptr == NULL && *bracode != OP_ONCE) - { - uschar *scode = bracode; - do - { - if (could_be_empty_branch(scode, ketcode, utf8)) - { - *bracode += OP_SBRA - OP_BRA; - break; - } - scode += GET(scode, 1); - } - while (*scode == OP_ALT); - } - } - } - - /* Else there's some kind of shambles */ - - else - { - *errorcodeptr = ERR11; - goto FAILED; - } - - /* If the character following a repeat is '+', or if certain optimization - tests above succeeded, possessive_quantifier is TRUE. For some of the - simpler opcodes, there is an special alternative opcode for this. For - anything else, we wrap the entire repeated item inside OP_ONCE brackets. - The '+' notation is just syntactic sugar, taken from Sun's Java package, - but the special opcodes can optimize it a bit. The repeated item starts at - tempcode, not at previous, which might be the first part of a string whose - (former) last char we repeated. - - Possessifying an 'exact' quantifier has no effect, so we can ignore it. But - an 'upto' may follow. We skip over an 'exact' item, and then test the - length of what remains before proceeding. */ - - if (possessive_quantifier) - { - int len; - if (*tempcode == OP_EXACT || *tempcode == OP_TYPEEXACT || - *tempcode == OP_NOTEXACT) - tempcode += _pcre_OP_lengths[*tempcode]; - len = code - tempcode; - if (len > 0) switch (*tempcode) - { - case OP_STAR: *tempcode = OP_POSSTAR; break; - case OP_PLUS: *tempcode = OP_POSPLUS; break; - case OP_QUERY: *tempcode = OP_POSQUERY; break; - case OP_UPTO: *tempcode = OP_POSUPTO; break; - - case OP_TYPESTAR: *tempcode = OP_TYPEPOSSTAR; break; - case OP_TYPEPLUS: *tempcode = OP_TYPEPOSPLUS; break; - case OP_TYPEQUERY: *tempcode = OP_TYPEPOSQUERY; break; - case OP_TYPEUPTO: *tempcode = OP_TYPEPOSUPTO; break; - - case OP_NOTSTAR: *tempcode = OP_NOTPOSSTAR; break; - case OP_NOTPLUS: *tempcode = OP_NOTPOSPLUS; break; - case OP_NOTQUERY: *tempcode = OP_NOTPOSQUERY; break; - case OP_NOTUPTO: *tempcode = OP_NOTPOSUPTO; break; - - default: - memmove(tempcode + 1+LINK_SIZE, tempcode, len); - code += 1 + LINK_SIZE; - len += 1 + LINK_SIZE; - tempcode[0] = OP_ONCE; - *code++ = OP_KET; - PUTINC(code, 0, len); - PUT(tempcode, 1, len); - break; - } - } - - /* In all case we no longer have a previous item. We also set the - "follows varying string" flag for subsequently encountered reqbytes if - it isn't already set and we have just passed a varying length item. */ - - END_REPEAT: - previous = NULL; - cd->req_varyopt |= reqvary; - break; - - - /* ===================================================================*/ - /* Start of nested parenthesized sub-expression, or comment or lookahead or - lookbehind or option setting or condition or all the other extended - parenthesis forms. */ - - case '(': - newoptions = options; - skipbytes = 0; - bravalue = OP_CBRA; - save_hwm = cd->hwm; - reset_bracount = FALSE; - - /* First deal with various "verbs" that can be introduced by '*'. */ - - if (*(++ptr) == '*' && (cd->ctypes[ptr[1]] & ctype_letter) != 0) - { - int i, namelen; - const char *vn = verbnames; - const uschar *name = ++ptr; - previous = NULL; - while ((cd->ctypes[*++ptr] & ctype_letter) != 0); - if (*ptr == ':') - { - *errorcodeptr = ERR59; /* Not supported */ - goto FAILED; - } - if (*ptr != ')') - { - *errorcodeptr = ERR60; - goto FAILED; - } - namelen = ptr - name; - for (i = 0; i < verbcount; i++) - { - if (namelen == verbs[i].len && - strncmp((char *)name, vn, namelen) == 0) - { - *code = verbs[i].op; - if (*code++ == OP_ACCEPT) cd->had_accept = TRUE; - break; - } - vn += verbs[i].len + 1; - } - if (i < verbcount) continue; - *errorcodeptr = ERR60; - goto FAILED; - } - - /* Deal with the extended parentheses; all are introduced by '?', and the - appearance of any of them means that this is not a capturing group. */ - - else if (*ptr == '?') - { - int i, set, unset, namelen; - int *optset; - const uschar *name; - uschar *slot; - - switch (*(++ptr)) - { - case '#': /* Comment; skip to ket */ - ptr++; - while (*ptr != 0 && *ptr != ')') ptr++; - if (*ptr == 0) - { - *errorcodeptr = ERR18; - goto FAILED; - } - continue; - - - /* ------------------------------------------------------------ */ - case '|': /* Reset capture count for each branch */ - reset_bracount = TRUE; - /* Fall through */ - - /* ------------------------------------------------------------ */ - case ':': /* Non-capturing bracket */ - bravalue = OP_BRA; - ptr++; - break; - - - /* ------------------------------------------------------------ */ - case '(': - bravalue = OP_COND; /* Conditional group */ - - /* A condition can be an assertion, a number (referring to a numbered - group), a name (referring to a named group), or 'R', referring to - recursion. R and R&name are also permitted for recursion tests. - - There are several syntaxes for testing a named group: (?(name)) is used - by Python; Perl 5.10 onwards uses (?() or (?('name')). - - There are two unfortunate ambiguities, caused by history. (a) 'R' can - be the recursive thing or the name 'R' (and similarly for 'R' followed - by digits), and (b) a number could be a name that consists of digits. - In both cases, we look for a name first; if not found, we try the other - cases. */ - - /* For conditions that are assertions, check the syntax, and then exit - the switch. This will take control down to where bracketed groups, - including assertions, are processed. */ - - if (ptr[1] == '?' && (ptr[2] == '=' || ptr[2] == '!' || ptr[2] == '<')) - break; - - /* Most other conditions use OP_CREF (a couple change to OP_RREF - below), and all need to skip 3 bytes at the start of the group. */ - - code[1+LINK_SIZE] = OP_CREF; - skipbytes = 3; - refsign = -1; - - /* Check for a test for recursion in a named group. */ - - if (ptr[1] == 'R' && ptr[2] == '&') - { - terminator = -1; - ptr += 2; - code[1+LINK_SIZE] = OP_RREF; /* Change the type of test */ - } - - /* Check for a test for a named group's having been set, using the Perl - syntax (?() or (?('name') */ - - else if (ptr[1] == '<') - { - terminator = '>'; - ptr++; - } - else if (ptr[1] == '\'') - { - terminator = '\''; - ptr++; - } - else - { - terminator = 0; - if (ptr[1] == '-' || ptr[1] == '+') refsign = *(++ptr); - } - - /* We now expect to read a name; any thing else is an error */ - - if ((cd->ctypes[ptr[1]] & ctype_word) == 0) - { - ptr += 1; /* To get the right offset */ - *errorcodeptr = ERR28; - goto FAILED; - } - - /* Read the name, but also get it as a number if it's all digits */ - - recno = 0; - name = ++ptr; - while ((cd->ctypes[*ptr] & ctype_word) != 0) - { - if (recno >= 0) - recno = ((digitab[*ptr] & ctype_digit) != 0)? - recno * 10 + *ptr - '0' : -1; - ptr++; - } - namelen = ptr - name; - - if ((terminator > 0 && *ptr++ != terminator) || *ptr++ != ')') - { - ptr--; /* Error offset */ - *errorcodeptr = ERR26; - goto FAILED; - } - - /* Do no further checking in the pre-compile phase. */ - - if (lengthptr != NULL) break; - - /* In the real compile we do the work of looking for the actual - reference. If the string started with "+" or "-" we require the rest to - be digits, in which case recno will be set. */ - - if (refsign > 0) - { - if (recno <= 0) - { - *errorcodeptr = ERR58; - goto FAILED; - } - if (refsign == '-') - { - recno = cd->bracount - recno + 1; - if (recno <= 0) - { - *errorcodeptr = ERR15; - goto FAILED; - } - } - else recno += cd->bracount; - PUT2(code, 2+LINK_SIZE, recno); - break; - } - - /* Otherwise (did not start with "+" or "-"), start by looking for the - name. */ - - slot = cd->name_table; - for (i = 0; i < cd->names_found; i++) - { - if (strncmp((char *)name, (char *)slot+2, namelen) == 0) break; - slot += cd->name_entry_size; - } - - /* Found a previous named subpattern */ - - if (i < cd->names_found) - { - recno = GET2(slot, 0); - PUT2(code, 2+LINK_SIZE, recno); - } - - /* Search the pattern for a forward reference */ - - else if ((i = find_parens(ptr, cd->bracount, name, namelen, - (options & PCRE_EXTENDED) != 0)) > 0) - { - PUT2(code, 2+LINK_SIZE, i); - } - - /* If terminator == 0 it means that the name followed directly after - the opening parenthesis [e.g. (?(abc)...] and in this case there are - some further alternatives to try. For the cases where terminator != 0 - [things like (?(... or (?('name')... or (?(R&name)... ] we have - now checked all the possibilities, so give an error. */ - - else if (terminator != 0) - { - *errorcodeptr = ERR15; - goto FAILED; - } - - /* Check for (?(R) for recursion. Allow digits after R to specify a - specific group number. */ - - else if (*name == 'R') - { - recno = 0; - for (i = 1; i < namelen; i++) - { - if ((digitab[name[i]] & ctype_digit) == 0) - { - *errorcodeptr = ERR15; - goto FAILED; - } - recno = recno * 10 + name[i] - '0'; - } - if (recno == 0) recno = RREF_ANY; - code[1+LINK_SIZE] = OP_RREF; /* Change test type */ - PUT2(code, 2+LINK_SIZE, recno); - } - - /* Similarly, check for the (?(DEFINE) "condition", which is always - false. */ - - else if (namelen == 6 && strncmp((char *)name, "DEFINE", 6) == 0) - { - code[1+LINK_SIZE] = OP_DEF; - skipbytes = 1; - } - - /* Check for the "name" actually being a subpattern number. */ - - else if (recno > 0) - { - PUT2(code, 2+LINK_SIZE, recno); - } - - /* Either an unidentified subpattern, or a reference to (?(0) */ - - else - { - *errorcodeptr = (recno == 0)? ERR35: ERR15; - goto FAILED; - } - break; - - - /* ------------------------------------------------------------ */ - case '=': /* Positive lookahead */ - bravalue = OP_ASSERT; - ptr++; - break; - - - /* ------------------------------------------------------------ */ - case '!': /* Negative lookahead */ - ptr++; - if (*ptr == ')') /* Optimize (?!) */ - { - *code++ = OP_FAIL; - previous = NULL; - continue; - } - bravalue = OP_ASSERT_NOT; - break; - - - /* ------------------------------------------------------------ */ - case '<': /* Lookbehind or named define */ - switch (ptr[1]) - { - case '=': /* Positive lookbehind */ - bravalue = OP_ASSERTBACK; - ptr += 2; - break; - - case '!': /* Negative lookbehind */ - bravalue = OP_ASSERTBACK_NOT; - ptr += 2; - break; - - default: /* Could be name define, else bad */ - if ((cd->ctypes[ptr[1]] & ctype_word) != 0) goto DEFINE_NAME; - ptr++; /* Correct offset for error */ - *errorcodeptr = ERR24; - goto FAILED; - } - break; - - - /* ------------------------------------------------------------ */ - case '>': /* One-time brackets */ - bravalue = OP_ONCE; - ptr++; - break; - - - /* ------------------------------------------------------------ */ - case 'C': /* Callout - may be followed by digits; */ - previous_callout = code; /* Save for later completion */ - after_manual_callout = 1; /* Skip one item before completing */ - *code++ = OP_CALLOUT; - { - int n = 0; - while ((digitab[*(++ptr)] & ctype_digit) != 0) - n = n * 10 + *ptr - '0'; - if (*ptr != ')') - { - *errorcodeptr = ERR39; - goto FAILED; - } - if (n > 255) - { - *errorcodeptr = ERR38; - goto FAILED; - } - *code++ = n; - PUT(code, 0, ptr - cd->start_pattern + 1); /* Pattern offset */ - PUT(code, LINK_SIZE, 0); /* Default length */ - code += 2 * LINK_SIZE; - } - previous = NULL; - continue; - - - /* ------------------------------------------------------------ */ - case 'P': /* Python-style named subpattern handling */ - if (*(++ptr) == '=' || *ptr == '>') /* Reference or recursion */ - { - is_recurse = *ptr == '>'; - terminator = ')'; - goto NAMED_REF_OR_RECURSE; - } - else if (*ptr != '<') /* Test for Python-style definition */ - { - *errorcodeptr = ERR41; - goto FAILED; - } - /* Fall through to handle (?P< as (?< is handled */ - - - /* ------------------------------------------------------------ */ - DEFINE_NAME: /* Come here from (?< handling */ - case '\'': - { - terminator = (*ptr == '<')? '>' : '\''; - name = ++ptr; - - while ((cd->ctypes[*ptr] & ctype_word) != 0) ptr++; - namelen = ptr - name; - - /* In the pre-compile phase, just do a syntax check. */ - - if (lengthptr != NULL) - { - if (*ptr != terminator) - { - *errorcodeptr = ERR42; - goto FAILED; - } - if (cd->names_found >= MAX_NAME_COUNT) - { - *errorcodeptr = ERR49; - goto FAILED; - } - if (namelen + 3 > cd->name_entry_size) - { - cd->name_entry_size = namelen + 3; - if (namelen > MAX_NAME_SIZE) - { - *errorcodeptr = ERR48; - goto FAILED; - } - } - } - - /* In the real compile, create the entry in the table */ - - else - { - slot = cd->name_table; - for (i = 0; i < cd->names_found; i++) - { - int crc = memcmp(name, slot+2, namelen); - if (crc == 0) - { - if (slot[2+namelen] == 0) - { - if ((options & PCRE_DUPNAMES) == 0) - { - *errorcodeptr = ERR43; - goto FAILED; - } - } - else crc = -1; /* Current name is substring */ - } - if (crc < 0) - { - memmove(slot + cd->name_entry_size, slot, - (cd->names_found - i) * cd->name_entry_size); - break; - } - slot += cd->name_entry_size; - } - - PUT2(slot, 0, cd->bracount + 1); - memcpy(slot + 2, name, namelen); - slot[2+namelen] = 0; - } - } - - /* In both cases, count the number of names we've encountered. */ - - ptr++; /* Move past > or ' */ - cd->names_found++; - goto NUMBERED_GROUP; - - - /* ------------------------------------------------------------ */ - case '&': /* Perl recursion/subroutine syntax */ - terminator = ')'; - is_recurse = TRUE; - /* Fall through */ - - /* We come here from the Python syntax above that handles both - references (?P=name) and recursion (?P>name), as well as falling - through from the Perl recursion syntax (?&name). */ - - NAMED_REF_OR_RECURSE: - name = ++ptr; - while ((cd->ctypes[*ptr] & ctype_word) != 0) ptr++; - namelen = ptr - name; - - /* In the pre-compile phase, do a syntax check and set a dummy - reference number. */ - - if (lengthptr != NULL) - { - if (*ptr != terminator) - { - *errorcodeptr = ERR42; - goto FAILED; - } - if (namelen > MAX_NAME_SIZE) - { - *errorcodeptr = ERR48; - goto FAILED; - } - recno = 0; - } - - /* In the real compile, seek the name in the table */ - - else - { - slot = cd->name_table; - for (i = 0; i < cd->names_found; i++) - { - if (strncmp((char *)name, (char *)slot+2, namelen) == 0) break; - slot += cd->name_entry_size; - } - - if (i < cd->names_found) /* Back reference */ - { - recno = GET2(slot, 0); - } - else if ((recno = /* Forward back reference */ - find_parens(ptr, cd->bracount, name, namelen, - (options & PCRE_EXTENDED) != 0)) <= 0) - { - *errorcodeptr = ERR15; - goto FAILED; - } - } - - /* In both phases, we can now go to the code than handles numerical - recursion or backreferences. */ - - if (is_recurse) goto HANDLE_RECURSION; - else goto HANDLE_REFERENCE; - - - /* ------------------------------------------------------------ */ - case 'R': /* Recursion */ - ptr++; /* Same as (?0) */ - /* Fall through */ - - - /* ------------------------------------------------------------ */ - case '-': case '+': - case '0': case '1': case '2': case '3': case '4': /* Recursion or */ - case '5': case '6': case '7': case '8': case '9': /* subroutine */ - { - const uschar *called; - - if ((refsign = *ptr) == '+') ptr++; - else if (refsign == '-') - { - if ((digitab[ptr[1]] & ctype_digit) == 0) - goto OTHER_CHAR_AFTER_QUERY; - ptr++; - } - - recno = 0; - while((digitab[*ptr] & ctype_digit) != 0) - recno = recno * 10 + *ptr++ - '0'; - - if (*ptr != ')') - { - *errorcodeptr = ERR29; - goto FAILED; - } - - if (refsign == '-') - { - if (recno == 0) - { - *errorcodeptr = ERR58; - goto FAILED; - } - recno = cd->bracount - recno + 1; - if (recno <= 0) - { - *errorcodeptr = ERR15; - goto FAILED; - } - } - else if (refsign == '+') - { - if (recno == 0) - { - *errorcodeptr = ERR58; - goto FAILED; - } - recno += cd->bracount; - } - - /* Come here from code above that handles a named recursion */ - - HANDLE_RECURSION: - - previous = code; - called = cd->start_code; - - /* When we are actually compiling, find the bracket that is being - referenced. Temporarily end the regex in case it doesn't exist before - this point. If we end up with a forward reference, first check that - the bracket does occur later so we can give the error (and position) - now. Then remember this forward reference in the workspace so it can - be filled in at the end. */ - - if (lengthptr == NULL) - { - *code = OP_END; - if (recno != 0) called = find_bracket(cd->start_code, utf8, recno); - - /* Forward reference */ - - if (called == NULL) - { - if (find_parens(ptr, cd->bracount, NULL, recno, - (options & PCRE_EXTENDED) != 0) < 0) - { - *errorcodeptr = ERR15; - goto FAILED; - } - called = cd->start_code + recno; - PUTINC(cd->hwm, 0, code + 2 + LINK_SIZE - cd->start_code); - } - - /* If not a forward reference, and the subpattern is still open, - this is a recursive call. We check to see if this is a left - recursion that could loop for ever, and diagnose that case. */ - - else if (GET(called, 1) == 0 && - could_be_empty(called, code, bcptr, utf8)) - { - *errorcodeptr = ERR40; - goto FAILED; - } - } - - /* Insert the recursion/subroutine item, automatically wrapped inside - "once" brackets. Set up a "previous group" length so that a - subsequent quantifier will work. */ - - *code = OP_ONCE; - PUT(code, 1, 2 + 2*LINK_SIZE); - code += 1 + LINK_SIZE; - - *code = OP_RECURSE; - PUT(code, 1, called - cd->start_code); - code += 1 + LINK_SIZE; - - *code = OP_KET; - PUT(code, 1, 2 + 2*LINK_SIZE); - code += 1 + LINK_SIZE; - - length_prevgroup = 3 + 3*LINK_SIZE; - } - - /* Can't determine a first byte now */ - - if (firstbyte == REQ_UNSET) firstbyte = REQ_NONE; - continue; - - - /* ------------------------------------------------------------ */ - default: /* Other characters: check option setting */ - OTHER_CHAR_AFTER_QUERY: - set = unset = 0; - optset = &set; - - while (*ptr != ')' && *ptr != ':') - { - switch (*ptr++) - { - case '-': optset = &unset; break; - - case 'J': /* Record that it changed in the external options */ - *optset |= PCRE_DUPNAMES; - cd->external_flags |= PCRE_JCHANGED; - break; - - case 'i': *optset |= PCRE_CASELESS; break; - case 'm': *optset |= PCRE_MULTILINE; break; - case 's': *optset |= PCRE_DOTALL; break; - case 'x': *optset |= PCRE_EXTENDED; break; - case 'U': *optset |= PCRE_UNGREEDY; break; - case 'X': *optset |= PCRE_EXTRA; break; - - default: *errorcodeptr = ERR12; - ptr--; /* Correct the offset */ - goto FAILED; - } - } - - /* Set up the changed option bits, but don't change anything yet. */ - - newoptions = (options | set) & (~unset); - - /* If the options ended with ')' this is not the start of a nested - group with option changes, so the options change at this level. If this - item is right at the start of the pattern, the options can be - abstracted and made external in the pre-compile phase, and ignored in - the compile phase. This can be helpful when matching -- for instance in - caseless checking of required bytes. - - If the code pointer is not (cd->start_code + 1 + LINK_SIZE), we are - definitely *not* at the start of the pattern because something has been - compiled. In the pre-compile phase, however, the code pointer can have - that value after the start, because it gets reset as code is discarded - during the pre-compile. However, this can happen only at top level - if - we are within parentheses, the starting BRA will still be present. At - any parenthesis level, the length value can be used to test if anything - has been compiled at that level. Thus, a test for both these conditions - is necessary to ensure we correctly detect the start of the pattern in - both phases. - - If we are not at the pattern start, compile code to change the ims - options if this setting actually changes any of them. We also pass the - new setting back so that it can be put at the start of any following - branches, and when this group ends (if we are in a group), a resetting - item can be compiled. */ - - if (*ptr == ')') - { - if (code == cd->start_code + 1 + LINK_SIZE && - (lengthptr == NULL || *lengthptr == 2 + 2*LINK_SIZE)) - { - cd->external_options = newoptions; - options = newoptions; - } - else - { - if ((options & PCRE_IMS) != (newoptions & PCRE_IMS)) - { - *code++ = OP_OPT; - *code++ = newoptions & PCRE_IMS; - } - - /* Change options at this level, and pass them back for use - in subsequent branches. Reset the greedy defaults and the case - value for firstbyte and reqbyte. */ - - *optionsptr = options = newoptions; - greedy_default = ((newoptions & PCRE_UNGREEDY) != 0); - greedy_non_default = greedy_default ^ 1; - req_caseopt = ((options & PCRE_CASELESS) != 0)? REQ_CASELESS : 0; - } - - previous = NULL; /* This item can't be repeated */ - continue; /* It is complete */ - } - - /* If the options ended with ':' we are heading into a nested group - with possible change of options. Such groups are non-capturing and are - not assertions of any kind. All we need to do is skip over the ':'; - the newoptions value is handled below. */ - - bravalue = OP_BRA; - ptr++; - } /* End of switch for character following (? */ - } /* End of (? handling */ - - /* Opening parenthesis not followed by '?'. If PCRE_NO_AUTO_CAPTURE is set, - all unadorned brackets become non-capturing and behave like (?:...) - brackets. */ - - else if ((options & PCRE_NO_AUTO_CAPTURE) != 0) - { - bravalue = OP_BRA; - } - - /* Else we have a capturing group. */ - - else - { - NUMBERED_GROUP: - cd->bracount += 1; - PUT2(code, 1+LINK_SIZE, cd->bracount); - skipbytes = 2; - } - - /* Process nested bracketed regex. Assertions may not be repeated, but - other kinds can be. All their opcodes are >= OP_ONCE. We copy code into a - non-register variable in order to be able to pass its address because some - compilers complain otherwise. Pass in a new setting for the ims options if - they have changed. */ - - previous = (bravalue >= OP_ONCE)? code : NULL; - *code = bravalue; - tempcode = code; - tempreqvary = cd->req_varyopt; /* Save value before bracket */ - length_prevgroup = 0; /* Initialize for pre-compile phase */ - - if (!compile_regex( - newoptions, /* The complete new option state */ - options & PCRE_IMS, /* The previous ims option state */ - &tempcode, /* Where to put code (updated) */ - &ptr, /* Input pointer (updated) */ - errorcodeptr, /* Where to put an error message */ - (bravalue == OP_ASSERTBACK || - bravalue == OP_ASSERTBACK_NOT), /* TRUE if back assert */ - reset_bracount, /* True if (?| group */ - skipbytes, /* Skip over bracket number */ - &subfirstbyte, /* For possible first char */ - &subreqbyte, /* For possible last char */ - bcptr, /* Current branch chain */ - cd, /* Tables block */ - (lengthptr == NULL)? NULL : /* Actual compile phase */ - &length_prevgroup /* Pre-compile phase */ - )) - goto FAILED; - - /* At the end of compiling, code is still pointing to the start of the - group, while tempcode has been updated to point past the end of the group - and any option resetting that may follow it. The pattern pointer (ptr) - is on the bracket. */ - - /* If this is a conditional bracket, check that there are no more than - two branches in the group, or just one if it's a DEFINE group. We do this - in the real compile phase, not in the pre-pass, where the whole group may - not be available. */ - - if (bravalue == OP_COND && lengthptr == NULL) - { - uschar *tc = code; - int condcount = 0; - - do { - condcount++; - tc += GET(tc,1); - } - while (*tc != OP_KET); - - /* A DEFINE group is never obeyed inline (the "condition" is always - false). It must have only one branch. */ - - if (code[LINK_SIZE+1] == OP_DEF) - { - if (condcount > 1) - { - *errorcodeptr = ERR54; - goto FAILED; - } - bravalue = OP_DEF; /* Just a flag to suppress char handling below */ - } - - /* A "normal" conditional group. If there is just one branch, we must not - make use of its firstbyte or reqbyte, because this is equivalent to an - empty second branch. */ - - else - { - if (condcount > 2) - { - *errorcodeptr = ERR27; - goto FAILED; - } - if (condcount == 1) subfirstbyte = subreqbyte = REQ_NONE; - } - } - - /* Error if hit end of pattern */ - - if (*ptr != ')') - { - *errorcodeptr = ERR14; - goto FAILED; - } - - /* In the pre-compile phase, update the length by the length of the group, - less the brackets at either end. Then reduce the compiled code to just a - set of non-capturing brackets so that it doesn't use much memory if it is - duplicated by a quantifier.*/ - - if (lengthptr != NULL) - { - if (OFLOW_MAX - *lengthptr < length_prevgroup - 2 - 2*LINK_SIZE) - { - *errorcodeptr = ERR20; - goto FAILED; - } - *lengthptr += length_prevgroup - 2 - 2*LINK_SIZE; - *code++ = OP_BRA; - PUTINC(code, 0, 1 + LINK_SIZE); - *code++ = OP_KET; - PUTINC(code, 0, 1 + LINK_SIZE); - break; /* No need to waste time with special character handling */ - } - - /* Otherwise update the main code pointer to the end of the group. */ - - code = tempcode; - - /* For a DEFINE group, required and first character settings are not - relevant. */ - - if (bravalue == OP_DEF) break; - - /* Handle updating of the required and first characters for other types of - group. Update for normal brackets of all kinds, and conditions with two - branches (see code above). If the bracket is followed by a quantifier with - zero repeat, we have to back off. Hence the definition of zeroreqbyte and - zerofirstbyte outside the main loop so that they can be accessed for the - back off. */ - - zeroreqbyte = reqbyte; - zerofirstbyte = firstbyte; - groupsetfirstbyte = FALSE; - - if (bravalue >= OP_ONCE) - { - /* If we have not yet set a firstbyte in this branch, take it from the - subpattern, remembering that it was set here so that a repeat of more - than one can replicate it as reqbyte if necessary. If the subpattern has - no firstbyte, set "none" for the whole branch. In both cases, a zero - repeat forces firstbyte to "none". */ - - if (firstbyte == REQ_UNSET) - { - if (subfirstbyte >= 0) - { - firstbyte = subfirstbyte; - groupsetfirstbyte = TRUE; - } - else firstbyte = REQ_NONE; - zerofirstbyte = REQ_NONE; - } - - /* If firstbyte was previously set, convert the subpattern's firstbyte - into reqbyte if there wasn't one, using the vary flag that was in - existence beforehand. */ - - else if (subfirstbyte >= 0 && subreqbyte < 0) - subreqbyte = subfirstbyte | tempreqvary; - - /* If the subpattern set a required byte (or set a first byte that isn't - really the first byte - see above), set it. */ - - if (subreqbyte >= 0) reqbyte = subreqbyte; - } - - /* For a forward assertion, we take the reqbyte, if set. This can be - helpful if the pattern that follows the assertion doesn't set a different - char. For example, it's useful for /(?=abcde).+/. We can't set firstbyte - for an assertion, however because it leads to incorrect effect for patterns - such as /(?=a)a.+/ when the "real" "a" would then become a reqbyte instead - of a firstbyte. This is overcome by a scan at the end if there's no - firstbyte, looking for an asserted first char. */ - - else if (bravalue == OP_ASSERT && subreqbyte >= 0) reqbyte = subreqbyte; - break; /* End of processing '(' */ - - - /* ===================================================================*/ - /* Handle metasequences introduced by \. For ones like \d, the ESC_ values - are arranged to be the negation of the corresponding OP_values. For the - back references, the values are ESC_REF plus the reference number. Only - back references and those types that consume a character may be repeated. - We can test for values between ESC_b and ESC_Z for the latter; this may - have to change if any new ones are ever created. */ - - case '\\': - tempptr = ptr; - c = check_escape(&ptr, errorcodeptr, cd->bracount, options, FALSE); - if (*errorcodeptr != 0) goto FAILED; - - if (c < 0) - { - if (-c == ESC_Q) /* Handle start of quoted string */ - { - if (ptr[1] == '\\' && ptr[2] == 'E') ptr += 2; /* avoid empty string */ - else inescq = TRUE; - continue; - } - - if (-c == ESC_E) continue; /* Perl ignores an orphan \E */ - - /* For metasequences that actually match a character, we disable the - setting of a first character if it hasn't already been set. */ - - if (firstbyte == REQ_UNSET && -c > ESC_b && -c < ESC_Z) - firstbyte = REQ_NONE; - - /* Set values to reset to if this is followed by a zero repeat. */ - - zerofirstbyte = firstbyte; - zeroreqbyte = reqbyte; - - /* \k or \k'name' is a back reference by name (Perl syntax). - We also support \k{name} (.NET syntax) */ - - if (-c == ESC_k && (ptr[1] == '<' || ptr[1] == '\'' || ptr[1] == '{')) - { - is_recurse = FALSE; - terminator = (*(++ptr) == '<')? '>' : (*ptr == '\'')? '\'' : '}'; - goto NAMED_REF_OR_RECURSE; - } - - /* Back references are handled specially; must disable firstbyte if - not set to cope with cases like (?=(\w+))\1: which would otherwise set - ':' later. */ - - if (-c >= ESC_REF) - { - recno = -c - ESC_REF; - - HANDLE_REFERENCE: /* Come here from named backref handling */ - if (firstbyte == REQ_UNSET) firstbyte = REQ_NONE; - previous = code; - *code++ = OP_REF; - PUT2INC(code, 0, recno); - cd->backref_map |= (recno < 32)? (1 << recno) : 1; - if (recno > cd->top_backref) cd->top_backref = recno; - } - - /* So are Unicode property matches, if supported. */ - -#ifdef SUPPORT_UCP - else if (-c == ESC_P || -c == ESC_p) - { - BOOL negated; - int pdata; - int ptype = get_ucp(&ptr, &negated, &pdata, errorcodeptr); - if (ptype < 0) goto FAILED; - previous = code; - *code++ = ((-c == ESC_p) != negated)? OP_PROP : OP_NOTPROP; - *code++ = ptype; - *code++ = pdata; - } -#else - - /* If Unicode properties are not supported, \X, \P, and \p are not - allowed. */ - - else if (-c == ESC_X || -c == ESC_P || -c == ESC_p) - { - *errorcodeptr = ERR45; - goto FAILED; - } -#endif - - /* For the rest (including \X when Unicode properties are supported), we - can obtain the OP value by negating the escape value. */ - - else - { - previous = (-c > ESC_b && -c < ESC_Z)? code : NULL; - *code++ = -c; - } - continue; - } - - /* We have a data character whose value is in c. In UTF-8 mode it may have - a value > 127. We set its representation in the length/buffer, and then - handle it as a data character. */ - -#ifdef SUPPORT_UTF8 - if (utf8 && c > 127) - mclength = _pcre_ord2utf8(c, mcbuffer); - else -#endif - - { - mcbuffer[0] = c; - mclength = 1; - } - goto ONE_CHAR; - - - /* ===================================================================*/ - /* Handle a literal character. It is guaranteed not to be whitespace or # - when the extended flag is set. If we are in UTF-8 mode, it may be a - multi-byte literal character. */ - - default: - NORMAL_CHAR: - mclength = 1; - mcbuffer[0] = c; - -#ifdef SUPPORT_UTF8 - if (utf8 && c >= 0xc0) - { - while ((ptr[1] & 0xc0) == 0x80) - mcbuffer[mclength++] = *(++ptr); - } -#endif - - /* At this point we have the character's bytes in mcbuffer, and the length - in mclength. When not in UTF-8 mode, the length is always 1. */ - - ONE_CHAR: - previous = code; - *code++ = ((options & PCRE_CASELESS) != 0)? OP_CHARNC : OP_CHAR; - for (c = 0; c < mclength; c++) *code++ = mcbuffer[c]; - - /* Remember if \r or \n were seen */ - - if (mcbuffer[0] == '\r' || mcbuffer[0] == '\n') - cd->external_flags |= PCRE_HASCRORLF; - - /* Set the first and required bytes appropriately. If no previous first - byte, set it from this character, but revert to none on a zero repeat. - Otherwise, leave the firstbyte value alone, and don't change it on a zero - repeat. */ - - if (firstbyte == REQ_UNSET) - { - zerofirstbyte = REQ_NONE; - zeroreqbyte = reqbyte; - - /* If the character is more than one byte long, we can set firstbyte - only if it is not to be matched caselessly. */ - - if (mclength == 1 || req_caseopt == 0) - { - firstbyte = mcbuffer[0] | req_caseopt; - if (mclength != 1) reqbyte = code[-1] | cd->req_varyopt; - } - else firstbyte = reqbyte = REQ_NONE; - } - - /* firstbyte was previously set; we can set reqbyte only the length is - 1 or the matching is caseful. */ - - else - { - zerofirstbyte = firstbyte; - zeroreqbyte = reqbyte; - if (mclength == 1 || req_caseopt == 0) - reqbyte = code[-1] | req_caseopt | cd->req_varyopt; - } - - break; /* End of literal character handling */ - } - } /* end of big loop */ - - -/* Control never reaches here by falling through, only by a goto for all the -error states. Pass back the position in the pattern so that it can be displayed -to the user for diagnosing the error. */ - -FAILED: -*ptrptr = ptr; -return FALSE; -} - - - - -/************************************************* -* Compile sequence of alternatives * -*************************************************/ - -/* On entry, ptr is pointing past the bracket character, but on return it -points to the closing bracket, or vertical bar, or end of string. The code -variable is pointing at the byte into which the BRA operator has been stored. -If the ims options are changed at the start (for a (?ims: group) or during any -branch, we need to insert an OP_OPT item at the start of every following branch -to ensure they get set correctly at run time, and also pass the new options -into every subsequent branch compile. - -This function is used during the pre-compile phase when we are trying to find -out the amount of memory needed, as well as during the real compile phase. The -value of lengthptr distinguishes the two phases. - -Arguments: - options option bits, including any changes for this subpattern - oldims previous settings of ims option bits - codeptr -> the address of the current code pointer - ptrptr -> the address of the current pattern pointer - errorcodeptr -> pointer to error code variable - lookbehind TRUE if this is a lookbehind assertion - reset_bracount TRUE to reset the count for each branch - skipbytes skip this many bytes at start (for brackets and OP_COND) - firstbyteptr place to put the first required character, or a negative number - reqbyteptr place to put the last required character, or a negative number - bcptr pointer to the chain of currently open branches - cd points to the data block with tables pointers etc. - lengthptr NULL during the real compile phase - points to length accumulator during pre-compile phase - -Returns: TRUE on success -*/ - -static BOOL -compile_regex(int options, int oldims, uschar **codeptr, const uschar **ptrptr, - int *errorcodeptr, BOOL lookbehind, BOOL reset_bracount, int skipbytes, - int *firstbyteptr, int *reqbyteptr, branch_chain *bcptr, compile_data *cd, - int *lengthptr) -{ -const uschar *ptr = *ptrptr; -uschar *code = *codeptr; -uschar *last_branch = code; -uschar *start_bracket = code; -uschar *reverse_count = NULL; -int firstbyte, reqbyte; -int branchfirstbyte, branchreqbyte; -int length; -int orig_bracount; -int max_bracount; -branch_chain bc; - -bc.outer = bcptr; -bc.current = code; - -firstbyte = reqbyte = REQ_UNSET; - -/* Accumulate the length for use in the pre-compile phase. Start with the -length of the BRA and KET and any extra bytes that are required at the -beginning. We accumulate in a local variable to save frequent testing of -lenthptr for NULL. We cannot do this by looking at the value of code at the -start and end of each alternative, because compiled items are discarded during -the pre-compile phase so that the work space is not exceeded. */ - -length = 2 + 2*LINK_SIZE + skipbytes; - -/* WARNING: If the above line is changed for any reason, you must also change -the code that abstracts option settings at the start of the pattern and makes -them global. It tests the value of length for (2 + 2*LINK_SIZE) in the -pre-compile phase to find out whether anything has yet been compiled or not. */ - -/* Offset is set zero to mark that this bracket is still open */ - -PUT(code, 1, 0); -code += 1 + LINK_SIZE + skipbytes; - -/* Loop for each alternative branch */ - -orig_bracount = max_bracount = cd->bracount; -for (;;) - { - /* For a (?| group, reset the capturing bracket count so that each branch - uses the same numbers. */ - - if (reset_bracount) cd->bracount = orig_bracount; - - /* Handle a change of ims options at the start of the branch */ - - if ((options & PCRE_IMS) != oldims) - { - *code++ = OP_OPT; - *code++ = options & PCRE_IMS; - length += 2; - } - - /* Set up dummy OP_REVERSE if lookbehind assertion */ - - if (lookbehind) - { - *code++ = OP_REVERSE; - reverse_count = code; - PUTINC(code, 0, 0); - length += 1 + LINK_SIZE; - } - - /* Now compile the branch; in the pre-compile phase its length gets added - into the length. */ - - if (!compile_branch(&options, &code, &ptr, errorcodeptr, &branchfirstbyte, - &branchreqbyte, &bc, cd, (lengthptr == NULL)? NULL : &length)) - { - *ptrptr = ptr; - return FALSE; - } - - /* Keep the highest bracket count in case (?| was used and some branch - has fewer than the rest. */ - - if (cd->bracount > max_bracount) max_bracount = cd->bracount; - - /* In the real compile phase, there is some post-processing to be done. */ - - if (lengthptr == NULL) - { - /* If this is the first branch, the firstbyte and reqbyte values for the - branch become the values for the regex. */ - - if (*last_branch != OP_ALT) - { - firstbyte = branchfirstbyte; - reqbyte = branchreqbyte; - } - - /* If this is not the first branch, the first char and reqbyte have to - match the values from all the previous branches, except that if the - previous value for reqbyte didn't have REQ_VARY set, it can still match, - and we set REQ_VARY for the regex. */ - - else - { - /* If we previously had a firstbyte, but it doesn't match the new branch, - we have to abandon the firstbyte for the regex, but if there was - previously no reqbyte, it takes on the value of the old firstbyte. */ - - if (firstbyte >= 0 && firstbyte != branchfirstbyte) - { - if (reqbyte < 0) reqbyte = firstbyte; - firstbyte = REQ_NONE; - } - - /* If we (now or from before) have no firstbyte, a firstbyte from the - branch becomes a reqbyte if there isn't a branch reqbyte. */ - - if (firstbyte < 0 && branchfirstbyte >= 0 && branchreqbyte < 0) - branchreqbyte = branchfirstbyte; - - /* Now ensure that the reqbytes match */ - - if ((reqbyte & ~REQ_VARY) != (branchreqbyte & ~REQ_VARY)) - reqbyte = REQ_NONE; - else reqbyte |= branchreqbyte; /* To "or" REQ_VARY */ - } - - /* If lookbehind, check that this branch matches a fixed-length string, and - put the length into the OP_REVERSE item. Temporarily mark the end of the - branch with OP_END. */ - - if (lookbehind) - { - int fixed_length; - *code = OP_END; - fixed_length = find_fixedlength(last_branch, options); - DPRINTF(("fixed length = %d\n", fixed_length)); - if (fixed_length < 0) - { - *errorcodeptr = (fixed_length == -2)? ERR36 : ERR25; - *ptrptr = ptr; - return FALSE; - } - PUT(reverse_count, 0, fixed_length); - } - } - - /* Reached end of expression, either ')' or end of pattern. In the real - compile phase, go back through the alternative branches and reverse the chain - of offsets, with the field in the BRA item now becoming an offset to the - first alternative. If there are no alternatives, it points to the end of the - group. The length in the terminating ket is always the length of the whole - bracketed item. If any of the ims options were changed inside the group, - compile a resetting op-code following, except at the very end of the pattern. - Return leaving the pointer at the terminating char. */ - - if (*ptr != '|') - { - if (lengthptr == NULL) - { - int branch_length = code - last_branch; - do - { - int prev_length = GET(last_branch, 1); - PUT(last_branch, 1, branch_length); - branch_length = prev_length; - last_branch -= branch_length; - } - while (branch_length > 0); - } - - /* Fill in the ket */ - - *code = OP_KET; - PUT(code, 1, code - start_bracket); - code += 1 + LINK_SIZE; - - /* Resetting option if needed */ - - if ((options & PCRE_IMS) != oldims && *ptr == ')') - { - *code++ = OP_OPT; - *code++ = oldims; - length += 2; - } - - /* Retain the highest bracket number, in case resetting was used. */ - - cd->bracount = max_bracount; - - /* Set values to pass back */ - - *codeptr = code; - *ptrptr = ptr; - *firstbyteptr = firstbyte; - *reqbyteptr = reqbyte; - if (lengthptr != NULL) - { - if (OFLOW_MAX - *lengthptr < length) - { - *errorcodeptr = ERR20; - return FALSE; - } - *lengthptr += length; - } - return TRUE; - } - - /* Another branch follows. In the pre-compile phase, we can move the code - pointer back to where it was for the start of the first branch. (That is, - pretend that each branch is the only one.) - - In the real compile phase, insert an ALT node. Its length field points back - to the previous branch while the bracket remains open. At the end the chain - is reversed. It's done like this so that the start of the bracket has a - zero offset until it is closed, making it possible to detect recursion. */ - - if (lengthptr != NULL) - { - code = *codeptr + 1 + LINK_SIZE + skipbytes; - length += 1 + LINK_SIZE; - } - else - { - *code = OP_ALT; - PUT(code, 1, code - last_branch); - bc.current = last_branch = code; - code += 1 + LINK_SIZE; - } - - ptr++; - } -/* Control never reaches here */ -} - - - - -/************************************************* -* Check for anchored expression * -*************************************************/ - -/* Try to find out if this is an anchored regular expression. Consider each -alternative branch. If they all start with OP_SOD or OP_CIRC, or with a bracket -all of whose alternatives start with OP_SOD or OP_CIRC (recurse ad lib), then -it's anchored. However, if this is a multiline pattern, then only OP_SOD -counts, since OP_CIRC can match in the middle. - -We can also consider a regex to be anchored if OP_SOM starts all its branches. -This is the code for \G, which means "match at start of match position, taking -into account the match offset". - -A branch is also implicitly anchored if it starts with .* and DOTALL is set, -because that will try the rest of the pattern at all possible matching points, -so there is no point trying again.... er .... - -.... except when the .* appears inside capturing parentheses, and there is a -subsequent back reference to those parentheses. We haven't enough information -to catch that case precisely. - -At first, the best we could do was to detect when .* was in capturing brackets -and the highest back reference was greater than or equal to that level. -However, by keeping a bitmap of the first 31 back references, we can catch some -of the more common cases more precisely. - -Arguments: - code points to start of expression (the bracket) - options points to the options setting - bracket_map a bitmap of which brackets we are inside while testing; this - handles up to substring 31; after that we just have to take - the less precise approach - backref_map the back reference bitmap - -Returns: TRUE or FALSE -*/ - -static BOOL -is_anchored(register const uschar *code, int *options, unsigned int bracket_map, - unsigned int backref_map) -{ -do { - const uschar *scode = first_significant_code(code + _pcre_OP_lengths[*code], - options, PCRE_MULTILINE, FALSE); - register int op = *scode; - - /* Non-capturing brackets */ - - if (op == OP_BRA) - { - if (!is_anchored(scode, options, bracket_map, backref_map)) return FALSE; - } - - /* Capturing brackets */ - - else if (op == OP_CBRA) - { - int n = GET2(scode, 1+LINK_SIZE); - int new_map = bracket_map | ((n < 32)? (1 << n) : 1); - if (!is_anchored(scode, options, new_map, backref_map)) return FALSE; - } - - /* Other brackets */ - - else if (op == OP_ASSERT || op == OP_ONCE || op == OP_COND) - { - if (!is_anchored(scode, options, bracket_map, backref_map)) return FALSE; - } - - /* .* is not anchored unless DOTALL is set and it isn't in brackets that - are or may be referenced. */ - - else if ((op == OP_TYPESTAR || op == OP_TYPEMINSTAR || - op == OP_TYPEPOSSTAR) && - (*options & PCRE_DOTALL) != 0) - { - if (scode[1] != OP_ANY || (bracket_map & backref_map) != 0) return FALSE; - } - - /* Check for explicit anchoring */ - - else if (op != OP_SOD && op != OP_SOM && - ((*options & PCRE_MULTILINE) != 0 || op != OP_CIRC)) - return FALSE; - code += GET(code, 1); - } -while (*code == OP_ALT); /* Loop for each alternative */ -return TRUE; -} - - - -/************************************************* -* Check for starting with ^ or .* * -*************************************************/ - -/* This is called to find out if every branch starts with ^ or .* so that -"first char" processing can be done to speed things up in multiline -matching and for non-DOTALL patterns that start with .* (which must start at -the beginning or after \n). As in the case of is_anchored() (see above), we -have to take account of back references to capturing brackets that contain .* -because in that case we can't make the assumption. - -Arguments: - code points to start of expression (the bracket) - bracket_map a bitmap of which brackets we are inside while testing; this - handles up to substring 31; after that we just have to take - the less precise approach - backref_map the back reference bitmap - -Returns: TRUE or FALSE -*/ - -static BOOL -is_startline(const uschar *code, unsigned int bracket_map, - unsigned int backref_map) -{ -do { - const uschar *scode = first_significant_code(code + _pcre_OP_lengths[*code], - NULL, 0, FALSE); - register int op = *scode; - - /* Non-capturing brackets */ - - if (op == OP_BRA) - { - if (!is_startline(scode, bracket_map, backref_map)) return FALSE; - } - - /* Capturing brackets */ - - else if (op == OP_CBRA) - { - int n = GET2(scode, 1+LINK_SIZE); - int new_map = bracket_map | ((n < 32)? (1 << n) : 1); - if (!is_startline(scode, new_map, backref_map)) return FALSE; - } - - /* Other brackets */ - - else if (op == OP_ASSERT || op == OP_ONCE || op == OP_COND) - { if (!is_startline(scode, bracket_map, backref_map)) return FALSE; } - - /* .* means "start at start or after \n" if it isn't in brackets that - may be referenced. */ - - else if (op == OP_TYPESTAR || op == OP_TYPEMINSTAR || op == OP_TYPEPOSSTAR) - { - if (scode[1] != OP_ANY || (bracket_map & backref_map) != 0) return FALSE; - } - - /* Check for explicit circumflex */ - - else if (op != OP_CIRC) return FALSE; - - /* Move on to the next alternative */ - - code += GET(code, 1); - } -while (*code == OP_ALT); /* Loop for each alternative */ -return TRUE; -} - - - -/************************************************* -* Check for asserted fixed first char * -*************************************************/ - -/* During compilation, the "first char" settings from forward assertions are -discarded, because they can cause conflicts with actual literals that follow. -However, if we end up without a first char setting for an unanchored pattern, -it is worth scanning the regex to see if there is an initial asserted first -char. If all branches start with the same asserted char, or with a bracket all -of whose alternatives start with the same asserted char (recurse ad lib), then -we return that char, otherwise -1. - -Arguments: - code points to start of expression (the bracket) - options pointer to the options (used to check casing changes) - inassert TRUE if in an assertion - -Returns: -1 or the fixed first char -*/ - -static int -find_firstassertedchar(const uschar *code, int *options, BOOL inassert) -{ -register int c = -1; -do { - int d; - const uschar *scode = - first_significant_code(code + 1+LINK_SIZE, options, PCRE_CASELESS, TRUE); - register int op = *scode; - - switch(op) - { - default: - return -1; - - case OP_BRA: - case OP_CBRA: - case OP_ASSERT: - case OP_ONCE: - case OP_COND: - if ((d = find_firstassertedchar(scode, options, op == OP_ASSERT)) < 0) - return -1; - if (c < 0) c = d; else if (c != d) return -1; - break; - - case OP_EXACT: /* Fall through */ - scode += 2; - - case OP_CHAR: - case OP_CHARNC: - case OP_PLUS: - case OP_MINPLUS: - case OP_POSPLUS: - if (!inassert) return -1; - if (c < 0) - { - c = scode[1]; - if ((*options & PCRE_CASELESS) != 0) c |= REQ_CASELESS; - } - else if (c != scode[1]) return -1; - break; - } - - code += GET(code, 1); - } -while (*code == OP_ALT); -return c; -} - - - -/************************************************* -* Compile a Regular Expression * -*************************************************/ - -/* This function takes a string and returns a pointer to a block of store -holding a compiled version of the expression. The original API for this -function had no error code return variable; it is retained for backwards -compatibility. The new function is given a new name. - -Arguments: - pattern the regular expression - options various option bits - errorcodeptr pointer to error code variable (pcre_compile2() only) - can be NULL if you don't want a code value - errorptr pointer to pointer to error text - erroroffset ptr offset in pattern where error was detected - tables pointer to character tables or NULL - -Returns: pointer to compiled data block, or NULL on error, - with errorptr and erroroffset set -*/ - -PCRE_EXP_DEFN pcre * -pcre_compile(const char *pattern, int options, const char **errorptr, - int *erroroffset, const unsigned char *tables) -{ -return pcre_compile2(pattern, options, NULL, errorptr, erroroffset, tables); -} - - -PCRE_EXP_DEFN pcre * -pcre_compile2(const char *pattern, int options, int *errorcodeptr, - const char **errorptr, int *erroroffset, const unsigned char *tables) -{ -real_pcre *re; -int length = 1; /* For final END opcode */ -int firstbyte, reqbyte, newline; -int errorcode = 0; -int skipatstart = 0; -#ifdef SUPPORT_UTF8 -BOOL utf8; -#endif -size_t size; -uschar *code; -const uschar *codestart; -const uschar *ptr; -compile_data compile_block; -compile_data *cd = &compile_block; - -/* This space is used for "compiling" into during the first phase, when we are -computing the amount of memory that is needed. Compiled items are thrown away -as soon as possible, so that a fairly large buffer should be sufficient for -this purpose. The same space is used in the second phase for remembering where -to fill in forward references to subpatterns. */ - -uschar cworkspace[COMPILE_WORK_SIZE]; - - -/* Set this early so that early errors get offset 0. */ - -ptr = (const uschar *)pattern; - -/* We can't pass back an error message if errorptr is NULL; I guess the best we -can do is just return NULL, but we can set a code value if there is a code -pointer. */ - -if (errorptr == NULL) - { - if (errorcodeptr != NULL) *errorcodeptr = 99; - return NULL; - } - -*errorptr = NULL; -if (errorcodeptr != NULL) *errorcodeptr = ERR0; - -/* However, we can give a message for this error */ - -if (erroroffset == NULL) - { - errorcode = ERR16; - goto PCRE_EARLY_ERROR_RETURN2; - } - -*erroroffset = 0; - -/* Can't support UTF8 unless PCRE has been compiled to include the code. */ - -#ifdef SUPPORT_UTF8 -utf8 = (options & PCRE_UTF8) != 0; -if (utf8 && (options & PCRE_NO_UTF8_CHECK) == 0 && - (*erroroffset = _pcre_valid_utf8((uschar *)pattern, -1)) >= 0) - { - errorcode = ERR44; - goto PCRE_EARLY_ERROR_RETURN2; - } -#else -if ((options & PCRE_UTF8) != 0) - { - errorcode = ERR32; - goto PCRE_EARLY_ERROR_RETURN; - } -#endif - -if ((options & ~PUBLIC_OPTIONS) != 0) - { - errorcode = ERR17; - goto PCRE_EARLY_ERROR_RETURN; - } - -/* Set up pointers to the individual character tables */ - -if (tables == NULL) tables = _pcre_default_tables; -cd->lcc = tables + lcc_offset; -cd->fcc = tables + fcc_offset; -cd->cbits = tables + cbits_offset; -cd->ctypes = tables + ctypes_offset; - -/* Check for global one-time settings at the start of the pattern, and remember -the offset for later. */ - -while (ptr[skipatstart] == '(' && ptr[skipatstart+1] == '*') - { - int newnl = 0; - int newbsr = 0; - - if (strncmp((char *)(ptr+skipatstart+2), "CR)", 3) == 0) - { skipatstart += 5; newnl = PCRE_NEWLINE_CR; } - else if (strncmp((char *)(ptr+skipatstart+2), "LF)", 3) == 0) - { skipatstart += 5; newnl = PCRE_NEWLINE_LF; } - else if (strncmp((char *)(ptr+skipatstart+2), "CRLF)", 5) == 0) - { skipatstart += 7; newnl = PCRE_NEWLINE_CR + PCRE_NEWLINE_LF; } - else if (strncmp((char *)(ptr+skipatstart+2), "ANY)", 4) == 0) - { skipatstart += 6; newnl = PCRE_NEWLINE_ANY; } - else if (strncmp((char *)(ptr+skipatstart+2), "ANYCRLF)", 8) == 0) - { skipatstart += 10; newnl = PCRE_NEWLINE_ANYCRLF; } - - else if (strncmp((char *)(ptr+skipatstart+2), "BSR_ANYCRLF)", 12) == 0) - { skipatstart += 14; newbsr = PCRE_BSR_ANYCRLF; } - else if (strncmp((char *)(ptr+skipatstart+2), "BSR_UNICODE)", 12) == 0) - { skipatstart += 14; newbsr = PCRE_BSR_UNICODE; } - - if (newnl != 0) - options = (options & ~PCRE_NEWLINE_BITS) | newnl; - else if (newbsr != 0) - options = (options & ~(PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE)) | newbsr; - else break; - } - -/* Check validity of \R options. */ - -switch (options & (PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE)) - { - case 0: - case PCRE_BSR_ANYCRLF: - case PCRE_BSR_UNICODE: - break; - default: errorcode = ERR56; goto PCRE_EARLY_ERROR_RETURN; - } - -/* Handle different types of newline. The three bits give seven cases. The -current code allows for fixed one- or two-byte sequences, plus "any" and -"anycrlf". */ - -switch (options & PCRE_NEWLINE_BITS) - { - case 0: newline = NEWLINE; break; /* Build-time default */ - case PCRE_NEWLINE_CR: newline = '\r'; break; - case PCRE_NEWLINE_LF: newline = '\n'; break; - case PCRE_NEWLINE_CR+ - PCRE_NEWLINE_LF: newline = ('\r' << 8) | '\n'; break; - case PCRE_NEWLINE_ANY: newline = -1; break; - case PCRE_NEWLINE_ANYCRLF: newline = -2; break; - default: errorcode = ERR56; goto PCRE_EARLY_ERROR_RETURN; - } - -if (newline == -2) - { - cd->nltype = NLTYPE_ANYCRLF; - } -else if (newline < 0) - { - cd->nltype = NLTYPE_ANY; - } -else - { - cd->nltype = NLTYPE_FIXED; - if (newline > 255) - { - cd->nllen = 2; - cd->nl[0] = (newline >> 8) & 255; - cd->nl[1] = newline & 255; - } - else - { - cd->nllen = 1; - cd->nl[0] = newline; - } - } - -/* Maximum back reference and backref bitmap. The bitmap records up to 31 back -references to help in deciding whether (.*) can be treated as anchored or not. -*/ - -cd->top_backref = 0; -cd->backref_map = 0; - -/* Reflect pattern for debugging output */ - -DPRINTF(("------------------------------------------------------------------\n")); -DPRINTF(("%s\n", pattern)); - -/* Pretend to compile the pattern while actually just accumulating the length -of memory required. This behaviour is triggered by passing a non-NULL final -argument to compile_regex(). We pass a block of workspace (cworkspace) for it -to compile parts of the pattern into; the compiled code is discarded when it is -no longer needed, so hopefully this workspace will never overflow, though there -is a test for its doing so. */ - -cd->bracount = 0; -cd->names_found = 0; -cd->name_entry_size = 0; -cd->name_table = NULL; -cd->start_workspace = cworkspace; -cd->start_code = cworkspace; -cd->hwm = cworkspace; -cd->start_pattern = (const uschar *)pattern; -cd->end_pattern = (const uschar *)(pattern + strlen(pattern)); -cd->req_varyopt = 0; -cd->external_options = options; -cd->external_flags = 0; - -/* Now do the pre-compile. On error, errorcode will be set non-zero, so we -don't need to look at the result of the function here. The initial options have -been put into the cd block so that they can be changed if an option setting is -found within the regex right at the beginning. Bringing initial option settings -outside can help speed up starting point checks. */ - -ptr += skipatstart; -code = cworkspace; -*code = OP_BRA; -(void)compile_regex(cd->external_options, cd->external_options & PCRE_IMS, - &code, &ptr, &errorcode, FALSE, FALSE, 0, &firstbyte, &reqbyte, NULL, cd, - &length); -if (errorcode != 0) goto PCRE_EARLY_ERROR_RETURN; - -DPRINTF(("end pre-compile: length=%d workspace=%d\n", length, - cd->hwm - cworkspace)); - -if (length > MAX_PATTERN_SIZE) - { - errorcode = ERR20; - goto PCRE_EARLY_ERROR_RETURN; - } - -/* Compute the size of data block needed and get it, either from malloc or -externally provided function. Integer overflow should no longer be possible -because nowadays we limit the maximum value of cd->names_found and -cd->name_entry_size. */ - -size = length + sizeof(real_pcre) + cd->names_found * (cd->name_entry_size + 3); -re = (real_pcre *)(pcre_malloc)(size); - -if (re == NULL) - { - errorcode = ERR21; - goto PCRE_EARLY_ERROR_RETURN; - } - -/* Put in the magic number, and save the sizes, initial options, internal -flags, and character table pointer. NULL is used for the default character -tables. The nullpad field is at the end; it's there to help in the case when a -regex compiled on a system with 4-byte pointers is run on another with 8-byte -pointers. */ - -re->magic_number = MAGIC_NUMBER; -re->size = size; -re->options = cd->external_options; -re->flags = cd->external_flags; -re->dummy1 = 0; -re->first_byte = 0; -re->req_byte = 0; -re->name_table_offset = sizeof(real_pcre); -re->name_entry_size = cd->name_entry_size; -re->name_count = cd->names_found; -re->ref_count = 0; -re->tables = (tables == _pcre_default_tables)? NULL : tables; -re->nullpad = NULL; - -/* The starting points of the name/number translation table and of the code are -passed around in the compile data block. The start/end pattern and initial -options are already set from the pre-compile phase, as is the name_entry_size -field. Reset the bracket count and the names_found field. Also reset the hwm -field; this time it's used for remembering forward references to subpatterns. -*/ - -cd->bracount = 0; -cd->names_found = 0; -cd->name_table = (uschar *)re + re->name_table_offset; -codestart = cd->name_table + re->name_entry_size * re->name_count; -cd->start_code = codestart; -cd->hwm = cworkspace; -cd->req_varyopt = 0; -cd->had_accept = FALSE; - -/* Set up a starting, non-extracting bracket, then compile the expression. On -error, errorcode will be set non-zero, so we don't need to look at the result -of the function here. */ - -ptr = (const uschar *)pattern + skipatstart; -code = (uschar *)codestart; -*code = OP_BRA; -(void)compile_regex(re->options, re->options & PCRE_IMS, &code, &ptr, - &errorcode, FALSE, FALSE, 0, &firstbyte, &reqbyte, NULL, cd, NULL); -re->top_bracket = cd->bracount; -re->top_backref = cd->top_backref; -re->flags = cd->external_flags; - -if (cd->had_accept) reqbyte = -1; /* Must disable after (*ACCEPT) */ - -/* If not reached end of pattern on success, there's an excess bracket. */ - -if (errorcode == 0 && *ptr != 0) errorcode = ERR22; - -/* Fill in the terminating state and check for disastrous overflow, but -if debugging, leave the test till after things are printed out. */ - -*code++ = OP_END; - -#ifndef DEBUG -if (code - codestart > length) errorcode = ERR23; -#endif - -/* Fill in any forward references that are required. */ - -while (errorcode == 0 && cd->hwm > cworkspace) - { - int offset, recno; - const uschar *groupptr; - cd->hwm -= LINK_SIZE; - offset = GET(cd->hwm, 0); - recno = GET(codestart, offset); - groupptr = find_bracket(codestart, (re->options & PCRE_UTF8) != 0, recno); - if (groupptr == NULL) errorcode = ERR53; - else PUT(((uschar *)codestart), offset, groupptr - codestart); - } - -/* Give an error if there's back reference to a non-existent capturing -subpattern. */ - -if (errorcode == 0 && re->top_backref > re->top_bracket) errorcode = ERR15; - -/* Failed to compile, or error while post-processing */ - -if (errorcode != 0) - { - (pcre_free)(re); - PCRE_EARLY_ERROR_RETURN: - *erroroffset = ptr - (const uschar *)pattern; - PCRE_EARLY_ERROR_RETURN2: - *errorptr = find_error_text(errorcode); - if (errorcodeptr != NULL) *errorcodeptr = errorcode; - return NULL; - } - -/* If the anchored option was not passed, set the flag if we can determine that -the pattern is anchored by virtue of ^ characters or \A or anything else (such -as starting with .* when DOTALL is set). - -Otherwise, if we know what the first byte has to be, save it, because that -speeds up unanchored matches no end. If not, see if we can set the -PCRE_STARTLINE flag. This is helpful for multiline matches when all branches -start with ^. and also when all branches start with .* for non-DOTALL matches. -*/ - -if ((re->options & PCRE_ANCHORED) == 0) - { - int temp_options = re->options; /* May get changed during these scans */ - if (is_anchored(codestart, &temp_options, 0, cd->backref_map)) - re->options |= PCRE_ANCHORED; - else - { - if (firstbyte < 0) - firstbyte = find_firstassertedchar(codestart, &temp_options, FALSE); - if (firstbyte >= 0) /* Remove caseless flag for non-caseable chars */ - { - int ch = firstbyte & 255; - re->first_byte = ((firstbyte & REQ_CASELESS) != 0 && - cd->fcc[ch] == ch)? ch : firstbyte; - re->flags |= PCRE_FIRSTSET; - } - else if (is_startline(codestart, 0, cd->backref_map)) - re->flags |= PCRE_STARTLINE; - } - } - -/* For an anchored pattern, we use the "required byte" only if it follows a -variable length item in the regex. Remove the caseless flag for non-caseable -bytes. */ - -if (reqbyte >= 0 && - ((re->options & PCRE_ANCHORED) == 0 || (reqbyte & REQ_VARY) != 0)) - { - int ch = reqbyte & 255; - re->req_byte = ((reqbyte & REQ_CASELESS) != 0 && - cd->fcc[ch] == ch)? (reqbyte & ~REQ_CASELESS) : reqbyte; - re->flags |= PCRE_REQCHSET; - } - -/* Print out the compiled data if debugging is enabled. This is never the -case when building a production library. */ - -#ifdef DEBUG - -printf("Length = %d top_bracket = %d top_backref = %d\n", - length, re->top_bracket, re->top_backref); - -printf("Options=%08x\n", re->options); - -if ((re->flags & PCRE_FIRSTSET) != 0) - { - int ch = re->first_byte & 255; - const char *caseless = ((re->first_byte & REQ_CASELESS) == 0)? - "" : " (caseless)"; - if (isprint(ch)) printf("First char = %c%s\n", ch, caseless); - else printf("First char = \\x%02x%s\n", ch, caseless); - } - -if ((re->flags & PCRE_REQCHSET) != 0) - { - int ch = re->req_byte & 255; - const char *caseless = ((re->req_byte & REQ_CASELESS) == 0)? - "" : " (caseless)"; - if (isprint(ch)) printf("Req char = %c%s\n", ch, caseless); - else printf("Req char = \\x%02x%s\n", ch, caseless); - } - -pcre_printint(re, stdout, TRUE); - -/* This check is done here in the debugging case so that the code that -was compiled can be seen. */ - -if (code - codestart > length) - { - (pcre_free)(re); - *errorptr = find_error_text(ERR23); - *erroroffset = ptr - (uschar *)pattern; - if (errorcodeptr != NULL) *errorcodeptr = ERR23; - return NULL; - } -#endif /* DEBUG */ - -return (pcre *)re; -} - -/* End of pcre_compile.c */ diff --git a/src/plugins/PCREPlugin/pcre_config.c b/src/plugins/PCREPlugin/pcre_config.c deleted file mode 100644 index 220ef93..0000000 --- a/src/plugins/PCREPlugin/pcre_config.c +++ /dev/null @@ -1,128 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_config(). */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Return info about what features are configured * -*************************************************/ - -/* This function has an extensible interface so that additional items can be -added compatibly. - -Arguments: - what what information is required - where where to put the information - -Returns: 0 if data returned, negative on error -*/ - -PCRE_EXP_DEFN int -pcre_config(int what, void *where) -{ -switch (what) - { - case PCRE_CONFIG_UTF8: -#ifdef SUPPORT_UTF8 - *((int *)where) = 1; -#else - *((int *)where) = 0; -#endif - break; - - case PCRE_CONFIG_UNICODE_PROPERTIES: -#ifdef SUPPORT_UCP - *((int *)where) = 1; -#else - *((int *)where) = 0; -#endif - break; - - case PCRE_CONFIG_NEWLINE: - *((int *)where) = NEWLINE; - break; - - case PCRE_CONFIG_BSR: -#ifdef BSR_ANYCRLF - *((int *)where) = 1; -#else - *((int *)where) = 0; -#endif - break; - - case PCRE_CONFIG_LINK_SIZE: - *((int *)where) = LINK_SIZE; - break; - - case PCRE_CONFIG_POSIX_MALLOC_THRESHOLD: - *((int *)where) = POSIX_MALLOC_THRESHOLD; - break; - - case PCRE_CONFIG_MATCH_LIMIT: - *((unsigned int *)where) = MATCH_LIMIT; - break; - - case PCRE_CONFIG_MATCH_LIMIT_RECURSION: - *((unsigned int *)where) = MATCH_LIMIT_RECURSION; - break; - - case PCRE_CONFIG_STACKRECURSE: -#ifdef NO_RECURSE - *((int *)where) = 0; -#else - *((int *)where) = 1; -#endif - break; - - default: return PCRE_ERROR_BADOPTION; - } - -return 0; -} - -/* End of pcre_config.c */ diff --git a/src/plugins/PCREPlugin/pcre_dfa_exec.c b/src/plugins/PCREPlugin/pcre_dfa_exec.c deleted file mode 100644 index e590fbb..0000000 --- a/src/plugins/PCREPlugin/pcre_dfa_exec.c +++ /dev/null @@ -1,2896 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_dfa_exec(), which is an -alternative matching function that uses a sort of DFA algorithm (not a true -FSM). This is NOT Perl- compatible, but it has advantages in certain -applications. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#define NLBLOCK md /* Block containing newline information */ -#define PSSTART start_subject /* Field containing processed string start */ -#define PSEND end_subject /* Field containing processed string end */ - -#include "pcre_internal.h" - - -/* For use to indent debugging output */ - -#define SP " " - - - -/************************************************* -* Code parameters and static tables * -*************************************************/ - -/* These are offsets that are used to turn the OP_TYPESTAR and friends opcodes -into others, under special conditions. A gap of 20 between the blocks should be -enough. The resulting opcodes don't have to be less than 256 because they are -never stored, so we push them well clear of the normal opcodes. */ - -#define OP_PROP_EXTRA 300 -#define OP_EXTUNI_EXTRA 320 -#define OP_ANYNL_EXTRA 340 -#define OP_HSPACE_EXTRA 360 -#define OP_VSPACE_EXTRA 380 - - -/* This table identifies those opcodes that are followed immediately by a -character that is to be tested in some way. This makes is possible to -centralize the loading of these characters. In the case of Type * etc, the -"character" is the opcode for \D, \d, \S, \s, \W, or \w, which will always be a -small value. ***NOTE*** If the start of this table is modified, the two tables -that follow must also be modified. */ - -static uschar coptable[] = { - 0, /* End */ - 0, 0, 0, 0, 0, /* \A, \G, \K, \B, \b */ - 0, 0, 0, 0, 0, 0, /* \D, \d, \S, \s, \W, \w */ - 0, 0, /* Any, Anybyte */ - 0, 0, 0, /* NOTPROP, PROP, EXTUNI */ - 0, 0, 0, 0, 0, /* \R, \H, \h, \V, \v */ - 0, 0, 0, 0, 0, /* \Z, \z, Opt, ^, $ */ - 1, /* Char */ - 1, /* Charnc */ - 1, /* not */ - /* Positive single-char repeats */ - 1, 1, 1, 1, 1, 1, /* *, *?, +, +?, ?, ?? */ - 3, 3, 3, /* upto, minupto, exact */ - 1, 1, 1, 3, /* *+, ++, ?+, upto+ */ - /* Negative single-char repeats - only for chars < 256 */ - 1, 1, 1, 1, 1, 1, /* NOT *, *?, +, +?, ?, ?? */ - 3, 3, 3, /* NOT upto, minupto, exact */ - 1, 1, 1, 3, /* NOT *+, ++, ?+, updo+ */ - /* Positive type repeats */ - 1, 1, 1, 1, 1, 1, /* Type *, *?, +, +?, ?, ?? */ - 3, 3, 3, /* Type upto, minupto, exact */ - 1, 1, 1, 3, /* Type *+, ++, ?+, upto+ */ - /* Character class & ref repeats */ - 0, 0, 0, 0, 0, 0, /* *, *?, +, +?, ?, ?? */ - 0, 0, /* CRRANGE, CRMINRANGE */ - 0, /* CLASS */ - 0, /* NCLASS */ - 0, /* XCLASS - variable length */ - 0, /* REF */ - 0, /* RECURSE */ - 0, /* CALLOUT */ - 0, /* Alt */ - 0, /* Ket */ - 0, /* KetRmax */ - 0, /* KetRmin */ - 0, /* Assert */ - 0, /* Assert not */ - 0, /* Assert behind */ - 0, /* Assert behind not */ - 0, /* Reverse */ - 0, 0, 0, 0, /* ONCE, BRA, CBRA, COND */ - 0, 0, 0, /* SBRA, SCBRA, SCOND */ - 0, /* CREF */ - 0, /* RREF */ - 0, /* DEF */ - 0, 0, /* BRAZERO, BRAMINZERO */ - 0, 0, 0, 0, /* PRUNE, SKIP, THEN, COMMIT */ - 0, 0 /* FAIL, ACCEPT */ -}; - -/* These 2 tables allow for compact code for testing for \D, \d, \S, \s, \W, -and \w */ - -static uschar toptable1[] = { - 0, 0, 0, 0, 0, 0, - ctype_digit, ctype_digit, - ctype_space, ctype_space, - ctype_word, ctype_word, - 0 /* OP_ANY */ -}; - -static uschar toptable2[] = { - 0, 0, 0, 0, 0, 0, - ctype_digit, 0, - ctype_space, 0, - ctype_word, 0, - 1 /* OP_ANY */ -}; - - -/* Structure for holding data about a particular state, which is in effect the -current data for an active path through the match tree. It must consist -entirely of ints because the working vector we are passed, and which we put -these structures in, is a vector of ints. */ - -typedef struct stateblock { - int offset; /* Offset to opcode */ - int count; /* Count for repeats */ - int ims; /* ims flag bits */ - int data; /* Some use extra data */ -} stateblock; - -#define INTS_PER_STATEBLOCK (sizeof(stateblock)/sizeof(int)) - - -#ifdef DEBUG -/************************************************* -* Print character string * -*************************************************/ - -/* Character string printing function for debugging. - -Arguments: - p points to string - length number of bytes - f where to print - -Returns: nothing -*/ - -static void -pchars(unsigned char *p, int length, FILE *f) -{ -int c; -while (length-- > 0) - { - if (isprint(c = *(p++))) - fprintf(f, "%c", c); - else - fprintf(f, "\\x%02x", c); - } -} -#endif - - - -/************************************************* -* Execute a Regular Expression - DFA engine * -*************************************************/ - -/* This internal function applies a compiled pattern to a subject string, -starting at a given point, using a DFA engine. This function is called from the -external one, possibly multiple times if the pattern is not anchored. The -function calls itself recursively for some kinds of subpattern. - -Arguments: - md the match_data block with fixed information - this_start_code the opening bracket of this subexpression's code - current_subject where we currently are in the subject string - start_offset start offset in the subject string - offsets vector to contain the matching string offsets - offsetcount size of same - workspace vector of workspace - wscount size of same - ims the current ims flags - rlevel function call recursion level - recursing regex recursive call level - -Returns: > 0 => - = 0 => - -1 => failed to match - < -1 => some kind of unexpected problem - -The following macros are used for adding states to the two state vectors (one -for the current character, one for the following character). */ - -#define ADD_ACTIVE(x,y) \ - if (active_count++ < wscount) \ - { \ - next_active_state->offset = (x); \ - next_active_state->count = (y); \ - next_active_state->ims = ims; \ - next_active_state++; \ - DPRINTF(("%.*sADD_ACTIVE(%d,%d)\n", rlevel*2-2, SP, (x), (y))); \ - } \ - else return PCRE_ERROR_DFA_WSSIZE - -#define ADD_ACTIVE_DATA(x,y,z) \ - if (active_count++ < wscount) \ - { \ - next_active_state->offset = (x); \ - next_active_state->count = (y); \ - next_active_state->ims = ims; \ - next_active_state->data = (z); \ - next_active_state++; \ - DPRINTF(("%.*sADD_ACTIVE_DATA(%d,%d,%d)\n", rlevel*2-2, SP, (x), (y), (z))); \ - } \ - else return PCRE_ERROR_DFA_WSSIZE - -#define ADD_NEW(x,y) \ - if (new_count++ < wscount) \ - { \ - next_new_state->offset = (x); \ - next_new_state->count = (y); \ - next_new_state->ims = ims; \ - next_new_state++; \ - DPRINTF(("%.*sADD_NEW(%d,%d)\n", rlevel*2-2, SP, (x), (y))); \ - } \ - else return PCRE_ERROR_DFA_WSSIZE - -#define ADD_NEW_DATA(x,y,z) \ - if (new_count++ < wscount) \ - { \ - next_new_state->offset = (x); \ - next_new_state->count = (y); \ - next_new_state->ims = ims; \ - next_new_state->data = (z); \ - next_new_state++; \ - DPRINTF(("%.*sADD_NEW_DATA(%d,%d,%d)\n", rlevel*2-2, SP, (x), (y), (z))); \ - } \ - else return PCRE_ERROR_DFA_WSSIZE - -/* And now, here is the code */ - -static int -internal_dfa_exec( - dfa_match_data *md, - const uschar *this_start_code, - const uschar *current_subject, - int start_offset, - int *offsets, - int offsetcount, - int *workspace, - int wscount, - int ims, - int rlevel, - int recursing) -{ -stateblock *active_states, *new_states, *temp_states; -stateblock *next_active_state, *next_new_state; - -const uschar *ctypes, *lcc, *fcc; -const uschar *ptr; -const uschar *end_code, *first_op; - -int active_count, new_count, match_count; - -/* Some fields in the md block are frequently referenced, so we load them into -independent variables in the hope that this will perform better. */ - -const uschar *start_subject = md->start_subject; -const uschar *end_subject = md->end_subject; -const uschar *start_code = md->start_code; - -#ifdef SUPPORT_UTF8 -BOOL utf8 = (md->poptions & PCRE_UTF8) != 0; -#else -BOOL utf8 = FALSE; -#endif - -rlevel++; -offsetcount &= (-2); - -wscount -= 2; -wscount = (wscount - (wscount % (INTS_PER_STATEBLOCK * 2))) / - (2 * INTS_PER_STATEBLOCK); - -DPRINTF(("\n%.*s---------------------\n" - "%.*sCall to internal_dfa_exec f=%d r=%d\n", - rlevel*2-2, SP, rlevel*2-2, SP, rlevel, recursing)); - -ctypes = md->tables + ctypes_offset; -lcc = md->tables + lcc_offset; -fcc = md->tables + fcc_offset; - -match_count = PCRE_ERROR_NOMATCH; /* A negative number */ - -active_states = (stateblock *)(workspace + 2); -next_new_state = new_states = active_states + wscount; -new_count = 0; - -first_op = this_start_code + 1 + LINK_SIZE + - ((*this_start_code == OP_CBRA || *this_start_code == OP_SCBRA)? 2:0); - -/* The first thing in any (sub) pattern is a bracket of some sort. Push all -the alternative states onto the list, and find out where the end is. This -makes is possible to use this function recursively, when we want to stop at a -matching internal ket rather than at the end. - -If the first opcode in the first alternative is OP_REVERSE, we are dealing with -a backward assertion. In that case, we have to find out the maximum amount to -move back, and set up each alternative appropriately. */ - -if (*first_op == OP_REVERSE) - { - int max_back = 0; - int gone_back; - - end_code = this_start_code; - do - { - int back = GET(end_code, 2+LINK_SIZE); - if (back > max_back) max_back = back; - end_code += GET(end_code, 1); - } - while (*end_code == OP_ALT); - - /* If we can't go back the amount required for the longest lookbehind - pattern, go back as far as we can; some alternatives may still be viable. */ - -#ifdef SUPPORT_UTF8 - /* In character mode we have to step back character by character */ - - if (utf8) - { - for (gone_back = 0; gone_back < max_back; gone_back++) - { - if (current_subject <= start_subject) break; - current_subject--; - while (current_subject > start_subject && - (*current_subject & 0xc0) == 0x80) - current_subject--; - } - } - else -#endif - - /* In byte-mode we can do this quickly. */ - - { - gone_back = (current_subject - max_back < start_subject)? - current_subject - start_subject : max_back; - current_subject -= gone_back; - } - - /* Now we can process the individual branches. */ - - end_code = this_start_code; - do - { - int back = GET(end_code, 2+LINK_SIZE); - if (back <= gone_back) - { - int bstate = end_code - start_code + 2 + 2*LINK_SIZE; - ADD_NEW_DATA(-bstate, 0, gone_back - back); - } - end_code += GET(end_code, 1); - } - while (*end_code == OP_ALT); - } - -/* This is the code for a "normal" subpattern (not a backward assertion). The -start of a whole pattern is always one of these. If we are at the top level, -we may be asked to restart matching from the same point that we reached for a -previous partial match. We still have to scan through the top-level branches to -find the end state. */ - -else - { - end_code = this_start_code; - - /* Restarting */ - - if (rlevel == 1 && (md->moptions & PCRE_DFA_RESTART) != 0) - { - do { end_code += GET(end_code, 1); } while (*end_code == OP_ALT); - new_count = workspace[1]; - if (!workspace[0]) - memcpy(new_states, active_states, new_count * sizeof(stateblock)); - } - - /* Not restarting */ - - else - { - int length = 1 + LINK_SIZE + - ((*this_start_code == OP_CBRA || *this_start_code == OP_SCBRA)? 2:0); - do - { - ADD_NEW(end_code - start_code + length, 0); - end_code += GET(end_code, 1); - length = 1 + LINK_SIZE; - } - while (*end_code == OP_ALT); - } - } - -workspace[0] = 0; /* Bit indicating which vector is current */ - -DPRINTF(("%.*sEnd state = %d\n", rlevel*2-2, SP, end_code - start_code)); - -/* Loop for scanning the subject */ - -ptr = current_subject; -for (;;) - { - int i, j; - int clen, dlen; - unsigned int c, d; - - /* Make the new state list into the active state list and empty the - new state list. */ - - temp_states = active_states; - active_states = new_states; - new_states = temp_states; - active_count = new_count; - new_count = 0; - - workspace[0] ^= 1; /* Remember for the restarting feature */ - workspace[1] = active_count; - -#ifdef DEBUG - printf("%.*sNext character: rest of subject = \"", rlevel*2-2, SP); - pchars((uschar *)ptr, strlen((char *)ptr), stdout); - printf("\"\n"); - - printf("%.*sActive states: ", rlevel*2-2, SP); - for (i = 0; i < active_count; i++) - printf("%d/%d ", active_states[i].offset, active_states[i].count); - printf("\n"); -#endif - - /* Set the pointers for adding new states */ - - next_active_state = active_states + active_count; - next_new_state = new_states; - - /* Load the current character from the subject outside the loop, as many - different states may want to look at it, and we assume that at least one - will. */ - - if (ptr < end_subject) - { - clen = 1; /* Number of bytes in the character */ -#ifdef SUPPORT_UTF8 - if (utf8) { GETCHARLEN(c, ptr, clen); } else -#endif /* SUPPORT_UTF8 */ - c = *ptr; - } - else - { - clen = 0; /* This indicates the end of the subject */ - c = NOTACHAR; /* This value should never actually be used */ - } - - /* Scan up the active states and act on each one. The result of an action - may be to add more states to the currently active list (e.g. on hitting a - parenthesis) or it may be to put states on the new list, for considering - when we move the character pointer on. */ - - for (i = 0; i < active_count; i++) - { - stateblock *current_state = active_states + i; - const uschar *code; - int state_offset = current_state->offset; - int count, codevalue; -#ifdef SUPPORT_UCP - int chartype, script; -#endif - -#ifdef DEBUG - printf ("%.*sProcessing state %d c=", rlevel*2-2, SP, state_offset); - if (clen == 0) printf("EOL\n"); - else if (c > 32 && c < 127) printf("'%c'\n", c); - else printf("0x%02x\n", c); -#endif - - /* This variable is referred to implicity in the ADD_xxx macros. */ - - ims = current_state->ims; - - /* A negative offset is a special case meaning "hold off going to this - (negated) state until the number of characters in the data field have - been skipped". */ - - if (state_offset < 0) - { - if (current_state->data > 0) - { - DPRINTF(("%.*sSkipping this character\n", rlevel*2-2, SP)); - ADD_NEW_DATA(state_offset, current_state->count, - current_state->data - 1); - continue; - } - else - { - current_state->offset = state_offset = -state_offset; - } - } - - /* Check for a duplicate state with the same count, and skip if found. */ - - for (j = 0; j < i; j++) - { - if (active_states[j].offset == state_offset && - active_states[j].count == current_state->count) - { - DPRINTF(("%.*sDuplicate state: skipped\n", rlevel*2-2, SP)); - goto NEXT_ACTIVE_STATE; - } - } - - /* The state offset is the offset to the opcode */ - - code = start_code + state_offset; - codevalue = *code; - - /* If this opcode is followed by an inline character, load it. It is - tempting to test for the presence of a subject character here, but that - is wrong, because sometimes zero repetitions of the subject are - permitted. - - We also use this mechanism for opcodes such as OP_TYPEPLUS that take an - argument that is not a data character - but is always one byte long. We - have to take special action to deal with \P, \p, \H, \h, \V, \v and \X in - this case. To keep the other cases fast, convert these ones to new opcodes. - */ - - if (coptable[codevalue] > 0) - { - dlen = 1; -#ifdef SUPPORT_UTF8 - if (utf8) { GETCHARLEN(d, (code + coptable[codevalue]), dlen); } else -#endif /* SUPPORT_UTF8 */ - d = code[coptable[codevalue]]; - if (codevalue >= OP_TYPESTAR) - { - switch(d) - { - case OP_ANYBYTE: return PCRE_ERROR_DFA_UITEM; - case OP_NOTPROP: - case OP_PROP: codevalue += OP_PROP_EXTRA; break; - case OP_ANYNL: codevalue += OP_ANYNL_EXTRA; break; - case OP_EXTUNI: codevalue += OP_EXTUNI_EXTRA; break; - case OP_NOT_HSPACE: - case OP_HSPACE: codevalue += OP_HSPACE_EXTRA; break; - case OP_NOT_VSPACE: - case OP_VSPACE: codevalue += OP_VSPACE_EXTRA; break; - default: break; - } - } - } - else - { - dlen = 0; /* Not strictly necessary, but compilers moan */ - d = NOTACHAR; /* if these variables are not set. */ - } - - - /* Now process the individual opcodes */ - - switch (codevalue) - { - -/* ========================================================================== */ - /* Reached a closing bracket. If not at the end of the pattern, carry - on with the next opcode. Otherwise, unless we have an empty string and - PCRE_NOTEMPTY is set, save the match data, shifting up all previous - matches so we always have the longest first. */ - - case OP_KET: - case OP_KETRMIN: - case OP_KETRMAX: - if (code != end_code) - { - ADD_ACTIVE(state_offset + 1 + LINK_SIZE, 0); - if (codevalue != OP_KET) - { - ADD_ACTIVE(state_offset - GET(code, 1), 0); - } - } - else if (ptr > current_subject || (md->moptions & PCRE_NOTEMPTY) == 0) - { - if (match_count < 0) match_count = (offsetcount >= 2)? 1 : 0; - else if (match_count > 0 && ++match_count * 2 >= offsetcount) - match_count = 0; - count = ((match_count == 0)? offsetcount : match_count * 2) - 2; - if (count > 0) memmove(offsets + 2, offsets, count * sizeof(int)); - if (offsetcount >= 2) - { - offsets[0] = current_subject - start_subject; - offsets[1] = ptr - start_subject; - DPRINTF(("%.*sSet matched string = \"%.*s\"\n", rlevel*2-2, SP, - offsets[1] - offsets[0], current_subject)); - } - if ((md->moptions & PCRE_DFA_SHORTEST) != 0) - { - DPRINTF(("%.*sEnd of internal_dfa_exec %d: returning %d\n" - "%.*s---------------------\n\n", rlevel*2-2, SP, rlevel, - match_count, rlevel*2-2, SP)); - return match_count; - } - } - break; - -/* ========================================================================== */ - /* These opcodes add to the current list of states without looking - at the current character. */ - - /*-----------------------------------------------------------------*/ - case OP_ALT: - do { code += GET(code, 1); } while (*code == OP_ALT); - ADD_ACTIVE(code - start_code, 0); - break; - - /*-----------------------------------------------------------------*/ - case OP_BRA: - case OP_SBRA: - do - { - ADD_ACTIVE(code - start_code + 1 + LINK_SIZE, 0); - code += GET(code, 1); - } - while (*code == OP_ALT); - break; - - /*-----------------------------------------------------------------*/ - case OP_CBRA: - case OP_SCBRA: - ADD_ACTIVE(code - start_code + 3 + LINK_SIZE, 0); - code += GET(code, 1); - while (*code == OP_ALT) - { - ADD_ACTIVE(code - start_code + 1 + LINK_SIZE, 0); - code += GET(code, 1); - } - break; - - /*-----------------------------------------------------------------*/ - case OP_BRAZERO: - case OP_BRAMINZERO: - ADD_ACTIVE(state_offset + 1, 0); - code += 1 + GET(code, 2); - while (*code == OP_ALT) code += GET(code, 1); - ADD_ACTIVE(code - start_code + 1 + LINK_SIZE, 0); - break; - - /*-----------------------------------------------------------------*/ - case OP_CIRC: - if ((ptr == start_subject && (md->moptions & PCRE_NOTBOL) == 0) || - ((ims & PCRE_MULTILINE) != 0 && - ptr != end_subject && - WAS_NEWLINE(ptr))) - { ADD_ACTIVE(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_EOD: - if (ptr >= end_subject) { ADD_ACTIVE(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_OPT: - ims = code[1]; - ADD_ACTIVE(state_offset + 2, 0); - break; - - /*-----------------------------------------------------------------*/ - case OP_SOD: - if (ptr == start_subject) { ADD_ACTIVE(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_SOM: - if (ptr == start_subject + start_offset) { ADD_ACTIVE(state_offset + 1, 0); } - break; - - -/* ========================================================================== */ - /* These opcodes inspect the next subject character, and sometimes - the previous one as well, but do not have an argument. The variable - clen contains the length of the current character and is zero if we are - at the end of the subject. */ - - /*-----------------------------------------------------------------*/ - case OP_ANY: - if (clen > 0 && ((ims & PCRE_DOTALL) != 0 || !IS_NEWLINE(ptr))) - { ADD_NEW(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_EODN: - if (clen == 0 || (IS_NEWLINE(ptr) && ptr == end_subject - md->nllen)) - { ADD_ACTIVE(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_DOLL: - if ((md->moptions & PCRE_NOTEOL) == 0) - { - if (clen == 0 || - (IS_NEWLINE(ptr) && - ((ims & PCRE_MULTILINE) != 0 || ptr == end_subject - md->nllen) - )) - { ADD_ACTIVE(state_offset + 1, 0); } - } - else if ((ims & PCRE_MULTILINE) != 0 && IS_NEWLINE(ptr)) - { ADD_ACTIVE(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - - case OP_DIGIT: - case OP_WHITESPACE: - case OP_WORDCHAR: - if (clen > 0 && c < 256 && - ((ctypes[c] & toptable1[codevalue]) ^ toptable2[codevalue]) != 0) - { ADD_NEW(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_NOT_DIGIT: - case OP_NOT_WHITESPACE: - case OP_NOT_WORDCHAR: - if (clen > 0 && (c >= 256 || - ((ctypes[c] & toptable1[codevalue]) ^ toptable2[codevalue]) != 0)) - { ADD_NEW(state_offset + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_WORD_BOUNDARY: - case OP_NOT_WORD_BOUNDARY: - { - int left_word, right_word; - - if (ptr > start_subject) - { - const uschar *temp = ptr - 1; -#ifdef SUPPORT_UTF8 - if (utf8) BACKCHAR(temp); -#endif - GETCHARTEST(d, temp); - left_word = d < 256 && (ctypes[d] & ctype_word) != 0; - } - else left_word = 0; - - if (clen > 0) right_word = c < 256 && (ctypes[c] & ctype_word) != 0; - else right_word = 0; - - if ((left_word == right_word) == (codevalue == OP_NOT_WORD_BOUNDARY)) - { ADD_ACTIVE(state_offset + 1, 0); } - } - break; - - - /*-----------------------------------------------------------------*/ - /* Check the next character by Unicode property. We will get here only - if the support is in the binary; otherwise a compile-time error occurs. - */ - -#ifdef SUPPORT_UCP - case OP_PROP: - case OP_NOTPROP: - if (clen > 0) - { - BOOL OK; - int category = _pcre_ucp_findprop(c, &chartype, &script); - switch(code[1]) - { - case PT_ANY: - OK = TRUE; - break; - - case PT_LAMP: - OK = chartype == ucp_Lu || chartype == ucp_Ll || chartype == ucp_Lt; - break; - - case PT_GC: - OK = category == code[2]; - break; - - case PT_PC: - OK = chartype == code[2]; - break; - - case PT_SC: - OK = script == code[2]; - break; - - /* Should never occur, but keep compilers from grumbling. */ - - default: - OK = codevalue != OP_PROP; - break; - } - - if (OK == (codevalue == OP_PROP)) { ADD_NEW(state_offset + 3, 0); } - } - break; -#endif - - - -/* ========================================================================== */ - /* These opcodes likewise inspect the subject character, but have an - argument that is not a data character. It is one of these opcodes: - OP_ANY, OP_DIGIT, OP_NOT_DIGIT, OP_WHITESPACE, OP_NOT_SPACE, OP_WORDCHAR, - OP_NOT_WORDCHAR. The value is loaded into d. */ - - case OP_TYPEPLUS: - case OP_TYPEMINPLUS: - case OP_TYPEPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + 2, 0); } - if (clen > 0) - { - if ((c >= 256 && d != OP_DIGIT && d != OP_WHITESPACE && d != OP_WORDCHAR) || - (c < 256 && - (d != OP_ANY || - (ims & PCRE_DOTALL) != 0 || - !IS_NEWLINE(ptr) - ) && - ((ctypes[c] & toptable1[d]) ^ toptable2[d]) != 0)) - { - if (count > 0 && codevalue == OP_TYPEPOSPLUS) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - count++; - ADD_NEW(state_offset, count); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_TYPEQUERY: - case OP_TYPEMINQUERY: - case OP_TYPEPOSQUERY: - ADD_ACTIVE(state_offset + 2, 0); - if (clen > 0) - { - if ((c >= 256 && d != OP_DIGIT && d != OP_WHITESPACE && d != OP_WORDCHAR) || - (c < 256 && - (d != OP_ANY || - (ims & PCRE_DOTALL) != 0 || - !IS_NEWLINE(ptr) - ) && - ((ctypes[c] & toptable1[d]) ^ toptable2[d]) != 0)) - { - if (codevalue == OP_TYPEPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW(state_offset + 2, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_TYPESTAR: - case OP_TYPEMINSTAR: - case OP_TYPEPOSSTAR: - ADD_ACTIVE(state_offset + 2, 0); - if (clen > 0) - { - if ((c >= 256 && d != OP_DIGIT && d != OP_WHITESPACE && d != OP_WORDCHAR) || - (c < 256 && - (d != OP_ANY || - (ims & PCRE_DOTALL) != 0 || - !IS_NEWLINE(ptr) - ) && - ((ctypes[c] & toptable1[d]) ^ toptable2[d]) != 0)) - { - if (codevalue == OP_TYPEPOSSTAR) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW(state_offset, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_TYPEEXACT: - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - if ((c >= 256 && d != OP_DIGIT && d != OP_WHITESPACE && d != OP_WORDCHAR) || - (c < 256 && - (d != OP_ANY || - (ims & PCRE_DOTALL) != 0 || - !IS_NEWLINE(ptr) - ) && - ((ctypes[c] & toptable1[d]) ^ toptable2[d]) != 0)) - { - if (++count >= GET2(code, 1)) - { ADD_NEW(state_offset + 4, 0); } - else - { ADD_NEW(state_offset, count); } - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_TYPEUPTO: - case OP_TYPEMINUPTO: - case OP_TYPEPOSUPTO: - ADD_ACTIVE(state_offset + 4, 0); - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - if ((c >= 256 && d != OP_DIGIT && d != OP_WHITESPACE && d != OP_WORDCHAR) || - (c < 256 && - (d != OP_ANY || - (ims & PCRE_DOTALL) != 0 || - !IS_NEWLINE(ptr) - ) && - ((ctypes[c] & toptable1[d]) ^ toptable2[d]) != 0)) - { - if (codevalue == OP_TYPEPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - if (++count >= GET2(code, 1)) - { ADD_NEW(state_offset + 4, 0); } - else - { ADD_NEW(state_offset, count); } - } - } - break; - -/* ========================================================================== */ - /* These are virtual opcodes that are used when something like - OP_TYPEPLUS has OP_PROP, OP_NOTPROP, OP_ANYNL, or OP_EXTUNI as its - argument. It keeps the code above fast for the other cases. The argument - is in the d variable. */ - -#ifdef SUPPORT_UCP - case OP_PROP_EXTRA + OP_TYPEPLUS: - case OP_PROP_EXTRA + OP_TYPEMINPLUS: - case OP_PROP_EXTRA + OP_TYPEPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + 4, 0); } - if (clen > 0) - { - BOOL OK; - int category = _pcre_ucp_findprop(c, &chartype, &script); - switch(code[2]) - { - case PT_ANY: - OK = TRUE; - break; - - case PT_LAMP: - OK = chartype == ucp_Lu || chartype == ucp_Ll || chartype == ucp_Lt; - break; - - case PT_GC: - OK = category == code[3]; - break; - - case PT_PC: - OK = chartype == code[3]; - break; - - case PT_SC: - OK = script == code[3]; - break; - - /* Should never occur, but keep compilers from grumbling. */ - - default: - OK = codevalue != OP_PROP; - break; - } - - if (OK == (d == OP_PROP)) - { - if (count > 0 && codevalue == OP_PROP_EXTRA + OP_TYPEPOSPLUS) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - count++; - ADD_NEW(state_offset, count); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_EXTUNI_EXTRA + OP_TYPEPLUS: - case OP_EXTUNI_EXTRA + OP_TYPEMINPLUS: - case OP_EXTUNI_EXTRA + OP_TYPEPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + 2, 0); } - if (clen > 0 && _pcre_ucp_findprop(c, &chartype, &script) != ucp_M) - { - const uschar *nptr = ptr + clen; - int ncount = 0; - if (count > 0 && codevalue == OP_EXTUNI_EXTRA + OP_TYPEPOSPLUS) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - while (nptr < end_subject) - { - int nd; - int ndlen = 1; - GETCHARLEN(nd, nptr, ndlen); - if (_pcre_ucp_findprop(nd, &chartype, &script) != ucp_M) break; - ncount++; - nptr += ndlen; - } - count++; - ADD_NEW_DATA(-state_offset, count, ncount); - } - break; -#endif - - /*-----------------------------------------------------------------*/ - case OP_ANYNL_EXTRA + OP_TYPEPLUS: - case OP_ANYNL_EXTRA + OP_TYPEMINPLUS: - case OP_ANYNL_EXTRA + OP_TYPEPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + 2, 0); } - if (clen > 0) - { - int ncount = 0; - switch (c) - { - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if ((md->moptions & PCRE_BSR_ANYCRLF) != 0) break; - goto ANYNL01; - - case 0x000d: - if (ptr + 1 < end_subject && ptr[1] == 0x0a) ncount = 1; - /* Fall through */ - - ANYNL01: - case 0x000a: - if (count > 0 && codevalue == OP_ANYNL_EXTRA + OP_TYPEPOSPLUS) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - count++; - ADD_NEW_DATA(-state_offset, count, ncount); - break; - - default: - break; - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_VSPACE_EXTRA + OP_TYPEPLUS: - case OP_VSPACE_EXTRA + OP_TYPEMINPLUS: - case OP_VSPACE_EXTRA + OP_TYPEPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + 2, 0); } - if (clen > 0) - { - BOOL OK; - switch (c) - { - case 0x000a: - case 0x000b: - case 0x000c: - case 0x000d: - case 0x0085: - case 0x2028: - case 0x2029: - OK = TRUE; - break; - - default: - OK = FALSE; - break; - } - - if (OK == (d == OP_VSPACE)) - { - if (count > 0 && codevalue == OP_VSPACE_EXTRA + OP_TYPEPOSPLUS) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - count++; - ADD_NEW_DATA(-state_offset, count, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_HSPACE_EXTRA + OP_TYPEPLUS: - case OP_HSPACE_EXTRA + OP_TYPEMINPLUS: - case OP_HSPACE_EXTRA + OP_TYPEPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + 2, 0); } - if (clen > 0) - { - BOOL OK; - switch (c) - { - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - OK = TRUE; - break; - - default: - OK = FALSE; - break; - } - - if (OK == (d == OP_HSPACE)) - { - if (count > 0 && codevalue == OP_HSPACE_EXTRA + OP_TYPEPOSPLUS) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - count++; - ADD_NEW_DATA(-state_offset, count, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ -#ifdef SUPPORT_UCP - case OP_PROP_EXTRA + OP_TYPEQUERY: - case OP_PROP_EXTRA + OP_TYPEMINQUERY: - case OP_PROP_EXTRA + OP_TYPEPOSQUERY: - count = 4; - goto QS1; - - case OP_PROP_EXTRA + OP_TYPESTAR: - case OP_PROP_EXTRA + OP_TYPEMINSTAR: - case OP_PROP_EXTRA + OP_TYPEPOSSTAR: - count = 0; - - QS1: - - ADD_ACTIVE(state_offset + 4, 0); - if (clen > 0) - { - BOOL OK; - int category = _pcre_ucp_findprop(c, &chartype, &script); - switch(code[2]) - { - case PT_ANY: - OK = TRUE; - break; - - case PT_LAMP: - OK = chartype == ucp_Lu || chartype == ucp_Ll || chartype == ucp_Lt; - break; - - case PT_GC: - OK = category == code[3]; - break; - - case PT_PC: - OK = chartype == code[3]; - break; - - case PT_SC: - OK = script == code[3]; - break; - - /* Should never occur, but keep compilers from grumbling. */ - - default: - OK = codevalue != OP_PROP; - break; - } - - if (OK == (d == OP_PROP)) - { - if (codevalue == OP_PROP_EXTRA + OP_TYPEPOSSTAR || - codevalue == OP_PROP_EXTRA + OP_TYPEPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW(state_offset + count, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_EXTUNI_EXTRA + OP_TYPEQUERY: - case OP_EXTUNI_EXTRA + OP_TYPEMINQUERY: - case OP_EXTUNI_EXTRA + OP_TYPEPOSQUERY: - count = 2; - goto QS2; - - case OP_EXTUNI_EXTRA + OP_TYPESTAR: - case OP_EXTUNI_EXTRA + OP_TYPEMINSTAR: - case OP_EXTUNI_EXTRA + OP_TYPEPOSSTAR: - count = 0; - - QS2: - - ADD_ACTIVE(state_offset + 2, 0); - if (clen > 0 && _pcre_ucp_findprop(c, &chartype, &script) != ucp_M) - { - const uschar *nptr = ptr + clen; - int ncount = 0; - if (codevalue == OP_EXTUNI_EXTRA + OP_TYPEPOSSTAR || - codevalue == OP_EXTUNI_EXTRA + OP_TYPEPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - while (nptr < end_subject) - { - int nd; - int ndlen = 1; - GETCHARLEN(nd, nptr, ndlen); - if (_pcre_ucp_findprop(nd, &chartype, &script) != ucp_M) break; - ncount++; - nptr += ndlen; - } - ADD_NEW_DATA(-(state_offset + count), 0, ncount); - } - break; -#endif - - /*-----------------------------------------------------------------*/ - case OP_ANYNL_EXTRA + OP_TYPEQUERY: - case OP_ANYNL_EXTRA + OP_TYPEMINQUERY: - case OP_ANYNL_EXTRA + OP_TYPEPOSQUERY: - count = 2; - goto QS3; - - case OP_ANYNL_EXTRA + OP_TYPESTAR: - case OP_ANYNL_EXTRA + OP_TYPEMINSTAR: - case OP_ANYNL_EXTRA + OP_TYPEPOSSTAR: - count = 0; - - QS3: - ADD_ACTIVE(state_offset + 2, 0); - if (clen > 0) - { - int ncount = 0; - switch (c) - { - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if ((md->moptions & PCRE_BSR_ANYCRLF) != 0) break; - goto ANYNL02; - - case 0x000d: - if (ptr + 1 < end_subject && ptr[1] == 0x0a) ncount = 1; - /* Fall through */ - - ANYNL02: - case 0x000a: - if (codevalue == OP_ANYNL_EXTRA + OP_TYPEPOSSTAR || - codevalue == OP_ANYNL_EXTRA + OP_TYPEPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW_DATA(-(state_offset + count), 0, ncount); - break; - - default: - break; - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_VSPACE_EXTRA + OP_TYPEQUERY: - case OP_VSPACE_EXTRA + OP_TYPEMINQUERY: - case OP_VSPACE_EXTRA + OP_TYPEPOSQUERY: - count = 2; - goto QS4; - - case OP_VSPACE_EXTRA + OP_TYPESTAR: - case OP_VSPACE_EXTRA + OP_TYPEMINSTAR: - case OP_VSPACE_EXTRA + OP_TYPEPOSSTAR: - count = 0; - - QS4: - ADD_ACTIVE(state_offset + 2, 0); - if (clen > 0) - { - BOOL OK; - switch (c) - { - case 0x000a: - case 0x000b: - case 0x000c: - case 0x000d: - case 0x0085: - case 0x2028: - case 0x2029: - OK = TRUE; - break; - - default: - OK = FALSE; - break; - } - if (OK == (d == OP_VSPACE)) - { - if (codevalue == OP_VSPACE_EXTRA + OP_TYPEPOSSTAR || - codevalue == OP_VSPACE_EXTRA + OP_TYPEPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW_DATA(-(state_offset + count), 0, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_HSPACE_EXTRA + OP_TYPEQUERY: - case OP_HSPACE_EXTRA + OP_TYPEMINQUERY: - case OP_HSPACE_EXTRA + OP_TYPEPOSQUERY: - count = 2; - goto QS5; - - case OP_HSPACE_EXTRA + OP_TYPESTAR: - case OP_HSPACE_EXTRA + OP_TYPEMINSTAR: - case OP_HSPACE_EXTRA + OP_TYPEPOSSTAR: - count = 0; - - QS5: - ADD_ACTIVE(state_offset + 2, 0); - if (clen > 0) - { - BOOL OK; - switch (c) - { - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - OK = TRUE; - break; - - default: - OK = FALSE; - break; - } - - if (OK == (d == OP_HSPACE)) - { - if (codevalue == OP_HSPACE_EXTRA + OP_TYPEPOSSTAR || - codevalue == OP_HSPACE_EXTRA + OP_TYPEPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW_DATA(-(state_offset + count), 0, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ -#ifdef SUPPORT_UCP - case OP_PROP_EXTRA + OP_TYPEEXACT: - case OP_PROP_EXTRA + OP_TYPEUPTO: - case OP_PROP_EXTRA + OP_TYPEMINUPTO: - case OP_PROP_EXTRA + OP_TYPEPOSUPTO: - if (codevalue != OP_PROP_EXTRA + OP_TYPEEXACT) - { ADD_ACTIVE(state_offset + 6, 0); } - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - BOOL OK; - int category = _pcre_ucp_findprop(c, &chartype, &script); - switch(code[4]) - { - case PT_ANY: - OK = TRUE; - break; - - case PT_LAMP: - OK = chartype == ucp_Lu || chartype == ucp_Ll || chartype == ucp_Lt; - break; - - case PT_GC: - OK = category == code[5]; - break; - - case PT_PC: - OK = chartype == code[5]; - break; - - case PT_SC: - OK = script == code[5]; - break; - - /* Should never occur, but keep compilers from grumbling. */ - - default: - OK = codevalue != OP_PROP; - break; - } - - if (OK == (d == OP_PROP)) - { - if (codevalue == OP_PROP_EXTRA + OP_TYPEPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - if (++count >= GET2(code, 1)) - { ADD_NEW(state_offset + 6, 0); } - else - { ADD_NEW(state_offset, count); } - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_EXTUNI_EXTRA + OP_TYPEEXACT: - case OP_EXTUNI_EXTRA + OP_TYPEUPTO: - case OP_EXTUNI_EXTRA + OP_TYPEMINUPTO: - case OP_EXTUNI_EXTRA + OP_TYPEPOSUPTO: - if (codevalue != OP_EXTUNI_EXTRA + OP_TYPEEXACT) - { ADD_ACTIVE(state_offset + 4, 0); } - count = current_state->count; /* Number already matched */ - if (clen > 0 && _pcre_ucp_findprop(c, &chartype, &script) != ucp_M) - { - const uschar *nptr = ptr + clen; - int ncount = 0; - if (codevalue == OP_EXTUNI_EXTRA + OP_TYPEPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - while (nptr < end_subject) - { - int nd; - int ndlen = 1; - GETCHARLEN(nd, nptr, ndlen); - if (_pcre_ucp_findprop(nd, &chartype, &script) != ucp_M) break; - ncount++; - nptr += ndlen; - } - if (++count >= GET2(code, 1)) - { ADD_NEW_DATA(-(state_offset + 4), 0, ncount); } - else - { ADD_NEW_DATA(-state_offset, count, ncount); } - } - break; -#endif - - /*-----------------------------------------------------------------*/ - case OP_ANYNL_EXTRA + OP_TYPEEXACT: - case OP_ANYNL_EXTRA + OP_TYPEUPTO: - case OP_ANYNL_EXTRA + OP_TYPEMINUPTO: - case OP_ANYNL_EXTRA + OP_TYPEPOSUPTO: - if (codevalue != OP_ANYNL_EXTRA + OP_TYPEEXACT) - { ADD_ACTIVE(state_offset + 4, 0); } - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - int ncount = 0; - switch (c) - { - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if ((md->moptions & PCRE_BSR_ANYCRLF) != 0) break; - goto ANYNL03; - - case 0x000d: - if (ptr + 1 < end_subject && ptr[1] == 0x0a) ncount = 1; - /* Fall through */ - - ANYNL03: - case 0x000a: - if (codevalue == OP_ANYNL_EXTRA + OP_TYPEPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - if (++count >= GET2(code, 1)) - { ADD_NEW_DATA(-(state_offset + 4), 0, ncount); } - else - { ADD_NEW_DATA(-state_offset, count, ncount); } - break; - - default: - break; - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_VSPACE_EXTRA + OP_TYPEEXACT: - case OP_VSPACE_EXTRA + OP_TYPEUPTO: - case OP_VSPACE_EXTRA + OP_TYPEMINUPTO: - case OP_VSPACE_EXTRA + OP_TYPEPOSUPTO: - if (codevalue != OP_VSPACE_EXTRA + OP_TYPEEXACT) - { ADD_ACTIVE(state_offset + 4, 0); } - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - BOOL OK; - switch (c) - { - case 0x000a: - case 0x000b: - case 0x000c: - case 0x000d: - case 0x0085: - case 0x2028: - case 0x2029: - OK = TRUE; - break; - - default: - OK = FALSE; - } - - if (OK == (d == OP_VSPACE)) - { - if (codevalue == OP_VSPACE_EXTRA + OP_TYPEPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - if (++count >= GET2(code, 1)) - { ADD_NEW_DATA(-(state_offset + 4), 0, 0); } - else - { ADD_NEW_DATA(-state_offset, count, 0); } - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_HSPACE_EXTRA + OP_TYPEEXACT: - case OP_HSPACE_EXTRA + OP_TYPEUPTO: - case OP_HSPACE_EXTRA + OP_TYPEMINUPTO: - case OP_HSPACE_EXTRA + OP_TYPEPOSUPTO: - if (codevalue != OP_HSPACE_EXTRA + OP_TYPEEXACT) - { ADD_ACTIVE(state_offset + 4, 0); } - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - BOOL OK; - switch (c) - { - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - OK = TRUE; - break; - - default: - OK = FALSE; - break; - } - - if (OK == (d == OP_HSPACE)) - { - if (codevalue == OP_HSPACE_EXTRA + OP_TYPEPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - if (++count >= GET2(code, 1)) - { ADD_NEW_DATA(-(state_offset + 4), 0, 0); } - else - { ADD_NEW_DATA(-state_offset, count, 0); } - } - } - break; - -/* ========================================================================== */ - /* These opcodes are followed by a character that is usually compared - to the current subject character; it is loaded into d. We still get - here even if there is no subject character, because in some cases zero - repetitions are permitted. */ - - /*-----------------------------------------------------------------*/ - case OP_CHAR: - if (clen > 0 && c == d) { ADD_NEW(state_offset + dlen + 1, 0); } - break; - - /*-----------------------------------------------------------------*/ - case OP_CHARNC: - if (clen == 0) break; - -#ifdef SUPPORT_UTF8 - if (utf8) - { - if (c == d) { ADD_NEW(state_offset + dlen + 1, 0); } else - { - unsigned int othercase; - if (c < 128) othercase = fcc[c]; else - - /* If we have Unicode property support, we can use it to test the - other case of the character. */ - -#ifdef SUPPORT_UCP - othercase = _pcre_ucp_othercase(c); -#else - othercase = NOTACHAR; -#endif - - if (d == othercase) { ADD_NEW(state_offset + dlen + 1, 0); } - } - } - else -#endif /* SUPPORT_UTF8 */ - - /* Non-UTF-8 mode */ - { - if (lcc[c] == lcc[d]) { ADD_NEW(state_offset + 2, 0); } - } - break; - - -#ifdef SUPPORT_UCP - /*-----------------------------------------------------------------*/ - /* This is a tricky one because it can match more than one character. - Find out how many characters to skip, and then set up a negative state - to wait for them to pass before continuing. */ - - case OP_EXTUNI: - if (clen > 0 && _pcre_ucp_findprop(c, &chartype, &script) != ucp_M) - { - const uschar *nptr = ptr + clen; - int ncount = 0; - while (nptr < end_subject) - { - int nclen = 1; - GETCHARLEN(c, nptr, nclen); - if (_pcre_ucp_findprop(c, &chartype, &script) != ucp_M) break; - ncount++; - nptr += nclen; - } - ADD_NEW_DATA(-(state_offset + 1), 0, ncount); - } - break; -#endif - - /*-----------------------------------------------------------------*/ - /* This is a tricky like EXTUNI because it too can match more than one - character (when CR is followed by LF). In this case, set up a negative - state to wait for one character to pass before continuing. */ - - case OP_ANYNL: - if (clen > 0) switch(c) - { - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if ((md->moptions & PCRE_BSR_ANYCRLF) != 0) break; - - case 0x000a: - ADD_NEW(state_offset + 1, 0); - break; - - case 0x000d: - if (ptr + 1 < end_subject && ptr[1] == 0x0a) - { - ADD_NEW_DATA(-(state_offset + 1), 0, 1); - } - else - { - ADD_NEW(state_offset + 1, 0); - } - break; - } - break; - - /*-----------------------------------------------------------------*/ - case OP_NOT_VSPACE: - if (clen > 0) switch(c) - { - case 0x000a: - case 0x000b: - case 0x000c: - case 0x000d: - case 0x0085: - case 0x2028: - case 0x2029: - break; - - default: - ADD_NEW(state_offset + 1, 0); - break; - } - break; - - /*-----------------------------------------------------------------*/ - case OP_VSPACE: - if (clen > 0) switch(c) - { - case 0x000a: - case 0x000b: - case 0x000c: - case 0x000d: - case 0x0085: - case 0x2028: - case 0x2029: - ADD_NEW(state_offset + 1, 0); - break; - - default: break; - } - break; - - /*-----------------------------------------------------------------*/ - case OP_NOT_HSPACE: - if (clen > 0) switch(c) - { - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - break; - - default: - ADD_NEW(state_offset + 1, 0); - break; - } - break; - - /*-----------------------------------------------------------------*/ - case OP_HSPACE: - if (clen > 0) switch(c) - { - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - ADD_NEW(state_offset + 1, 0); - break; - } - break; - - /*-----------------------------------------------------------------*/ - /* Match a negated single character. This is only used for one-byte - characters, that is, we know that d < 256. The character we are - checking (c) can be multibyte. */ - - case OP_NOT: - if (clen > 0) - { - unsigned int otherd = ((ims & PCRE_CASELESS) != 0)? fcc[d] : d; - if (c != d && c != otherd) { ADD_NEW(state_offset + dlen + 1, 0); } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_PLUS: - case OP_MINPLUS: - case OP_POSPLUS: - case OP_NOTPLUS: - case OP_NOTMINPLUS: - case OP_NOTPOSPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(state_offset + dlen + 1, 0); } - if (clen > 0) - { - unsigned int otherd = NOTACHAR; - if ((ims & PCRE_CASELESS) != 0) - { -#ifdef SUPPORT_UTF8 - if (utf8 && d >= 128) - { -#ifdef SUPPORT_UCP - otherd = _pcre_ucp_othercase(d); -#endif /* SUPPORT_UCP */ - } - else -#endif /* SUPPORT_UTF8 */ - otherd = fcc[d]; - } - if ((c == d || c == otherd) == (codevalue < OP_NOTSTAR)) - { - if (count > 0 && - (codevalue == OP_POSPLUS || codevalue == OP_NOTPOSPLUS)) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - count++; - ADD_NEW(state_offset, count); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_QUERY: - case OP_MINQUERY: - case OP_POSQUERY: - case OP_NOTQUERY: - case OP_NOTMINQUERY: - case OP_NOTPOSQUERY: - ADD_ACTIVE(state_offset + dlen + 1, 0); - if (clen > 0) - { - unsigned int otherd = NOTACHAR; - if ((ims & PCRE_CASELESS) != 0) - { -#ifdef SUPPORT_UTF8 - if (utf8 && d >= 128) - { -#ifdef SUPPORT_UCP - otherd = _pcre_ucp_othercase(d); -#endif /* SUPPORT_UCP */ - } - else -#endif /* SUPPORT_UTF8 */ - otherd = fcc[d]; - } - if ((c == d || c == otherd) == (codevalue < OP_NOTSTAR)) - { - if (codevalue == OP_POSQUERY || codevalue == OP_NOTPOSQUERY) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW(state_offset + dlen + 1, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_STAR: - case OP_MINSTAR: - case OP_POSSTAR: - case OP_NOTSTAR: - case OP_NOTMINSTAR: - case OP_NOTPOSSTAR: - ADD_ACTIVE(state_offset + dlen + 1, 0); - if (clen > 0) - { - unsigned int otherd = NOTACHAR; - if ((ims & PCRE_CASELESS) != 0) - { -#ifdef SUPPORT_UTF8 - if (utf8 && d >= 128) - { -#ifdef SUPPORT_UCP - otherd = _pcre_ucp_othercase(d); -#endif /* SUPPORT_UCP */ - } - else -#endif /* SUPPORT_UTF8 */ - otherd = fcc[d]; - } - if ((c == d || c == otherd) == (codevalue < OP_NOTSTAR)) - { - if (codevalue == OP_POSSTAR || codevalue == OP_NOTPOSSTAR) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - ADD_NEW(state_offset, 0); - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_EXACT: - case OP_NOTEXACT: - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - unsigned int otherd = NOTACHAR; - if ((ims & PCRE_CASELESS) != 0) - { -#ifdef SUPPORT_UTF8 - if (utf8 && d >= 128) - { -#ifdef SUPPORT_UCP - otherd = _pcre_ucp_othercase(d); -#endif /* SUPPORT_UCP */ - } - else -#endif /* SUPPORT_UTF8 */ - otherd = fcc[d]; - } - if ((c == d || c == otherd) == (codevalue < OP_NOTSTAR)) - { - if (++count >= GET2(code, 1)) - { ADD_NEW(state_offset + dlen + 3, 0); } - else - { ADD_NEW(state_offset, count); } - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_UPTO: - case OP_MINUPTO: - case OP_POSUPTO: - case OP_NOTUPTO: - case OP_NOTMINUPTO: - case OP_NOTPOSUPTO: - ADD_ACTIVE(state_offset + dlen + 3, 0); - count = current_state->count; /* Number already matched */ - if (clen > 0) - { - unsigned int otherd = NOTACHAR; - if ((ims & PCRE_CASELESS) != 0) - { -#ifdef SUPPORT_UTF8 - if (utf8 && d >= 128) - { -#ifdef SUPPORT_UCP - otherd = _pcre_ucp_othercase(d); -#endif /* SUPPORT_UCP */ - } - else -#endif /* SUPPORT_UTF8 */ - otherd = fcc[d]; - } - if ((c == d || c == otherd) == (codevalue < OP_NOTSTAR)) - { - if (codevalue == OP_POSUPTO || codevalue == OP_NOTPOSUPTO) - { - active_count--; /* Remove non-match possibility */ - next_active_state--; - } - if (++count >= GET2(code, 1)) - { ADD_NEW(state_offset + dlen + 3, 0); } - else - { ADD_NEW(state_offset, count); } - } - } - break; - - -/* ========================================================================== */ - /* These are the class-handling opcodes */ - - case OP_CLASS: - case OP_NCLASS: - case OP_XCLASS: - { - BOOL isinclass = FALSE; - int next_state_offset; - const uschar *ecode; - - /* For a simple class, there is always just a 32-byte table, and we - can set isinclass from it. */ - - if (codevalue != OP_XCLASS) - { - ecode = code + 33; - if (clen > 0) - { - isinclass = (c > 255)? (codevalue == OP_NCLASS) : - ((code[1 + c/8] & (1 << (c&7))) != 0); - } - } - - /* An extended class may have a table or a list of single characters, - ranges, or both, and it may be positive or negative. There's a - function that sorts all this out. */ - - else - { - ecode = code + GET(code, 1); - if (clen > 0) isinclass = _pcre_xclass(c, code + 1 + LINK_SIZE); - } - - /* At this point, isinclass is set for all kinds of class, and ecode - points to the byte after the end of the class. If there is a - quantifier, this is where it will be. */ - - next_state_offset = ecode - start_code; - - switch (*ecode) - { - case OP_CRSTAR: - case OP_CRMINSTAR: - ADD_ACTIVE(next_state_offset + 1, 0); - if (isinclass) { ADD_NEW(state_offset, 0); } - break; - - case OP_CRPLUS: - case OP_CRMINPLUS: - count = current_state->count; /* Already matched */ - if (count > 0) { ADD_ACTIVE(next_state_offset + 1, 0); } - if (isinclass) { count++; ADD_NEW(state_offset, count); } - break; - - case OP_CRQUERY: - case OP_CRMINQUERY: - ADD_ACTIVE(next_state_offset + 1, 0); - if (isinclass) { ADD_NEW(next_state_offset + 1, 0); } - break; - - case OP_CRRANGE: - case OP_CRMINRANGE: - count = current_state->count; /* Already matched */ - if (count >= GET2(ecode, 1)) - { ADD_ACTIVE(next_state_offset + 5, 0); } - if (isinclass) - { - int max = GET2(ecode, 3); - if (++count >= max && max != 0) /* Max 0 => no limit */ - { ADD_NEW(next_state_offset + 5, 0); } - else - { ADD_NEW(state_offset, count); } - } - break; - - default: - if (isinclass) { ADD_NEW(next_state_offset, 0); } - break; - } - } - break; - -/* ========================================================================== */ - /* These are the opcodes for fancy brackets of various kinds. We have - to use recursion in order to handle them. */ - - case OP_ASSERT: - case OP_ASSERT_NOT: - case OP_ASSERTBACK: - case OP_ASSERTBACK_NOT: - { - int rc; - int local_offsets[2]; - int local_workspace[1000]; - const uschar *endasscode = code + GET(code, 1); - - while (*endasscode == OP_ALT) endasscode += GET(endasscode, 1); - - rc = internal_dfa_exec( - md, /* static match data */ - code, /* this subexpression's code */ - ptr, /* where we currently are */ - ptr - start_subject, /* start offset */ - local_offsets, /* offset vector */ - sizeof(local_offsets)/sizeof(int), /* size of same */ - local_workspace, /* workspace vector */ - sizeof(local_workspace)/sizeof(int), /* size of same */ - ims, /* the current ims flags */ - rlevel, /* function recursion level */ - recursing); /* pass on regex recursion */ - - if ((rc >= 0) == (codevalue == OP_ASSERT || codevalue == OP_ASSERTBACK)) - { ADD_ACTIVE(endasscode + LINK_SIZE + 1 - start_code, 0); } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_COND: - case OP_SCOND: - { - int local_offsets[1000]; - int local_workspace[1000]; - int condcode = code[LINK_SIZE+1]; - - /* Back reference conditions are not supported */ - - if (condcode == OP_CREF) return PCRE_ERROR_DFA_UCOND; - - /* The DEFINE condition is always false */ - - if (condcode == OP_DEF) - { - ADD_ACTIVE(state_offset + GET(code, 1) + LINK_SIZE + 1, 0); - } - - /* The only supported version of OP_RREF is for the value RREF_ANY, - which means "test if in any recursion". We can't test for specifically - recursed groups. */ - - else if (condcode == OP_RREF) - { - int value = GET2(code, LINK_SIZE+2); - if (value != RREF_ANY) return PCRE_ERROR_DFA_UCOND; - if (recursing > 0) { ADD_ACTIVE(state_offset + LINK_SIZE + 4, 0); } - else { ADD_ACTIVE(state_offset + GET(code, 1) + LINK_SIZE + 1, 0); } - } - - /* Otherwise, the condition is an assertion */ - - else - { - int rc; - const uschar *asscode = code + LINK_SIZE + 1; - const uschar *endasscode = asscode + GET(asscode, 1); - - while (*endasscode == OP_ALT) endasscode += GET(endasscode, 1); - - rc = internal_dfa_exec( - md, /* fixed match data */ - asscode, /* this subexpression's code */ - ptr, /* where we currently are */ - ptr - start_subject, /* start offset */ - local_offsets, /* offset vector */ - sizeof(local_offsets)/sizeof(int), /* size of same */ - local_workspace, /* workspace vector */ - sizeof(local_workspace)/sizeof(int), /* size of same */ - ims, /* the current ims flags */ - rlevel, /* function recursion level */ - recursing); /* pass on regex recursion */ - - if ((rc >= 0) == - (condcode == OP_ASSERT || condcode == OP_ASSERTBACK)) - { ADD_ACTIVE(endasscode + LINK_SIZE + 1 - start_code, 0); } - else - { ADD_ACTIVE(state_offset + GET(code, 1) + LINK_SIZE + 1, 0); } - } - } - break; - - /*-----------------------------------------------------------------*/ - case OP_RECURSE: - { - int local_offsets[1000]; - int local_workspace[1000]; - int rc; - - DPRINTF(("%.*sStarting regex recursion %d\n", rlevel*2-2, SP, - recursing + 1)); - - rc = internal_dfa_exec( - md, /* fixed match data */ - start_code + GET(code, 1), /* this subexpression's code */ - ptr, /* where we currently are */ - ptr - start_subject, /* start offset */ - local_offsets, /* offset vector */ - sizeof(local_offsets)/sizeof(int), /* size of same */ - local_workspace, /* workspace vector */ - sizeof(local_workspace)/sizeof(int), /* size of same */ - ims, /* the current ims flags */ - rlevel, /* function recursion level */ - recursing + 1); /* regex recurse level */ - - DPRINTF(("%.*sReturn from regex recursion %d: rc=%d\n", rlevel*2-2, SP, - recursing + 1, rc)); - - /* Ran out of internal offsets */ - - if (rc == 0) return PCRE_ERROR_DFA_RECURSE; - - /* For each successful matched substring, set up the next state with a - count of characters to skip before trying it. Note that the count is in - characters, not bytes. */ - - if (rc > 0) - { - for (rc = rc*2 - 2; rc >= 0; rc -= 2) - { - const uschar *p = start_subject + local_offsets[rc]; - const uschar *pp = start_subject + local_offsets[rc+1]; - int charcount = local_offsets[rc+1] - local_offsets[rc]; - while (p < pp) if ((*p++ & 0xc0) == 0x80) charcount--; - if (charcount > 0) - { - ADD_NEW_DATA(-(state_offset + LINK_SIZE + 1), 0, (charcount - 1)); - } - else - { - ADD_ACTIVE(state_offset + LINK_SIZE + 1, 0); - } - } - } - else if (rc != PCRE_ERROR_NOMATCH) return rc; - } - break; - - /*-----------------------------------------------------------------*/ - case OP_ONCE: - { - int local_offsets[2]; - int local_workspace[1000]; - - int rc = internal_dfa_exec( - md, /* fixed match data */ - code, /* this subexpression's code */ - ptr, /* where we currently are */ - ptr - start_subject, /* start offset */ - local_offsets, /* offset vector */ - sizeof(local_offsets)/sizeof(int), /* size of same */ - local_workspace, /* workspace vector */ - sizeof(local_workspace)/sizeof(int), /* size of same */ - ims, /* the current ims flags */ - rlevel, /* function recursion level */ - recursing); /* pass on regex recursion */ - - if (rc >= 0) - { - const uschar *end_subpattern = code; - int charcount = local_offsets[1] - local_offsets[0]; - int next_state_offset, repeat_state_offset; - - do { end_subpattern += GET(end_subpattern, 1); } - while (*end_subpattern == OP_ALT); - next_state_offset = end_subpattern - start_code + LINK_SIZE + 1; - - /* If the end of this subpattern is KETRMAX or KETRMIN, we must - arrange for the repeat state also to be added to the relevant list. - Calculate the offset, or set -1 for no repeat. */ - - repeat_state_offset = (*end_subpattern == OP_KETRMAX || - *end_subpattern == OP_KETRMIN)? - end_subpattern - start_code - GET(end_subpattern, 1) : -1; - - /* If we have matched an empty string, add the next state at the - current character pointer. This is important so that the duplicate - checking kicks in, which is what breaks infinite loops that match an - empty string. */ - - if (charcount == 0) - { - ADD_ACTIVE(next_state_offset, 0); - } - - /* Optimization: if there are no more active states, and there - are no new states yet set up, then skip over the subject string - right here, to save looping. Otherwise, set up the new state to swing - into action when the end of the substring is reached. */ - - else if (i + 1 >= active_count && new_count == 0) - { - ptr += charcount; - clen = 0; - ADD_NEW(next_state_offset, 0); - - /* If we are adding a repeat state at the new character position, - we must fudge things so that it is the only current state. - Otherwise, it might be a duplicate of one we processed before, and - that would cause it to be skipped. */ - - if (repeat_state_offset >= 0) - { - next_active_state = active_states; - active_count = 0; - i = -1; - ADD_ACTIVE(repeat_state_offset, 0); - } - } - else - { - const uschar *p = start_subject + local_offsets[0]; - const uschar *pp = start_subject + local_offsets[1]; - while (p < pp) if ((*p++ & 0xc0) == 0x80) charcount--; - ADD_NEW_DATA(-next_state_offset, 0, (charcount - 1)); - if (repeat_state_offset >= 0) - { ADD_NEW_DATA(-repeat_state_offset, 0, (charcount - 1)); } - } - - } - else if (rc != PCRE_ERROR_NOMATCH) return rc; - } - break; - - -/* ========================================================================== */ - /* Handle callouts */ - - case OP_CALLOUT: - if (pcre_callout != NULL) - { - int rrc; - pcre_callout_block cb; - cb.version = 1; /* Version 1 of the callout block */ - cb.callout_number = code[1]; - cb.offset_vector = offsets; - cb.subject = (PCRE_SPTR)start_subject; - cb.subject_length = end_subject - start_subject; - cb.start_match = current_subject - start_subject; - cb.current_position = ptr - start_subject; - cb.pattern_position = GET(code, 2); - cb.next_item_length = GET(code, 2 + LINK_SIZE); - cb.capture_top = 1; - cb.capture_last = -1; - cb.callout_data = md->callout_data; - if ((rrc = (*pcre_callout)(&cb)) < 0) return rrc; /* Abandon */ - if (rrc == 0) { ADD_ACTIVE(state_offset + 2 + 2*LINK_SIZE, 0); } - } - break; - - -/* ========================================================================== */ - default: /* Unsupported opcode */ - return PCRE_ERROR_DFA_UITEM; - } - - NEXT_ACTIVE_STATE: continue; - - } /* End of loop scanning active states */ - - /* We have finished the processing at the current subject character. If no - new states have been set for the next character, we have found all the - matches that we are going to find. If we are at the top level and partial - matching has been requested, check for appropriate conditions. */ - - if (new_count <= 0) - { - if (match_count < 0 && /* No matches found */ - rlevel == 1 && /* Top level match function */ - (md->moptions & PCRE_PARTIAL) != 0 && /* Want partial matching */ - ptr >= end_subject && /* Reached end of subject */ - ptr > current_subject) /* Matched non-empty string */ - { - if (offsetcount >= 2) - { - offsets[0] = current_subject - start_subject; - offsets[1] = end_subject - start_subject; - } - match_count = PCRE_ERROR_PARTIAL; - } - - DPRINTF(("%.*sEnd of internal_dfa_exec %d: returning %d\n" - "%.*s---------------------\n\n", rlevel*2-2, SP, rlevel, match_count, - rlevel*2-2, SP)); - break; /* In effect, "return", but see the comment below */ - } - - /* One or more states are active for the next character. */ - - ptr += clen; /* Advance to next subject character */ - } /* Loop to move along the subject string */ - -/* Control gets here from "break" a few lines above. We do it this way because -if we use "return" above, we have compiler trouble. Some compilers warn if -there's nothing here because they think the function doesn't return a value. On -the other hand, if we put a dummy statement here, some more clever compilers -complain that it can't be reached. Sigh. */ - -return match_count; -} - - - - -/************************************************* -* Execute a Regular Expression - DFA engine * -*************************************************/ - -/* This external function applies a compiled re to a subject string using a DFA -engine. This function calls the internal function multiple times if the pattern -is not anchored. - -Arguments: - argument_re points to the compiled expression - extra_data points to extra data or is NULL - subject points to the subject string - length length of subject string (may contain binary zeros) - start_offset where to start in the subject string - options option bits - offsets vector of match offsets - offsetcount size of same - workspace workspace vector - wscount size of same - -Returns: > 0 => number of match offset pairs placed in offsets - = 0 => offsets overflowed; longest matches are present - -1 => failed to match - < -1 => some kind of unexpected problem -*/ - -PCRE_EXP_DEFN int -pcre_dfa_exec(const pcre *argument_re, const pcre_extra *extra_data, - const char *subject, int length, int start_offset, int options, int *offsets, - int offsetcount, int *workspace, int wscount) -{ -real_pcre *re = (real_pcre *)argument_re; -dfa_match_data match_block; -dfa_match_data *md = &match_block; -BOOL utf8, anchored, startline, firstline; -const uschar *current_subject, *end_subject, *lcc; - -pcre_study_data internal_study; -const pcre_study_data *study = NULL; -real_pcre internal_re; - -const uschar *req_byte_ptr; -const uschar *start_bits = NULL; -BOOL first_byte_caseless = FALSE; -BOOL req_byte_caseless = FALSE; -int first_byte = -1; -int req_byte = -1; -int req_byte2 = -1; -int newline; - -/* Plausibility checks */ - -if ((options & ~PUBLIC_DFA_EXEC_OPTIONS) != 0) return PCRE_ERROR_BADOPTION; -if (re == NULL || subject == NULL || workspace == NULL || - (offsets == NULL && offsetcount > 0)) return PCRE_ERROR_NULL; -if (offsetcount < 0) return PCRE_ERROR_BADCOUNT; -if (wscount < 20) return PCRE_ERROR_DFA_WSSIZE; - -/* We need to find the pointer to any study data before we test for byte -flipping, so we scan the extra_data block first. This may set two fields in the -match block, so we must initialize them beforehand. However, the other fields -in the match block must not be set until after the byte flipping. */ - -md->tables = re->tables; -md->callout_data = NULL; - -if (extra_data != NULL) - { - unsigned int flags = extra_data->flags; - if ((flags & PCRE_EXTRA_STUDY_DATA) != 0) - study = (const pcre_study_data *)extra_data->study_data; - if ((flags & PCRE_EXTRA_MATCH_LIMIT) != 0) return PCRE_ERROR_DFA_UMLIMIT; - if ((flags & PCRE_EXTRA_MATCH_LIMIT_RECURSION) != 0) - return PCRE_ERROR_DFA_UMLIMIT; - if ((flags & PCRE_EXTRA_CALLOUT_DATA) != 0) - md->callout_data = extra_data->callout_data; - if ((flags & PCRE_EXTRA_TABLES) != 0) - md->tables = extra_data->tables; - } - -/* Check that the first field in the block is the magic number. If it is not, -test for a regex that was compiled on a host of opposite endianness. If this is -the case, flipped values are put in internal_re and internal_study if there was -study data too. */ - -if (re->magic_number != MAGIC_NUMBER) - { - re = _pcre_try_flipped(re, &internal_re, study, &internal_study); - if (re == NULL) return PCRE_ERROR_BADMAGIC; - if (study != NULL) study = &internal_study; - } - -/* Set some local values */ - -current_subject = (const unsigned char *)subject + start_offset; -end_subject = (const unsigned char *)subject + length; -req_byte_ptr = current_subject - 1; - -#ifdef SUPPORT_UTF8 -utf8 = (re->options & PCRE_UTF8) != 0; -#else -utf8 = FALSE; -#endif - -anchored = (options & (PCRE_ANCHORED|PCRE_DFA_RESTART)) != 0 || - (re->options & PCRE_ANCHORED) != 0; - -/* The remaining fixed data for passing around. */ - -md->start_code = (const uschar *)argument_re + - re->name_table_offset + re->name_count * re->name_entry_size; -md->start_subject = (const unsigned char *)subject; -md->end_subject = end_subject; -md->moptions = options; -md->poptions = re->options; - -/* If the BSR option is not set at match time, copy what was set -at compile time. */ - -if ((md->moptions & (PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE)) == 0) - { - if ((re->options & (PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE)) != 0) - md->moptions |= re->options & (PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE); -#ifdef BSR_ANYCRLF - else md->moptions |= PCRE_BSR_ANYCRLF; -#endif - } - -/* Handle different types of newline. The three bits give eight cases. If -nothing is set at run time, whatever was used at compile time applies. */ - -switch ((((options & PCRE_NEWLINE_BITS) == 0)? re->options : (pcre_uint32)options) & - PCRE_NEWLINE_BITS) - { - case 0: newline = NEWLINE; break; /* Compile-time default */ - case PCRE_NEWLINE_CR: newline = '\r'; break; - case PCRE_NEWLINE_LF: newline = '\n'; break; - case PCRE_NEWLINE_CR+ - PCRE_NEWLINE_LF: newline = ('\r' << 8) | '\n'; break; - case PCRE_NEWLINE_ANY: newline = -1; break; - case PCRE_NEWLINE_ANYCRLF: newline = -2; break; - default: return PCRE_ERROR_BADNEWLINE; - } - -if (newline == -2) - { - md->nltype = NLTYPE_ANYCRLF; - } -else if (newline < 0) - { - md->nltype = NLTYPE_ANY; - } -else - { - md->nltype = NLTYPE_FIXED; - if (newline > 255) - { - md->nllen = 2; - md->nl[0] = (newline >> 8) & 255; - md->nl[1] = newline & 255; - } - else - { - md->nllen = 1; - md->nl[0] = newline; - } - } - -/* Check a UTF-8 string if required. Unfortunately there's no way of passing -back the character offset. */ - -#ifdef SUPPORT_UTF8 -if (utf8 && (options & PCRE_NO_UTF8_CHECK) == 0) - { - if (_pcre_valid_utf8((uschar *)subject, length) >= 0) - return PCRE_ERROR_BADUTF8; - if (start_offset > 0 && start_offset < length) - { - int tb = ((uschar *)subject)[start_offset]; - if (tb > 127) - { - tb &= 0xc0; - if (tb != 0 && tb != 0xc0) return PCRE_ERROR_BADUTF8_OFFSET; - } - } - } -#endif - -/* If the exec call supplied NULL for tables, use the inbuilt ones. This -is a feature that makes it possible to save compiled regex and re-use them -in other programs later. */ - -if (md->tables == NULL) md->tables = _pcre_default_tables; - -/* The lower casing table and the "must be at the start of a line" flag are -used in a loop when finding where to start. */ - -lcc = md->tables + lcc_offset; -startline = (re->flags & PCRE_STARTLINE) != 0; -firstline = (re->options & PCRE_FIRSTLINE) != 0; - -/* Set up the first character to match, if available. The first_byte value is -never set for an anchored regular expression, but the anchoring may be forced -at run time, so we have to test for anchoring. The first char may be unset for -an unanchored pattern, of course. If there's no first char and the pattern was -studied, there may be a bitmap of possible first characters. */ - -if (!anchored) - { - if ((re->flags & PCRE_FIRSTSET) != 0) - { - first_byte = re->first_byte & 255; - if ((first_byte_caseless = ((re->first_byte & REQ_CASELESS) != 0)) == TRUE) - first_byte = lcc[first_byte]; - } - else - { - if (startline && study != NULL && - (study->options & PCRE_STUDY_MAPPED) != 0) - start_bits = study->start_bits; - } - } - -/* For anchored or unanchored matches, there may be a "last known required -character" set. */ - -if ((re->flags & PCRE_REQCHSET) != 0) - { - req_byte = re->req_byte & 255; - req_byte_caseless = (re->req_byte & REQ_CASELESS) != 0; - req_byte2 = (md->tables + fcc_offset)[req_byte]; /* case flipped */ - } - -/* Call the main matching function, looping for a non-anchored regex after a -failed match. Unless restarting, optimize by moving to the first match -character if possible, when not anchored. Then unless wanting a partial match, -check for a required later character. */ - -for (;;) - { - int rc; - - if ((options & PCRE_DFA_RESTART) == 0) - { - const uschar *save_end_subject = end_subject; - - /* Advance to a unique first char if possible. If firstline is TRUE, the - start of the match is constrained to the first line of a multiline string. - Implement this by temporarily adjusting end_subject so that we stop - scanning at a newline. If the match fails at the newline, later code breaks - this loop. */ - - if (firstline) - { - const uschar *t = current_subject; - while (t < md->end_subject && !IS_NEWLINE(t)) t++; - end_subject = t; - } - - if (first_byte >= 0) - { - if (first_byte_caseless) - while (current_subject < end_subject && - lcc[*current_subject] != first_byte) - current_subject++; - else - while (current_subject < end_subject && *current_subject != first_byte) - current_subject++; - } - - /* Or to just after a linebreak for a multiline match if possible */ - - else if (startline) - { - if (current_subject > md->start_subject + start_offset) - { - while (current_subject <= end_subject && !WAS_NEWLINE(current_subject)) - current_subject++; - - /* If we have just passed a CR and the newline option is ANY or - ANYCRLF, and we are now at a LF, advance the match position by one more - character. */ - - if (current_subject[-1] == '\r' && - (md->nltype == NLTYPE_ANY || md->nltype == NLTYPE_ANYCRLF) && - current_subject < end_subject && - *current_subject == '\n') - current_subject++; - } - } - - /* Or to a non-unique first char after study */ - - else if (start_bits != NULL) - { - while (current_subject < end_subject) - { - register unsigned int c = *current_subject; - if ((start_bits[c/8] & (1 << (c&7))) == 0) current_subject++; - else break; - } - } - - /* Restore fudged end_subject */ - - end_subject = save_end_subject; - } - - /* If req_byte is set, we know that that character must appear in the subject - for the match to succeed. If the first character is set, req_byte must be - later in the subject; otherwise the test starts at the match point. This - optimization can save a huge amount of work in patterns with nested unlimited - repeats that aren't going to match. Writing separate code for cased/caseless - versions makes it go faster, as does using an autoincrement and backing off - on a match. - - HOWEVER: when the subject string is very, very long, searching to its end can - take a long time, and give bad performance on quite ordinary patterns. This - showed up when somebody was matching /^C/ on a 32-megabyte string... so we - don't do this when the string is sufficiently long. - - ALSO: this processing is disabled when partial matching is requested. - */ - - if (req_byte >= 0 && - end_subject - current_subject < REQ_BYTE_MAX && - (options & PCRE_PARTIAL) == 0) - { - register const uschar *p = current_subject + ((first_byte >= 0)? 1 : 0); - - /* We don't need to repeat the search if we haven't yet reached the - place we found it at last time. */ - - if (p > req_byte_ptr) - { - if (req_byte_caseless) - { - while (p < end_subject) - { - register int pp = *p++; - if (pp == req_byte || pp == req_byte2) { p--; break; } - } - } - else - { - while (p < end_subject) - { - if (*p++ == req_byte) { p--; break; } - } - } - - /* If we can't find the required character, break the matching loop, - which will cause a return or PCRE_ERROR_NOMATCH. */ - - if (p >= end_subject) break; - - /* If we have found the required character, save the point where we - found it, so that we don't search again next time round the loop if - the start hasn't passed this character yet. */ - - req_byte_ptr = p; - } - } - - /* OK, now we can do the business */ - - rc = internal_dfa_exec( - md, /* fixed match data */ - md->start_code, /* this subexpression's code */ - current_subject, /* where we currently are */ - start_offset, /* start offset in subject */ - offsets, /* offset vector */ - offsetcount, /* size of same */ - workspace, /* workspace vector */ - wscount, /* size of same */ - re->options & (PCRE_CASELESS|PCRE_MULTILINE|PCRE_DOTALL), /* ims flags */ - 0, /* function recurse level */ - 0); /* regex recurse level */ - - /* Anything other than "no match" means we are done, always; otherwise, carry - on only if not anchored. */ - - if (rc != PCRE_ERROR_NOMATCH || anchored) return rc; - - /* Advance to the next subject character unless we are at the end of a line - and firstline is set. */ - - if (firstline && IS_NEWLINE(current_subject)) break; - current_subject++; - if (utf8) - { - while (current_subject < end_subject && (*current_subject & 0xc0) == 0x80) - current_subject++; - } - if (current_subject > end_subject) break; - - /* If we have just passed a CR and we are now at a LF, and the pattern does - not contain any explicit matches for \r or \n, and the newline option is CRLF - or ANY or ANYCRLF, advance the match position by one more character. */ - - if (current_subject[-1] == '\r' && - current_subject < end_subject && - *current_subject == '\n' && - (re->flags & PCRE_HASCRORLF) == 0 && - (md->nltype == NLTYPE_ANY || - md->nltype == NLTYPE_ANYCRLF || - md->nllen == 2)) - current_subject++; - - } /* "Bumpalong" loop */ - -return PCRE_ERROR_NOMATCH; -} - -/* End of pcre_dfa_exec.c */ diff --git a/src/plugins/PCREPlugin/pcre_dftables.c b/src/plugins/PCREPlugin/pcre_dftables.c deleted file mode 100644 index ae3e3ef..0000000 --- a/src/plugins/PCREPlugin/pcre_dftables.c +++ /dev/null @@ -1,192 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* This file is automatically written by the dftables auxiliary -program. If you edit it by hand, you might like to edit the Makefile to -prevent its ever being regenerated. - -This file contains the default tables for characters with codes less than -128 (ASCII characters). These tables are used when no external tables are -passed to PCRE. - -The following #include is present because without it gcc 4.x may remove -the array definition from the final binary if PCRE is built into a static -library and dead code stripping is activated. This leads to link errors. -Pulling in the header ensures that the array gets flagged as "someone -outside this compilation unit might reference this" and so it will always -be supplied to the linker. */ - -#include "pcre_internal.h" - -const unsigned char _pcre_default_tables[] = { - -/* This table is a lower casing table. */ - - 0, 1, 2, 3, 4, 5, 6, 7, - 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, - 24, 25, 26, 27, 28, 29, 30, 31, - 32, 33, 34, 35, 36, 37, 38, 39, - 40, 41, 42, 43, 44, 45, 46, 47, - 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, - 64, 97, 98, 99,100,101,102,103, - 104,105,106,107,108,109,110,111, - 112,113,114,115,116,117,118,119, - 120,121,122, 91, 92, 93, 94, 95, - 96, 97, 98, 99,100,101,102,103, - 104,105,106,107,108,109,110,111, - 112,113,114,115,116,117,118,119, - 120,121,122,123,124,125,126,127, - 128,129,130,131,132,133,134,135, - 136,137,138,139,140,141,142,143, - 144,145,146,147,148,149,150,151, - 152,153,154,155,156,157,158,159, - 160,161,162,163,164,165,166,167, - 168,169,170,171,172,173,174,175, - 176,177,178,179,180,181,182,183, - 184,185,186,187,188,189,190,191, - 192,193,194,195,196,197,198,199, - 200,201,202,203,204,205,206,207, - 208,209,210,211,212,213,214,215, - 216,217,218,219,220,221,222,223, - 224,225,226,227,228,229,230,231, - 232,233,234,235,236,237,238,239, - 240,241,242,243,244,245,246,247, - 248,249,250,251,252,253,254,255, - -/* This table is a case flipping table. */ - - 0, 1, 2, 3, 4, 5, 6, 7, - 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, - 24, 25, 26, 27, 28, 29, 30, 31, - 32, 33, 34, 35, 36, 37, 38, 39, - 40, 41, 42, 43, 44, 45, 46, 47, - 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, - 64, 97, 98, 99,100,101,102,103, - 104,105,106,107,108,109,110,111, - 112,113,114,115,116,117,118,119, - 120,121,122, 91, 92, 93, 94, 95, - 96, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90,123,124,125,126,127, - 128,129,130,131,132,133,134,135, - 136,137,138,139,140,141,142,143, - 144,145,146,147,148,149,150,151, - 152,153,154,155,156,157,158,159, - 160,161,162,163,164,165,166,167, - 168,169,170,171,172,173,174,175, - 176,177,178,179,180,181,182,183, - 184,185,186,187,188,189,190,191, - 192,193,194,195,196,197,198,199, - 200,201,202,203,204,205,206,207, - 208,209,210,211,212,213,214,215, - 216,217,218,219,220,221,222,223, - 224,225,226,227,228,229,230,231, - 232,233,234,235,236,237,238,239, - 240,241,242,243,244,245,246,247, - 248,249,250,251,252,253,254,255, - -/* This table contains bit maps for various character classes. -Each map is 32 bytes long and the bits run from the least -significant end of each byte. The classes that have their own -maps are: space, xdigit, digit, upper, lower, word, graph -print, punct, and cntrl. Other classes are built from combinations. */ - - 0x00,0x3e,0x00,0x00,0x01,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0x00,0x00,0xff,0x03, - 0x7e,0x00,0x00,0x00,0x7e,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0x00,0x00,0xff,0x03, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0xfe,0xff,0xff,0x07,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0xfe,0xff,0xff,0x07, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0x00,0x00,0xff,0x03, - 0xfe,0xff,0xff,0x87,0xfe,0xff,0xff,0x07, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0xfe,0xff,0xff,0xff, - 0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x7f, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0xff,0xff,0xff,0xff, - 0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x7f, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0x00,0x00,0x00,0x00,0xfe,0xff,0x00,0xfc, - 0x01,0x00,0x00,0xf8,0x01,0x00,0x00,0x78, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - - 0xff,0xff,0xff,0xff,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x80, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, - -/* This table identifies various classes of character by individual bits: - 0x01 white space character - 0x02 letter - 0x04 decimal digit - 0x08 hexadecimal digit - 0x10 alphanumeric or '_' - 0x80 regular expression metacharacter or binary zero -*/ - - 0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 0- 7 */ - 0x00,0x01,0x01,0x00,0x01,0x01,0x00,0x00, /* 8- 15 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 16- 23 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 24- 31 */ - 0x01,0x00,0x00,0x00,0x80,0x00,0x00,0x00, /* - ' */ - 0x80,0x80,0x80,0x80,0x00,0x00,0x80,0x00, /* ( - / */ - 0x1c,0x1c,0x1c,0x1c,0x1c,0x1c,0x1c,0x1c, /* 0 - 7 */ - 0x1c,0x1c,0x00,0x00,0x00,0x00,0x00,0x80, /* 8 - ? */ - 0x00,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x12, /* @ - G */ - 0x12,0x12,0x12,0x12,0x12,0x12,0x12,0x12, /* H - O */ - 0x12,0x12,0x12,0x12,0x12,0x12,0x12,0x12, /* P - W */ - 0x12,0x12,0x12,0x80,0x80,0x00,0x80,0x10, /* X - _ */ - 0x00,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x12, /* ` - g */ - 0x12,0x12,0x12,0x12,0x12,0x12,0x12,0x12, /* h - o */ - 0x12,0x12,0x12,0x12,0x12,0x12,0x12,0x12, /* p - w */ - 0x12,0x12,0x12,0x80,0x80,0x00,0x00,0x00, /* x -127 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 128-135 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 136-143 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 144-151 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 152-159 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 160-167 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 168-175 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 176-183 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 184-191 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 192-199 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 200-207 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 208-215 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 216-223 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 224-231 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 232-239 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* 240-247 */ - 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};/* 248-255 */ - -/* End of chartables.c */ diff --git a/src/plugins/PCREPlugin/pcre_exec.c b/src/plugins/PCREPlugin/pcre_exec.c deleted file mode 100644 index 6db7c35..0000000 --- a/src/plugins/PCREPlugin/pcre_exec.c +++ /dev/null @@ -1,4938 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains pcre_exec(), the externally visible function that does -pattern matching using an NFA algorithm, trying to mimic Perl as closely as -possible. There are also some static supporting functions. */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#define NLBLOCK md /* Block containing newline information */ -#define PSSTART start_subject /* Field containing processed string start */ -#define PSEND end_subject /* Field containing processed string end */ - -#include "pcre_internal.h" - -/* Undefine some potentially clashing cpp symbols */ - -#undef min -#undef max - -/* Flag bits for the match() function */ - -#define match_condassert 0x01 /* Called to check a condition assertion */ -#define match_cbegroup 0x02 /* Could-be-empty unlimited repeat group */ - -/* Non-error returns from the match() function. Error returns are externally -defined PCRE_ERROR_xxx codes, which are all negative. */ - -#define MATCH_MATCH 1 -#define MATCH_NOMATCH 0 - -/* Special internal returns from the match() function. Make them sufficiently -negative to avoid the external error codes. */ - -#define MATCH_COMMIT (-999) -#define MATCH_PRUNE (-998) -#define MATCH_SKIP (-997) -#define MATCH_THEN (-996) - -/* Maximum number of ints of offset to save on the stack for recursive calls. -If the offset vector is bigger, malloc is used. This should be a multiple of 3, -because the offset vector is always a multiple of 3 long. */ - -#define REC_STACK_SAVE_MAX 30 - -/* Min and max values for the common repeats; for the maxima, 0 => infinity */ - -static const char rep_min[] = { 0, 0, 1, 1, 0, 0 }; -static const char rep_max[] = { 0, 0, 0, 0, 1, 1 }; - - - -#ifdef DEBUG -/************************************************* -* Debugging function to print chars * -*************************************************/ - -/* Print a sequence of chars in printable format, stopping at the end of the -subject if the requested. - -Arguments: - p points to characters - length number to print - is_subject TRUE if printing from within md->start_subject - md pointer to matching data block, if is_subject is TRUE - -Returns: nothing -*/ - -static void -pchars(const uschar *p, int length, BOOL is_subject, match_data *md) -{ -unsigned int c; -if (is_subject && length > md->end_subject - p) length = md->end_subject - p; -while (length-- > 0) - if (isprint(c = *(p++))) printf("%c", c); else printf("\\x%02x", c); -} -#endif - - - -/************************************************* -* Match a back-reference * -*************************************************/ - -/* If a back reference hasn't been set, the length that is passed is greater -than the number of characters left in the string, so the match fails. - -Arguments: - offset index into the offset vector - eptr points into the subject - length length to be matched - md points to match data block - ims the ims flags - -Returns: TRUE if matched -*/ - -static BOOL -match_ref(int offset, register USPTR eptr, int length, match_data *md, - unsigned long int ims) -{ -USPTR p = md->start_subject + md->offset_vector[offset]; - -#ifdef DEBUG -if (eptr >= md->end_subject) - printf("matching subject "); -else - { - printf("matching subject "); - pchars(eptr, length, TRUE, md); - } -printf(" against backref "); -pchars(p, length, FALSE, md); -printf("\n"); -#endif - -/* Always fail if not enough characters left */ - -if (length > md->end_subject - eptr) return FALSE; - -/* Separate the caselesss case for speed */ - -if ((ims & PCRE_CASELESS) != 0) - { - while (length-- > 0) - if (md->lcc[*p++] != md->lcc[*eptr++]) return FALSE; - } -else - { while (length-- > 0) if (*p++ != *eptr++) return FALSE; } - -return TRUE; -} - - - -/*************************************************************************** -**************************************************************************** - RECURSION IN THE match() FUNCTION - -The match() function is highly recursive, though not every recursive call -increases the recursive depth. Nevertheless, some regular expressions can cause -it to recurse to a great depth. I was writing for Unix, so I just let it call -itself recursively. This uses the stack for saving everything that has to be -saved for a recursive call. On Unix, the stack can be large, and this works -fine. - -It turns out that on some non-Unix-like systems there are problems with -programs that use a lot of stack. (This despite the fact that every last chip -has oodles of memory these days, and techniques for extending the stack have -been known for decades.) So.... - -There is a fudge, triggered by defining NO_RECURSE, which avoids recursive -calls by keeping local variables that need to be preserved in blocks of memory -obtained from malloc() instead instead of on the stack. Macros are used to -achieve this so that the actual code doesn't look very different to what it -always used to. - -The original heap-recursive code used longjmp(). However, it seems that this -can be very slow on some operating systems. Following a suggestion from Stan -Switzer, the use of longjmp() has been abolished, at the cost of having to -provide a unique number for each call to RMATCH. There is no way of generating -a sequence of numbers at compile time in C. I have given them names, to make -them stand out more clearly. - -Crude tests on x86 Linux show a small speedup of around 5-8%. However, on -FreeBSD, avoiding longjmp() more than halves the time taken to run the standard -tests. Furthermore, not using longjmp() means that local dynamic variables -don't have indeterminate values; this has meant that the frame size can be -reduced because the result can be "passed back" by straight setting of the -variable instead of being passed in the frame. -**************************************************************************** -***************************************************************************/ - -/* Numbers for RMATCH calls. When this list is changed, the code at HEAP_RETURN -below must be updated in sync. */ - -enum { RM1=1, RM2, RM3, RM4, RM5, RM6, RM7, RM8, RM9, RM10, - RM11, RM12, RM13, RM14, RM15, RM16, RM17, RM18, RM19, RM20, - RM21, RM22, RM23, RM24, RM25, RM26, RM27, RM28, RM29, RM30, - RM31, RM32, RM33, RM34, RM35, RM36, RM37, RM38, RM39, RM40, - RM41, RM42, RM43, RM44, RM45, RM46, RM47, RM48, RM49, RM50, - RM51, RM52, RM53, RM54 }; - -/* These versions of the macros use the stack, as normal. There are debugging -versions and production versions. Note that the "rw" argument of RMATCH isn't -actuall used in this definition. */ - -#ifndef NO_RECURSE -#define REGISTER register - -#ifdef DEBUG -#define RMATCH(ra,rb,rc,rd,re,rf,rg,rw) \ - { \ - printf("match() called in line %d\n", __LINE__); \ - rrc = match(ra,rb,mstart,rc,rd,re,rf,rg,rdepth+1); \ - printf("to line %d\n", __LINE__); \ - } -#define RRETURN(ra) \ - { \ - printf("match() returned %d from line %d ", ra, __LINE__); \ - return ra; \ - } -#else -#define RMATCH(ra,rb,rc,rd,re,rf,rg,rw) \ - rrc = match(ra,rb,mstart,rc,rd,re,rf,rg,rdepth+1) -#define RRETURN(ra) return ra -#endif - -#else - - -/* These versions of the macros manage a private stack on the heap. Note that -the "rd" argument of RMATCH isn't actually used in this definition. It's the md -argument of match(), which never changes. */ - -#define REGISTER - -#define RMATCH(ra,rb,rc,rd,re,rf,rg,rw)\ - {\ - heapframe *newframe = (pcre_stack_malloc)(sizeof(heapframe));\ - frame->Xwhere = rw; \ - newframe->Xeptr = ra;\ - newframe->Xecode = rb;\ - newframe->Xmstart = mstart;\ - newframe->Xoffset_top = rc;\ - newframe->Xims = re;\ - newframe->Xeptrb = rf;\ - newframe->Xflags = rg;\ - newframe->Xrdepth = frame->Xrdepth + 1;\ - newframe->Xprevframe = frame;\ - frame = newframe;\ - DPRINTF(("restarting from line %d\n", __LINE__));\ - goto HEAP_RECURSE;\ - L_##rw:\ - DPRINTF(("jumped back to line %d\n", __LINE__));\ - } - -#define RRETURN(ra)\ - {\ - heapframe *newframe = frame;\ - frame = newframe->Xprevframe;\ - (pcre_stack_free)(newframe);\ - if (frame != NULL)\ - {\ - rrc = ra;\ - goto HEAP_RETURN;\ - }\ - return ra;\ - } - - -/* Structure for remembering the local variables in a private frame */ - -typedef struct heapframe { - struct heapframe *Xprevframe; - - /* Function arguments that may change */ - - const uschar *Xeptr; - const uschar *Xecode; - const uschar *Xmstart; - int Xoffset_top; - long int Xims; - eptrblock *Xeptrb; - int Xflags; - unsigned int Xrdepth; - - /* Function local variables */ - - const uschar *Xcallpat; - const uschar *Xcharptr; - const uschar *Xdata; - const uschar *Xnext; - const uschar *Xpp; - const uschar *Xprev; - const uschar *Xsaved_eptr; - - recursion_info Xnew_recursive; - - BOOL Xcur_is_word; - BOOL Xcondition; - BOOL Xprev_is_word; - - unsigned long int Xoriginal_ims; - -#ifdef SUPPORT_UCP - int Xprop_type; - int Xprop_value; - int Xprop_fail_result; - int Xprop_category; - int Xprop_chartype; - int Xprop_script; - int Xoclength; - uschar Xocchars[8]; -#endif - - int Xctype; - unsigned int Xfc; - int Xfi; - int Xlength; - int Xmax; - int Xmin; - int Xnumber; - int Xoffset; - int Xop; - int Xsave_capture_last; - int Xsave_offset1, Xsave_offset2, Xsave_offset3; - int Xstacksave[REC_STACK_SAVE_MAX]; - - eptrblock Xnewptrb; - - /* Where to jump back to */ - - int Xwhere; - -} heapframe; - -#endif - - -/*************************************************************************** -***************************************************************************/ - - - -/************************************************* -* Match from current position * -*************************************************/ - -/* This function is called recursively in many circumstances. Whenever it -returns a negative (error) response, the outer incarnation must also return the -same response. - -Performance note: It might be tempting to extract commonly used fields from the -md structure (e.g. utf8, end_subject) into individual variables to improve -performance. Tests using gcc on a SPARC disproved this; in the first case, it -made performance worse. - -Arguments: - eptr pointer to current character in subject - ecode pointer to current position in compiled code - mstart pointer to the current match start position (can be modified - by encountering \K) - offset_top current top pointer - md pointer to "static" info for the match - ims current /i, /m, and /s options - eptrb pointer to chain of blocks containing eptr at start of - brackets - for testing for empty matches - flags can contain - match_condassert - this is an assertion condition - match_cbegroup - this is the start of an unlimited repeat - group that can match an empty string - rdepth the recursion depth - -Returns: MATCH_MATCH if matched ) these values are >= 0 - MATCH_NOMATCH if failed to match ) - a negative PCRE_ERROR_xxx value if aborted by an error condition - (e.g. stopped by repeated call or recursion limit) -*/ - -static int -match(REGISTER USPTR eptr, REGISTER const uschar *ecode, const uschar *mstart, - int offset_top, match_data *md, unsigned long int ims, eptrblock *eptrb, - int flags, unsigned int rdepth) -{ -/* These variables do not need to be preserved over recursion in this function, -so they can be ordinary variables in all cases. Mark some of them with -"register" because they are used a lot in loops. */ - -register int rrc; /* Returns from recursive calls */ -register int i; /* Used for loops not involving calls to RMATCH() */ -register unsigned int c; /* Character values not kept over RMATCH() calls */ -register BOOL utf8; /* Local copy of UTF-8 flag for speed */ - -BOOL minimize, possessive; /* Quantifier options */ - -/* When recursion is not being used, all "local" variables that have to be -preserved over calls to RMATCH() are part of a "frame" which is obtained from -heap storage. Set up the top-level frame here; others are obtained from the -heap whenever RMATCH() does a "recursion". See the macro definitions above. */ - -#ifdef NO_RECURSE -heapframe *frame = (pcre_stack_malloc)(sizeof(heapframe)); -frame->Xprevframe = NULL; /* Marks the top level */ - -/* Copy in the original argument variables */ - -frame->Xeptr = eptr; -frame->Xecode = ecode; -frame->Xmstart = mstart; -frame->Xoffset_top = offset_top; -frame->Xims = ims; -frame->Xeptrb = eptrb; -frame->Xflags = flags; -frame->Xrdepth = rdepth; - -/* This is where control jumps back to to effect "recursion" */ - -HEAP_RECURSE: - -/* Macros make the argument variables come from the current frame */ - -#define eptr frame->Xeptr -#define ecode frame->Xecode -#define mstart frame->Xmstart -#define offset_top frame->Xoffset_top -#define ims frame->Xims -#define eptrb frame->Xeptrb -#define flags frame->Xflags -#define rdepth frame->Xrdepth - -/* Ditto for the local variables */ - -#ifdef SUPPORT_UTF8 -#define charptr frame->Xcharptr -#endif -#define callpat frame->Xcallpat -#define data frame->Xdata -#define next frame->Xnext -#define pp frame->Xpp -#define prev frame->Xprev -#define saved_eptr frame->Xsaved_eptr - -#define new_recursive frame->Xnew_recursive - -#define cur_is_word frame->Xcur_is_word -#define condition frame->Xcondition -#define prev_is_word frame->Xprev_is_word - -#define original_ims frame->Xoriginal_ims - -#ifdef SUPPORT_UCP -#define prop_type frame->Xprop_type -#define prop_value frame->Xprop_value -#define prop_fail_result frame->Xprop_fail_result -#define prop_category frame->Xprop_category -#define prop_chartype frame->Xprop_chartype -#define prop_script frame->Xprop_script -#define oclength frame->Xoclength -#define occhars frame->Xocchars -#endif - -#define ctype frame->Xctype -#define fc frame->Xfc -#define fi frame->Xfi -#define length frame->Xlength -#define max frame->Xmax -#define min frame->Xmin -#define number frame->Xnumber -#define offset frame->Xoffset -#define op frame->Xop -#define save_capture_last frame->Xsave_capture_last -#define save_offset1 frame->Xsave_offset1 -#define save_offset2 frame->Xsave_offset2 -#define save_offset3 frame->Xsave_offset3 -#define stacksave frame->Xstacksave - -#define newptrb frame->Xnewptrb - -/* When recursion is being used, local variables are allocated on the stack and -get preserved during recursion in the normal way. In this environment, fi and -i, and fc and c, can be the same variables. */ - -#else /* NO_RECURSE not defined */ -#define fi i -#define fc c - - -#ifdef SUPPORT_UTF8 /* Many of these variables are used only */ -const uschar *charptr; /* in small blocks of the code. My normal */ -#endif /* style of coding would have declared */ -const uschar *callpat; /* them within each of those blocks. */ -const uschar *data; /* However, in order to accommodate the */ -const uschar *next; /* version of this code that uses an */ -USPTR pp; /* external "stack" implemented on the */ -const uschar *prev; /* heap, it is easier to declare them all */ -USPTR saved_eptr; /* here, so the declarations can be cut */ - /* out in a block. The only declarations */ -recursion_info new_recursive; /* within blocks below are for variables */ - /* that do not have to be preserved over */ -BOOL cur_is_word; /* a recursive call to RMATCH(). */ -BOOL condition; -BOOL prev_is_word; - -unsigned long int original_ims; - -#ifdef SUPPORT_UCP -int prop_type; -int prop_value; -int prop_fail_result; -int prop_category; -int prop_chartype; -int prop_script; -int oclength; -uschar occhars[8]; -#endif - -int ctype; -int length; -int max; -int min; -int number; -int offset; -int op; -int save_capture_last; -int save_offset1, save_offset2, save_offset3; -int stacksave[REC_STACK_SAVE_MAX]; - -eptrblock newptrb; -#endif /* NO_RECURSE */ - -/* These statements are here to stop the compiler complaining about unitialized -variables. */ - -#ifdef SUPPORT_UCP -prop_value = 0; -prop_fail_result = 0; -#endif - - -/* This label is used for tail recursion, which is used in a few cases even -when NO_RECURSE is not defined, in order to reduce the amount of stack that is -used. Thanks to Ian Taylor for noticing this possibility and sending the -original patch. */ - -TAIL_RECURSE: - -/* OK, now we can get on with the real code of the function. Recursive calls -are specified by the macro RMATCH and RRETURN is used to return. When -NO_RECURSE is *not* defined, these just turn into a recursive call to match() -and a "return", respectively (possibly with some debugging if DEBUG is -defined). However, RMATCH isn't like a function call because it's quite a -complicated macro. It has to be used in one particular way. This shouldn't, -however, impact performance when true recursion is being used. */ - -#ifdef SUPPORT_UTF8 -utf8 = md->utf8; /* Local copy of the flag */ -#else -utf8 = FALSE; -#endif - -/* First check that we haven't called match() too many times, or that we -haven't exceeded the recursive call limit. */ - -if (md->match_call_count++ >= md->match_limit) RRETURN(PCRE_ERROR_MATCHLIMIT); -if (rdepth >= md->match_limit_recursion) RRETURN(PCRE_ERROR_RECURSIONLIMIT); - -original_ims = ims; /* Save for resetting on ')' */ - -/* At the start of a group with an unlimited repeat that may match an empty -string, the match_cbegroup flag is set. When this is the case, add the current -subject pointer to the chain of such remembered pointers, to be checked when we -hit the closing ket, in order to break infinite loops that match no characters. -When match() is called in other circumstances, don't add to the chain. The -match_cbegroup flag must NOT be used with tail recursion, because the memory -block that is used is on the stack, so a new one may be required for each -match(). */ - -if ((flags & match_cbegroup) != 0) - { - newptrb.epb_saved_eptr = eptr; - newptrb.epb_prev = eptrb; - eptrb = &newptrb; - } - -/* Now start processing the opcodes. */ - -for (;;) - { - minimize = possessive = FALSE; - op = *ecode; - - /* For partial matching, remember if we ever hit the end of the subject after - matching at least one subject character. */ - - if (md->partial && - eptr >= md->end_subject && - eptr > mstart) - md->hitend = TRUE; - - switch(op) - { - case OP_FAIL: - RRETURN(MATCH_NOMATCH); - - case OP_PRUNE: - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, - ims, eptrb, flags, RM51); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - RRETURN(MATCH_PRUNE); - - case OP_COMMIT: - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, - ims, eptrb, flags, RM52); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - RRETURN(MATCH_COMMIT); - - case OP_SKIP: - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, - ims, eptrb, flags, RM53); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - md->start_match_ptr = eptr; /* Pass back current position */ - RRETURN(MATCH_SKIP); - - case OP_THEN: - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, - ims, eptrb, flags, RM54); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - RRETURN(MATCH_THEN); - - /* Handle a capturing bracket. If there is space in the offset vector, save - the current subject position in the working slot at the top of the vector. - We mustn't change the current values of the data slot, because they may be - set from a previous iteration of this group, and be referred to by a - reference inside the group. - - If the bracket fails to match, we need to restore this value and also the - values of the final offsets, in case they were set by a previous iteration - of the same bracket. - - If there isn't enough space in the offset vector, treat this as if it were - a non-capturing bracket. Don't worry about setting the flag for the error - case here; that is handled in the code for KET. */ - - case OP_CBRA: - case OP_SCBRA: - number = GET2(ecode, 1+LINK_SIZE); - offset = number << 1; - -#ifdef DEBUG - printf("start bracket %d\n", number); - printf("subject="); - pchars(eptr, 16, TRUE, md); - printf("\n"); -#endif - - if (offset < md->offset_max) - { - save_offset1 = md->offset_vector[offset]; - save_offset2 = md->offset_vector[offset+1]; - save_offset3 = md->offset_vector[md->offset_end - number]; - save_capture_last = md->capture_last; - - DPRINTF(("saving %d %d %d\n", save_offset1, save_offset2, save_offset3)); - md->offset_vector[md->offset_end - number] = eptr - md->start_subject; - - flags = (op == OP_SCBRA)? match_cbegroup : 0; - do - { - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, - ims, eptrb, flags, RM1); - if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) RRETURN(rrc); - md->capture_last = save_capture_last; - ecode += GET(ecode, 1); - } - while (*ecode == OP_ALT); - - DPRINTF(("bracket %d failed\n", number)); - - md->offset_vector[offset] = save_offset1; - md->offset_vector[offset+1] = save_offset2; - md->offset_vector[md->offset_end - number] = save_offset3; - - RRETURN(MATCH_NOMATCH); - } - - /* FALL THROUGH ... Insufficient room for saving captured contents. Treat - as a non-capturing bracket. */ - - /* VVVVVVVVVVVVVVVVVVVVVVVVV */ - /* VVVVVVVVVVVVVVVVVVVVVVVVV */ - - DPRINTF(("insufficient capture room: treat as non-capturing\n")); - - /* VVVVVVVVVVVVVVVVVVVVVVVVV */ - /* VVVVVVVVVVVVVVVVVVVVVVVVV */ - - /* Non-capturing bracket. Loop for all the alternatives. When we get to the - final alternative within the brackets, we would return the result of a - recursive call to match() whatever happened. We can reduce stack usage by - turning this into a tail recursion, except in the case when match_cbegroup - is set.*/ - - case OP_BRA: - case OP_SBRA: - DPRINTF(("start non-capturing bracket\n")); - flags = (op >= OP_SBRA)? match_cbegroup : 0; - for (;;) - { - if (ecode[GET(ecode, 1)] != OP_ALT) /* Final alternative */ - { - if (flags == 0) /* Not a possibly empty group */ - { - ecode += _pcre_OP_lengths[*ecode]; - DPRINTF(("bracket 0 tail recursion\n")); - goto TAIL_RECURSE; - } - - /* Possibly empty group; can't use tail recursion. */ - - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, ims, - eptrb, flags, RM48); - RRETURN(rrc); - } - - /* For non-final alternatives, continue the loop for a NOMATCH result; - otherwise return. */ - - RMATCH(eptr, ecode + _pcre_OP_lengths[*ecode], offset_top, md, ims, - eptrb, flags, RM2); - if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) RRETURN(rrc); - ecode += GET(ecode, 1); - } - /* Control never reaches here. */ - - /* Conditional group: compilation checked that there are no more than - two branches. If the condition is false, skipping the first branch takes us - past the end if there is only one branch, but that's OK because that is - exactly what going to the ket would do. As there is only one branch to be - obeyed, we can use tail recursion to avoid using another stack frame. */ - - case OP_COND: - case OP_SCOND: - if (ecode[LINK_SIZE+1] == OP_RREF) /* Recursion test */ - { - offset = GET2(ecode, LINK_SIZE + 2); /* Recursion group number*/ - condition = md->recursive != NULL && - (offset == RREF_ANY || offset == md->recursive->group_num); - ecode += condition? 3 : GET(ecode, 1); - } - - else if (ecode[LINK_SIZE+1] == OP_CREF) /* Group used test */ - { - offset = GET2(ecode, LINK_SIZE+2) << 1; /* Doubled ref number */ - condition = offset < offset_top && md->offset_vector[offset] >= 0; - ecode += condition? 3 : GET(ecode, 1); - } - - else if (ecode[LINK_SIZE+1] == OP_DEF) /* DEFINE - always false */ - { - condition = FALSE; - ecode += GET(ecode, 1); - } - - /* The condition is an assertion. Call match() to evaluate it - setting - the final argument match_condassert causes it to stop at the end of an - assertion. */ - - else - { - RMATCH(eptr, ecode + 1 + LINK_SIZE, offset_top, md, ims, NULL, - match_condassert, RM3); - if (rrc == MATCH_MATCH) - { - condition = TRUE; - ecode += 1 + LINK_SIZE + GET(ecode, LINK_SIZE + 2); - while (*ecode == OP_ALT) ecode += GET(ecode, 1); - } - else if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) - { - RRETURN(rrc); /* Need braces because of following else */ - } - else - { - condition = FALSE; - ecode += GET(ecode, 1); - } - } - - /* We are now at the branch that is to be obeyed. As there is only one, - we can use tail recursion to avoid using another stack frame, except when - match_cbegroup is required for an unlimited repeat of a possibly empty - group. If the second alternative doesn't exist, we can just plough on. */ - - if (condition || *ecode == OP_ALT) - { - ecode += 1 + LINK_SIZE; - if (op == OP_SCOND) /* Possibly empty group */ - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, match_cbegroup, RM49); - RRETURN(rrc); - } - else /* Group must match something */ - { - flags = 0; - goto TAIL_RECURSE; - } - } - else /* Condition false & no 2nd alternative */ - { - ecode += 1 + LINK_SIZE; - } - break; - - - /* End of the pattern, either real or forced. If we are in a top-level - recursion, we should restore the offsets appropriately and continue from - after the call. */ - - case OP_ACCEPT: - case OP_END: - if (md->recursive != NULL && md->recursive->group_num == 0) - { - recursion_info *rec = md->recursive; - DPRINTF(("End of pattern in a (?0) recursion\n")); - md->recursive = rec->prevrec; - memmove(md->offset_vector, rec->offset_save, - rec->saved_max * sizeof(int)); - mstart = rec->save_start; - ims = original_ims; - ecode = rec->after_call; - break; - } - - /* Otherwise, if PCRE_NOTEMPTY is set, fail if we have matched an empty - string - backtracking will then try other alternatives, if any. */ - - if (md->notempty && eptr == mstart) RRETURN(MATCH_NOMATCH); - md->end_match_ptr = eptr; /* Record where we ended */ - md->end_offset_top = offset_top; /* and how many extracts were taken */ - md->start_match_ptr = mstart; /* and the start (\K can modify) */ - RRETURN(MATCH_MATCH); - - /* Change option settings */ - - case OP_OPT: - ims = ecode[1]; - ecode += 2; - DPRINTF(("ims set to %02lx\n", ims)); - break; - - /* Assertion brackets. Check the alternative branches in turn - the - matching won't pass the KET for an assertion. If any one branch matches, - the assertion is true. Lookbehind assertions have an OP_REVERSE item at the - start of each branch to move the current point backwards, so the code at - this level is identical to the lookahead case. */ - - case OP_ASSERT: - case OP_ASSERTBACK: - do - { - RMATCH(eptr, ecode + 1 + LINK_SIZE, offset_top, md, ims, NULL, 0, - RM4); - if (rrc == MATCH_MATCH) break; - if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) RRETURN(rrc); - ecode += GET(ecode, 1); - } - while (*ecode == OP_ALT); - if (*ecode == OP_KET) RRETURN(MATCH_NOMATCH); - - /* If checking an assertion for a condition, return MATCH_MATCH. */ - - if ((flags & match_condassert) != 0) RRETURN(MATCH_MATCH); - - /* Continue from after the assertion, updating the offsets high water - mark, since extracts may have been taken during the assertion. */ - - do ecode += GET(ecode,1); while (*ecode == OP_ALT); - ecode += 1 + LINK_SIZE; - offset_top = md->end_offset_top; - continue; - - /* Negative assertion: all branches must fail to match */ - - case OP_ASSERT_NOT: - case OP_ASSERTBACK_NOT: - do - { - RMATCH(eptr, ecode + 1 + LINK_SIZE, offset_top, md, ims, NULL, 0, - RM5); - if (rrc == MATCH_MATCH) RRETURN(MATCH_NOMATCH); - if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) RRETURN(rrc); - ecode += GET(ecode,1); - } - while (*ecode == OP_ALT); - - if ((flags & match_condassert) != 0) RRETURN(MATCH_MATCH); - - ecode += 1 + LINK_SIZE; - continue; - - /* Move the subject pointer back. This occurs only at the start of - each branch of a lookbehind assertion. If we are too close to the start to - move back, this match function fails. When working with UTF-8 we move - back a number of characters, not bytes. */ - - case OP_REVERSE: -#ifdef SUPPORT_UTF8 - if (utf8) - { - i = GET(ecode, 1); - while (i-- > 0) - { - eptr--; - if (eptr < md->start_subject) RRETURN(MATCH_NOMATCH); - BACKCHAR(eptr); - } - } - else -#endif - - /* No UTF-8 support, or not in UTF-8 mode: count is byte count */ - - { - eptr -= GET(ecode, 1); - if (eptr < md->start_subject) RRETURN(MATCH_NOMATCH); - } - - /* Skip to next op code */ - - ecode += 1 + LINK_SIZE; - break; - - /* The callout item calls an external function, if one is provided, passing - details of the match so far. This is mainly for debugging, though the - function is able to force a failure. */ - - case OP_CALLOUT: - if (pcre_callout != NULL) - { - pcre_callout_block cb; - cb.version = 1; /* Version 1 of the callout block */ - cb.callout_number = ecode[1]; - cb.offset_vector = md->offset_vector; - cb.subject = (PCRE_SPTR)md->start_subject; - cb.subject_length = md->end_subject - md->start_subject; - cb.start_match = mstart - md->start_subject; - cb.current_position = eptr - md->start_subject; - cb.pattern_position = GET(ecode, 2); - cb.next_item_length = GET(ecode, 2 + LINK_SIZE); - cb.capture_top = offset_top/2; - cb.capture_last = md->capture_last; - cb.callout_data = md->callout_data; - if ((rrc = (*pcre_callout)(&cb)) > 0) RRETURN(MATCH_NOMATCH); - if (rrc < 0) RRETURN(rrc); - } - ecode += 2 + 2*LINK_SIZE; - break; - - /* Recursion either matches the current regex, or some subexpression. The - offset data is the offset to the starting bracket from the start of the - whole pattern. (This is so that it works from duplicated subpatterns.) - - If there are any capturing brackets started but not finished, we have to - save their starting points and reinstate them after the recursion. However, - we don't know how many such there are (offset_top records the completed - total) so we just have to save all the potential data. There may be up to - 65535 such values, which is too large to put on the stack, but using malloc - for small numbers seems expensive. As a compromise, the stack is used when - there are no more than REC_STACK_SAVE_MAX values to store; otherwise malloc - is used. A problem is what to do if the malloc fails ... there is no way of - returning to the top level with an error. Save the top REC_STACK_SAVE_MAX - values on the stack, and accept that the rest may be wrong. - - There are also other values that have to be saved. We use a chained - sequence of blocks that actually live on the stack. Thanks to Robin Houston - for the original version of this logic. */ - - case OP_RECURSE: - { - callpat = md->start_code + GET(ecode, 1); - new_recursive.group_num = (callpat == md->start_code)? 0 : - GET2(callpat, 1 + LINK_SIZE); - - /* Add to "recursing stack" */ - - new_recursive.prevrec = md->recursive; - md->recursive = &new_recursive; - - /* Find where to continue from afterwards */ - - ecode += 1 + LINK_SIZE; - new_recursive.after_call = ecode; - - /* Now save the offset data. */ - - new_recursive.saved_max = md->offset_end; - if (new_recursive.saved_max <= REC_STACK_SAVE_MAX) - new_recursive.offset_save = stacksave; - else - { - new_recursive.offset_save = - (int *)(pcre_malloc)(new_recursive.saved_max * sizeof(int)); - if (new_recursive.offset_save == NULL) RRETURN(PCRE_ERROR_NOMEMORY); - } - - memcpy(new_recursive.offset_save, md->offset_vector, - new_recursive.saved_max * sizeof(int)); - new_recursive.save_start = mstart; - mstart = eptr; - - /* OK, now we can do the recursion. For each top-level alternative we - restore the offset and recursion data. */ - - DPRINTF(("Recursing into group %d\n", new_recursive.group_num)); - flags = (*callpat >= OP_SBRA)? match_cbegroup : 0; - do - { - RMATCH(eptr, callpat + _pcre_OP_lengths[*callpat], offset_top, - md, ims, eptrb, flags, RM6); - if (rrc == MATCH_MATCH) - { - DPRINTF(("Recursion matched\n")); - md->recursive = new_recursive.prevrec; - if (new_recursive.offset_save != stacksave) - (pcre_free)(new_recursive.offset_save); - RRETURN(MATCH_MATCH); - } - else if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) - { - DPRINTF(("Recursion gave error %d\n", rrc)); - RRETURN(rrc); - } - - md->recursive = &new_recursive; - memcpy(md->offset_vector, new_recursive.offset_save, - new_recursive.saved_max * sizeof(int)); - callpat += GET(callpat, 1); - } - while (*callpat == OP_ALT); - - DPRINTF(("Recursion didn't match\n")); - md->recursive = new_recursive.prevrec; - if (new_recursive.offset_save != stacksave) - (pcre_free)(new_recursive.offset_save); - RRETURN(MATCH_NOMATCH); - } - /* Control never reaches here */ - - /* "Once" brackets are like assertion brackets except that after a match, - the point in the subject string is not moved back. Thus there can never be - a move back into the brackets. Friedl calls these "atomic" subpatterns. - Check the alternative branches in turn - the matching won't pass the KET - for this kind of subpattern. If any one branch matches, we carry on as at - the end of a normal bracket, leaving the subject pointer. */ - - case OP_ONCE: - prev = ecode; - saved_eptr = eptr; - - do - { - RMATCH(eptr, ecode + 1 + LINK_SIZE, offset_top, md, ims, eptrb, 0, RM7); - if (rrc == MATCH_MATCH) break; - if (rrc != MATCH_NOMATCH && rrc != MATCH_THEN) RRETURN(rrc); - ecode += GET(ecode,1); - } - while (*ecode == OP_ALT); - - /* If hit the end of the group (which could be repeated), fail */ - - if (*ecode != OP_ONCE && *ecode != OP_ALT) RRETURN(MATCH_NOMATCH); - - /* Continue as from after the assertion, updating the offsets high water - mark, since extracts may have been taken. */ - - do ecode += GET(ecode, 1); while (*ecode == OP_ALT); - - offset_top = md->end_offset_top; - eptr = md->end_match_ptr; - - /* For a non-repeating ket, just continue at this level. This also - happens for a repeating ket if no characters were matched in the group. - This is the forcible breaking of infinite loops as implemented in Perl - 5.005. If there is an options reset, it will get obeyed in the normal - course of events. */ - - if (*ecode == OP_KET || eptr == saved_eptr) - { - ecode += 1+LINK_SIZE; - break; - } - - /* The repeating kets try the rest of the pattern or restart from the - preceding bracket, in the appropriate order. The second "call" of match() - uses tail recursion, to avoid using another stack frame. We need to reset - any options that changed within the bracket before re-running it, so - check the next opcode. */ - - if (ecode[1+LINK_SIZE] == OP_OPT) - { - ims = (ims & ~PCRE_IMS) | ecode[4]; - DPRINTF(("ims set to %02lx at group repeat\n", ims)); - } - - if (*ecode == OP_KETRMIN) - { - RMATCH(eptr, ecode + 1 + LINK_SIZE, offset_top, md, ims, eptrb, 0, RM8); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - ecode = prev; - flags = 0; - goto TAIL_RECURSE; - } - else /* OP_KETRMAX */ - { - RMATCH(eptr, prev, offset_top, md, ims, eptrb, match_cbegroup, RM9); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - ecode += 1 + LINK_SIZE; - flags = 0; - goto TAIL_RECURSE; - } - /* Control never gets here */ - - /* An alternation is the end of a branch; scan along to find the end of the - bracketed group and go to there. */ - - case OP_ALT: - do ecode += GET(ecode,1); while (*ecode == OP_ALT); - break; - - /* BRAZERO and BRAMINZERO occur just before a bracket group, indicating - that it may occur zero times. It may repeat infinitely, or not at all - - i.e. it could be ()* or ()? in the pattern. Brackets with fixed upper - repeat limits are compiled as a number of copies, with the optional ones - preceded by BRAZERO or BRAMINZERO. */ - - case OP_BRAZERO: - { - next = ecode+1; - RMATCH(eptr, next, offset_top, md, ims, eptrb, 0, RM10); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - do next += GET(next,1); while (*next == OP_ALT); - ecode = next + 1 + LINK_SIZE; - } - break; - - case OP_BRAMINZERO: - { - next = ecode+1; - do next += GET(next, 1); while (*next == OP_ALT); - RMATCH(eptr, next + 1+LINK_SIZE, offset_top, md, ims, eptrb, 0, RM11); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - ecode++; - } - break; - - /* End of a group, repeated or non-repeating. */ - - case OP_KET: - case OP_KETRMIN: - case OP_KETRMAX: - prev = ecode - GET(ecode, 1); - - /* If this was a group that remembered the subject start, in order to break - infinite repeats of empty string matches, retrieve the subject start from - the chain. Otherwise, set it NULL. */ - - if (*prev >= OP_SBRA) - { - saved_eptr = eptrb->epb_saved_eptr; /* Value at start of group */ - eptrb = eptrb->epb_prev; /* Backup to previous group */ - } - else saved_eptr = NULL; - - /* If we are at the end of an assertion group, stop matching and return - MATCH_MATCH, but record the current high water mark for use by positive - assertions. Do this also for the "once" (atomic) groups. */ - - if (*prev == OP_ASSERT || *prev == OP_ASSERT_NOT || - *prev == OP_ASSERTBACK || *prev == OP_ASSERTBACK_NOT || - *prev == OP_ONCE) - { - md->end_match_ptr = eptr; /* For ONCE */ - md->end_offset_top = offset_top; - RRETURN(MATCH_MATCH); - } - - /* For capturing groups we have to check the group number back at the start - and if necessary complete handling an extraction by setting the offsets and - bumping the high water mark. Note that whole-pattern recursion is coded as - a recurse into group 0, so it won't be picked up here. Instead, we catch it - when the OP_END is reached. Other recursion is handled here. */ - - if (*prev == OP_CBRA || *prev == OP_SCBRA) - { - number = GET2(prev, 1+LINK_SIZE); - offset = number << 1; - -#ifdef DEBUG - printf("end bracket %d", number); - printf("\n"); -#endif - - md->capture_last = number; - if (offset >= md->offset_max) md->offset_overflow = TRUE; else - { - md->offset_vector[offset] = - md->offset_vector[md->offset_end - number]; - md->offset_vector[offset+1] = eptr - md->start_subject; - if (offset_top <= offset) offset_top = offset + 2; - } - - /* Handle a recursively called group. Restore the offsets - appropriately and continue from after the call. */ - - if (md->recursive != NULL && md->recursive->group_num == number) - { - recursion_info *rec = md->recursive; - DPRINTF(("Recursion (%d) succeeded - continuing\n", number)); - md->recursive = rec->prevrec; - mstart = rec->save_start; - memcpy(md->offset_vector, rec->offset_save, - rec->saved_max * sizeof(int)); - ecode = rec->after_call; - ims = original_ims; - break; - } - } - - /* For both capturing and non-capturing groups, reset the value of the ims - flags, in case they got changed during the group. */ - - ims = original_ims; - DPRINTF(("ims reset to %02lx\n", ims)); - - /* For a non-repeating ket, just continue at this level. This also - happens for a repeating ket if no characters were matched in the group. - This is the forcible breaking of infinite loops as implemented in Perl - 5.005. If there is an options reset, it will get obeyed in the normal - course of events. */ - - if (*ecode == OP_KET || eptr == saved_eptr) - { - ecode += 1 + LINK_SIZE; - break; - } - - /* The repeating kets try the rest of the pattern or restart from the - preceding bracket, in the appropriate order. In the second case, we can use - tail recursion to avoid using another stack frame, unless we have an - unlimited repeat of a group that can match an empty string. */ - - flags = (*prev >= OP_SBRA)? match_cbegroup : 0; - - if (*ecode == OP_KETRMIN) - { - RMATCH(eptr, ecode + 1 + LINK_SIZE, offset_top, md, ims, eptrb, 0, RM12); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (flags != 0) /* Could match an empty string */ - { - RMATCH(eptr, prev, offset_top, md, ims, eptrb, flags, RM50); - RRETURN(rrc); - } - ecode = prev; - goto TAIL_RECURSE; - } - else /* OP_KETRMAX */ - { - RMATCH(eptr, prev, offset_top, md, ims, eptrb, flags, RM13); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - ecode += 1 + LINK_SIZE; - flags = 0; - goto TAIL_RECURSE; - } - /* Control never gets here */ - - /* Start of subject unless notbol, or after internal newline if multiline */ - - case OP_CIRC: - if (md->notbol && eptr == md->start_subject) RRETURN(MATCH_NOMATCH); - if ((ims & PCRE_MULTILINE) != 0) - { - if (eptr != md->start_subject && - (eptr == md->end_subject || !WAS_NEWLINE(eptr))) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - } - /* ... else fall through */ - - /* Start of subject assertion */ - - case OP_SOD: - if (eptr != md->start_subject) RRETURN(MATCH_NOMATCH); - ecode++; - break; - - /* Start of match assertion */ - - case OP_SOM: - if (eptr != md->start_subject + md->start_offset) RRETURN(MATCH_NOMATCH); - ecode++; - break; - - /* Reset the start of match point */ - - case OP_SET_SOM: - mstart = eptr; - ecode++; - break; - - /* Assert before internal newline if multiline, or before a terminating - newline unless endonly is set, else end of subject unless noteol is set. */ - - case OP_DOLL: - if ((ims & PCRE_MULTILINE) != 0) - { - if (eptr < md->end_subject) - { if (!IS_NEWLINE(eptr)) RRETURN(MATCH_NOMATCH); } - else - { if (md->noteol) RRETURN(MATCH_NOMATCH); } - ecode++; - break; - } - else - { - if (md->noteol) RRETURN(MATCH_NOMATCH); - if (!md->endonly) - { - if (eptr != md->end_subject && - (!IS_NEWLINE(eptr) || eptr != md->end_subject - md->nllen)) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - } - } - /* ... else fall through for endonly */ - - /* End of subject assertion (\z) */ - - case OP_EOD: - if (eptr < md->end_subject) RRETURN(MATCH_NOMATCH); - ecode++; - break; - - /* End of subject or ending \n assertion (\Z) */ - - case OP_EODN: - if (eptr != md->end_subject && - (!IS_NEWLINE(eptr) || eptr != md->end_subject - md->nllen)) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - /* Word boundary assertions */ - - case OP_NOT_WORD_BOUNDARY: - case OP_WORD_BOUNDARY: - { - - /* Find out if the previous and current characters are "word" characters. - It takes a bit more work in UTF-8 mode. Characters > 255 are assumed to - be "non-word" characters. */ - -#ifdef SUPPORT_UTF8 - if (utf8) - { - if (eptr == md->start_subject) prev_is_word = FALSE; else - { - const uschar *lastptr = eptr - 1; - while((*lastptr & 0xc0) == 0x80) lastptr--; - GETCHAR(c, lastptr); - prev_is_word = c < 256 && (md->ctypes[c] & ctype_word) != 0; - } - if (eptr >= md->end_subject) cur_is_word = FALSE; else - { - GETCHAR(c, eptr); - cur_is_word = c < 256 && (md->ctypes[c] & ctype_word) != 0; - } - } - else -#endif - - /* More streamlined when not in UTF-8 mode */ - - { - prev_is_word = (eptr != md->start_subject) && - ((md->ctypes[eptr[-1]] & ctype_word) != 0); - cur_is_word = (eptr < md->end_subject) && - ((md->ctypes[*eptr] & ctype_word) != 0); - } - - /* Now see if the situation is what we want */ - - if ((*ecode++ == OP_WORD_BOUNDARY)? - cur_is_word == prev_is_word : cur_is_word != prev_is_word) - RRETURN(MATCH_NOMATCH); - } - break; - - /* Match a single character type; inline for speed */ - - case OP_ANY: - if ((ims & PCRE_DOTALL) == 0) - { - if (IS_NEWLINE(eptr)) RRETURN(MATCH_NOMATCH); - } - if (eptr++ >= md->end_subject) RRETURN(MATCH_NOMATCH); - if (utf8) - while (eptr < md->end_subject && (*eptr & 0xc0) == 0x80) eptr++; - ecode++; - break; - - /* Match a single byte, even in UTF-8 mode. This opcode really does match - any byte, even newline, independent of the setting of PCRE_DOTALL. */ - - case OP_ANYBYTE: - if (eptr++ >= md->end_subject) RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_NOT_DIGIT: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - if ( -#ifdef SUPPORT_UTF8 - c < 256 && -#endif - (md->ctypes[c] & ctype_digit) != 0 - ) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_DIGIT: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - if ( -#ifdef SUPPORT_UTF8 - c >= 256 || -#endif - (md->ctypes[c] & ctype_digit) == 0 - ) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_NOT_WHITESPACE: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - if ( -#ifdef SUPPORT_UTF8 - c < 256 && -#endif - (md->ctypes[c] & ctype_space) != 0 - ) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_WHITESPACE: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - if ( -#ifdef SUPPORT_UTF8 - c >= 256 || -#endif - (md->ctypes[c] & ctype_space) == 0 - ) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_NOT_WORDCHAR: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - if ( -#ifdef SUPPORT_UTF8 - c < 256 && -#endif - (md->ctypes[c] & ctype_word) != 0 - ) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_WORDCHAR: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - if ( -#ifdef SUPPORT_UTF8 - c >= 256 || -#endif - (md->ctypes[c] & ctype_word) == 0 - ) - RRETURN(MATCH_NOMATCH); - ecode++; - break; - - case OP_ANYNL: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x000d: - if (eptr < md->end_subject && *eptr == 0x0a) eptr++; - break; - - case 0x000a: - break; - - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if (md->bsr_anycrlf) RRETURN(MATCH_NOMATCH); - break; - } - ecode++; - break; - - case OP_NOT_HSPACE: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - switch(c) - { - default: break; - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - RRETURN(MATCH_NOMATCH); - } - ecode++; - break; - - case OP_HSPACE: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - break; - } - ecode++; - break; - - case OP_NOT_VSPACE: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - switch(c) - { - default: break; - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - RRETURN(MATCH_NOMATCH); - } - ecode++; - break; - - case OP_VSPACE: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - break; - } - ecode++; - break; - -#ifdef SUPPORT_UCP - /* Check the next character by Unicode property. We will get here only - if the support is in the binary; otherwise a compile-time error occurs. */ - - case OP_PROP: - case OP_NOTPROP: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - { - int chartype, script; - int category = _pcre_ucp_findprop(c, &chartype, &script); - - switch(ecode[1]) - { - case PT_ANY: - if (op == OP_NOTPROP) RRETURN(MATCH_NOMATCH); - break; - - case PT_LAMP: - if ((chartype == ucp_Lu || - chartype == ucp_Ll || - chartype == ucp_Lt) == (op == OP_NOTPROP)) - RRETURN(MATCH_NOMATCH); - break; - - case PT_GC: - if ((ecode[2] != category) == (op == OP_PROP)) - RRETURN(MATCH_NOMATCH); - break; - - case PT_PC: - if ((ecode[2] != chartype) == (op == OP_PROP)) - RRETURN(MATCH_NOMATCH); - break; - - case PT_SC: - if ((ecode[2] != script) == (op == OP_PROP)) - RRETURN(MATCH_NOMATCH); - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - - ecode += 3; - } - break; - - /* Match an extended Unicode sequence. We will get here only if the support - is in the binary; otherwise a compile-time error occurs. */ - - case OP_EXTUNI: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - { - int chartype, script; - int category = _pcre_ucp_findprop(c, &chartype, &script); - if (category == ucp_M) RRETURN(MATCH_NOMATCH); - while (eptr < md->end_subject) - { - int len = 1; - if (!utf8) c = *eptr; else - { - GETCHARLEN(c, eptr, len); - } - category = _pcre_ucp_findprop(c, &chartype, &script); - if (category != ucp_M) break; - eptr += len; - } - } - ecode++; - break; -#endif - - - /* Match a back reference, possibly repeatedly. Look past the end of the - item to see if there is repeat information following. The code is similar - to that for character classes, but repeated for efficiency. Then obey - similar code to character type repeats - written out again for speed. - However, if the referenced string is the empty string, always treat - it as matched, any number of times (otherwise there could be infinite - loops). */ - - case OP_REF: - { - offset = GET2(ecode, 1) << 1; /* Doubled ref number */ - ecode += 3; /* Advance past item */ - - /* If the reference is unset, set the length to be longer than the amount - of subject left; this ensures that every attempt at a match fails. We - can't just fail here, because of the possibility of quantifiers with zero - minima. */ - - length = (offset >= offset_top || md->offset_vector[offset] < 0)? - md->end_subject - eptr + 1 : - md->offset_vector[offset+1] - md->offset_vector[offset]; - - /* Set up for repetition, or handle the non-repeated case */ - - switch (*ecode) - { - case OP_CRSTAR: - case OP_CRMINSTAR: - case OP_CRPLUS: - case OP_CRMINPLUS: - case OP_CRQUERY: - case OP_CRMINQUERY: - c = *ecode++ - OP_CRSTAR; - minimize = (c & 1) != 0; - min = rep_min[c]; /* Pick up values from tables; */ - max = rep_max[c]; /* zero for max => infinity */ - if (max == 0) max = INT_MAX; - break; - - case OP_CRRANGE: - case OP_CRMINRANGE: - minimize = (*ecode == OP_CRMINRANGE); - min = GET2(ecode, 1); - max = GET2(ecode, 3); - if (max == 0) max = INT_MAX; - ecode += 5; - break; - - default: /* No repeat follows */ - if (!match_ref(offset, eptr, length, md, ims)) RRETURN(MATCH_NOMATCH); - eptr += length; - continue; /* With the main loop */ - } - - /* If the length of the reference is zero, just continue with the - main loop. */ - - if (length == 0) continue; - - /* First, ensure the minimum number of matches are present. We get back - the length of the reference string explicitly rather than passing the - address of eptr, so that eptr can be a register variable. */ - - for (i = 1; i <= min; i++) - { - if (!match_ref(offset, eptr, length, md, ims)) RRETURN(MATCH_NOMATCH); - eptr += length; - } - - /* If min = max, continue at the same level without recursion. - They are not both allowed to be zero. */ - - if (min == max) continue; - - /* If minimizing, keep trying and advancing the pointer */ - - if (minimize) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM14); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || !match_ref(offset, eptr, length, md, ims)) - RRETURN(MATCH_NOMATCH); - eptr += length; - } - /* Control never gets here */ - } - - /* If maximizing, find the longest string and work backwards */ - - else - { - pp = eptr; - for (i = min; i < max; i++) - { - if (!match_ref(offset, eptr, length, md, ims)) break; - eptr += length; - } - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM15); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - eptr -= length; - } - RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - - - - /* Match a bit-mapped character class, possibly repeatedly. This op code is - used when all the characters in the class have values in the range 0-255, - and either the matching is caseful, or the characters are in the range - 0-127 when UTF-8 processing is enabled. The only difference between - OP_CLASS and OP_NCLASS occurs when a data character outside the range is - encountered. - - First, look past the end of the item to see if there is repeat information - following. Then obey similar code to character type repeats - written out - again for speed. */ - - case OP_NCLASS: - case OP_CLASS: - { - data = ecode + 1; /* Save for matching */ - ecode += 33; /* Advance past the item */ - - switch (*ecode) - { - case OP_CRSTAR: - case OP_CRMINSTAR: - case OP_CRPLUS: - case OP_CRMINPLUS: - case OP_CRQUERY: - case OP_CRMINQUERY: - c = *ecode++ - OP_CRSTAR; - minimize = (c & 1) != 0; - min = rep_min[c]; /* Pick up values from tables; */ - max = rep_max[c]; /* zero for max => infinity */ - if (max == 0) max = INT_MAX; - break; - - case OP_CRRANGE: - case OP_CRMINRANGE: - minimize = (*ecode == OP_CRMINRANGE); - min = GET2(ecode, 1); - max = GET2(ecode, 3); - if (max == 0) max = INT_MAX; - ecode += 5; - break; - - default: /* No repeat follows */ - min = max = 1; - break; - } - - /* First, ensure the minimum number of matches are present. */ - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - if (c > 255) - { - if (op == OP_CLASS) RRETURN(MATCH_NOMATCH); - } - else - { - if ((data[c/8] & (1 << (c&7))) == 0) RRETURN(MATCH_NOMATCH); - } - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - c = *eptr++; - if ((data[c/8] & (1 << (c&7))) == 0) RRETURN(MATCH_NOMATCH); - } - } - - /* If max == min we can continue with the main loop without the - need to recurse. */ - - if (min == max) continue; - - /* If minimizing, keep testing the rest of the expression and advancing - the pointer while it matches the class. */ - - if (minimize) - { -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM16); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - if (c > 255) - { - if (op == OP_CLASS) RRETURN(MATCH_NOMATCH); - } - else - { - if ((data[c/8] & (1 << (c&7))) == 0) RRETURN(MATCH_NOMATCH); - } - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM17); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - c = *eptr++; - if ((data[c/8] & (1 << (c&7))) == 0) RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - } - - /* If maximizing, find the longest possible run, then work backwards. */ - - else - { - pp = eptr; - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c > 255) - { - if (op == OP_CLASS) break; - } - else - { - if ((data[c/8] & (1 << (c&7))) == 0) break; - } - eptr += len; - } - for (;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM18); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - BACKCHAR(eptr); - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - c = *eptr; - if ((data[c/8] & (1 << (c&7))) == 0) break; - eptr++; - } - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM19); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - eptr--; - } - } - - RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - - - /* Match an extended character class. This opcode is encountered only - in UTF-8 mode, because that's the only time it is compiled. */ - -#ifdef SUPPORT_UTF8 - case OP_XCLASS: - { - data = ecode + 1 + LINK_SIZE; /* Save for matching */ - ecode += GET(ecode, 1); /* Advance past the item */ - - switch (*ecode) - { - case OP_CRSTAR: - case OP_CRMINSTAR: - case OP_CRPLUS: - case OP_CRMINPLUS: - case OP_CRQUERY: - case OP_CRMINQUERY: - c = *ecode++ - OP_CRSTAR; - minimize = (c & 1) != 0; - min = rep_min[c]; /* Pick up values from tables; */ - max = rep_max[c]; /* zero for max => infinity */ - if (max == 0) max = INT_MAX; - break; - - case OP_CRRANGE: - case OP_CRMINRANGE: - minimize = (*ecode == OP_CRMINRANGE); - min = GET2(ecode, 1); - max = GET2(ecode, 3); - if (max == 0) max = INT_MAX; - ecode += 5; - break; - - default: /* No repeat follows */ - min = max = 1; - break; - } - - /* First, ensure the minimum number of matches are present. */ - - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - if (!_pcre_xclass(c, data)) RRETURN(MATCH_NOMATCH); - } - - /* If max == min we can continue with the main loop without the - need to recurse. */ - - if (min == max) continue; - - /* If minimizing, keep testing the rest of the expression and advancing - the pointer while it matches the class. */ - - if (minimize) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM20); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - if (!_pcre_xclass(c, data)) RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - } - - /* If maximizing, find the longest possible run, then work backwards. */ - - else - { - pp = eptr; - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (!_pcre_xclass(c, data)) break; - eptr += len; - } - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM21); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - if (utf8) BACKCHAR(eptr); - } - RRETURN(MATCH_NOMATCH); - } - - /* Control never gets here */ - } -#endif /* End of XCLASS */ - - /* Match a single character, casefully */ - - case OP_CHAR: -#ifdef SUPPORT_UTF8 - if (utf8) - { - length = 1; - ecode++; - GETCHARLEN(fc, ecode, length); - if (length > md->end_subject - eptr) RRETURN(MATCH_NOMATCH); - while (length-- > 0) if (*ecode++ != *eptr++) RRETURN(MATCH_NOMATCH); - } - else -#endif - - /* Non-UTF-8 mode */ - { - if (md->end_subject - eptr < 1) RRETURN(MATCH_NOMATCH); - if (ecode[1] != *eptr++) RRETURN(MATCH_NOMATCH); - ecode += 2; - } - break; - - /* Match a single character, caselessly */ - - case OP_CHARNC: -#ifdef SUPPORT_UTF8 - if (utf8) - { - length = 1; - ecode++; - GETCHARLEN(fc, ecode, length); - - if (length > md->end_subject - eptr) RRETURN(MATCH_NOMATCH); - - /* If the pattern character's value is < 128, we have only one byte, and - can use the fast lookup table. */ - - if (fc < 128) - { - if (md->lcc[*ecode++] != md->lcc[*eptr++]) RRETURN(MATCH_NOMATCH); - } - - /* Otherwise we must pick up the subject character */ - - else - { - unsigned int dc; - GETCHARINC(dc, eptr); - ecode += length; - - /* If we have Unicode property support, we can use it to test the other - case of the character, if there is one. */ - - if (fc != dc) - { -#ifdef SUPPORT_UCP - if (dc != _pcre_ucp_othercase(fc)) -#endif - RRETURN(MATCH_NOMATCH); - } - } - } - else -#endif /* SUPPORT_UTF8 */ - - /* Non-UTF-8 mode */ - { - if (md->end_subject - eptr < 1) RRETURN(MATCH_NOMATCH); - if (md->lcc[ecode[1]] != md->lcc[*eptr++]) RRETURN(MATCH_NOMATCH); - ecode += 2; - } - break; - - /* Match a single character repeatedly. */ - - case OP_EXACT: - min = max = GET2(ecode, 1); - ecode += 3; - goto REPEATCHAR; - - case OP_POSUPTO: - possessive = TRUE; - /* Fall through */ - - case OP_UPTO: - case OP_MINUPTO: - min = 0; - max = GET2(ecode, 1); - minimize = *ecode == OP_MINUPTO; - ecode += 3; - goto REPEATCHAR; - - case OP_POSSTAR: - possessive = TRUE; - min = 0; - max = INT_MAX; - ecode++; - goto REPEATCHAR; - - case OP_POSPLUS: - possessive = TRUE; - min = 1; - max = INT_MAX; - ecode++; - goto REPEATCHAR; - - case OP_POSQUERY: - possessive = TRUE; - min = 0; - max = 1; - ecode++; - goto REPEATCHAR; - - case OP_STAR: - case OP_MINSTAR: - case OP_PLUS: - case OP_MINPLUS: - case OP_QUERY: - case OP_MINQUERY: - c = *ecode++ - OP_STAR; - minimize = (c & 1) != 0; - min = rep_min[c]; /* Pick up values from tables; */ - max = rep_max[c]; /* zero for max => infinity */ - if (max == 0) max = INT_MAX; - - /* Common code for all repeated single-character matches. We can give - up quickly if there are fewer than the minimum number of characters left in - the subject. */ - - REPEATCHAR: -#ifdef SUPPORT_UTF8 - if (utf8) - { - length = 1; - charptr = ecode; - GETCHARLEN(fc, ecode, length); - if (min * length > md->end_subject - eptr) RRETURN(MATCH_NOMATCH); - ecode += length; - - /* Handle multibyte character matching specially here. There is - support for caseless matching if UCP support is present. */ - - if (length > 1) - { -#ifdef SUPPORT_UCP - unsigned int othercase; - if ((ims & PCRE_CASELESS) != 0 && - (othercase = _pcre_ucp_othercase(fc)) != NOTACHAR) - oclength = _pcre_ord2utf8(othercase, occhars); - else oclength = 0; -#endif /* SUPPORT_UCP */ - - for (i = 1; i <= min; i++) - { - if (memcmp(eptr, charptr, length) == 0) eptr += length; -#ifdef SUPPORT_UCP - /* Need braces because of following else */ - else if (oclength == 0) { RRETURN(MATCH_NOMATCH); } - else - { - if (memcmp(eptr, occhars, oclength) != 0) RRETURN(MATCH_NOMATCH); - eptr += oclength; - } -#else /* without SUPPORT_UCP */ - else { RRETURN(MATCH_NOMATCH); } -#endif /* SUPPORT_UCP */ - } - - if (min == max) continue; - - if (minimize) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM22); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - if (memcmp(eptr, charptr, length) == 0) eptr += length; -#ifdef SUPPORT_UCP - /* Need braces because of following else */ - else if (oclength == 0) { RRETURN(MATCH_NOMATCH); } - else - { - if (memcmp(eptr, occhars, oclength) != 0) RRETURN(MATCH_NOMATCH); - eptr += oclength; - } -#else /* without SUPPORT_UCP */ - else { RRETURN (MATCH_NOMATCH); } -#endif /* SUPPORT_UCP */ - } - /* Control never gets here */ - } - - else /* Maximize */ - { - pp = eptr; - for (i = min; i < max; i++) - { - if (eptr > md->end_subject - length) break; - if (memcmp(eptr, charptr, length) == 0) eptr += length; -#ifdef SUPPORT_UCP - else if (oclength == 0) break; - else - { - if (memcmp(eptr, occhars, oclength) != 0) break; - eptr += oclength; - } -#else /* without SUPPORT_UCP */ - else break; -#endif /* SUPPORT_UCP */ - } - - if (possessive) continue; - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM23); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr == pp) RRETURN(MATCH_NOMATCH); -#ifdef SUPPORT_UCP - eptr--; - BACKCHAR(eptr); -#else /* without SUPPORT_UCP */ - eptr -= length; -#endif /* SUPPORT_UCP */ - } - } - /* Control never gets here */ - } - - /* If the length of a UTF-8 character is 1, we fall through here, and - obey the code as for non-UTF-8 characters below, though in this case the - value of fc will always be < 128. */ - } - else -#endif /* SUPPORT_UTF8 */ - - /* When not in UTF-8 mode, load a single-byte character. */ - { - if (min > md->end_subject - eptr) RRETURN(MATCH_NOMATCH); - fc = *ecode++; - } - - /* The value of fc at this point is always less than 256, though we may or - may not be in UTF-8 mode. The code is duplicated for the caseless and - caseful cases, for speed, since matching characters is likely to be quite - common. First, ensure the minimum number of matches are present. If min = - max, continue at the same level without recursing. Otherwise, if - minimizing, keep trying the rest of the expression and advancing one - matching character if failing, up to the maximum. Alternatively, if - maximizing, find the maximum number of characters and work backwards. */ - - DPRINTF(("matching %c{%d,%d} against subject %.*s\n", fc, min, max, - max, eptr)); - - if ((ims & PCRE_CASELESS) != 0) - { - fc = md->lcc[fc]; - for (i = 1; i <= min; i++) - if (fc != md->lcc[*eptr++]) RRETURN(MATCH_NOMATCH); - if (min == max) continue; - if (minimize) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM24); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject || - fc != md->lcc[*eptr++]) - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - } - else /* Maximize */ - { - pp = eptr; - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || fc != md->lcc[*eptr]) break; - eptr++; - } - if (possessive) continue; - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM25); - eptr--; - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - } - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - } - - /* Caseful comparisons (includes all multi-byte characters) */ - - else - { - for (i = 1; i <= min; i++) if (fc != *eptr++) RRETURN(MATCH_NOMATCH); - if (min == max) continue; - if (minimize) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM26); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject || fc != *eptr++) - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - } - else /* Maximize */ - { - pp = eptr; - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || fc != *eptr) break; - eptr++; - } - if (possessive) continue; - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM27); - eptr--; - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - } - RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - - /* Match a negated single one-byte character. The character we are - checking can be multibyte. */ - - case OP_NOT: - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - ecode++; - GETCHARINCTEST(c, eptr); - if ((ims & PCRE_CASELESS) != 0) - { -#ifdef SUPPORT_UTF8 - if (c < 256) -#endif - c = md->lcc[c]; - if (md->lcc[*ecode++] == c) RRETURN(MATCH_NOMATCH); - } - else - { - if (*ecode++ == c) RRETURN(MATCH_NOMATCH); - } - break; - - /* Match a negated single one-byte character repeatedly. This is almost a - repeat of the code for a repeated single character, but I haven't found a - nice way of commoning these up that doesn't require a test of the - positive/negative option for each character match. Maybe that wouldn't add - very much to the time taken, but character matching *is* what this is all - about... */ - - case OP_NOTEXACT: - min = max = GET2(ecode, 1); - ecode += 3; - goto REPEATNOTCHAR; - - case OP_NOTUPTO: - case OP_NOTMINUPTO: - min = 0; - max = GET2(ecode, 1); - minimize = *ecode == OP_NOTMINUPTO; - ecode += 3; - goto REPEATNOTCHAR; - - case OP_NOTPOSSTAR: - possessive = TRUE; - min = 0; - max = INT_MAX; - ecode++; - goto REPEATNOTCHAR; - - case OP_NOTPOSPLUS: - possessive = TRUE; - min = 1; - max = INT_MAX; - ecode++; - goto REPEATNOTCHAR; - - case OP_NOTPOSQUERY: - possessive = TRUE; - min = 0; - max = 1; - ecode++; - goto REPEATNOTCHAR; - - case OP_NOTPOSUPTO: - possessive = TRUE; - min = 0; - max = GET2(ecode, 1); - ecode += 3; - goto REPEATNOTCHAR; - - case OP_NOTSTAR: - case OP_NOTMINSTAR: - case OP_NOTPLUS: - case OP_NOTMINPLUS: - case OP_NOTQUERY: - case OP_NOTMINQUERY: - c = *ecode++ - OP_NOTSTAR; - minimize = (c & 1) != 0; - min = rep_min[c]; /* Pick up values from tables; */ - max = rep_max[c]; /* zero for max => infinity */ - if (max == 0) max = INT_MAX; - - /* Common code for all repeated single-byte matches. We can give up quickly - if there are fewer than the minimum number of bytes left in the - subject. */ - - REPEATNOTCHAR: - if (min > md->end_subject - eptr) RRETURN(MATCH_NOMATCH); - fc = *ecode++; - - /* The code is duplicated for the caseless and caseful cases, for speed, - since matching characters is likely to be quite common. First, ensure the - minimum number of matches are present. If min = max, continue at the same - level without recursing. Otherwise, if minimizing, keep trying the rest of - the expression and advancing one matching character if failing, up to the - maximum. Alternatively, if maximizing, find the maximum number of - characters and work backwards. */ - - DPRINTF(("negative matching %c{%d,%d} against subject %.*s\n", fc, min, max, - max, eptr)); - - if ((ims & PCRE_CASELESS) != 0) - { - fc = md->lcc[fc]; - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - register unsigned int d; - for (i = 1; i <= min; i++) - { - GETCHARINC(d, eptr); - if (d < 256) d = md->lcc[d]; - if (fc == d) RRETURN(MATCH_NOMATCH); - } - } - else -#endif - - /* Not UTF-8 mode */ - { - for (i = 1; i <= min; i++) - if (fc == md->lcc[*eptr++]) RRETURN(MATCH_NOMATCH); - } - - if (min == max) continue; - - if (minimize) - { -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - register unsigned int d; - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM28); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - GETCHARINC(d, eptr); - if (d < 256) d = md->lcc[d]; - if (fi >= max || eptr >= md->end_subject || fc == d) - RRETURN(MATCH_NOMATCH); - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM29); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject || fc == md->lcc[*eptr++]) - RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - } - - /* Maximize case */ - - else - { - pp = eptr; - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - register unsigned int d; - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(d, eptr, len); - if (d < 256) d = md->lcc[d]; - if (fc == d) break; - eptr += len; - } - if (possessive) continue; - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM30); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - BACKCHAR(eptr); - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || fc == md->lcc[*eptr]) break; - eptr++; - } - if (possessive) continue; - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM31); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - eptr--; - } - } - - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - } - - /* Caseful comparisons */ - - else - { -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - register unsigned int d; - for (i = 1; i <= min; i++) - { - GETCHARINC(d, eptr); - if (fc == d) RRETURN(MATCH_NOMATCH); - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (i = 1; i <= min; i++) - if (fc == *eptr++) RRETURN(MATCH_NOMATCH); - } - - if (min == max) continue; - - if (minimize) - { -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - register unsigned int d; - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM32); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - GETCHARINC(d, eptr); - if (fi >= max || eptr >= md->end_subject || fc == d) - RRETURN(MATCH_NOMATCH); - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM33); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject || fc == *eptr++) - RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - } - - /* Maximize case */ - - else - { - pp = eptr; - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - register unsigned int d; - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(d, eptr, len); - if (fc == d) break; - eptr += len; - } - if (possessive) continue; - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM34); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - BACKCHAR(eptr); - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || fc == *eptr) break; - eptr++; - } - if (possessive) continue; - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM35); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - eptr--; - } - } - - RRETURN(MATCH_NOMATCH); - } - } - /* Control never gets here */ - - /* Match a single character type repeatedly; several different opcodes - share code. This is very similar to the code for single characters, but we - repeat it in the interests of efficiency. */ - - case OP_TYPEEXACT: - min = max = GET2(ecode, 1); - minimize = TRUE; - ecode += 3; - goto REPEATTYPE; - - case OP_TYPEUPTO: - case OP_TYPEMINUPTO: - min = 0; - max = GET2(ecode, 1); - minimize = *ecode == OP_TYPEMINUPTO; - ecode += 3; - goto REPEATTYPE; - - case OP_TYPEPOSSTAR: - possessive = TRUE; - min = 0; - max = INT_MAX; - ecode++; - goto REPEATTYPE; - - case OP_TYPEPOSPLUS: - possessive = TRUE; - min = 1; - max = INT_MAX; - ecode++; - goto REPEATTYPE; - - case OP_TYPEPOSQUERY: - possessive = TRUE; - min = 0; - max = 1; - ecode++; - goto REPEATTYPE; - - case OP_TYPEPOSUPTO: - possessive = TRUE; - min = 0; - max = GET2(ecode, 1); - ecode += 3; - goto REPEATTYPE; - - case OP_TYPESTAR: - case OP_TYPEMINSTAR: - case OP_TYPEPLUS: - case OP_TYPEMINPLUS: - case OP_TYPEQUERY: - case OP_TYPEMINQUERY: - c = *ecode++ - OP_TYPESTAR; - minimize = (c & 1) != 0; - min = rep_min[c]; /* Pick up values from tables; */ - max = rep_max[c]; /* zero for max => infinity */ - if (max == 0) max = INT_MAX; - - /* Common code for all repeated single character type matches. Note that - in UTF-8 mode, '.' matches a character of any length, but for the other - character types, the valid characters are all one-byte long. */ - - REPEATTYPE: - ctype = *ecode++; /* Code for the character type */ - -#ifdef SUPPORT_UCP - if (ctype == OP_PROP || ctype == OP_NOTPROP) - { - prop_fail_result = ctype == OP_NOTPROP; - prop_type = *ecode++; - prop_value = *ecode++; - } - else prop_type = -1; -#endif - - /* First, ensure the minimum number of matches are present. Use inline - code for maximizing the speed, and do the type test once at the start - (i.e. keep it out of the loop). Also we can test that there are at least - the minimum number of bytes before we start. This isn't as effective in - UTF-8 mode, but it does no harm. Separate the UTF-8 code completely as that - is tidier. Also separate the UCP code, which can be the same for both UTF-8 - and single-bytes. */ - - if (min > md->end_subject - eptr) RRETURN(MATCH_NOMATCH); - if (min > 0) - { -#ifdef SUPPORT_UCP - if (prop_type >= 0) - { - switch(prop_type) - { - case PT_ANY: - if (prop_fail_result) RRETURN(MATCH_NOMATCH); - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - } - break; - - case PT_LAMP: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_chartype == ucp_Lu || - prop_chartype == ucp_Ll || - prop_chartype == ucp_Lt) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - break; - - case PT_GC: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_category == prop_value) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - break; - - case PT_PC: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_chartype == prop_value) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - break; - - case PT_SC: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_script == prop_value) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - } - - /* Match extended Unicode sequences. We will get here only if the - support is in the binary; otherwise a compile-time error occurs. */ - - else if (ctype == OP_EXTUNI) - { - for (i = 1; i <= min; i++) - { - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category == ucp_M) RRETURN(MATCH_NOMATCH); - while (eptr < md->end_subject) - { - int len = 1; - if (!utf8) c = *eptr; else - { - GETCHARLEN(c, eptr, len); - } - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category != ucp_M) break; - eptr += len; - } - } - } - - else -#endif /* SUPPORT_UCP */ - -/* Handle all other cases when the coding is UTF-8 */ - -#ifdef SUPPORT_UTF8 - if (utf8) switch(ctype) - { - case OP_ANY: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject || - ((ims & PCRE_DOTALL) == 0 && IS_NEWLINE(eptr))) - RRETURN(MATCH_NOMATCH); - eptr++; - while (eptr < md->end_subject && (*eptr & 0xc0) == 0x80) eptr++; - } - break; - - case OP_ANYBYTE: - eptr += min; - break; - - case OP_ANYNL: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x000d: - if (eptr < md->end_subject && *eptr == 0x0a) eptr++; - break; - - case 0x000a: - break; - - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if (md->bsr_anycrlf) RRETURN(MATCH_NOMATCH); - break; - } - } - break; - - case OP_NOT_HSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - switch(c) - { - default: break; - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - RRETURN(MATCH_NOMATCH); - } - } - break; - - case OP_HSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - break; - } - } - break; - - case OP_NOT_VSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - switch(c) - { - default: break; - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - RRETURN(MATCH_NOMATCH); - } - } - break; - - case OP_VSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - break; - } - } - break; - - case OP_NOT_DIGIT: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - if (c < 128 && (md->ctypes[c] & ctype_digit) != 0) - RRETURN(MATCH_NOMATCH); - } - break; - - case OP_DIGIT: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject || - *eptr >= 128 || (md->ctypes[*eptr++] & ctype_digit) == 0) - RRETURN(MATCH_NOMATCH); - /* No need to skip more bytes - we know it's a 1-byte character */ - } - break; - - case OP_NOT_WHITESPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject || - (*eptr < 128 && (md->ctypes[*eptr] & ctype_space) != 0)) - RRETURN(MATCH_NOMATCH); - while (++eptr < md->end_subject && (*eptr & 0xc0) == 0x80); - } - break; - - case OP_WHITESPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject || - *eptr >= 128 || (md->ctypes[*eptr++] & ctype_space) == 0) - RRETURN(MATCH_NOMATCH); - /* No need to skip more bytes - we know it's a 1-byte character */ - } - break; - - case OP_NOT_WORDCHAR: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject || - (*eptr < 128 && (md->ctypes[*eptr] & ctype_word) != 0)) - RRETURN(MATCH_NOMATCH); - while (++eptr < md->end_subject && (*eptr & 0xc0) == 0x80); - } - break; - - case OP_WORDCHAR: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject || - *eptr >= 128 || (md->ctypes[*eptr++] & ctype_word) == 0) - RRETURN(MATCH_NOMATCH); - /* No need to skip more bytes - we know it's a 1-byte character */ - } - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } /* End switch(ctype) */ - - else -#endif /* SUPPORT_UTF8 */ - - /* Code for the non-UTF-8 case for minimum matching of operators other - than OP_PROP and OP_NOTPROP. We can assume that there are the minimum - number of bytes present, as this was tested above. */ - - switch(ctype) - { - case OP_ANY: - if ((ims & PCRE_DOTALL) == 0) - { - for (i = 1; i <= min; i++) - { - if (IS_NEWLINE(eptr)) RRETURN(MATCH_NOMATCH); - eptr++; - } - } - else eptr += min; - break; - - case OP_ANYBYTE: - eptr += min; - break; - - /* Because of the CRLF case, we can't assume the minimum number of - bytes are present in this case. */ - - case OP_ANYNL: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - switch(*eptr++) - { - default: RRETURN(MATCH_NOMATCH); - case 0x000d: - if (eptr < md->end_subject && *eptr == 0x0a) eptr++; - break; - case 0x000a: - break; - - case 0x000b: - case 0x000c: - case 0x0085: - if (md->bsr_anycrlf) RRETURN(MATCH_NOMATCH); - break; - } - } - break; - - case OP_NOT_HSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - switch(*eptr++) - { - default: break; - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - RRETURN(MATCH_NOMATCH); - } - } - break; - - case OP_HSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - switch(*eptr++) - { - default: RRETURN(MATCH_NOMATCH); - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - break; - } - } - break; - - case OP_NOT_VSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - switch(*eptr++) - { - default: break; - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - RRETURN(MATCH_NOMATCH); - } - } - break; - - case OP_VSPACE: - for (i = 1; i <= min; i++) - { - if (eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - switch(*eptr++) - { - default: RRETURN(MATCH_NOMATCH); - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - break; - } - } - break; - - case OP_NOT_DIGIT: - for (i = 1; i <= min; i++) - if ((md->ctypes[*eptr++] & ctype_digit) != 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_DIGIT: - for (i = 1; i <= min; i++) - if ((md->ctypes[*eptr++] & ctype_digit) == 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_NOT_WHITESPACE: - for (i = 1; i <= min; i++) - if ((md->ctypes[*eptr++] & ctype_space) != 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_WHITESPACE: - for (i = 1; i <= min; i++) - if ((md->ctypes[*eptr++] & ctype_space) == 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_NOT_WORDCHAR: - for (i = 1; i <= min; i++) - if ((md->ctypes[*eptr++] & ctype_word) != 0) - RRETURN(MATCH_NOMATCH); - break; - - case OP_WORDCHAR: - for (i = 1; i <= min; i++) - if ((md->ctypes[*eptr++] & ctype_word) == 0) - RRETURN(MATCH_NOMATCH); - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - } - - /* If min = max, continue at the same level without recursing */ - - if (min == max) continue; - - /* If minimizing, we have to test the rest of the pattern before each - subsequent match. Again, separate the UTF-8 case for speed, and also - separate the UCP cases. */ - - if (minimize) - { -#ifdef SUPPORT_UCP - if (prop_type >= 0) - { - switch(prop_type) - { - case PT_ANY: - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM36); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - if (prop_fail_result) RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - - case PT_LAMP: - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM37); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_chartype == ucp_Lu || - prop_chartype == ucp_Ll || - prop_chartype == ucp_Lt) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - - case PT_GC: - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM38); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_category == prop_value) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - - case PT_PC: - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM39); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_chartype == prop_value) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - - case PT_SC: - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM40); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINC(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_script == prop_value) == prop_fail_result) - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - } - - /* Match extended Unicode sequences. We will get here only if the - support is in the binary; otherwise a compile-time error occurs. */ - - else if (ctype == OP_EXTUNI) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM41); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject) RRETURN(MATCH_NOMATCH); - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category == ucp_M) RRETURN(MATCH_NOMATCH); - while (eptr < md->end_subject) - { - int len = 1; - if (!utf8) c = *eptr; else - { - GETCHARLEN(c, eptr, len); - } - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category != ucp_M) break; - eptr += len; - } - } - } - - else -#endif /* SUPPORT_UCP */ - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - if (utf8) - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM42); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject || - (ctype == OP_ANY && (ims & PCRE_DOTALL) == 0 && - IS_NEWLINE(eptr))) - RRETURN(MATCH_NOMATCH); - - GETCHARINC(c, eptr); - switch(ctype) - { - case OP_ANY: /* This is the DOTALL case */ - break; - - case OP_ANYBYTE: - break; - - case OP_ANYNL: - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x000d: - if (eptr < md->end_subject && *eptr == 0x0a) eptr++; - break; - case 0x000a: - break; - - case 0x000b: - case 0x000c: - case 0x0085: - case 0x2028: - case 0x2029: - if (md->bsr_anycrlf) RRETURN(MATCH_NOMATCH); - break; - } - break; - - case OP_NOT_HSPACE: - switch(c) - { - default: break; - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - RRETURN(MATCH_NOMATCH); - } - break; - - case OP_HSPACE: - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - break; - } - break; - - case OP_NOT_VSPACE: - switch(c) - { - default: break; - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - RRETURN(MATCH_NOMATCH); - } - break; - - case OP_VSPACE: - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - break; - } - break; - - case OP_NOT_DIGIT: - if (c < 256 && (md->ctypes[c] & ctype_digit) != 0) - RRETURN(MATCH_NOMATCH); - break; - - case OP_DIGIT: - if (c >= 256 || (md->ctypes[c] & ctype_digit) == 0) - RRETURN(MATCH_NOMATCH); - break; - - case OP_NOT_WHITESPACE: - if (c < 256 && (md->ctypes[c] & ctype_space) != 0) - RRETURN(MATCH_NOMATCH); - break; - - case OP_WHITESPACE: - if (c >= 256 || (md->ctypes[c] & ctype_space) == 0) - RRETURN(MATCH_NOMATCH); - break; - - case OP_NOT_WORDCHAR: - if (c < 256 && (md->ctypes[c] & ctype_word) != 0) - RRETURN(MATCH_NOMATCH); - break; - - case OP_WORDCHAR: - if (c >= 256 || (md->ctypes[c] & ctype_word) == 0) - RRETURN(MATCH_NOMATCH); - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - } - } - else -#endif - /* Not UTF-8 mode */ - { - for (fi = min;; fi++) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM43); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (fi >= max || eptr >= md->end_subject || - ((ims & PCRE_DOTALL) == 0 && IS_NEWLINE(eptr))) - RRETURN(MATCH_NOMATCH); - - c = *eptr++; - switch(ctype) - { - case OP_ANY: /* This is the DOTALL case */ - break; - - case OP_ANYBYTE: - break; - - case OP_ANYNL: - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x000d: - if (eptr < md->end_subject && *eptr == 0x0a) eptr++; - break; - - case 0x000a: - break; - - case 0x000b: - case 0x000c: - case 0x0085: - if (md->bsr_anycrlf) RRETURN(MATCH_NOMATCH); - break; - } - break; - - case OP_NOT_HSPACE: - switch(c) - { - default: break; - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - RRETURN(MATCH_NOMATCH); - } - break; - - case OP_HSPACE: - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - break; - } - break; - - case OP_NOT_VSPACE: - switch(c) - { - default: break; - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - RRETURN(MATCH_NOMATCH); - } - break; - - case OP_VSPACE: - switch(c) - { - default: RRETURN(MATCH_NOMATCH); - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - break; - } - break; - - case OP_NOT_DIGIT: - if ((md->ctypes[c] & ctype_digit) != 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_DIGIT: - if ((md->ctypes[c] & ctype_digit) == 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_NOT_WHITESPACE: - if ((md->ctypes[c] & ctype_space) != 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_WHITESPACE: - if ((md->ctypes[c] & ctype_space) == 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_NOT_WORDCHAR: - if ((md->ctypes[c] & ctype_word) != 0) RRETURN(MATCH_NOMATCH); - break; - - case OP_WORDCHAR: - if ((md->ctypes[c] & ctype_word) == 0) RRETURN(MATCH_NOMATCH); - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - } - } - /* Control never gets here */ - } - - /* If maximizing, it is worth using inline code for speed, doing the type - test once at the start (i.e. keep it out of the loop). Again, keep the - UTF-8 and UCP stuff separate. */ - - else - { - pp = eptr; /* Remember where we started */ - -#ifdef SUPPORT_UCP - if (prop_type >= 0) - { - switch(prop_type) - { - case PT_ANY: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (prop_fail_result) break; - eptr+= len; - } - break; - - case PT_LAMP: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_chartype == ucp_Lu || - prop_chartype == ucp_Ll || - prop_chartype == ucp_Lt) == prop_fail_result) - break; - eptr+= len; - } - break; - - case PT_GC: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_category == prop_value) == prop_fail_result) - break; - eptr+= len; - } - break; - - case PT_PC: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_chartype == prop_value) == prop_fail_result) - break; - eptr+= len; - } - break; - - case PT_SC: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if ((prop_script == prop_value) == prop_fail_result) - break; - eptr+= len; - } - break; - } - - /* eptr is now past the end of the maximum run */ - - if (possessive) continue; - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM44); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - if (utf8) BACKCHAR(eptr); - } - } - - /* Match extended Unicode sequences. We will get here only if the - support is in the binary; otherwise a compile-time error occurs. */ - - else if (ctype == OP_EXTUNI) - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - GETCHARINCTEST(c, eptr); - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category == ucp_M) break; - while (eptr < md->end_subject) - { - int len = 1; - if (!utf8) c = *eptr; else - { - GETCHARLEN(c, eptr, len); - } - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category != ucp_M) break; - eptr += len; - } - } - - /* eptr is now past the end of the maximum run */ - - if (possessive) continue; - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM45); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - for (;;) /* Move back over one extended */ - { - int len = 1; - if (!utf8) c = *eptr; else - { - BACKCHAR(eptr); - GETCHARLEN(c, eptr, len); - } - prop_category = _pcre_ucp_findprop(c, &prop_chartype, &prop_script); - if (prop_category != ucp_M) break; - eptr--; - } - } - } - - else -#endif /* SUPPORT_UCP */ - -#ifdef SUPPORT_UTF8 - /* UTF-8 mode */ - - if (utf8) - { - switch(ctype) - { - case OP_ANY: - if (max < INT_MAX) - { - if ((ims & PCRE_DOTALL) == 0) - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || IS_NEWLINE(eptr)) break; - eptr++; - while (eptr < md->end_subject && (*eptr & 0xc0) == 0x80) eptr++; - } - } - else - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - eptr++; - while (eptr < md->end_subject && (*eptr & 0xc0) == 0x80) eptr++; - } - } - } - - /* Handle unlimited UTF-8 repeat */ - - else - { - if ((ims & PCRE_DOTALL) == 0) - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || IS_NEWLINE(eptr)) break; - eptr++; - while (eptr < md->end_subject && (*eptr & 0xc0) == 0x80) eptr++; - } - } - else - { - eptr = md->end_subject; - } - } - break; - - /* The byte case is the same as non-UTF8 */ - - case OP_ANYBYTE: - c = max - min; - if (c > (unsigned int)(md->end_subject - eptr)) - c = md->end_subject - eptr; - eptr += c; - break; - - case OP_ANYNL: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c == 0x000d) - { - if (++eptr >= md->end_subject) break; - if (*eptr == 0x000a) eptr++; - } - else - { - if (c != 0x000a && - (md->bsr_anycrlf || - (c != 0x000b && c != 0x000c && - c != 0x0085 && c != 0x2028 && c != 0x2029))) - break; - eptr += len; - } - } - break; - - case OP_NOT_HSPACE: - case OP_HSPACE: - for (i = min; i < max; i++) - { - BOOL gotspace; - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - switch(c) - { - default: gotspace = FALSE; break; - case 0x09: /* HT */ - case 0x20: /* SPACE */ - case 0xa0: /* NBSP */ - case 0x1680: /* OGHAM SPACE MARK */ - case 0x180e: /* MONGOLIAN VOWEL SEPARATOR */ - case 0x2000: /* EN QUAD */ - case 0x2001: /* EM QUAD */ - case 0x2002: /* EN SPACE */ - case 0x2003: /* EM SPACE */ - case 0x2004: /* THREE-PER-EM SPACE */ - case 0x2005: /* FOUR-PER-EM SPACE */ - case 0x2006: /* SIX-PER-EM SPACE */ - case 0x2007: /* FIGURE SPACE */ - case 0x2008: /* PUNCTUATION SPACE */ - case 0x2009: /* THIN SPACE */ - case 0x200A: /* HAIR SPACE */ - case 0x202f: /* NARROW NO-BREAK SPACE */ - case 0x205f: /* MEDIUM MATHEMATICAL SPACE */ - case 0x3000: /* IDEOGRAPHIC SPACE */ - gotspace = TRUE; - break; - } - if (gotspace == (ctype == OP_NOT_HSPACE)) break; - eptr += len; - } - break; - - case OP_NOT_VSPACE: - case OP_VSPACE: - for (i = min; i < max; i++) - { - BOOL gotspace; - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - switch(c) - { - default: gotspace = FALSE; break; - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - case 0x0d: /* CR */ - case 0x85: /* NEL */ - case 0x2028: /* LINE SEPARATOR */ - case 0x2029: /* PARAGRAPH SEPARATOR */ - gotspace = TRUE; - break; - } - if (gotspace == (ctype == OP_NOT_VSPACE)) break; - eptr += len; - } - break; - - case OP_NOT_DIGIT: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c < 256 && (md->ctypes[c] & ctype_digit) != 0) break; - eptr+= len; - } - break; - - case OP_DIGIT: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c >= 256 ||(md->ctypes[c] & ctype_digit) == 0) break; - eptr+= len; - } - break; - - case OP_NOT_WHITESPACE: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c < 256 && (md->ctypes[c] & ctype_space) != 0) break; - eptr+= len; - } - break; - - case OP_WHITESPACE: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c >= 256 ||(md->ctypes[c] & ctype_space) == 0) break; - eptr+= len; - } - break; - - case OP_NOT_WORDCHAR: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c < 256 && (md->ctypes[c] & ctype_word) != 0) break; - eptr+= len; - } - break; - - case OP_WORDCHAR: - for (i = min; i < max; i++) - { - int len = 1; - if (eptr >= md->end_subject) break; - GETCHARLEN(c, eptr, len); - if (c >= 256 || (md->ctypes[c] & ctype_word) == 0) break; - eptr+= len; - } - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - - /* eptr is now past the end of the maximum run */ - - if (possessive) continue; - for(;;) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM46); - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - if (eptr-- == pp) break; /* Stop if tried at original pos */ - BACKCHAR(eptr); - } - } - else -#endif /* SUPPORT_UTF8 */ - - /* Not UTF-8 mode */ - { - switch(ctype) - { - case OP_ANY: - if ((ims & PCRE_DOTALL) == 0) - { - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || IS_NEWLINE(eptr)) break; - eptr++; - } - break; - } - /* For DOTALL case, fall through and treat as \C */ - - case OP_ANYBYTE: - c = max - min; - if (c > (unsigned int)(md->end_subject - eptr)) - c = md->end_subject - eptr; - eptr += c; - break; - - case OP_ANYNL: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - c = *eptr; - if (c == 0x000d) - { - if (++eptr >= md->end_subject) break; - if (*eptr == 0x000a) eptr++; - } - else - { - if (c != 0x000a && - (md->bsr_anycrlf || - (c != 0x000b && c != 0x000c && c != 0x0085))) - break; - eptr++; - } - } - break; - - case OP_NOT_HSPACE: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - c = *eptr; - if (c == 0x09 || c == 0x20 || c == 0xa0) break; - eptr++; - } - break; - - case OP_HSPACE: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - c = *eptr; - if (c != 0x09 && c != 0x20 && c != 0xa0) break; - eptr++; - } - break; - - case OP_NOT_VSPACE: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - c = *eptr; - if (c == 0x0a || c == 0x0b || c == 0x0c || c == 0x0d || c == 0x85) - break; - eptr++; - } - break; - - case OP_VSPACE: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject) break; - c = *eptr; - if (c != 0x0a && c != 0x0b && c != 0x0c && c != 0x0d && c != 0x85) - break; - eptr++; - } - break; - - case OP_NOT_DIGIT: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || (md->ctypes[*eptr] & ctype_digit) != 0) - break; - eptr++; - } - break; - - case OP_DIGIT: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || (md->ctypes[*eptr] & ctype_digit) == 0) - break; - eptr++; - } - break; - - case OP_NOT_WHITESPACE: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || (md->ctypes[*eptr] & ctype_space) != 0) - break; - eptr++; - } - break; - - case OP_WHITESPACE: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || (md->ctypes[*eptr] & ctype_space) == 0) - break; - eptr++; - } - break; - - case OP_NOT_WORDCHAR: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || (md->ctypes[*eptr] & ctype_word) != 0) - break; - eptr++; - } - break; - - case OP_WORDCHAR: - for (i = min; i < max; i++) - { - if (eptr >= md->end_subject || (md->ctypes[*eptr] & ctype_word) == 0) - break; - eptr++; - } - break; - - default: - RRETURN(PCRE_ERROR_INTERNAL); - } - - /* eptr is now past the end of the maximum run */ - - if (possessive) continue; - while (eptr >= pp) - { - RMATCH(eptr, ecode, offset_top, md, ims, eptrb, 0, RM47); - eptr--; - if (rrc != MATCH_NOMATCH) RRETURN(rrc); - } - } - - /* Get here if we can't make it match with any permitted repetitions */ - - RRETURN(MATCH_NOMATCH); - } - /* Control never gets here */ - - /* There's been some horrible disaster. Arrival here can only mean there is - something seriously wrong in the code above or the OP_xxx definitions. */ - - default: - DPRINTF(("Unknown opcode %d\n", *ecode)); - RRETURN(PCRE_ERROR_UNKNOWN_OPCODE); - } - - /* Do not stick any code in here without much thought; it is assumed - that "continue" in the code above comes out to here to repeat the main - loop. */ - - } /* End of main loop */ -/* Control never reaches here */ - - -/* When compiling to use the heap rather than the stack for recursive calls to -match(), the RRETURN() macro jumps here. The number that is saved in -frame->Xwhere indicates which label we actually want to return to. */ - -#ifdef NO_RECURSE -#define LBL(val) case val: goto L_RM##val; -HEAP_RETURN: -switch (frame->Xwhere) - { - LBL( 1) LBL( 2) LBL( 3) LBL( 4) LBL( 5) LBL( 6) LBL( 7) LBL( 8) - LBL( 9) LBL(10) LBL(11) LBL(12) LBL(13) LBL(14) LBL(15) LBL(17) - LBL(19) LBL(24) LBL(25) LBL(26) LBL(27) LBL(29) LBL(31) LBL(33) - LBL(35) LBL(43) LBL(47) LBL(48) LBL(49) LBL(50) LBL(51) LBL(52) - LBL(53) LBL(54) -#ifdef SUPPORT_UTF8 - LBL(16) LBL(18) LBL(20) LBL(21) LBL(22) LBL(23) LBL(28) LBL(30) - LBL(32) LBL(34) LBL(42) LBL(46) -#ifdef SUPPORT_UCP - LBL(36) LBL(37) LBL(38) LBL(39) LBL(40) LBL(41) LBL(44) LBL(45) -#endif /* SUPPORT_UCP */ -#endif /* SUPPORT_UTF8 */ - default: - DPRINTF(("jump error in pcre match: label %d non-existent\n", frame->Xwhere)); - return PCRE_ERROR_INTERNAL; - } -#undef LBL -#endif /* NO_RECURSE */ -} - - -/*************************************************************************** -**************************************************************************** - RECURSION IN THE match() FUNCTION - -Undefine all the macros that were defined above to handle this. */ - -#ifdef NO_RECURSE -#undef eptr -#undef ecode -#undef mstart -#undef offset_top -#undef ims -#undef eptrb -#undef flags - -#undef callpat -#undef charptr -#undef data -#undef next -#undef pp -#undef prev -#undef saved_eptr - -#undef new_recursive - -#undef cur_is_word -#undef condition -#undef prev_is_word - -#undef original_ims - -#undef ctype -#undef length -#undef max -#undef min -#undef number -#undef offset -#undef op -#undef save_capture_last -#undef save_offset1 -#undef save_offset2 -#undef save_offset3 -#undef stacksave - -#undef newptrb - -#endif - -/* These two are defined as macros in both cases */ - -#undef fc -#undef fi - -/*************************************************************************** -***************************************************************************/ - - - -/************************************************* -* Execute a Regular Expression * -*************************************************/ - -/* This function applies a compiled re to a subject string and picks out -portions of the string if it matches. Two elements in the vector are set for -each substring: the offsets to the start and end of the substring. - -Arguments: - argument_re points to the compiled expression - extra_data points to extra data or is NULL - subject points to the subject string - length length of subject string (may contain binary zeros) - start_offset where to start in the subject string - options option bits - offsets points to a vector of ints to be filled in with offsets - offsetcount the number of elements in the vector - -Returns: > 0 => success; value is the number of elements filled in - = 0 => success, but offsets is not big enough - -1 => failed to match - < -1 => some kind of unexpected problem -*/ - -PCRE_EXP_DEFN int -pcre_exec(const pcre *argument_re, const pcre_extra *extra_data, - PCRE_SPTR subject, int length, int start_offset, int options, int *offsets, - int offsetcount) -{ -int rc, resetcount, ocount; -int first_byte = -1; -int req_byte = -1; -int req_byte2 = -1; -int newline; -unsigned long int ims; -BOOL using_temporary_offsets = FALSE; -BOOL anchored; -BOOL startline; -BOOL firstline; -BOOL first_byte_caseless = FALSE; -BOOL req_byte_caseless = FALSE; -BOOL utf8; -match_data match_block; -match_data *md = &match_block; -const uschar *tables; -const uschar *start_bits = NULL; -USPTR start_match = (USPTR)subject + start_offset; -USPTR end_subject; -USPTR req_byte_ptr = start_match - 1; - -pcre_study_data internal_study; -const pcre_study_data *study; - -real_pcre internal_re; -const real_pcre *external_re = (const real_pcre *)argument_re; -const real_pcre *re = external_re; - -/* Plausibility checks */ - -if ((options & ~PUBLIC_EXEC_OPTIONS) != 0) return PCRE_ERROR_BADOPTION; -if (re == NULL || subject == NULL || - (offsets == NULL && offsetcount > 0)) return PCRE_ERROR_NULL; -if (offsetcount < 0) return PCRE_ERROR_BADCOUNT; - -/* Fish out the optional data from the extra_data structure, first setting -the default values. */ - -study = NULL; -md->match_limit = MATCH_LIMIT; -md->match_limit_recursion = MATCH_LIMIT_RECURSION; -md->callout_data = NULL; - -/* The table pointer is always in native byte order. */ - -tables = external_re->tables; - -if (extra_data != NULL) - { - register unsigned int flags = extra_data->flags; - if ((flags & PCRE_EXTRA_STUDY_DATA) != 0) - study = (const pcre_study_data *)extra_data->study_data; - if ((flags & PCRE_EXTRA_MATCH_LIMIT) != 0) - md->match_limit = extra_data->match_limit; - if ((flags & PCRE_EXTRA_MATCH_LIMIT_RECURSION) != 0) - md->match_limit_recursion = extra_data->match_limit_recursion; - if ((flags & PCRE_EXTRA_CALLOUT_DATA) != 0) - md->callout_data = extra_data->callout_data; - if ((flags & PCRE_EXTRA_TABLES) != 0) tables = extra_data->tables; - } - -/* If the exec call supplied NULL for tables, use the inbuilt ones. This -is a feature that makes it possible to save compiled regex and re-use them -in other programs later. */ - -if (tables == NULL) tables = _pcre_default_tables; - -/* Check that the first field in the block is the magic number. If it is not, -test for a regex that was compiled on a host of opposite endianness. If this is -the case, flipped values are put in internal_re and internal_study if there was -study data too. */ - -if (re->magic_number != MAGIC_NUMBER) - { - re = _pcre_try_flipped(re, &internal_re, study, &internal_study); - if (re == NULL) return PCRE_ERROR_BADMAGIC; - if (study != NULL) study = &internal_study; - } - -/* Set up other data */ - -anchored = ((re->options | options) & PCRE_ANCHORED) != 0; -startline = (re->flags & PCRE_STARTLINE) != 0; -firstline = (re->options & PCRE_FIRSTLINE) != 0; - -/* The code starts after the real_pcre block and the capture name table. */ - -md->start_code = (const uschar *)external_re + re->name_table_offset + - re->name_count * re->name_entry_size; - -md->start_subject = (USPTR)subject; -md->start_offset = start_offset; -md->end_subject = md->start_subject + length; -end_subject = md->end_subject; - -md->endonly = (re->options & PCRE_DOLLAR_ENDONLY) != 0; -utf8 = md->utf8 = (re->options & PCRE_UTF8) != 0; - -md->notbol = (options & PCRE_NOTBOL) != 0; -md->noteol = (options & PCRE_NOTEOL) != 0; -md->notempty = (options & PCRE_NOTEMPTY) != 0; -md->partial = (options & PCRE_PARTIAL) != 0; -md->hitend = FALSE; - -md->recursive = NULL; /* No recursion at top level */ - -md->lcc = tables + lcc_offset; -md->ctypes = tables + ctypes_offset; - -/* Handle different \R options. */ - -switch (options & (PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE)) - { - case 0: - if ((re->options & (PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE)) != 0) - md->bsr_anycrlf = (re->options & PCRE_BSR_ANYCRLF) != 0; - else -#ifdef BSR_ANYCRLF - md->bsr_anycrlf = TRUE; -#else - md->bsr_anycrlf = FALSE; -#endif - break; - - case PCRE_BSR_ANYCRLF: - md->bsr_anycrlf = TRUE; - break; - - case PCRE_BSR_UNICODE: - md->bsr_anycrlf = FALSE; - break; - - default: return PCRE_ERROR_BADNEWLINE; - } - -/* Handle different types of newline. The three bits give eight cases. If -nothing is set at run time, whatever was used at compile time applies. */ - -switch ((((options & PCRE_NEWLINE_BITS) == 0)? re->options : - (pcre_uint32)options) & PCRE_NEWLINE_BITS) - { - case 0: newline = NEWLINE; break; /* Compile-time default */ - case PCRE_NEWLINE_CR: newline = '\r'; break; - case PCRE_NEWLINE_LF: newline = '\n'; break; - case PCRE_NEWLINE_CR+ - PCRE_NEWLINE_LF: newline = ('\r' << 8) | '\n'; break; - case PCRE_NEWLINE_ANY: newline = -1; break; - case PCRE_NEWLINE_ANYCRLF: newline = -2; break; - default: return PCRE_ERROR_BADNEWLINE; - } - -if (newline == -2) - { - md->nltype = NLTYPE_ANYCRLF; - } -else if (newline < 0) - { - md->nltype = NLTYPE_ANY; - } -else - { - md->nltype = NLTYPE_FIXED; - if (newline > 255) - { - md->nllen = 2; - md->nl[0] = (newline >> 8) & 255; - md->nl[1] = newline & 255; - } - else - { - md->nllen = 1; - md->nl[0] = newline; - } - } - -/* Partial matching is supported only for a restricted set of regexes at the -moment. */ - -if (md->partial && (re->flags & PCRE_NOPARTIAL) != 0) - return PCRE_ERROR_BADPARTIAL; - -/* Check a UTF-8 string if required. Unfortunately there's no way of passing -back the character offset. */ - -#ifdef SUPPORT_UTF8 -if (utf8 && (options & PCRE_NO_UTF8_CHECK) == 0) - { - if (_pcre_valid_utf8((uschar *)subject, length) >= 0) - return PCRE_ERROR_BADUTF8; - if (start_offset > 0 && start_offset < length) - { - int tb = ((uschar *)subject)[start_offset]; - if (tb > 127) - { - tb &= 0xc0; - if (tb != 0 && tb != 0xc0) return PCRE_ERROR_BADUTF8_OFFSET; - } - } - } -#endif - -/* The ims options can vary during the matching as a result of the presence -of (?ims) items in the pattern. They are kept in a local variable so that -restoring at the exit of a group is easy. */ - -ims = re->options & (PCRE_CASELESS|PCRE_MULTILINE|PCRE_DOTALL); - -/* If the expression has got more back references than the offsets supplied can -hold, we get a temporary chunk of working store to use during the matching. -Otherwise, we can use the vector supplied, rounding down its size to a multiple -of 3. */ - -ocount = offsetcount - (offsetcount % 3); - -if (re->top_backref > 0 && re->top_backref >= ocount/3) - { - ocount = re->top_backref * 3 + 3; - md->offset_vector = (int *)(pcre_malloc)(ocount * sizeof(int)); - if (md->offset_vector == NULL) return PCRE_ERROR_NOMEMORY; - using_temporary_offsets = TRUE; - DPRINTF(("Got memory to hold back references\n")); - } -else md->offset_vector = offsets; - -md->offset_end = ocount; -md->offset_max = (2*ocount)/3; -md->offset_overflow = FALSE; -md->capture_last = -1; - -/* Compute the minimum number of offsets that we need to reset each time. Doing -this makes a huge difference to execution time when there aren't many brackets -in the pattern. */ - -resetcount = 2 + re->top_bracket * 2; -if (resetcount > offsetcount) resetcount = ocount; - -/* Reset the working variable associated with each extraction. These should -never be used unless previously set, but they get saved and restored, and so we -initialize them to avoid reading uninitialized locations. */ - -if (md->offset_vector != NULL) - { - register int *iptr = md->offset_vector + ocount; - register int *iend = iptr - resetcount/2 + 1; - while (--iptr >= iend) *iptr = -1; - } - -/* Set up the first character to match, if available. The first_byte value is -never set for an anchored regular expression, but the anchoring may be forced -at run time, so we have to test for anchoring. The first char may be unset for -an unanchored pattern, of course. If there's no first char and the pattern was -studied, there may be a bitmap of possible first characters. */ - -if (!anchored) - { - if ((re->flags & PCRE_FIRSTSET) != 0) - { - first_byte = re->first_byte & 255; - if ((first_byte_caseless = ((re->first_byte & REQ_CASELESS) != 0)) == TRUE) - first_byte = md->lcc[first_byte]; - } - else - if (!startline && study != NULL && - (study->options & PCRE_STUDY_MAPPED) != 0) - start_bits = study->start_bits; - } - -/* For anchored or unanchored matches, there may be a "last known required -character" set. */ - -if ((re->flags & PCRE_REQCHSET) != 0) - { - req_byte = re->req_byte & 255; - req_byte_caseless = (re->req_byte & REQ_CASELESS) != 0; - req_byte2 = (tables + fcc_offset)[req_byte]; /* case flipped */ - } - - -/* ==========================================================================*/ - -/* Loop for handling unanchored repeated matching attempts; for anchored regexs -the loop runs just once. */ - -for(;;) - { - USPTR save_end_subject = end_subject; - USPTR new_start_match; - - /* Reset the maximum number of extractions we might see. */ - - if (md->offset_vector != NULL) - { - register int *iptr = md->offset_vector; - register int *iend = iptr + resetcount; - while (iptr < iend) *iptr++ = -1; - } - - /* Advance to a unique first char if possible. If firstline is TRUE, the - start of the match is constrained to the first line of a multiline string. - That is, the match must be before or at the first newline. Implement this by - temporarily adjusting end_subject so that we stop scanning at a newline. If - the match fails at the newline, later code breaks this loop. */ - - if (firstline) - { - USPTR t = start_match; - while (t < md->end_subject && !IS_NEWLINE(t)) t++; - end_subject = t; - } - - /* Now test for a unique first byte */ - - if (first_byte >= 0) - { - if (first_byte_caseless) - while (start_match < end_subject && - md->lcc[*start_match] != first_byte) - start_match++; - else - while (start_match < end_subject && *start_match != first_byte) - start_match++; - } - - /* Or to just after a linebreak for a multiline match if possible */ - - else if (startline) - { - if (start_match > md->start_subject + start_offset) - { - while (start_match <= end_subject && !WAS_NEWLINE(start_match)) - start_match++; - - /* If we have just passed a CR and the newline option is ANY or ANYCRLF, - and we are now at a LF, advance the match position by one more character. - */ - - if (start_match[-1] == '\r' && - (md->nltype == NLTYPE_ANY || md->nltype == NLTYPE_ANYCRLF) && - start_match < end_subject && - *start_match == '\n') - start_match++; - } - } - - /* Or to a non-unique first char after study */ - - else if (start_bits != NULL) - { - while (start_match < end_subject) - { - register unsigned int c = *start_match; - if ((start_bits[c/8] & (1 << (c&7))) == 0) start_match++; else break; - } - } - - /* Restore fudged end_subject */ - - end_subject = save_end_subject; - -#ifdef DEBUG /* Sigh. Some compilers never learn. */ - printf(">>>> Match against: "); - pchars(start_match, end_subject - start_match, TRUE, md); - printf("\n"); -#endif - - /* If req_byte is set, we know that that character must appear in the subject - for the match to succeed. If the first character is set, req_byte must be - later in the subject; otherwise the test starts at the match point. This - optimization can save a huge amount of backtracking in patterns with nested - unlimited repeats that aren't going to match. Writing separate code for - cased/caseless versions makes it go faster, as does using an autoincrement - and backing off on a match. - - HOWEVER: when the subject string is very, very long, searching to its end can - take a long time, and give bad performance on quite ordinary patterns. This - showed up when somebody was matching something like /^\d+C/ on a 32-megabyte - string... so we don't do this when the string is sufficiently long. - - ALSO: this processing is disabled when partial matching is requested. - */ - - if (req_byte >= 0 && - end_subject - start_match < REQ_BYTE_MAX && - !md->partial) - { - register USPTR p = start_match + ((first_byte >= 0)? 1 : 0); - - /* We don't need to repeat the search if we haven't yet reached the - place we found it at last time. */ - - if (p > req_byte_ptr) - { - if (req_byte_caseless) - { - while (p < end_subject) - { - register int pp = *p++; - if (pp == req_byte || pp == req_byte2) { p--; break; } - } - } - else - { - while (p < end_subject) - { - if (*p++ == req_byte) { p--; break; } - } - } - - /* If we can't find the required character, break the matching loop, - forcing a match failure. */ - - if (p >= end_subject) - { - rc = MATCH_NOMATCH; - break; - } - - /* If we have found the required character, save the point where we - found it, so that we don't search again next time round the loop if - the start hasn't passed this character yet. */ - - req_byte_ptr = p; - } - } - - /* OK, we can now run the match. */ - - md->start_match_ptr = start_match; - md->match_call_count = 0; - rc = match(start_match, md->start_code, start_match, 2, md, ims, NULL, 0, 0); - - switch(rc) - { - /* NOMATCH and PRUNE advance by one character. THEN at this level acts - exactly like PRUNE. */ - - case MATCH_NOMATCH: - case MATCH_PRUNE: - case MATCH_THEN: - new_start_match = start_match + 1; -#ifdef SUPPORT_UTF8 - if (utf8) - while(new_start_match < end_subject && (*new_start_match & 0xc0) == 0x80) - new_start_match++; -#endif - break; - - /* SKIP passes back the next starting point explicitly. */ - - case MATCH_SKIP: - new_start_match = md->start_match_ptr; - break; - - /* COMMIT disables the bumpalong, but otherwise behaves as NOMATCH. */ - - case MATCH_COMMIT: - rc = MATCH_NOMATCH; - goto ENDLOOP; - - /* Any other return is some kind of error. */ - - default: - goto ENDLOOP; - } - - /* Control reaches here for the various types of "no match at this point" - result. Reset the code to MATCH_NOMATCH for subsequent checking. */ - - rc = MATCH_NOMATCH; - - /* If PCRE_FIRSTLINE is set, the match must happen before or at the first - newline in the subject (though it may continue over the newline). Therefore, - if we have just failed to match, starting at a newline, do not continue. */ - - if (firstline && IS_NEWLINE(start_match)) break; - - /* Advance to new matching position */ - - start_match = new_start_match; - - /* Break the loop if the pattern is anchored or if we have passed the end of - the subject. */ - - if (anchored || start_match > end_subject) break; - - /* If we have just passed a CR and we are now at a LF, and the pattern does - not contain any explicit matches for \r or \n, and the newline option is CRLF - or ANY or ANYCRLF, advance the match position by one more character. */ - - if (start_match[-1] == '\r' && - start_match < end_subject && - *start_match == '\n' && - (re->flags & PCRE_HASCRORLF) == 0 && - (md->nltype == NLTYPE_ANY || - md->nltype == NLTYPE_ANYCRLF || - md->nllen == 2)) - start_match++; - - } /* End of for(;;) "bumpalong" loop */ - -/* ==========================================================================*/ - -/* We reach here when rc is not MATCH_NOMATCH, or if one of the stopping -conditions is true: - -(1) The pattern is anchored or the match was failed by (*COMMIT); - -(2) We are past the end of the subject; - -(3) PCRE_FIRSTLINE is set and we have failed to match at a newline, because - this option requests that a match occur at or before the first newline in - the subject. - -When we have a match and the offset vector is big enough to deal with any -backreferences, captured substring offsets will already be set up. In the case -where we had to get some local store to hold offsets for backreference -processing, copy those that we can. In this case there need not be overflow if -certain parts of the pattern were not used, even though there are more -capturing parentheses than vector slots. */ - -ENDLOOP: - -if (rc == MATCH_MATCH) - { - if (using_temporary_offsets) - { - if (offsetcount >= 4) - { - memcpy(offsets + 2, md->offset_vector + 2, - (offsetcount - 2) * sizeof(int)); - DPRINTF(("Copied offsets from temporary memory\n")); - } - if (md->end_offset_top > offsetcount) md->offset_overflow = TRUE; - DPRINTF(("Freeing temporary memory\n")); - (pcre_free)(md->offset_vector); - } - - /* Set the return code to the number of captured strings, or 0 if there are - too many to fit into the vector. */ - - rc = md->offset_overflow? 0 : md->end_offset_top/2; - - /* If there is space, set up the whole thing as substring 0. The value of - md->start_match_ptr might be modified if \K was encountered on the success - matching path. */ - - if (offsetcount < 2) rc = 0; else - { - offsets[0] = md->start_match_ptr - md->start_subject; - offsets[1] = md->end_match_ptr - md->start_subject; - } - - DPRINTF((">>>> returning %d\n", rc)); - return rc; - } - -/* Control gets here if there has been an error, or if the overall match -attempt has failed at all permitted starting positions. */ - -if (using_temporary_offsets) - { - DPRINTF(("Freeing temporary memory\n")); - (pcre_free)(md->offset_vector); - } - -if (rc != MATCH_NOMATCH) - { - DPRINTF((">>>> error: returning %d\n", rc)); - return rc; - } -else if (md->partial && md->hitend) - { - DPRINTF((">>>> returning PCRE_ERROR_PARTIAL\n")); - return PCRE_ERROR_PARTIAL; - } -else - { - DPRINTF((">>>> returning PCRE_ERROR_NOMATCH\n")); - return PCRE_ERROR_NOMATCH; - } -} - -/* End of pcre_exec.c */ diff --git a/src/plugins/PCREPlugin/pcre_fullinfo.c b/src/plugins/PCREPlugin/pcre_fullinfo.c deleted file mode 100644 index 04e31f6..0000000 --- a/src/plugins/PCREPlugin/pcre_fullinfo.c +++ /dev/null @@ -1,165 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/*PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_fullinfo(), which returns -information about a compiled pattern. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Return info about compiled pattern * -*************************************************/ - -/* This is a newer "info" function which has an extensible interface so -that additional items can be added compatibly. - -Arguments: - argument_re points to compiled code - extra_data points extra data, or NULL - what what information is required - where where to put the information - -Returns: 0 if data returned, negative on error -*/ - -PCRE_EXP_DEFN int -pcre_fullinfo(const pcre *argument_re, const pcre_extra *extra_data, int what, - void *where) -{ -real_pcre internal_re; -pcre_study_data internal_study; -const real_pcre *re = (const real_pcre *)argument_re; -const pcre_study_data *study = NULL; - -if (re == NULL || where == NULL) return PCRE_ERROR_NULL; - -if (extra_data != NULL && (extra_data->flags & PCRE_EXTRA_STUDY_DATA) != 0) - study = (const pcre_study_data *)extra_data->study_data; - -if (re->magic_number != MAGIC_NUMBER) - { - re = _pcre_try_flipped(re, &internal_re, study, &internal_study); - if (re == NULL) return PCRE_ERROR_BADMAGIC; - if (study != NULL) study = &internal_study; - } - -switch (what) - { - case PCRE_INFO_OPTIONS: - *((unsigned long int *)where) = re->options & PUBLIC_OPTIONS; - break; - - case PCRE_INFO_SIZE: - *((size_t *)where) = re->size; - break; - - case PCRE_INFO_STUDYSIZE: - *((size_t *)where) = (study == NULL)? 0 : study->size; - break; - - case PCRE_INFO_CAPTURECOUNT: - *((int *)where) = re->top_bracket; - break; - - case PCRE_INFO_BACKREFMAX: - *((int *)where) = re->top_backref; - break; - - case PCRE_INFO_FIRSTBYTE: - *((int *)where) = - ((re->flags & PCRE_FIRSTSET) != 0)? re->first_byte : - ((re->flags & PCRE_STARTLINE) != 0)? -1 : -2; - break; - - /* Make sure we pass back the pointer to the bit vector in the external - block, not the internal copy (with flipped integer fields). */ - - case PCRE_INFO_FIRSTTABLE: - *((const uschar **)where) = - (study != NULL && (study->options & PCRE_STUDY_MAPPED) != 0)? - ((const pcre_study_data *)extra_data->study_data)->start_bits : NULL; - break; - - case PCRE_INFO_LASTLITERAL: - *((int *)where) = - ((re->flags & PCRE_REQCHSET) != 0)? re->req_byte : -1; - break; - - case PCRE_INFO_NAMEENTRYSIZE: - *((int *)where) = re->name_entry_size; - break; - - case PCRE_INFO_NAMECOUNT: - *((int *)where) = re->name_count; - break; - - case PCRE_INFO_NAMETABLE: - *((const uschar **)where) = (const uschar *)re + re->name_table_offset; - break; - - case PCRE_INFO_DEFAULT_TABLES: - *((const uschar **)where) = (const uschar *)(_pcre_default_tables); - break; - - case PCRE_INFO_OKPARTIAL: - *((int *)where) = (re->flags & PCRE_NOPARTIAL) == 0; - break; - - case PCRE_INFO_JCHANGED: - *((int *)where) = (re->flags & PCRE_JCHANGED) != 0; - break; - - case PCRE_INFO_HASCRORLF: - *((int *)where) = (re->flags & PCRE_HASCRORLF) != 0; - break; - - default: return PCRE_ERROR_BADOPTION; - } - -return 0; -} - -/* End of pcre_fullinfo.c */ diff --git a/src/plugins/PCREPlugin/pcre_get.c b/src/plugins/PCREPlugin/pcre_get.c deleted file mode 100644 index fc283c8..0000000 --- a/src/plugins/PCREPlugin/pcre_get.c +++ /dev/null @@ -1,465 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains some convenience functions for extracting substrings -from the subject string after a regex match has succeeded. The original idea -for these functions came from Scott Wimer. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Find number for named string * -*************************************************/ - -/* This function is used by the get_first_set() function below, as well -as being generally available. It assumes that names are unique. - -Arguments: - code the compiled regex - stringname the name whose number is required - -Returns: the number of the named parentheses, or a negative number - (PCRE_ERROR_NOSUBSTRING) if not found -*/ - -int -pcre_get_stringnumber(const pcre *code, const char *stringname) -{ -int rc; -int entrysize; -int top, bot; -uschar *nametable; - -if ((rc = pcre_fullinfo(code, NULL, PCRE_INFO_NAMECOUNT, &top)) != 0) - return rc; -if (top <= 0) return PCRE_ERROR_NOSUBSTRING; - -if ((rc = pcre_fullinfo(code, NULL, PCRE_INFO_NAMEENTRYSIZE, &entrysize)) != 0) - return rc; -if ((rc = pcre_fullinfo(code, NULL, PCRE_INFO_NAMETABLE, &nametable)) != 0) - return rc; - -bot = 0; -while (top > bot) - { - int mid = (top + bot) / 2; - uschar *entry = nametable + entrysize*mid; - int c = strcmp(stringname, (char *)(entry + 2)); - if (c == 0) return (entry[0] << 8) + entry[1]; - if (c > 0) bot = mid + 1; else top = mid; - } - -return PCRE_ERROR_NOSUBSTRING; -} - - - -/************************************************* -* Find (multiple) entries for named string * -*************************************************/ - -/* This is used by the get_first_set() function below, as well as being -generally available. It is used when duplicated names are permitted. - -Arguments: - code the compiled regex - stringname the name whose entries required - firstptr where to put the pointer to the first entry - lastptr where to put the pointer to the last entry - -Returns: the length of each entry, or a negative number - (PCRE_ERROR_NOSUBSTRING) if not found -*/ - -int -pcre_get_stringtable_entries(const pcre *code, const char *stringname, - char **firstptr, char **lastptr) -{ -int rc; -int entrysize; -int top, bot; -uschar *nametable, *lastentry; - -if ((rc = pcre_fullinfo(code, NULL, PCRE_INFO_NAMECOUNT, &top)) != 0) - return rc; -if (top <= 0) return PCRE_ERROR_NOSUBSTRING; - -if ((rc = pcre_fullinfo(code, NULL, PCRE_INFO_NAMEENTRYSIZE, &entrysize)) != 0) - return rc; -if ((rc = pcre_fullinfo(code, NULL, PCRE_INFO_NAMETABLE, &nametable)) != 0) - return rc; - -lastentry = nametable + entrysize * (top - 1); -bot = 0; -while (top > bot) - { - int mid = (top + bot) / 2; - uschar *entry = nametable + entrysize*mid; - int c = strcmp(stringname, (char *)(entry + 2)); - if (c == 0) - { - uschar *first = entry; - uschar *last = entry; - while (first > nametable) - { - if (strcmp(stringname, (char *)(first - entrysize + 2)) != 0) break; - first -= entrysize; - } - while (last < lastentry) - { - if (strcmp(stringname, (char *)(last + entrysize + 2)) != 0) break; - last += entrysize; - } - *firstptr = (char *)first; - *lastptr = (char *)last; - return entrysize; - } - if (c > 0) bot = mid + 1; else top = mid; - } - -return PCRE_ERROR_NOSUBSTRING; -} - - - -/************************************************* -* Find first set of multiple named strings * -*************************************************/ - -/* This function allows for duplicate names in the table of named substrings. -It returns the number of the first one that was set in a pattern match. - -Arguments: - code the compiled regex - stringname the name of the capturing substring - ovector the vector of matched substrings - -Returns: the number of the first that is set, - or the number of the last one if none are set, - or a negative number on error -*/ - -static int -get_first_set(const pcre *code, const char *stringname, int *ovector) -{ -const real_pcre *re = (const real_pcre *)code; -int entrysize; -char *first, *last; -uschar *entry; -if ((re->options & PCRE_DUPNAMES) == 0 && (re->flags & PCRE_JCHANGED) == 0) - return pcre_get_stringnumber(code, stringname); -entrysize = pcre_get_stringtable_entries(code, stringname, &first, &last); -if (entrysize <= 0) return entrysize; -for (entry = (uschar *)first; entry <= (uschar *)last; entry += entrysize) - { - int n = (entry[0] << 8) + entry[1]; - if (ovector[n*2] >= 0) return n; - } -return (first[0] << 8) + first[1]; -} - - - - -/************************************************* -* Copy captured string to given buffer * -*************************************************/ - -/* This function copies a single captured substring into a given buffer. -Note that we use memcpy() rather than strncpy() in case there are binary zeros -in the string. - -Arguments: - subject the subject string that was matched - ovector pointer to the offsets table - stringcount the number of substrings that were captured - (i.e. the yield of the pcre_exec call, unless - that was zero, in which case it should be 1/3 - of the offset table size) - stringnumber the number of the required substring - buffer where to put the substring - size the size of the buffer - -Returns: if successful: - the length of the copied string, not including the zero - that is put on the end; can be zero - if not successful: - PCRE_ERROR_NOMEMORY (-6) buffer too small - PCRE_ERROR_NOSUBSTRING (-7) no such captured substring -*/ - -int -pcre_copy_substring(const char *subject, int *ovector, int stringcount, - int stringnumber, char *buffer, int size) -{ -int yield; -if (stringnumber < 0 || stringnumber >= stringcount) - return PCRE_ERROR_NOSUBSTRING; -stringnumber *= 2; -yield = ovector[stringnumber+1] - ovector[stringnumber]; -if (size < yield + 1) return PCRE_ERROR_NOMEMORY; -memcpy(buffer, subject + ovector[stringnumber], yield); -buffer[yield] = 0; -return yield; -} - - - -/************************************************* -* Copy named captured string to given buffer * -*************************************************/ - -/* This function copies a single captured substring into a given buffer, -identifying it by name. If the regex permits duplicate names, the first -substring that is set is chosen. - -Arguments: - code the compiled regex - subject the subject string that was matched - ovector pointer to the offsets table - stringcount the number of substrings that were captured - (i.e. the yield of the pcre_exec call, unless - that was zero, in which case it should be 1/3 - of the offset table size) - stringname the name of the required substring - buffer where to put the substring - size the size of the buffer - -Returns: if successful: - the length of the copied string, not including the zero - that is put on the end; can be zero - if not successful: - PCRE_ERROR_NOMEMORY (-6) buffer too small - PCRE_ERROR_NOSUBSTRING (-7) no such captured substring -*/ - -int -pcre_copy_named_substring(const pcre *code, const char *subject, int *ovector, - int stringcount, const char *stringname, char *buffer, int size) -{ -int n = get_first_set(code, stringname, ovector); -if (n <= 0) return n; -return pcre_copy_substring(subject, ovector, stringcount, n, buffer, size); -} - - - -/************************************************* -* Copy all captured strings to new store * -*************************************************/ - -/* This function gets one chunk of store and builds a list of pointers and all -of the captured substrings in it. A NULL pointer is put on the end of the list. - -Arguments: - subject the subject string that was matched - ovector pointer to the offsets table - stringcount the number of substrings that were captured - (i.e. the yield of the pcre_exec call, unless - that was zero, in which case it should be 1/3 - of the offset table size) - listptr set to point to the list of pointers - -Returns: if successful: 0 - if not successful: - PCRE_ERROR_NOMEMORY (-6) failed to get store -*/ - -int -pcre_get_substring_list(const char *subject, int *ovector, int stringcount, - const char ***listptr) -{ -int i; -int size = sizeof(char *); -int double_count = stringcount * 2; -char **stringlist; -char *p; - -for (i = 0; i < double_count; i += 2) - size += sizeof(char *) + ovector[i+1] - ovector[i] + 1; - -stringlist = (char **)(pcre_malloc)(size); -if (stringlist == NULL) return PCRE_ERROR_NOMEMORY; - -*listptr = (const char **)stringlist; -p = (char *)(stringlist + stringcount + 1); - -for (i = 0; i < double_count; i += 2) - { - int len = ovector[i+1] - ovector[i]; - memcpy(p, subject + ovector[i], len); - *stringlist++ = p; - p += len; - *p++ = 0; - } - -*stringlist = NULL; -return 0; -} - - - -/************************************************* -* Free store obtained by get_substring_list * -*************************************************/ - -/* This function exists for the benefit of people calling PCRE from non-C -programs that can call its functions, but not free() or (pcre_free)() directly. - -Argument: the result of a previous pcre_get_substring_list() -Returns: nothing -*/ - -void -pcre_free_substring_list(const char **pointer) -{ -(pcre_free)((void *)pointer); -} - - - -/************************************************* -* Copy captured string to new store * -*************************************************/ - -/* This function copies a single captured substring into a piece of new -store - -Arguments: - subject the subject string that was matched - ovector pointer to the offsets table - stringcount the number of substrings that were captured - (i.e. the yield of the pcre_exec call, unless - that was zero, in which case it should be 1/3 - of the offset table size) - stringnumber the number of the required substring - stringptr where to put a pointer to the substring - -Returns: if successful: - the length of the string, not including the zero that - is put on the end; can be zero - if not successful: - PCRE_ERROR_NOMEMORY (-6) failed to get store - PCRE_ERROR_NOSUBSTRING (-7) substring not present -*/ - -int -pcre_get_substring(const char *subject, int *ovector, int stringcount, - int stringnumber, const char **stringptr) -{ -int yield; -char *substring; -if (stringnumber < 0 || stringnumber >= stringcount) - return PCRE_ERROR_NOSUBSTRING; -stringnumber *= 2; -yield = ovector[stringnumber+1] - ovector[stringnumber]; -substring = (char *)(pcre_malloc)(yield + 1); -if (substring == NULL) return PCRE_ERROR_NOMEMORY; -memcpy(substring, subject + ovector[stringnumber], yield); -substring[yield] = 0; -*stringptr = substring; -return yield; -} - - - -/************************************************* -* Copy named captured string to new store * -*************************************************/ - -/* This function copies a single captured substring, identified by name, into -new store. If the regex permits duplicate names, the first substring that is -set is chosen. - -Arguments: - code the compiled regex - subject the subject string that was matched - ovector pointer to the offsets table - stringcount the number of substrings that were captured - (i.e. the yield of the pcre_exec call, unless - that was zero, in which case it should be 1/3 - of the offset table size) - stringname the name of the required substring - stringptr where to put the pointer - -Returns: if successful: - the length of the copied string, not including the zero - that is put on the end; can be zero - if not successful: - PCRE_ERROR_NOMEMORY (-6) couldn't get memory - PCRE_ERROR_NOSUBSTRING (-7) no such captured substring -*/ - -int -pcre_get_named_substring(const pcre *code, const char *subject, int *ovector, - int stringcount, const char *stringname, const char **stringptr) -{ -int n = get_first_set(code, stringname, ovector); -if (n <= 0) return n; -return pcre_get_substring(subject, ovector, stringcount, n, stringptr); -} - - - - -/************************************************* -* Free store obtained by get_substring * -*************************************************/ - -/* This function exists for the benefit of people calling PCRE from non-C -programs that can call its functions, but not free() or (pcre_free)() directly. - -Argument: the result of a previous pcre_get_substring() -Returns: nothing -*/ - -void -pcre_free_substring(const char *pointer) -{ -(pcre_free)((void *)pointer); -} - -/* End of pcre_get.c */ diff --git a/src/plugins/PCREPlugin/pcre_globals.c b/src/plugins/PCREPlugin/pcre_globals.c deleted file mode 100644 index 4794819..0000000 --- a/src/plugins/PCREPlugin/pcre_globals.c +++ /dev/null @@ -1,63 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains global variables that are exported by the PCRE library. -PCRE is thread-clean and doesn't use any global variables in the normal sense. -However, it calls memory allocation and freeing functions via the four -indirections below, and it can optionally do callouts, using the fifth -indirection. These values can be changed by the caller, but are shared between -all threads. However, when compiling for Virtual Pascal, things are done -differently, and global variables are not used (see pcre.in). */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - -#ifndef VPCOMPAT -PCRE_EXP_DATA_DEFN void *(*pcre_malloc)(size_t) = malloc; -PCRE_EXP_DATA_DEFN void (*pcre_free)(void *) = free; -PCRE_EXP_DATA_DEFN void *(*pcre_stack_malloc)(size_t) = malloc; -PCRE_EXP_DATA_DEFN void (*pcre_stack_free)(void *) = free; -PCRE_EXP_DATA_DEFN int (*pcre_callout)(pcre_callout_block *) = NULL; -#endif - -/* End of pcre_globals.c */ diff --git a/src/plugins/PCREPlugin/pcre_info.c b/src/plugins/PCREPlugin/pcre_info.c deleted file mode 100644 index 9bcccbc..0000000 --- a/src/plugins/PCREPlugin/pcre_info.c +++ /dev/null @@ -1,93 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_info(), which gives some -information about a compiled pattern. However, use of this function is now -deprecated, as it has been superseded by pcre_fullinfo(). */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* (Obsolete) Return info about compiled pattern * -*************************************************/ - -/* This is the original "info" function. It picks potentially useful data out -of the private structure, but its interface was too rigid. It remains for -backwards compatibility. The public options are passed back in an int - though -the re->options field has been expanded to a long int, all the public options -at the low end of it, and so even on 16-bit systems this will still be OK. -Therefore, I haven't changed the API for pcre_info(). - -Arguments: - argument_re points to compiled code - optptr where to pass back the options - first_byte where to pass back the first character, - or -1 if multiline and all branches start ^, - or -2 otherwise - -Returns: number of capturing subpatterns - or negative values on error -*/ - -PCRE_EXP_DEFN int -pcre_info(const pcre *argument_re, int *optptr, int *first_byte) -{ -real_pcre internal_re; -const real_pcre *re = (const real_pcre *)argument_re; -if (re == NULL) return PCRE_ERROR_NULL; -if (re->magic_number != MAGIC_NUMBER) - { - re = _pcre_try_flipped(re, &internal_re, NULL, NULL); - if (re == NULL) return PCRE_ERROR_BADMAGIC; - } -if (optptr != NULL) *optptr = (int)(re->options & PUBLIC_OPTIONS); -if (first_byte != NULL) - *first_byte = ((re->flags & PCRE_FIRSTSET) != 0)? re->first_byte : - ((re->flags & PCRE_STARTLINE) != 0)? -1 : -2; -return re->top_bracket; -} - -/* End of pcre_info.c */ diff --git a/src/plugins/PCREPlugin/pcre_internal.h b/src/plugins/PCREPlugin/pcre_internal.h deleted file mode 100644 index 1d691c3..0000000 --- a/src/plugins/PCREPlugin/pcre_internal.h +++ /dev/null @@ -1,1118 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -#include "config.h" - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - -/* This header contains definitions that are shared between the different -modules, but which are not relevant to the exported API. This includes some -functions whose names all begin with "_pcre_". */ - -#ifndef PCRE_INTERNAL_H -#define PCRE_INTERNAL_H - -/* Define DEBUG to get debugging output on stdout. */ - -#if 0 -#define DEBUG -#endif - -/* Use a macro for debugging printing, 'cause that eliminates the use of #ifdef -inline, and there are *still* stupid compilers about that don't like indented -pre-processor statements, or at least there were when I first wrote this. After -all, it had only been about 10 years then... - -It turns out that the Mac Debugging.h header also defines the macro DPRINTF, so -be absolutely sure we get our version. */ - -#undef DPRINTF -#ifdef DEBUG -#define DPRINTF(p) printf p -#else -#define DPRINTF(p) /* Nothing */ -#endif - - -/* Standard C headers plus the external interface definition. The only time -setjmp and stdarg are used is when NO_RECURSE is set. */ - -#include -#include -#include -#include -#include -#include -#include -#include - -/* When compiling a DLL for Windows, the exported symbols have to be declared -using some MS magic. I found some useful information on this web page: -http://msdn2.microsoft.com/en-us/library/y4h7bcy6(VS.80).aspx. According to the -information there, using __declspec(dllexport) without "extern" we have a -definition; with "extern" we have a declaration. The settings here override the -setting in pcre.h (which is included below); it defines only PCRE_EXP_DECL, -which is all that is needed for applications (they just import the symbols). We -use: - - PCRE_EXP_DECL for declarations - PCRE_EXP_DEFN for definitions of exported functions - PCRE_EXP_DATA_DEFN for definitions of exported variables - -The reason for the two DEFN macros is that in non-Windows environments, one -does not want to have "extern" before variable definitions because it leads to -compiler warnings. So we distinguish between functions and variables. In -Windows, the two should always be the same. - -The reason for wrapping this in #ifndef PCRE_EXP_DECL is so that pcretest, -which is an application, but needs to import this file in order to "peek" at -internals, can #include pcre.h first to get an application's-eye view. - -In principle, people compiling for non-Windows, non-Unix-like (i.e. uncommon, -special-purpose environments) might want to stick other stuff in front of -exported symbols. That's why, in the non-Windows case, we set PCRE_EXP_DEFN and -PCRE_EXP_DATA_DEFN only if they are not already set. */ - -#ifndef PCRE_EXP_DECL -# ifdef _WIN32 -# ifndef PCRE_STATIC -# define PCRE_EXP_DECL extern __declspec(dllexport) -# define PCRE_EXP_DEFN __declspec(dllexport) -# define PCRE_EXP_DATA_DEFN __declspec(dllexport) -# else -# define PCRE_EXP_DECL extern -# define PCRE_EXP_DEFN -# define PCRE_EXP_DATA_DEFN -# endif -# else -# ifdef __cplusplus -# define PCRE_EXP_DECL extern "C" -# else -# define PCRE_EXP_DECL extern -# endif -# ifndef PCRE_EXP_DEFN -# define PCRE_EXP_DEFN PCRE_EXP_DECL -# endif -# ifndef PCRE_EXP_DATA_DEFN -# define PCRE_EXP_DATA_DEFN -# endif -# endif -#endif - -/* We need to have types that specify unsigned 16-bit and 32-bit integers. We -cannot determine these outside the compilation (e.g. by running a program as -part of "configure") because PCRE is often cross-compiled for use on other -systems. Instead we make use of the maximum sizes that are available at -preprocessor time in standard C environments. */ - -#if USHRT_MAX == 65535 - typedef unsigned short pcre_uint16; -#elif UINT_MAX == 65535 - typedef unsigned int pcre_uint16; -#else - #error Cannot determine a type for 16-bit unsigned integers -#endif - -#if UINT_MAX == 4294967295 - typedef unsigned int pcre_uint32; -#elif ULONG_MAX == 4294967295 - typedef unsigned long int pcre_uint32; -#else - #error Cannot determine a type for 32-bit unsigned integers -#endif - -/* All character handling must be done as unsigned characters. Otherwise there -are problems with top-bit-set characters and functions such as isspace(). -However, we leave the interface to the outside world as char *, because that -should make things easier for callers. We define a short type for unsigned char -to save lots of typing. I tried "uchar", but it causes problems on Digital -Unix, where it is defined in sys/types, so use "uschar" instead. */ - -typedef unsigned char uschar; - -/* This is an unsigned int value that no character can ever have. UTF-8 -characters only go up to 0x7fffffff (though Unicode doesn't go beyond -0x0010ffff). */ - -#define NOTACHAR 0xffffffff - -/* PCRE is able to support several different kinds of newline (CR, LF, CRLF, -"any" and "anycrlf" at present). The following macros are used to package up -testing for newlines. NLBLOCK, PSSTART, and PSEND are defined in the various -modules to indicate in which datablock the parameters exist, and what the -start/end of string field names are. */ - -#define NLTYPE_FIXED 0 /* Newline is a fixed length string */ -#define NLTYPE_ANY 1 /* Newline is any Unicode line ending */ -#define NLTYPE_ANYCRLF 2 /* Newline is CR, LF, or CRLF */ - -/* This macro checks for a newline at the given position */ - -#define IS_NEWLINE(p) \ - ((NLBLOCK->nltype != NLTYPE_FIXED)? \ - ((p) < NLBLOCK->PSEND && \ - _pcre_is_newline((p), NLBLOCK->nltype, NLBLOCK->PSEND, &(NLBLOCK->nllen),\ - utf8)) \ - : \ - ((p) <= NLBLOCK->PSEND - NLBLOCK->nllen && \ - (p)[0] == NLBLOCK->nl[0] && \ - (NLBLOCK->nllen == 1 || (p)[1] == NLBLOCK->nl[1]) \ - ) \ - ) - -/* This macro checks for a newline immediately preceding the given position */ - -#define WAS_NEWLINE(p) \ - ((NLBLOCK->nltype != NLTYPE_FIXED)? \ - ((p) > NLBLOCK->PSSTART && \ - _pcre_was_newline((p), NLBLOCK->nltype, NLBLOCK->PSSTART, \ - &(NLBLOCK->nllen), utf8)) \ - : \ - ((p) >= NLBLOCK->PSSTART + NLBLOCK->nllen && \ - (p)[-NLBLOCK->nllen] == NLBLOCK->nl[0] && \ - (NLBLOCK->nllen == 1 || (p)[-NLBLOCK->nllen+1] == NLBLOCK->nl[1]) \ - ) \ - ) - -/* When PCRE is compiled as a C++ library, the subject pointer can be replaced -with a custom type. This makes it possible, for example, to allow pcre_exec() -to process subject strings that are discontinuous by using a smart pointer -class. It must always be possible to inspect all of the subject string in -pcre_exec() because of the way it backtracks. Two macros are required in the -normal case, for sign-unspecified and unsigned char pointers. The former is -used for the external interface and appears in pcre.h, which is why its name -must begin with PCRE_. */ - -#ifdef CUSTOM_SUBJECT_PTR -#define PCRE_SPTR CUSTOM_SUBJECT_PTR -#define USPTR CUSTOM_SUBJECT_PTR -#else -#define PCRE_SPTR const char * -#define USPTR const unsigned char * -#endif - - - -/* Include the public PCRE header and the definitions of UCP character property -values. */ - -#include "pcre.h" -#include "ucp.h" - -/* When compiling for use with the Virtual Pascal compiler, these functions -need to have their names changed. PCRE must be compiled with the -DVPCOMPAT -option on the command line. */ - -#ifdef VPCOMPAT -#define strlen(s) _strlen(s) -#define strncmp(s1,s2,m) _strncmp(s1,s2,m) -#define memcmp(s,c,n) _memcmp(s,c,n) -#define memcpy(d,s,n) _memcpy(d,s,n) -#define memmove(d,s,n) _memmove(d,s,n) -#define memset(s,c,n) _memset(s,c,n) -#else /* VPCOMPAT */ - -/* To cope with SunOS4 and other systems that lack memmove() but have bcopy(), -define a macro for memmove() if HAVE_MEMMOVE is false, provided that HAVE_BCOPY -is set. Otherwise, include an emulating function for those systems that have -neither (there some non-Unix environments where this is the case). */ - -#ifndef HAVE_MEMMOVE -#undef memmove /* some systems may have a macro */ -#ifdef HAVE_BCOPY -#define memmove(a, b, c) bcopy(b, a, c) -#else /* HAVE_BCOPY */ -static void * -pcre_memmove(void *d, const void *s, size_t n) -{ -size_t i; -unsigned char *dest = (unsigned char *)d; -const unsigned char *src = (const unsigned char *)s; -if (dest > src) - { - dest += n; - src += n; - for (i = 0; i < n; ++i) *(--dest) = *(--src); - return (void *)dest; - } -else - { - for (i = 0; i < n; ++i) *dest++ = *src++; - return (void *)(dest - n); - } -} -#define memmove(a, b, c) pcre_memmove(a, b, c) -#endif /* not HAVE_BCOPY */ -#endif /* not HAVE_MEMMOVE */ -#endif /* not VPCOMPAT */ - - -/* PCRE keeps offsets in its compiled code as 2-byte quantities (always stored -in big-endian order) by default. These are used, for example, to link from the -start of a subpattern to its alternatives and its end. The use of 2 bytes per -offset limits the size of the compiled regex to around 64K, which is big enough -for almost everybody. However, I received a request for an even bigger limit. -For this reason, and also to make the code easier to maintain, the storing and -loading of offsets from the byte string is now handled by the macros that are -defined here. - -The macros are controlled by the value of LINK_SIZE. This defaults to 2 in -the config.h file, but can be overridden by using -D on the command line. This -is automated on Unix systems via the "configure" command. */ - -#if LINK_SIZE == 2 - -#define PUT(a,n,d) \ - (a[n] = (d) >> 8), \ - (a[(n)+1] = (d) & 255) - -#define GET(a,n) \ - (((a)[n] << 8) | (a)[(n)+1]) - -#define MAX_PATTERN_SIZE (1 << 16) - - -#elif LINK_SIZE == 3 - -#define PUT(a,n,d) \ - (a[n] = (d) >> 16), \ - (a[(n)+1] = (d) >> 8), \ - (a[(n)+2] = (d) & 255) - -#define GET(a,n) \ - (((a)[n] << 16) | ((a)[(n)+1] << 8) | (a)[(n)+2]) - -#define MAX_PATTERN_SIZE (1 << 24) - - -#elif LINK_SIZE == 4 - -#define PUT(a,n,d) \ - (a[n] = (d) >> 24), \ - (a[(n)+1] = (d) >> 16), \ - (a[(n)+2] = (d) >> 8), \ - (a[(n)+3] = (d) & 255) - -#define GET(a,n) \ - (((a)[n] << 24) | ((a)[(n)+1] << 16) | ((a)[(n)+2] << 8) | (a)[(n)+3]) - -#define MAX_PATTERN_SIZE (1 << 30) /* Keep it positive */ - - -#else -#error LINK_SIZE must be either 2, 3, or 4 -#endif - - -/* Convenience macro defined in terms of the others */ - -#define PUTINC(a,n,d) PUT(a,n,d), a += LINK_SIZE - - -/* PCRE uses some other 2-byte quantities that do not change when the size of -offsets changes. There are used for repeat counts and for other things such as -capturing parenthesis numbers in back references. */ - -#define PUT2(a,n,d) \ - a[n] = (d) >> 8; \ - a[(n)+1] = (d) & 255 - -#define GET2(a,n) \ - (((a)[n] << 8) | (a)[(n)+1]) - -#define PUT2INC(a,n,d) PUT2(a,n,d), a += 2 - - -/* When UTF-8 encoding is being used, a character is no longer just a single -byte. The macros for character handling generate simple sequences when used in -byte-mode, and more complicated ones for UTF-8 characters. BACKCHAR should -never be called in byte mode. To make sure it can never even appear when UTF-8 -support is omitted, we don't even define it. */ - -#ifndef SUPPORT_UTF8 -#define GETCHAR(c, eptr) c = *eptr; -#define GETCHARTEST(c, eptr) c = *eptr; -#define GETCHARINC(c, eptr) c = *eptr++; -#define GETCHARINCTEST(c, eptr) c = *eptr++; -#define GETCHARLEN(c, eptr, len) c = *eptr; -/* #define BACKCHAR(eptr) */ - -#else /* SUPPORT_UTF8 */ - -/* Get the next UTF-8 character, not advancing the pointer. This is called when -we know we are in UTF-8 mode. */ - -#define GETCHAR(c, eptr) \ - c = *eptr; \ - if (c >= 0xc0) \ - { \ - int gcii; \ - int gcaa = _pcre_utf8_table4[c & 0x3f]; /* Number of additional bytes */ \ - int gcss = 6*gcaa; \ - c = (c & _pcre_utf8_table3[gcaa]) << gcss; \ - for (gcii = 1; gcii <= gcaa; gcii++) \ - { \ - gcss -= 6; \ - c |= (eptr[gcii] & 0x3f) << gcss; \ - } \ - } - -/* Get the next UTF-8 character, testing for UTF-8 mode, and not advancing the -pointer. */ - -#define GETCHARTEST(c, eptr) \ - c = *eptr; \ - if (utf8 && c >= 0xc0) \ - { \ - int gcii; \ - int gcaa = _pcre_utf8_table4[c & 0x3f]; /* Number of additional bytes */ \ - int gcss = 6*gcaa; \ - c = (c & _pcre_utf8_table3[gcaa]) << gcss; \ - for (gcii = 1; gcii <= gcaa; gcii++) \ - { \ - gcss -= 6; \ - c |= (eptr[gcii] & 0x3f) << gcss; \ - } \ - } - -/* Get the next UTF-8 character, advancing the pointer. This is called when we -know we are in UTF-8 mode. */ - -#define GETCHARINC(c, eptr) \ - c = *eptr++; \ - if (c >= 0xc0) \ - { \ - int gcaa = _pcre_utf8_table4[c & 0x3f]; /* Number of additional bytes */ \ - int gcss = 6*gcaa; \ - c = (c & _pcre_utf8_table3[gcaa]) << gcss; \ - while (gcaa-- > 0) \ - { \ - gcss -= 6; \ - c |= (*eptr++ & 0x3f) << gcss; \ - } \ - } - -/* Get the next character, testing for UTF-8 mode, and advancing the pointer */ - -#define GETCHARINCTEST(c, eptr) \ - c = *eptr++; \ - if (utf8 && c >= 0xc0) \ - { \ - int gcaa = _pcre_utf8_table4[c & 0x3f]; /* Number of additional bytes */ \ - int gcss = 6*gcaa; \ - c = (c & _pcre_utf8_table3[gcaa]) << gcss; \ - while (gcaa-- > 0) \ - { \ - gcss -= 6; \ - c |= (*eptr++ & 0x3f) << gcss; \ - } \ - } - -/* Get the next UTF-8 character, not advancing the pointer, incrementing length -if there are extra bytes. This is called when we know we are in UTF-8 mode. */ - -#define GETCHARLEN(c, eptr, len) \ - c = *eptr; \ - if (c >= 0xc0) \ - { \ - int gcii; \ - int gcaa = _pcre_utf8_table4[c & 0x3f]; /* Number of additional bytes */ \ - int gcss = 6*gcaa; \ - c = (c & _pcre_utf8_table3[gcaa]) << gcss; \ - for (gcii = 1; gcii <= gcaa; gcii++) \ - { \ - gcss -= 6; \ - c |= (eptr[gcii] & 0x3f) << gcss; \ - } \ - len += gcaa; \ - } - -/* If the pointer is not at the start of a character, move it back until -it is. This is called only in UTF-8 mode - we don't put a test within the macro -because almost all calls are already within a block of UTF-8 only code. */ - -#define BACKCHAR(eptr) while((*eptr & 0xc0) == 0x80) eptr-- - -#endif - - -/* In case there is no definition of offsetof() provided - though any proper -Standard C system should have one. */ - -#ifndef offsetof -#define offsetof(p_type,field) ((size_t)&(((p_type *)0)->field)) -#endif - - -/* These are the public options that can change during matching. */ - -#define PCRE_IMS (PCRE_CASELESS|PCRE_MULTILINE|PCRE_DOTALL) - -/* Private flags containing information about the compiled regex. They used to -live at the top end of the options word, but that got almost full, so now they -are in a 16-bit flags word. */ - -#define PCRE_NOPARTIAL 0x0001 /* can't use partial with this regex */ -#define PCRE_FIRSTSET 0x0002 /* first_byte is set */ -#define PCRE_REQCHSET 0x0004 /* req_byte is set */ -#define PCRE_STARTLINE 0x0008 /* start after \n for multiline */ -#define PCRE_JCHANGED 0x0010 /* j option used in regex */ -#define PCRE_HASCRORLF 0x0020 /* explicit \r or \n in pattern */ - -/* Options for the "extra" block produced by pcre_study(). */ - -#define PCRE_STUDY_MAPPED 0x01 /* a map of starting chars exists */ - -/* Masks for identifying the public options that are permitted at compile -time, run time, or study time, respectively. */ - -#define PCRE_NEWLINE_BITS (PCRE_NEWLINE_CR|PCRE_NEWLINE_LF|PCRE_NEWLINE_ANY| \ - PCRE_NEWLINE_ANYCRLF) - -#define PUBLIC_OPTIONS \ - (PCRE_CASELESS|PCRE_EXTENDED|PCRE_ANCHORED|PCRE_MULTILINE| \ - PCRE_DOTALL|PCRE_DOLLAR_ENDONLY|PCRE_EXTRA|PCRE_UNGREEDY|PCRE_UTF8| \ - PCRE_NO_AUTO_CAPTURE|PCRE_NO_UTF8_CHECK|PCRE_AUTO_CALLOUT|PCRE_FIRSTLINE| \ - PCRE_DUPNAMES|PCRE_NEWLINE_BITS|PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE) - -#define PUBLIC_EXEC_OPTIONS \ - (PCRE_ANCHORED|PCRE_NOTBOL|PCRE_NOTEOL|PCRE_NOTEMPTY|PCRE_NO_UTF8_CHECK| \ - PCRE_PARTIAL|PCRE_NEWLINE_BITS|PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE) - -#define PUBLIC_DFA_EXEC_OPTIONS \ - (PCRE_ANCHORED|PCRE_NOTBOL|PCRE_NOTEOL|PCRE_NOTEMPTY|PCRE_NO_UTF8_CHECK| \ - PCRE_PARTIAL|PCRE_DFA_SHORTEST|PCRE_DFA_RESTART|PCRE_NEWLINE_BITS| \ - PCRE_BSR_ANYCRLF|PCRE_BSR_UNICODE) - -#define PUBLIC_STUDY_OPTIONS 0 /* None defined */ - -/* Magic number to provide a small check against being handed junk. Also used -to detect whether a pattern was compiled on a host of different endianness. */ - -#define MAGIC_NUMBER 0x50435245UL /* 'PCRE' */ - -/* Negative values for the firstchar and reqchar variables */ - -#define REQ_UNSET (-2) -#define REQ_NONE (-1) - -/* The maximum remaining length of subject we are prepared to search for a -req_byte match. */ - -#define REQ_BYTE_MAX 1000 - -/* Flags added to firstbyte or reqbyte; a "non-literal" item is either a -variable-length repeat, or a anything other than literal characters. */ - -#define REQ_CASELESS 0x0100 /* indicates caselessness */ -#define REQ_VARY 0x0200 /* reqbyte followed non-literal item */ - -/* Miscellaneous definitions */ - -typedef int BOOL; - -#define FALSE 0 -#define TRUE 1 - -/* Escape items that are just an encoding of a particular data value. */ - -#ifndef ESC_e -#define ESC_e 27 -#endif - -#ifndef ESC_f -#define ESC_f '\f' -#endif - -#ifndef ESC_n -#define ESC_n '\n' -#endif - -#ifndef ESC_r -#define ESC_r '\r' -#endif - -/* We can't officially use ESC_t because it is a POSIX reserved identifier -(presumably because of all the others like size_t). */ - -#ifndef ESC_tee -#define ESC_tee '\t' -#endif - -/* Codes for different types of Unicode property */ - -#define PT_ANY 0 /* Any property - matches all chars */ -#define PT_LAMP 1 /* L& - the union of Lu, Ll, Lt */ -#define PT_GC 2 /* General characteristic (e.g. L) */ -#define PT_PC 3 /* Particular characteristic (e.g. Lu) */ -#define PT_SC 4 /* Script (e.g. Han) */ - -/* Flag bits and data types for the extended class (OP_XCLASS) for classes that -contain UTF-8 characters with values greater than 255. */ - -#define XCL_NOT 0x01 /* Flag: this is a negative class */ -#define XCL_MAP 0x02 /* Flag: a 32-byte map is present */ - -#define XCL_END 0 /* Marks end of individual items */ -#define XCL_SINGLE 1 /* Single item (one multibyte char) follows */ -#define XCL_RANGE 2 /* A range (two multibyte chars) follows */ -#define XCL_PROP 3 /* Unicode property (2-byte property code follows) */ -#define XCL_NOTPROP 4 /* Unicode inverted property (ditto) */ - -/* These are escaped items that aren't just an encoding of a particular data -value such as \n. They must have non-zero values, as check_escape() returns -their negation. Also, they must appear in the same order as in the opcode -definitions below, up to ESC_z. There's a dummy for OP_ANY because it -corresponds to "." rather than an escape sequence. The final one must be -ESC_REF as subsequent values are used for backreferences (\1, \2, \3, etc). -There are two tests in the code for an escape greater than ESC_b and less than -ESC_Z to detect the types that may be repeated. These are the types that -consume characters. If any new escapes are put in between that don't consume a -character, that code will have to change. */ - -enum { ESC_A = 1, ESC_G, ESC_K, ESC_B, ESC_b, ESC_D, ESC_d, ESC_S, ESC_s, - ESC_W, ESC_w, ESC_dum1, ESC_C, ESC_P, ESC_p, ESC_R, ESC_H, ESC_h, - ESC_V, ESC_v, ESC_X, ESC_Z, ESC_z, ESC_E, ESC_Q, ESC_k, ESC_REF }; - - -/* Opcode table: Starting from 1 (i.e. after OP_END), the values up to -OP_EOD must correspond in order to the list of escapes immediately above. - -*** NOTE NOTE NOTE *** Whenever this list is updated, the two macro definitions -that follow must also be updated to match. There is also a table called -"coptable" in pcre_dfa_exec.c that must be updated. */ - -enum { - OP_END, /* 0 End of pattern */ - - /* Values corresponding to backslashed metacharacters */ - - OP_SOD, /* 1 Start of data: \A */ - OP_SOM, /* 2 Start of match (subject + offset): \G */ - OP_SET_SOM, /* 3 Set start of match (\K) */ - OP_NOT_WORD_BOUNDARY, /* 4 \B */ - OP_WORD_BOUNDARY, /* 5 \b */ - OP_NOT_DIGIT, /* 6 \D */ - OP_DIGIT, /* 7 \d */ - OP_NOT_WHITESPACE, /* 8 \S */ - OP_WHITESPACE, /* 9 \s */ - OP_NOT_WORDCHAR, /* 10 \W */ - OP_WORDCHAR, /* 11 \w */ - OP_ANY, /* 12 Match any character */ - OP_ANYBYTE, /* 13 Match any byte (\C); different to OP_ANY for UTF-8 */ - OP_NOTPROP, /* 14 \P (not Unicode property) */ - OP_PROP, /* 15 \p (Unicode property) */ - OP_ANYNL, /* 16 \R (any newline sequence) */ - OP_NOT_HSPACE, /* 17 \H (not horizontal whitespace) */ - OP_HSPACE, /* 18 \h (horizontal whitespace) */ - OP_NOT_VSPACE, /* 19 \V (not vertical whitespace) */ - OP_VSPACE, /* 20 \v (vertical whitespace) */ - OP_EXTUNI, /* 21 \X (extended Unicode sequence */ - OP_EODN, /* 22 End of data or \n at end of data: \Z. */ - OP_EOD, /* 23 End of data: \z */ - - OP_OPT, /* 24 Set runtime options */ - OP_CIRC, /* 25 Start of line - varies with multiline switch */ - OP_DOLL, /* 26 End of line - varies with multiline switch */ - OP_CHAR, /* 27 Match one character, casefully */ - OP_CHARNC, /* 28 Match one character, caselessly */ - OP_NOT, /* 29 Match one character, not the following one */ - - OP_STAR, /* 30 The maximizing and minimizing versions of */ - OP_MINSTAR, /* 31 these six opcodes must come in pairs, with */ - OP_PLUS, /* 32 the minimizing one second. */ - OP_MINPLUS, /* 33 This first set applies to single characters.*/ - OP_QUERY, /* 34 */ - OP_MINQUERY, /* 35 */ - - OP_UPTO, /* 36 From 0 to n matches */ - OP_MINUPTO, /* 37 */ - OP_EXACT, /* 38 Exactly n matches */ - - OP_POSSTAR, /* 39 Possessified star */ - OP_POSPLUS, /* 40 Possessified plus */ - OP_POSQUERY, /* 41 Posesssified query */ - OP_POSUPTO, /* 42 Possessified upto */ - - OP_NOTSTAR, /* 43 The maximizing and minimizing versions of */ - OP_NOTMINSTAR, /* 44 these six opcodes must come in pairs, with */ - OP_NOTPLUS, /* 45 the minimizing one second. They must be in */ - OP_NOTMINPLUS, /* 46 exactly the same order as those above. */ - OP_NOTQUERY, /* 47 This set applies to "not" single characters. */ - OP_NOTMINQUERY, /* 48 */ - - OP_NOTUPTO, /* 49 From 0 to n matches */ - OP_NOTMINUPTO, /* 50 */ - OP_NOTEXACT, /* 51 Exactly n matches */ - - OP_NOTPOSSTAR, /* 52 Possessified versions */ - OP_NOTPOSPLUS, /* 53 */ - OP_NOTPOSQUERY, /* 54 */ - OP_NOTPOSUPTO, /* 55 */ - - OP_TYPESTAR, /* 56 The maximizing and minimizing versions of */ - OP_TYPEMINSTAR, /* 57 these six opcodes must come in pairs, with */ - OP_TYPEPLUS, /* 58 the minimizing one second. These codes must */ - OP_TYPEMINPLUS, /* 59 be in exactly the same order as those above. */ - OP_TYPEQUERY, /* 60 This set applies to character types such as \d */ - OP_TYPEMINQUERY, /* 61 */ - - OP_TYPEUPTO, /* 62 From 0 to n matches */ - OP_TYPEMINUPTO, /* 63 */ - OP_TYPEEXACT, /* 64 Exactly n matches */ - - OP_TYPEPOSSTAR, /* 65 Possessified versions */ - OP_TYPEPOSPLUS, /* 66 */ - OP_TYPEPOSQUERY, /* 67 */ - OP_TYPEPOSUPTO, /* 68 */ - - OP_CRSTAR, /* 69 The maximizing and minimizing versions of */ - OP_CRMINSTAR, /* 70 all these opcodes must come in pairs, with */ - OP_CRPLUS, /* 71 the minimizing one second. These codes must */ - OP_CRMINPLUS, /* 72 be in exactly the same order as those above. */ - OP_CRQUERY, /* 73 These are for character classes and back refs */ - OP_CRMINQUERY, /* 74 */ - OP_CRRANGE, /* 75 These are different to the three sets above. */ - OP_CRMINRANGE, /* 76 */ - - OP_CLASS, /* 77 Match a character class, chars < 256 only */ - OP_NCLASS, /* 78 Same, but the bitmap was created from a negative - class - the difference is relevant only when a UTF-8 - character > 255 is encountered. */ - - OP_XCLASS, /* 79 Extended class for handling UTF-8 chars within the - class. This does both positive and negative. */ - - OP_REF, /* 80 Match a back reference */ - OP_RECURSE, /* 81 Match a numbered subpattern (possibly recursive) */ - OP_CALLOUT, /* 82 Call out to external function if provided */ - - OP_ALT, /* 83 Start of alternation */ - OP_KET, /* 84 End of group that doesn't have an unbounded repeat */ - OP_KETRMAX, /* 85 These two must remain together and in this */ - OP_KETRMIN, /* 86 order. They are for groups the repeat for ever. */ - - /* The assertions must come before BRA, CBRA, ONCE, and COND.*/ - - OP_ASSERT, /* 87 Positive lookahead */ - OP_ASSERT_NOT, /* 88 Negative lookahead */ - OP_ASSERTBACK, /* 89 Positive lookbehind */ - OP_ASSERTBACK_NOT, /* 90 Negative lookbehind */ - OP_REVERSE, /* 91 Move pointer back - used in lookbehind assertions */ - - /* ONCE, BRA, CBRA, and COND must come after the assertions, with ONCE first, - as there's a test for >= ONCE for a subpattern that isn't an assertion. */ - - OP_ONCE, /* 92 Atomic group */ - OP_BRA, /* 93 Start of non-capturing bracket */ - OP_CBRA, /* 94 Start of capturing bracket */ - OP_COND, /* 95 Conditional group */ - - /* These three must follow the previous three, in the same order. There's a - check for >= SBRA to distinguish the two sets. */ - - OP_SBRA, /* 96 Start of non-capturing bracket, check empty */ - OP_SCBRA, /* 97 Start of capturing bracket, check empty */ - OP_SCOND, /* 98 Conditional group, check empty */ - - OP_CREF, /* 99 Used to hold a capture number as condition */ - OP_RREF, /* 100 Used to hold a recursion number as condition */ - OP_DEF, /* 101 The DEFINE condition */ - - OP_BRAZERO, /* 102 These two must remain together and in this */ - OP_BRAMINZERO, /* 103 order. */ - - /* These are backtracking control verbs */ - - OP_PRUNE, /* 104 */ - OP_SKIP, /* 105 */ - OP_THEN, /* 106 */ - OP_COMMIT, /* 107 */ - - /* These are forced failure and success verbs */ - - OP_FAIL, /* 108 */ - OP_ACCEPT /* 109 */ -}; - - -/* This macro defines textual names for all the opcodes. These are used only -for debugging. The macro is referenced only in pcre_printint.c. */ - -#define OP_NAME_LIST \ - "End", "\\A", "\\G", "\\K", "\\B", "\\b", "\\D", "\\d", \ - "\\S", "\\s", "\\W", "\\w", "Any", "Anybyte", \ - "notprop", "prop", "\\R", "\\H", "\\h", "\\V", "\\v", \ - "extuni", "\\Z", "\\z", \ - "Opt", "^", "$", "char", "charnc", "not", \ - "*", "*?", "+", "+?", "?", "??", "{", "{", "{", \ - "*+","++", "?+", "{", \ - "*", "*?", "+", "+?", "?", "??", "{", "{", "{", \ - "*+","++", "?+", "{", \ - "*", "*?", "+", "+?", "?", "??", "{", "{", "{", \ - "*+","++", "?+", "{", \ - "*", "*?", "+", "+?", "?", "??", "{", "{", \ - "class", "nclass", "xclass", "Ref", "Recurse", "Callout", \ - "Alt", "Ket", "KetRmax", "KetRmin", "Assert", "Assert not", \ - "AssertB", "AssertB not", "Reverse", \ - "Once", "Bra", "CBra", "Cond", "SBra", "SCBra", "SCond", \ - "Cond ref", "Cond rec", "Cond def", "Brazero", "Braminzero", \ - "*PRUNE", "*SKIP", "*THEN", "*COMMIT", "*FAIL", "*ACCEPT" - - -/* This macro defines the length of fixed length operations in the compiled -regex. The lengths are used when searching for specific things, and also in the -debugging printing of a compiled regex. We use a macro so that it can be -defined close to the definitions of the opcodes themselves. - -As things have been extended, some of these are no longer fixed lenths, but are -minima instead. For example, the length of a single-character repeat may vary -in UTF-8 mode. The code that uses this table must know about such things. */ - -#define OP_LENGTHS \ - 1, /* End */ \ - 1, 1, 1, 1, 1, /* \A, \G, \K, \B, \b */ \ - 1, 1, 1, 1, 1, 1, /* \D, \d, \S, \s, \W, \w */ \ - 1, 1, /* Any, Anybyte */ \ - 3, 3, 1, /* NOTPROP, PROP, EXTUNI */ \ - 1, 1, 1, 1, 1, /* \R, \H, \h, \V, \v */ \ - 1, 1, 2, 1, 1, /* \Z, \z, Opt, ^, $ */ \ - 2, /* Char - the minimum length */ \ - 2, /* Charnc - the minimum length */ \ - 2, /* not */ \ - /* Positive single-char repeats ** These are */ \ - 2, 2, 2, 2, 2, 2, /* *, *?, +, +?, ?, ?? ** minima in */ \ - 4, 4, 4, /* upto, minupto, exact ** UTF-8 mode */ \ - 2, 2, 2, 4, /* *+, ++, ?+, upto+ */ \ - /* Negative single-char repeats - only for chars < 256 */ \ - 2, 2, 2, 2, 2, 2, /* NOT *, *?, +, +?, ?, ?? */ \ - 4, 4, 4, /* NOT upto, minupto, exact */ \ - 2, 2, 2, 4, /* Possessive *, +, ?, upto */ \ - /* Positive type repeats */ \ - 2, 2, 2, 2, 2, 2, /* Type *, *?, +, +?, ?, ?? */ \ - 4, 4, 4, /* Type upto, minupto, exact */ \ - 2, 2, 2, 4, /* Possessive *+, ++, ?+, upto+ */ \ - /* Character class & ref repeats */ \ - 1, 1, 1, 1, 1, 1, /* *, *?, +, +?, ?, ?? */ \ - 5, 5, /* CRRANGE, CRMINRANGE */ \ - 33, /* CLASS */ \ - 33, /* NCLASS */ \ - 0, /* XCLASS - variable length */ \ - 3, /* REF */ \ - 1+LINK_SIZE, /* RECURSE */ \ - 2+2*LINK_SIZE, /* CALLOUT */ \ - 1+LINK_SIZE, /* Alt */ \ - 1+LINK_SIZE, /* Ket */ \ - 1+LINK_SIZE, /* KetRmax */ \ - 1+LINK_SIZE, /* KetRmin */ \ - 1+LINK_SIZE, /* Assert */ \ - 1+LINK_SIZE, /* Assert not */ \ - 1+LINK_SIZE, /* Assert behind */ \ - 1+LINK_SIZE, /* Assert behind not */ \ - 1+LINK_SIZE, /* Reverse */ \ - 1+LINK_SIZE, /* ONCE */ \ - 1+LINK_SIZE, /* BRA */ \ - 3+LINK_SIZE, /* CBRA */ \ - 1+LINK_SIZE, /* COND */ \ - 1+LINK_SIZE, /* SBRA */ \ - 3+LINK_SIZE, /* SCBRA */ \ - 1+LINK_SIZE, /* SCOND */ \ - 3, /* CREF */ \ - 3, /* RREF */ \ - 1, /* DEF */ \ - 1, 1, /* BRAZERO, BRAMINZERO */ \ - 1, 1, 1, 1, /* PRUNE, SKIP, THEN, COMMIT, */ \ - 1, 1 /* FAIL, ACCEPT */ - - -/* A magic value for OP_RREF to indicate the "any recursion" condition. */ - -#define RREF_ANY 0xffff - -/* Error code numbers. They are given names so that they can more easily be -tracked. */ - -enum { ERR0, ERR1, ERR2, ERR3, ERR4, ERR5, ERR6, ERR7, ERR8, ERR9, - ERR10, ERR11, ERR12, ERR13, ERR14, ERR15, ERR16, ERR17, ERR18, ERR19, - ERR20, ERR21, ERR22, ERR23, ERR24, ERR25, ERR26, ERR27, ERR28, ERR29, - ERR30, ERR31, ERR32, ERR33, ERR34, ERR35, ERR36, ERR37, ERR38, ERR39, - ERR40, ERR41, ERR42, ERR43, ERR44, ERR45, ERR46, ERR47, ERR48, ERR49, - ERR50, ERR51, ERR52, ERR53, ERR54, ERR55, ERR56, ERR57, ERR58, ERR59, - ERR60, ERR61 }; - -/* The real format of the start of the pcre block; the index of names and the -code vector run on as long as necessary after the end. We store an explicit -offset to the name table so that if a regex is compiled on one host, saved, and -then run on another where the size of pointers is different, all might still -be well. For the case of compiled-on-4 and run-on-8, we include an extra -pointer that is always NULL. For future-proofing, a few dummy fields were -originally included - even though you can never get this planning right - but -there is only one left now. - -NOTE NOTE NOTE: -Because people can now save and re-use compiled patterns, any additions to this -structure should be made at the end, and something earlier (e.g. a new -flag in the options or one of the dummy fields) should indicate that the new -fields are present. Currently PCRE always sets the dummy fields to zero. -NOTE NOTE NOTE: -*/ - -typedef struct real_pcre { - pcre_uint32 magic_number; - pcre_uint32 size; /* Total that was malloced */ - pcre_uint32 options; /* Public options */ - pcre_uint16 flags; /* Private flags */ - pcre_uint16 dummy1; /* For future use */ - pcre_uint16 top_bracket; - pcre_uint16 top_backref; - pcre_uint16 first_byte; - pcre_uint16 req_byte; - pcre_uint16 name_table_offset; /* Offset to name table that follows */ - pcre_uint16 name_entry_size; /* Size of any name items */ - pcre_uint16 name_count; /* Number of name items */ - pcre_uint16 ref_count; /* Reference count */ - - const unsigned char *tables; /* Pointer to tables or NULL for std */ - const unsigned char *nullpad; /* NULL padding */ -} real_pcre; - -/* The format of the block used to store data from pcre_study(). The same -remark (see NOTE above) about extending this structure applies. */ - -typedef struct pcre_study_data { - pcre_uint32 size; /* Total that was malloced */ - pcre_uint32 options; - uschar start_bits[32]; -} pcre_study_data; - -/* Structure for passing "static" information around between the functions -doing the compiling, so that they are thread-safe. */ - -typedef struct compile_data { - const uschar *lcc; /* Points to lower casing table */ - const uschar *fcc; /* Points to case-flipping table */ - const uschar *cbits; /* Points to character type table */ - const uschar *ctypes; /* Points to table of type maps */ - const uschar *start_workspace;/* The start of working space */ - const uschar *start_code; /* The start of the compiled code */ - const uschar *start_pattern; /* The start of the pattern */ - const uschar *end_pattern; /* The end of the pattern */ - uschar *hwm; /* High watermark of workspace */ - uschar *name_table; /* The name/number table */ - int names_found; /* Number of entries so far */ - int name_entry_size; /* Size of each entry */ - int bracount; /* Count of capturing parens */ - int top_backref; /* Maximum back reference */ - unsigned int backref_map; /* Bitmap of low back refs */ - int external_options; /* External (initial) options */ - int external_flags; /* External flag bits to be set */ - int req_varyopt; /* "After variable item" flag for reqbyte */ - BOOL had_accept; /* (*ACCEPT) encountered */ - int nltype; /* Newline type */ - int nllen; /* Newline string length */ - uschar nl[4]; /* Newline string when fixed length */ -} compile_data; - -/* Structure for maintaining a chain of pointers to the currently incomplete -branches, for testing for left recursion. */ - -typedef struct branch_chain { - struct branch_chain *outer; - uschar *current; -} branch_chain; - -/* Structure for items in a linked list that represents an explicit recursive -call within the pattern. */ - -typedef struct recursion_info { - struct recursion_info *prevrec; /* Previous recursion record (or NULL) */ - int group_num; /* Number of group that was called */ - const uschar *after_call; /* "Return value": points after the call in the expr */ - USPTR save_start; /* Old value of mstart */ - int *offset_save; /* Pointer to start of saved offsets */ - int saved_max; /* Number of saved offsets */ -} recursion_info; - -/* Structure for building a chain of data for holding the values of the subject -pointer at the start of each subpattern, so as to detect when an empty string -has been matched by a subpattern - to break infinite loops. */ - -typedef struct eptrblock { - struct eptrblock *epb_prev; - USPTR epb_saved_eptr; -} eptrblock; - - -/* Structure for passing "static" information around between the functions -doing traditional NFA matching, so that they are thread-safe. */ - -typedef struct match_data { - unsigned long int match_call_count; /* As it says */ - unsigned long int match_limit; /* As it says */ - unsigned long int match_limit_recursion; /* As it says */ - int *offset_vector; /* Offset vector */ - int offset_end; /* One past the end */ - int offset_max; /* The maximum usable for return data */ - int nltype; /* Newline type */ - int nllen; /* Newline string length */ - uschar nl[4]; /* Newline string when fixed */ - const uschar *lcc; /* Points to lower casing table */ - const uschar *ctypes; /* Points to table of type maps */ - BOOL offset_overflow; /* Set if too many extractions */ - BOOL notbol; /* NOTBOL flag */ - BOOL noteol; /* NOTEOL flag */ - BOOL utf8; /* UTF8 flag */ - BOOL endonly; /* Dollar not before final \n */ - BOOL notempty; /* Empty string match not wanted */ - BOOL partial; /* PARTIAL flag */ - BOOL hitend; /* Hit the end of the subject at some point */ - BOOL bsr_anycrlf; /* \R is just any CRLF, not full Unicode */ - const uschar *start_code; /* For use when recursing */ - USPTR start_subject; /* Start of the subject string */ - USPTR end_subject; /* End of the subject string */ - USPTR start_match_ptr; /* Start of matched string */ - USPTR end_match_ptr; /* Subject position at end match */ - int end_offset_top; /* Highwater mark at end of match */ - int capture_last; /* Most recent capture number */ - int start_offset; /* The start offset value */ - eptrblock *eptrchain; /* Chain of eptrblocks for tail recursions */ - int eptrn; /* Next free eptrblock */ - recursion_info *recursive; /* Linked list of recursion data */ - void *callout_data; /* To pass back to callouts */ -} match_data; - -/* A similar structure is used for the same purpose by the DFA matching -functions. */ - -typedef struct dfa_match_data { - const uschar *start_code; /* Start of the compiled pattern */ - const uschar *start_subject; /* Start of the subject string */ - const uschar *end_subject; /* End of subject string */ - const uschar *tables; /* Character tables */ - int moptions; /* Match options */ - int poptions; /* Pattern options */ - int nltype; /* Newline type */ - int nllen; /* Newline string length */ - uschar nl[4]; /* Newline string when fixed */ - void *callout_data; /* To pass back to callouts */ -} dfa_match_data; - -/* Bit definitions for entries in the pcre_ctypes table. */ - -#define ctype_space 0x01 -#define ctype_letter 0x02 -#define ctype_digit 0x04 -#define ctype_xdigit 0x08 -#define ctype_word 0x10 /* alphameric or '_' */ -#define ctype_meta 0x80 /* regexp meta char or zero (end pattern) */ - -/* Offsets for the bitmap tables in pcre_cbits. Each table contains a set -of bits for a class map. Some classes are built by combining these tables. */ - -#define cbit_space 0 /* [:space:] or \s */ -#define cbit_xdigit 32 /* [:xdigit:] */ -#define cbit_digit 64 /* [:digit:] or \d */ -#define cbit_upper 96 /* [:upper:] */ -#define cbit_lower 128 /* [:lower:] */ -#define cbit_word 160 /* [:word:] or \w */ -#define cbit_graph 192 /* [:graph:] */ -#define cbit_print 224 /* [:print:] */ -#define cbit_punct 256 /* [:punct:] */ -#define cbit_cntrl 288 /* [:cntrl:] */ -#define cbit_length 320 /* Length of the cbits table */ - -/* Offsets of the various tables from the base tables pointer, and -total length. */ - -#define lcc_offset 0 -#define fcc_offset 256 -#define cbits_offset 512 -#define ctypes_offset (cbits_offset + cbit_length) -#define tables_length (ctypes_offset + 256) - -/* Layout of the UCP type table that translates property names into types and -codes. Each entry used to point directly to a name, but to reduce the number of -relocations in shared libraries, it now has an offset into a single string -instead. */ - -typedef struct { - pcre_uint16 name_offset; - pcre_uint16 type; - pcre_uint16 value; -} ucp_type_table; - - -/* Internal shared data tables. These are tables that are used by more than one -of the exported public functions. They have to be "external" in the C sense, -but are not part of the PCRE public API. The data for these tables is in the -pcre_tables.c module. */ - -extern const int _pcre_utf8_table1[]; -extern const int _pcre_utf8_table2[]; -extern const int _pcre_utf8_table3[]; -extern const uschar _pcre_utf8_table4[]; - -extern const int _pcre_utf8_table1_size; - -extern const char _pcre_utt_names[]; -extern const ucp_type_table _pcre_utt[]; -extern const int _pcre_utt_size; - -extern const uschar _pcre_default_tables[]; - -extern const uschar _pcre_OP_lengths[]; - - -/* Internal shared functions. These are functions that are used by more than -one of the exported public functions. They have to be "external" in the C -sense, but are not part of the PCRE public API. */ - -extern BOOL _pcre_is_newline(const uschar *, int, const uschar *, - int *, BOOL); -extern int _pcre_ord2utf8(int, uschar *); -extern real_pcre *_pcre_try_flipped(const real_pcre *, real_pcre *, - const pcre_study_data *, pcre_study_data *); -extern int _pcre_ucp_findprop(const unsigned int, int *, int *); -extern unsigned int _pcre_ucp_othercase(const unsigned int); -extern int _pcre_valid_utf8(const uschar *, int); -extern BOOL _pcre_was_newline(const uschar *, int, const uschar *, - int *, BOOL); -extern BOOL _pcre_xclass(int, const uschar *); - -#endif - -/* End of pcre_internal.h */ diff --git a/src/plugins/PCREPlugin/pcre_maketables.c b/src/plugins/PCREPlugin/pcre_maketables.c deleted file mode 100644 index 352bea9..0000000 --- a/src/plugins/PCREPlugin/pcre_maketables.c +++ /dev/null @@ -1,143 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_maketables(), which builds -character tables for PCRE in the current locale. The file is compiled on its -own as part of the PCRE library. However, it is also included in the -compilation of dftables.c, in which case the macro DFTABLES is defined. */ - - -#ifndef DFTABLES -# ifdef HAVE_CONFIG_H -# include "config.h" -# endif -# include "pcre_internal.h" -#endif - - -/************************************************* -* Create PCRE character tables * -*************************************************/ - -/* This function builds a set of character tables for use by PCRE and returns -a pointer to them. They are build using the ctype functions, and consequently -their contents will depend upon the current locale setting. When compiled as -part of the library, the store is obtained via pcre_malloc(), but when compiled -inside dftables, use malloc(). - -Arguments: none -Returns: pointer to the contiguous block of data -*/ - -const unsigned char * -pcre_maketables(void) -{ -unsigned char *yield, *p; -int i; - -#ifndef DFTABLES -yield = (unsigned char*)(pcre_malloc)(tables_length); -#else -yield = (unsigned char*)malloc(tables_length); -#endif - -if (yield == NULL) return NULL; -p = yield; - -/* First comes the lower casing table */ - -for (i = 0; i < 256; i++) *p++ = tolower(i); - -/* Next the case-flipping table */ - -for (i = 0; i < 256; i++) *p++ = islower(i)? toupper(i) : tolower(i); - -/* Then the character class tables. Don't try to be clever and save effort on -exclusive ones - in some locales things may be different. Note that the table -for "space" includes everything "isspace" gives, including VT in the default -locale. This makes it work for the POSIX class [:space:]. Note also that it is -possible for a character to be alnum or alpha without being lower or upper, -such as "male and female ordinals" (\xAA and \xBA) in the fr_FR locale (at -least under Debian Linux's locales as of 12/2005). So we must test for alnum -specially. */ - -memset(p, 0, cbit_length); -for (i = 0; i < 256; i++) - { - if (isdigit(i)) p[cbit_digit + i/8] |= 1 << (i&7); - if (isupper(i)) p[cbit_upper + i/8] |= 1 << (i&7); - if (islower(i)) p[cbit_lower + i/8] |= 1 << (i&7); - if (isalnum(i)) p[cbit_word + i/8] |= 1 << (i&7); - if (i == '_') p[cbit_word + i/8] |= 1 << (i&7); - if (isspace(i)) p[cbit_space + i/8] |= 1 << (i&7); - if (isxdigit(i))p[cbit_xdigit + i/8] |= 1 << (i&7); - if (isgraph(i)) p[cbit_graph + i/8] |= 1 << (i&7); - if (isprint(i)) p[cbit_print + i/8] |= 1 << (i&7); - if (ispunct(i)) p[cbit_punct + i/8] |= 1 << (i&7); - if (iscntrl(i)) p[cbit_cntrl + i/8] |= 1 << (i&7); - } -p += cbit_length; - -/* Finally, the character type table. In this, we exclude VT from the white -space chars, because Perl doesn't recognize it as such for \s and for comments -within regexes. */ - -for (i = 0; i < 256; i++) - { - int x = 0; - if (i != 0x0b && isspace(i)) x += ctype_space; - if (isalpha(i)) x += ctype_letter; - if (isdigit(i)) x += ctype_digit; - if (isxdigit(i)) x += ctype_xdigit; - if (isalnum(i) || i == '_') x += ctype_word; - - /* Note: strchr includes the terminating zero in the characters it considers. - In this instance, that is ok because we want binary zero to be flagged as a - meta-character, which in this sense is any character that terminates a run - of data characters. */ - - if (strchr("\\*+?{^.$|()[", i) != 0) x += ctype_meta; - *p++ = x; - } - -return yield; -} - -/* End of pcre_maketables.c */ diff --git a/src/plugins/PCREPlugin/pcre_newline.c b/src/plugins/PCREPlugin/pcre_newline.c deleted file mode 100644 index 1708d93..0000000 --- a/src/plugins/PCREPlugin/pcre_newline.c +++ /dev/null @@ -1,164 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains internal functions for testing newlines when more than -one kind of newline is to be recognized. When a newline is found, its length is -returned. In principle, we could implement several newline "types", each -referring to a different set of newline characters. At present, PCRE supports -only NLTYPE_FIXED, which gets handled without these functions, NLTYPE_ANYCRLF, -and NLTYPE_ANY. The full list of Unicode newline characters is taken from -http://unicode.org/unicode/reports/tr18/. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - - -/************************************************* -* Check for newline at given position * -*************************************************/ - -/* It is guaranteed that the initial value of ptr is less than the end of the -string that is being processed. - -Arguments: - ptr pointer to possible newline - type the newline type - endptr pointer to the end of the string - lenptr where to return the length - utf8 TRUE if in utf8 mode - -Returns: TRUE or FALSE -*/ - -BOOL -_pcre_is_newline(const uschar *ptr, int type, const uschar *endptr, - int *lenptr, BOOL utf8) -{ -int c; -if (utf8) { GETCHAR(c, ptr); } else c = *ptr; - -if (type == NLTYPE_ANYCRLF) switch(c) - { - case 0x000a: *lenptr = 1; return TRUE; /* LF */ - case 0x000d: *lenptr = (ptr < endptr - 1 && ptr[1] == 0x0a)? 2 : 1; - return TRUE; /* CR */ - default: return FALSE; - } - -/* NLTYPE_ANY */ - -else switch(c) - { - case 0x000a: /* LF */ - case 0x000b: /* VT */ - case 0x000c: *lenptr = 1; return TRUE; /* FF */ - case 0x000d: *lenptr = (ptr < endptr - 1 && ptr[1] == 0x0a)? 2 : 1; - return TRUE; /* CR */ - case 0x0085: *lenptr = utf8? 2 : 1; return TRUE; /* NEL */ - case 0x2028: /* LS */ - case 0x2029: *lenptr = 3; return TRUE; /* PS */ - default: return FALSE; - } -} - - - -/************************************************* -* Check for newline at previous position * -*************************************************/ - -/* It is guaranteed that the initial value of ptr is greater than the start of -the string that is being processed. - -Arguments: - ptr pointer to possible newline - type the newline type - startptr pointer to the start of the string - lenptr where to return the length - utf8 TRUE if in utf8 mode - -Returns: TRUE or FALSE -*/ - -BOOL -_pcre_was_newline(const uschar *ptr, int type, const uschar *startptr, - int *lenptr, BOOL utf8) -{ -int c; -ptr--; -#ifdef SUPPORT_UTF8 -if (utf8) - { - BACKCHAR(ptr); - GETCHAR(c, ptr); - } -else c = *ptr; -#else /* no UTF-8 support */ -c = *ptr; -#endif /* SUPPORT_UTF8 */ - -if (type == NLTYPE_ANYCRLF) switch(c) - { - case 0x000a: *lenptr = (ptr > startptr && ptr[-1] == 0x0d)? 2 : 1; - return TRUE; /* LF */ - case 0x000d: *lenptr = 1; return TRUE; /* CR */ - default: return FALSE; - } - -else switch(c) - { - case 0x000a: *lenptr = (ptr > startptr && ptr[-1] == 0x0d)? 2 : 1; - return TRUE; /* LF */ - case 0x000b: /* VT */ - case 0x000c: /* FF */ - case 0x000d: *lenptr = 1; return TRUE; /* CR */ - case 0x0085: *lenptr = utf8? 2 : 1; return TRUE; /* NEL */ - case 0x2028: /* LS */ - case 0x2029: *lenptr = 3; return TRUE; /* PS */ - default: return FALSE; - } -} - -/* End of pcre_newline.c */ diff --git a/src/plugins/PCREPlugin/pcre_ord2utf8.c b/src/plugins/PCREPlugin/pcre_ord2utf8.c deleted file mode 100644 index d3904c6..0000000 --- a/src/plugins/PCREPlugin/pcre_ord2utf8.c +++ /dev/null @@ -1,85 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This file contains a private PCRE function that converts an ordinal -character value into a UTF8 string. */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Convert character value to UTF-8 * -*************************************************/ - -/* This function takes an integer value in the range 0 - 0x7fffffff -and encodes it as a UTF-8 character in 0 to 6 bytes. - -Arguments: - cvalue the character value - buffer pointer to buffer for result - at least 6 bytes long - -Returns: number of characters placed in the buffer -*/ - -int -_pcre_ord2utf8(int cvalue, uschar *buffer) -{ -#ifdef SUPPORT_UTF8 -register int i, j; -for (i = 0; i < _pcre_utf8_table1_size; i++) - if (cvalue <= _pcre_utf8_table1[i]) break; -buffer += i; -for (j = i; j > 0; j--) - { - *buffer-- = 0x80 | (cvalue & 0x3f); - cvalue >>= 6; - } -*buffer = _pcre_utf8_table2[i] | cvalue; -return i + 1; -#else -return 0; /* Keep compiler happy; this function won't ever be */ -#endif /* called when SUPPORT_UTF8 is not defined. */ -} - -/* End of pcre_ord2utf8.c */ diff --git a/src/plugins/PCREPlugin/pcre_plugin.c b/src/plugins/PCREPlugin/pcre_plugin.c deleted file mode 100644 index f7b74ee..0000000 --- a/src/plugins/PCREPlugin/pcre_plugin.c +++ /dev/null @@ -1,400 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2007-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "../../structures.h" -#include -#include "pcre.h" -#include "pcreposix.h" - -#ifdef __cplusplus -extern "C" { -#endif - -#ifndef isnumber -#define isnumber(i_n_arg) ((i_n_arg>='0')&&(i_n_arg<='9')) -#endif - -static struct pluginlink * pl; - -static pthread_mutex_t pcre_mutex; - - -static struct filter pcre_first_filter = { - NULL, - "Fake filter", - NULL, NULL, - NULL, NULL, - NULL, NULL, NULL, - NULL, NULL -}; - -static struct filter *pcre_last_filter; -static int pcre_loaded = 0; -static int pcre_options = 0; - -static struct pcreopt { - char * name; - int value; -} pcreopts[]= { - - {"PCRE_CASELESS", 0x00000001}, - {"PCRE_MULTILINE", 0x00000002}, - {"PCRE_DOTALL", 0x00000004}, - {"PCRE_EXTENDED", 0x00000008}, - {"PCRE_ANCHORED", 0x00000010}, - {"PCRE_DOLLAR_ENDONLY", 0x00000020}, - {"PCRE_EXTRA", 0x00000040}, - {"PCRE_NOTBOL", 0x00000080}, - {"PCRE_NOTEOL", 0x00000100}, - {"PCRE_UNGREEDY", 0x00000200}, - {"PCRE_NOTEMPTY", 0x00000400}, - {"PCRE_UTF8", 0x00000800}, - {"PCRE_NO_AUTO_CAPTURE", 0x00001000}, - {"PCRE_NO_UTF8_CHECK", 0x00002000}, - {"PCRE_AUTO_CALLOUT", 0x00004000}, - {"PCRE_PARTIAL", 0x00008000}, - {"PCRE_DFA_SHORTEST", 0x00010000}, - {"PCRE_DFA_RESTART", 0x00020000}, - {"PCRE_FIRSTLINE", 0x00040000}, - {"PCRE_DUPNAMES", 0x00080000}, - {"PCRE_NEWLINE_CR", 0x00100000}, - {"PCRE_NEWLINE_LF", 0x00200000}, - {"PCRE_NEWLINE_CRLF", 0x00300000}, - {"PCRE_NEWLINE_ANY", 0x00400000}, - {"PCRE_NEWLINE_ANYCRLF", 0x00500000}, - {"PCRE_BSR_ANYCRLF", 0x00800000}, - {"PCRE_BSR_UNICODE", 0x01000000}, - {NULL, 0} -}; - -struct pcre_filter_data { - int users; - pcre * re; - int action; - char * replace; - struct ace *acl; -}; - -static void pcre_data_free(struct pcre_filter_data *pcrefd){ - pthread_mutex_lock(&pcre_mutex); - pcrefd->users--; - if(!pcrefd->users){ - if(pcrefd->re) pl->myfree(pcrefd->re); - if(pcrefd->acl) pl->freeacl(pcrefd->acl); - if(pcrefd->replace) pl->myfree(pcrefd->replace); - pl->myfree(pcrefd); - } - pthread_mutex_unlock(&pcre_mutex); -} - - - - -static void* pcre_filter_open(void * idata, struct srvparam * param){ -#define pcrefd ((struct pcre_filter_data *)idata) - if(idata){ - pthread_mutex_lock(&pcre_mutex); - pcrefd->users++; - pthread_mutex_unlock(&pcre_mutex); - } -#undef pcrefd - return idata; -} - - - -static FILTER_ACTION pcre_filter_client(void *fo, struct clientparam * param, void** fc){ - int res; - struct ace tmpace; - - *fc = fo; - if(!fo) return PASS; -#define pcrefd ((struct pcre_filter_data *)fo) - if(!pcrefd->acl) return CONTINUE; - memset (&tmpace, 0, sizeof(struct ace)); - tmpace.src = pcrefd->acl->src; - res = pl->ACLMatches(&tmpace, param); -#undef pcrefd - return (res)? CONTINUE:PASS; -} - -static FILTER_ACTION pcre_filter_buffer(void *fc, struct clientparam *param, unsigned char ** buf_p, int * bufsize_p, int offset, int * length_p){ - int ovector[48]; - int count = 0; - struct ace *acl; - int match = 0; - int replen, num; - char * replace; - char * tmpbuf, *target, *newbuf; - int nreplaces=0; -#define pcrefd ((struct pcre_filter_data *)fc) - - for(acl = pcrefd->acl; acl; acl=acl->next){ - if(pl->ACLMatches(pcrefd->acl, param)){ - match = 1; - break; - } - } - if(!match) return CONTINUE; - if(!pcrefd->re) return pcrefd->action; - for(; offset < *length_p; nreplaces++){ - - count = pcre_exec(pcrefd->re, NULL, (char *)*buf_p, *length_p, offset, 0, ovector, 48); - if(count <= 0) break; - if(!(replace = pcrefd->replace) || param->nooverwritefilter) return pcrefd->action; - - replen = *length_p - ovector[1]; - while(*replace){ - if(*replace == '\\' && *(replace +1)){ - replace+=2; - ++replen; - } - else if(*replace == '$' && isnumber(*(replace+1))){ - replace ++; - num = atoi(replace); - while(isnumber(*replace)) replace++; - if(num > (count - 1)) continue; - replen += (ovector[(num<<1) + 1] - ovector[(num<<1)]); - } - else { - replace++; - replen++; - } - } - - tmpbuf = (*pl->myalloc)(replen); - if(!tmpbuf) return CONTINUE; - for(target = tmpbuf, replace = pcrefd->replace; *replace; ){ - if(*replace == '\\' && *(replace +1)){ - *target++ = replace[1]; - replace+=2; - } - else if(*replace == '$' && isnumber(*(replace+1))){ - replace ++; - num = atoi(replace); - if(num > (count - 1)) continue; - memcpy(target, *buf_p + ovector[(num<<1)], ovector[(num<<1) + 1] - ovector[(num<<1)]); - target += (ovector[(num<<1) + 1] - ovector[(num<<1)]); - while(isnumber(*replace)) replace++; - } - else { - *target++ = *replace++; - } - } - memcpy(target, *buf_p + ovector[1], *length_p - ovector[1]); - if((ovector[0] + replen + 1) > *bufsize_p){ - newbuf = (*pl->myalloc)(ovector[0] + replen + 1); - if(!newbuf){ - (*pl->myfree)(tmpbuf); - return CONTINUE; - } - memcpy(newbuf, *buf_p, ovector[0]); - (*pl->myfree)(*buf_p); - *buf_p = (unsigned char *)newbuf; - *bufsize_p = ovector[0] + replen + 1; - } - memcpy(*buf_p + ovector[0], tmpbuf, replen); - (*pl->myfree)(tmpbuf); - (*buf_p)[ovector[0] + replen] = 0; - *length_p = ovector[0] + replen; - if(ovector[0] + replen <= offset){ - break; - } - offset = ovector[0] + (int)strlen(pcrefd->replace); - } - return nreplaces? pcrefd->action : CONTINUE; -#undef pcrefd -} - -static void pcre_filter_clear(void *fo){ -} - -static void pcre_filter_close(void *fo){ - if(!fo) return; - pcre_data_free((struct pcre_filter_data *)fo); -} - -static int h_pcre(int argc, unsigned char **argv){ - int action = 0; - pcre *re = NULL; - struct ace *acl; - int offset = 4; - const char * errptr; - struct pcre_filter_data *flt; - struct filter *newf; - char *replace = NULL; - - if(!strncmp((char *)argv[2], "allow",5)) action = PASS; - else if(!strncmp((char *)argv[2], "deny",4)) action = REJECT; - else if(!strncmp((char *)argv[2], "remove",6)) action = REMOVE; - else if(!strncmp((char *)argv[2], "dunno",5)) action = CONTINUE; - else return 1; - if(!strncmp((char *)argv[0], "pcre_rewrite", 12)) { - int i,j; - offset = 5; - replace = pl->mystrdup((char *)argv[4]); - if(!replace) return 9; - for(i=0, j=0; replace[i]; i++, j++){ - if(replace[i] == '\\'){ - switch(replace[i+1]){ - case 'r': - i++; - replace[j] = '\r'; - break; - case 'n': - i++; - replace[j] = '\n'; - break; - case '0': - i++; - replace[j] = 0; - break; - case '\\': - i++; - default: - replace[j] = '\\'; - break; - } - } - else replace[j] = replace[i]; - } - replace[j] = 0; - } - if(!(acl = pl->make_ace(argc - offset, argv + offset))) return 2; - acl->nolog = (strstr((char *)argv[2],"log") == 0); - if(*argv[3] && !(*argv[3] == '*' && !argv[3][1]) ){ - re = pcre_compile((char *)argv[3], pcre_options, &errptr, &offset, NULL); - if(!re) { - pl->myfree(acl); - if(replace) pl->myfree(replace); - return 3; - } - } - flt = pl->myalloc(sizeof(struct pcre_filter_data)); - newf = pl->myalloc(sizeof(struct filter)); - - if(!flt || !newf) { - pl->myfree(acl); - pl->myfree(re); - if(replace) pl->myfree(replace); - if(flt) pl->myfree(flt); - return 4; - } - memset(flt, 0, sizeof(struct pcre_filter_data)); - memset(newf, 0, sizeof(struct filter)); - flt->action = action; - flt->re = re; - flt->acl = acl; - flt->replace = replace; - flt->users = 1; - newf->instance = "pcre"; - newf->data = flt; - newf->filter_open = pcre_filter_open; - newf->filter_client = pcre_filter_client; - if(strstr((char *)argv[1], "request"))newf->filter_request = pcre_filter_buffer; - if(strstr((char *)argv[1], "cliheader"))newf->filter_header_cli = pcre_filter_buffer; - if(strstr((char *)argv[1], "clidata"))newf->filter_data_cli = pcre_filter_buffer; - if(strstr((char *)argv[1], "srvheader"))newf->filter_header_srv = pcre_filter_buffer; - if(strstr((char *)argv[1], "srvdata"))newf->filter_data_srv = pcre_filter_buffer; - newf->filter_clear = pcre_filter_clear; - newf->filter_close = pcre_filter_close; - - if(!pcre_last_filter){ - newf->next = pcre_first_filter.next; - pcre_first_filter.next=newf; - } - else { - newf->next = pcre_last_filter->next; - pcre_last_filter->next = newf; - } - pcre_last_filter=newf; - - return 0; -} - -static int h_pcre_extend(int argc, unsigned char **argv){ - struct ace *acl; - if(!pcre_last_filter || !pcre_last_filter->data) return 1; - acl = ((struct pcre_filter_data *)pcre_last_filter->data)->acl; - if(!acl) return 2; - for(; acl->next; acl=acl->next); - acl->next = (*pl->make_ace)(argc - 1, argv + 1); - if(!acl->next) return 3; - return 0; -} - -static int h_pcre_options(int argc, unsigned char **argv){ - int i,j; - - pcre_options = 0; - for(j=1; jmyalloc; - pcre_free = pl->myfree; - pcre_loaded = 1; - pthread_mutex_init(&pcre_mutex, NULL); - regexp_symbols[6].value = pl->myfree; - regexp_symbols[6].next = pl->symbols.next; - pl->symbols.next = regexp_symbols; - pcre_commandhandlers[3].next = pl->commandhandlers->next; - pl->commandhandlers->next = pcre_commandhandlers; - pcre_first_filter.next = pl->conf->filters; - pl->conf->filters = &pcre_first_filter; - } - else if(pcre_last_filter){ - pcre_first_filter.next = pcre_last_filter->next; - flt = pcre_first_filter.next; - for(; flt; flt = tmpflt){ - tmpflt = flt->next; - if(flt->data) - pcre_data_free((struct pcre_filter_data *)flt->data); - pl->myfree(flt); - if(flt == pcre_last_filter) break; - } - } - pcre_last_filter = NULL; - return 0; - - } -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/PCREPlugin/pcre_refcount.c b/src/plugins/PCREPlugin/pcre_refcount.c deleted file mode 100644 index b14103c..0000000 --- a/src/plugins/PCREPlugin/pcre_refcount.c +++ /dev/null @@ -1,82 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_refcount(), which is an -auxiliary function that can be used to maintain a reference count in a compiled -pattern data block. This might be helpful in applications where the block is -shared by different users. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Maintain reference count * -*************************************************/ - -/* The reference count is a 16-bit field, initialized to zero. It is not -possible to transfer a non-zero count from one host to a different host that -has a different byte order - though I can't see why anyone in their right mind -would ever want to do that! - -Arguments: - argument_re points to compiled code - adjust value to add to the count - -Returns: the (possibly updated) count value (a non-negative number), or - a negative error number -*/ - -PCRE_EXP_DEFN int -pcre_refcount(pcre *argument_re, int adjust) -{ -real_pcre *re = (real_pcre *)argument_re; -if (re == NULL) return PCRE_ERROR_NULL; -re->ref_count = (-adjust > re->ref_count)? 0 : - (adjust + re->ref_count > 65535)? 65535 : - re->ref_count + adjust; -return re->ref_count; -} - -/* End of pcre_refcount.c */ diff --git a/src/plugins/PCREPlugin/pcre_study.c b/src/plugins/PCREPlugin/pcre_study.c deleted file mode 100644 index 1c28384..0000000 --- a/src/plugins/PCREPlugin/pcre_study.c +++ /dev/null @@ -1,579 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_study(), along with local -supporting functions. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/* Returns from set_start_bits() */ - -enum { SSB_FAIL, SSB_DONE, SSB_CONTINUE }; - - -/************************************************* -* Set a bit and maybe its alternate case * -*************************************************/ - -/* Given a character, set its bit in the table, and also the bit for the other -version of a letter if we are caseless. - -Arguments: - start_bits points to the bit map - c is the character - caseless the caseless flag - cd the block with char table pointers - -Returns: nothing -*/ - -static void -set_bit(uschar *start_bits, unsigned int c, BOOL caseless, compile_data *cd) -{ -start_bits[c/8] |= (1 << (c&7)); -if (caseless && (cd->ctypes[c] & ctype_letter) != 0) - start_bits[cd->fcc[c]/8] |= (1 << (cd->fcc[c]&7)); -} - - - -/************************************************* -* Create bitmap of starting bytes * -*************************************************/ - -/* This function scans a compiled unanchored expression recursively and -attempts to build a bitmap of the set of possible starting bytes. As time goes -by, we may be able to get more clever at doing this. The SSB_CONTINUE return is -useful for parenthesized groups in patterns such as (a*)b where the group -provides some optional starting bytes but scanning must continue at the outer -level to find at least one mandatory byte. At the outermost level, this -function fails unless the result is SSB_DONE. - -Arguments: - code points to an expression - start_bits points to a 32-byte table, initialized to 0 - caseless the current state of the caseless flag - utf8 TRUE if in UTF-8 mode - cd the block with char table pointers - -Returns: SSB_FAIL => Failed to find any starting bytes - SSB_DONE => Found mandatory starting bytes - SSB_CONTINUE => Found optional starting bytes -*/ - -static int -set_start_bits(const uschar *code, uschar *start_bits, BOOL caseless, - BOOL utf8, compile_data *cd) -{ -register int c; -int yield = SSB_DONE; - -#if 0 -/* ========================================================================= */ -/* The following comment and code was inserted in January 1999. In May 2006, -when it was observed to cause compiler warnings about unused values, I took it -out again. If anybody is still using OS/2, they will have to put it back -manually. */ - -/* This next statement and the later reference to dummy are here in order to -trick the optimizer of the IBM C compiler for OS/2 into generating correct -code. Apparently IBM isn't going to fix the problem, and we would rather not -disable optimization (in this module it actually makes a big difference, and -the pcre module can use all the optimization it can get). */ - -volatile int dummy; -/* ========================================================================= */ -#endif - -do - { - const uschar *tcode = code + (((int)*code == OP_CBRA)? 3:1) + LINK_SIZE; - BOOL try_next = TRUE; - - while (try_next) /* Loop for items in this branch */ - { - int rc; - switch(*tcode) - { - /* Fail if we reach something we don't understand */ - - default: - return SSB_FAIL; - - /* If we hit a bracket or a positive lookahead assertion, recurse to set - bits from within the subpattern. If it can't find anything, we have to - give up. If it finds some mandatory character(s), we are done for this - branch. Otherwise, carry on scanning after the subpattern. */ - - case OP_BRA: - case OP_SBRA: - case OP_CBRA: - case OP_SCBRA: - case OP_ONCE: - case OP_ASSERT: - rc = set_start_bits(tcode, start_bits, caseless, utf8, cd); - if (rc == SSB_FAIL) return SSB_FAIL; - if (rc == SSB_DONE) try_next = FALSE; else - { - do tcode += GET(tcode, 1); while (*tcode == OP_ALT); - tcode += 1 + LINK_SIZE; - } - break; - - /* If we hit ALT or KET, it means we haven't found anything mandatory in - this branch, though we might have found something optional. For ALT, we - continue with the next alternative, but we have to arrange that the final - result from subpattern is SSB_CONTINUE rather than SSB_DONE. For KET, - return SSB_CONTINUE: if this is the top level, that indicates failure, - but after a nested subpattern, it causes scanning to continue. */ - - case OP_ALT: - yield = SSB_CONTINUE; - try_next = FALSE; - break; - - case OP_KET: - case OP_KETRMAX: - case OP_KETRMIN: - return SSB_CONTINUE; - - /* Skip over callout */ - - case OP_CALLOUT: - tcode += 2 + 2*LINK_SIZE; - break; - - /* Skip over lookbehind and negative lookahead assertions */ - - case OP_ASSERT_NOT: - case OP_ASSERTBACK: - case OP_ASSERTBACK_NOT: - do tcode += GET(tcode, 1); while (*tcode == OP_ALT); - tcode += 1 + LINK_SIZE; - break; - - /* Skip over an option setting, changing the caseless flag */ - - case OP_OPT: - caseless = (tcode[1] & PCRE_CASELESS) != 0; - tcode += 2; - break; - - /* BRAZERO does the bracket, but carries on. */ - - case OP_BRAZERO: - case OP_BRAMINZERO: - if (set_start_bits(++tcode, start_bits, caseless, utf8, cd) == SSB_FAIL) - return SSB_FAIL; -/* ========================================================================= - See the comment at the head of this function concerning the next line, - which was an old fudge for the benefit of OS/2. - dummy = 1; - ========================================================================= */ - do tcode += GET(tcode,1); while (*tcode == OP_ALT); - tcode += 1 + LINK_SIZE; - break; - - /* Single-char * or ? sets the bit and tries the next item */ - - case OP_STAR: - case OP_MINSTAR: - case OP_POSSTAR: - case OP_QUERY: - case OP_MINQUERY: - case OP_POSQUERY: - set_bit(start_bits, tcode[1], caseless, cd); - tcode += 2; -#ifdef SUPPORT_UTF8 - if (utf8 && tcode[-1] >= 0xc0) - tcode += _pcre_utf8_table4[tcode[-1] & 0x3f]; -#endif - break; - - /* Single-char upto sets the bit and tries the next */ - - case OP_UPTO: - case OP_MINUPTO: - case OP_POSUPTO: - set_bit(start_bits, tcode[3], caseless, cd); - tcode += 4; -#ifdef SUPPORT_UTF8 - if (utf8 && tcode[-1] >= 0xc0) - tcode += _pcre_utf8_table4[tcode[-1] & 0x3f]; -#endif - break; - - /* At least one single char sets the bit and stops */ - - case OP_EXACT: /* Fall through */ - tcode += 2; - - case OP_CHAR: - case OP_CHARNC: - case OP_PLUS: - case OP_MINPLUS: - case OP_POSPLUS: - set_bit(start_bits, tcode[1], caseless, cd); - try_next = FALSE; - break; - - /* Single character type sets the bits and stops */ - - case OP_NOT_DIGIT: - for (c = 0; c < 32; c++) - start_bits[c] |= ~cd->cbits[c+cbit_digit]; - try_next = FALSE; - break; - - case OP_DIGIT: - for (c = 0; c < 32; c++) - start_bits[c] |= cd->cbits[c+cbit_digit]; - try_next = FALSE; - break; - - /* The cbit_space table has vertical tab as whitespace; we have to - discard it. */ - - case OP_NOT_WHITESPACE: - for (c = 0; c < 32; c++) - { - int d = cd->cbits[c+cbit_space]; - if (c == 1) d &= ~0x08; - start_bits[c] |= ~d; - } - try_next = FALSE; - break; - - /* The cbit_space table has vertical tab as whitespace; we have to - discard it. */ - - case OP_WHITESPACE: - for (c = 0; c < 32; c++) - { - int d = cd->cbits[c+cbit_space]; - if (c == 1) d &= ~0x08; - start_bits[c] |= d; - } - try_next = FALSE; - break; - - case OP_NOT_WORDCHAR: - for (c = 0; c < 32; c++) - start_bits[c] |= ~cd->cbits[c+cbit_word]; - try_next = FALSE; - break; - - case OP_WORDCHAR: - for (c = 0; c < 32; c++) - start_bits[c] |= cd->cbits[c+cbit_word]; - try_next = FALSE; - break; - - /* One or more character type fudges the pointer and restarts, knowing - it will hit a single character type and stop there. */ - - case OP_TYPEPLUS: - case OP_TYPEMINPLUS: - tcode++; - break; - - case OP_TYPEEXACT: - tcode += 3; - break; - - /* Zero or more repeats of character types set the bits and then - try again. */ - - case OP_TYPEUPTO: - case OP_TYPEMINUPTO: - case OP_TYPEPOSUPTO: - tcode += 2; /* Fall through */ - - case OP_TYPESTAR: - case OP_TYPEMINSTAR: - case OP_TYPEPOSSTAR: - case OP_TYPEQUERY: - case OP_TYPEMINQUERY: - case OP_TYPEPOSQUERY: - switch(tcode[1]) - { - case OP_ANY: - return SSB_FAIL; - - case OP_NOT_DIGIT: - for (c = 0; c < 32; c++) - start_bits[c] |= ~cd->cbits[c+cbit_digit]; - break; - - case OP_DIGIT: - for (c = 0; c < 32; c++) - start_bits[c] |= cd->cbits[c+cbit_digit]; - break; - - /* The cbit_space table has vertical tab as whitespace; we have to - discard it. */ - - case OP_NOT_WHITESPACE: - for (c = 0; c < 32; c++) - { - int d = cd->cbits[c+cbit_space]; - if (c == 1) d &= ~0x08; - start_bits[c] |= ~d; - } - break; - - /* The cbit_space table has vertical tab as whitespace; we have to - discard it. */ - - case OP_WHITESPACE: - for (c = 0; c < 32; c++) - { - int d = cd->cbits[c+cbit_space]; - if (c == 1) d &= ~0x08; - start_bits[c] |= d; - } - break; - - case OP_NOT_WORDCHAR: - for (c = 0; c < 32; c++) - start_bits[c] |= ~cd->cbits[c+cbit_word]; - break; - - case OP_WORDCHAR: - for (c = 0; c < 32; c++) - start_bits[c] |= cd->cbits[c+cbit_word]; - break; - } - - tcode += 2; - break; - - /* Character class where all the information is in a bit map: set the - bits and either carry on or not, according to the repeat count. If it was - a negative class, and we are operating with UTF-8 characters, any byte - with a value >= 0xc4 is a potentially valid starter because it starts a - character with a value > 255. */ - - case OP_NCLASS: -#ifdef SUPPORT_UTF8 - if (utf8) - { - start_bits[24] |= 0xf0; /* Bits for 0xc4 - 0xc8 */ - memset(start_bits+25, 0xff, 7); /* Bits for 0xc9 - 0xff */ - } -#endif - /* Fall through */ - - case OP_CLASS: - { - tcode++; - - /* In UTF-8 mode, the bits in a bit map correspond to character - values, not to byte values. However, the bit map we are constructing is - for byte values. So we have to do a conversion for characters whose - value is > 127. In fact, there are only two possible starting bytes for - characters in the range 128 - 255. */ - -#ifdef SUPPORT_UTF8 - if (utf8) - { - for (c = 0; c < 16; c++) start_bits[c] |= tcode[c]; - for (c = 128; c < 256; c++) - { - if ((tcode[c/8] && (1 << (c&7))) != 0) - { - int d = (c >> 6) | 0xc0; /* Set bit for this starter */ - start_bits[d/8] |= (1 << (d&7)); /* and then skip on to the */ - c = (c & 0xc0) + 0x40 - 1; /* next relevant character. */ - } - } - } - - /* In non-UTF-8 mode, the two bit maps are completely compatible. */ - - else -#endif - { - for (c = 0; c < 32; c++) start_bits[c] |= tcode[c]; - } - - /* Advance past the bit map, and act on what follows */ - - tcode += 32; - switch (*tcode) - { - case OP_CRSTAR: - case OP_CRMINSTAR: - case OP_CRQUERY: - case OP_CRMINQUERY: - tcode++; - break; - - case OP_CRRANGE: - case OP_CRMINRANGE: - if (((tcode[1] << 8) + tcode[2]) == 0) tcode += 5; - else try_next = FALSE; - break; - - default: - try_next = FALSE; - break; - } - } - break; /* End of bitmap class handling */ - - } /* End of switch */ - } /* End of try_next loop */ - - code += GET(code, 1); /* Advance to next branch */ - } -while (*code == OP_ALT); -return yield; -} - - - -/************************************************* -* Study a compiled expression * -*************************************************/ - -/* This function is handed a compiled expression that it must study to produce -information that will speed up the matching. It returns a pcre_extra block -which then gets handed back to pcre_exec(). - -Arguments: - re points to the compiled expression - options contains option bits - errorptr points to where to place error messages; - set NULL unless error - -Returns: pointer to a pcre_extra block, with study_data filled in and the - appropriate flag set; - NULL on error or if no optimization possible -*/ - -PCRE_EXP_DEFN pcre_extra * -pcre_study(const pcre *external_re, int options, const char **errorptr) -{ -uschar start_bits[32]; -pcre_extra *extra; -pcre_study_data *study; -const uschar *tables; -uschar *code; -compile_data compile_block; -const real_pcre *re = (const real_pcre *)external_re; - -*errorptr = NULL; - -if (re == NULL || re->magic_number != MAGIC_NUMBER) - { - *errorptr = "argument is not a compiled regular expression"; - return NULL; - } - -if ((options & ~PUBLIC_STUDY_OPTIONS) != 0) - { - *errorptr = "unknown or incorrect option bit(s) set"; - return NULL; - } - -code = (uschar *)re + re->name_table_offset + - (re->name_count * re->name_entry_size); - -/* For an anchored pattern, or an unanchored pattern that has a first char, or -a multiline pattern that matches only at "line starts", no further processing -at present. */ - -if ((re->options & PCRE_ANCHORED) != 0 || - (re->flags & (PCRE_FIRSTSET|PCRE_STARTLINE)) != 0) - return NULL; - -/* Set the character tables in the block that is passed around */ - -tables = re->tables; -if (tables == NULL) - (void)pcre_fullinfo(external_re, NULL, PCRE_INFO_DEFAULT_TABLES, - (void *)(&tables)); - -compile_block.lcc = tables + lcc_offset; -compile_block.fcc = tables + fcc_offset; -compile_block.cbits = tables + cbits_offset; -compile_block.ctypes = tables + ctypes_offset; - -/* See if we can find a fixed set of initial characters for the pattern. */ - -memset(start_bits, 0, 32 * sizeof(uschar)); -if (set_start_bits(code, start_bits, (re->options & PCRE_CASELESS) != 0, - (re->options & PCRE_UTF8) != 0, &compile_block) != SSB_DONE) return NULL; - -/* Get a pcre_extra block and a pcre_study_data block. The study data is put in -the latter, which is pointed to by the former, which may also get additional -data set later by the calling program. At the moment, the size of -pcre_study_data is fixed. We nevertheless save it in a field for returning via -the pcre_fullinfo() function so that if it becomes variable in the future, we -don't have to change that code. */ - -extra = (pcre_extra *)(pcre_malloc) - (sizeof(pcre_extra) + sizeof(pcre_study_data)); - -if (extra == NULL) - { - *errorptr = "failed to get memory"; - return NULL; - } - -study = (pcre_study_data *)((char *)extra + sizeof(pcre_extra)); -extra->flags = PCRE_EXTRA_STUDY_DATA; -extra->study_data = study; - -study->size = sizeof(pcre_study_data); -study->options = PCRE_STUDY_MAPPED; -memcpy(study->start_bits, start_bits, sizeof(start_bits)); - -return extra; -} - -/* End of pcre_study.c */ diff --git a/src/plugins/PCREPlugin/pcre_tables.c b/src/plugins/PCREPlugin/pcre_tables.c deleted file mode 100644 index 4b14fd1..0000000 --- a/src/plugins/PCREPlugin/pcre_tables.c +++ /dev/null @@ -1,318 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains some fixed tables that are used by more than one of the -PCRE code modules. The tables are also #included by the pcretest program, which -uses macros to change their names from _pcre_xxx to xxxx, thereby avoiding name -clashes with the library. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/* Table of sizes for the fixed-length opcodes. It's defined in a macro so that -the definition is next to the definition of the opcodes in pcre_internal.h. */ - -const uschar _pcre_OP_lengths[] = { OP_LENGTHS }; - - - -/************************************************* -* Tables for UTF-8 support * -*************************************************/ - -/* These are the breakpoints for different numbers of bytes in a UTF-8 -character. */ - -#ifdef SUPPORT_UTF8 - -const int _pcre_utf8_table1[] = - { 0x7f, 0x7ff, 0xffff, 0x1fffff, 0x3ffffff, 0x7fffffff}; - -const int _pcre_utf8_table1_size = sizeof(_pcre_utf8_table1)/sizeof(int); - -/* These are the indicator bits and the mask for the data bits to set in the -first byte of a character, indexed by the number of additional bytes. */ - -const int _pcre_utf8_table2[] = { 0, 0xc0, 0xe0, 0xf0, 0xf8, 0xfc}; -const int _pcre_utf8_table3[] = { 0xff, 0x1f, 0x0f, 0x07, 0x03, 0x01}; - -/* Table of the number of extra bytes, indexed by the first byte masked with -0x3f. The highest number for a valid UTF-8 first byte is in fact 0x3d. */ - -const uschar _pcre_utf8_table4[] = { - 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, - 2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2, - 3,3,3,3,3,3,3,3,4,4,4,4,5,5,5,5 }; - -/* The pcre_utt[] table below translates Unicode property names into type and -code values. It is searched by binary chop, so must be in collating sequence of -name. Originally, the table contained pointers to the name strings in the first -field of each entry. However, that leads to a large number of relocations when -a shared library is dynamically loaded. A significant reduction is made by -putting all the names into a single, large string and then using offsets in the -table itself. Maintenance is more error-prone, but frequent changes to this -data is unlikely. */ - -const char _pcre_utt_names[] = - "Any\0" - "Arabic\0" - "Armenian\0" - "Balinese\0" - "Bengali\0" - "Bopomofo\0" - "Braille\0" - "Buginese\0" - "Buhid\0" - "C\0" - "Canadian_Aboriginal\0" - "Cc\0" - "Cf\0" - "Cherokee\0" - "Cn\0" - "Co\0" - "Common\0" - "Coptic\0" - "Cs\0" - "Cuneiform\0" - "Cypriot\0" - "Cyrillic\0" - "Deseret\0" - "Devanagari\0" - "Ethiopic\0" - "Georgian\0" - "Glagolitic\0" - "Gothic\0" - "Greek\0" - "Gujarati\0" - "Gurmukhi\0" - "Han\0" - "Hangul\0" - "Hanunoo\0" - "Hebrew\0" - "Hiragana\0" - "Inherited\0" - "Kannada\0" - "Katakana\0" - "Kharoshthi\0" - "Khmer\0" - "L\0" - "L&\0" - "Lao\0" - "Latin\0" - "Limbu\0" - "Linear_B\0" - "Ll\0" - "Lm\0" - "Lo\0" - "Lt\0" - "Lu\0" - "M\0" - "Malayalam\0" - "Mc\0" - "Me\0" - "Mn\0" - "Mongolian\0" - "Myanmar\0" - "N\0" - "Nd\0" - "New_Tai_Lue\0" - "Nko\0" - "Nl\0" - "No\0" - "Ogham\0" - "Old_Italic\0" - "Old_Persian\0" - "Oriya\0" - "Osmanya\0" - "P\0" - "Pc\0" - "Pd\0" - "Pe\0" - "Pf\0" - "Phags_Pa\0" - "Phoenician\0" - "Pi\0" - "Po\0" - "Ps\0" - "Runic\0" - "S\0" - "Sc\0" - "Shavian\0" - "Sinhala\0" - "Sk\0" - "Sm\0" - "So\0" - "Syloti_Nagri\0" - "Syriac\0" - "Tagalog\0" - "Tagbanwa\0" - "Tai_Le\0" - "Tamil\0" - "Telugu\0" - "Thaana\0" - "Thai\0" - "Tibetan\0" - "Tifinagh\0" - "Ugaritic\0" - "Yi\0" - "Z\0" - "Zl\0" - "Zp\0" - "Zs\0"; - -const ucp_type_table _pcre_utt[] = { - { 0, PT_ANY, 0 }, - { 4, PT_SC, ucp_Arabic }, - { 11, PT_SC, ucp_Armenian }, - { 20, PT_SC, ucp_Balinese }, - { 29, PT_SC, ucp_Bengali }, - { 37, PT_SC, ucp_Bopomofo }, - { 46, PT_SC, ucp_Braille }, - { 54, PT_SC, ucp_Buginese }, - { 63, PT_SC, ucp_Buhid }, - { 69, PT_GC, ucp_C }, - { 71, PT_SC, ucp_Canadian_Aboriginal }, - { 91, PT_PC, ucp_Cc }, - { 94, PT_PC, ucp_Cf }, - { 97, PT_SC, ucp_Cherokee }, - { 106, PT_PC, ucp_Cn }, - { 109, PT_PC, ucp_Co }, - { 112, PT_SC, ucp_Common }, - { 119, PT_SC, ucp_Coptic }, - { 126, PT_PC, ucp_Cs }, - { 129, PT_SC, ucp_Cuneiform }, - { 139, PT_SC, ucp_Cypriot }, - { 147, PT_SC, ucp_Cyrillic }, - { 156, PT_SC, ucp_Deseret }, - { 164, PT_SC, ucp_Devanagari }, - { 175, PT_SC, ucp_Ethiopic }, - { 184, PT_SC, ucp_Georgian }, - { 193, PT_SC, ucp_Glagolitic }, - { 204, PT_SC, ucp_Gothic }, - { 211, PT_SC, ucp_Greek }, - { 217, PT_SC, ucp_Gujarati }, - { 226, PT_SC, ucp_Gurmukhi }, - { 235, PT_SC, ucp_Han }, - { 239, PT_SC, ucp_Hangul }, - { 246, PT_SC, ucp_Hanunoo }, - { 254, PT_SC, ucp_Hebrew }, - { 261, PT_SC, ucp_Hiragana }, - { 270, PT_SC, ucp_Inherited }, - { 280, PT_SC, ucp_Kannada }, - { 288, PT_SC, ucp_Katakana }, - { 297, PT_SC, ucp_Kharoshthi }, - { 308, PT_SC, ucp_Khmer }, - { 314, PT_GC, ucp_L }, - { 316, PT_LAMP, 0 }, - { 319, PT_SC, ucp_Lao }, - { 323, PT_SC, ucp_Latin }, - { 329, PT_SC, ucp_Limbu }, - { 335, PT_SC, ucp_Linear_B }, - { 344, PT_PC, ucp_Ll }, - { 347, PT_PC, ucp_Lm }, - { 350, PT_PC, ucp_Lo }, - { 353, PT_PC, ucp_Lt }, - { 356, PT_PC, ucp_Lu }, - { 359, PT_GC, ucp_M }, - { 361, PT_SC, ucp_Malayalam }, - { 371, PT_PC, ucp_Mc }, - { 374, PT_PC, ucp_Me }, - { 377, PT_PC, ucp_Mn }, - { 380, PT_SC, ucp_Mongolian }, - { 390, PT_SC, ucp_Myanmar }, - { 398, PT_GC, ucp_N }, - { 400, PT_PC, ucp_Nd }, - { 403, PT_SC, ucp_New_Tai_Lue }, - { 415, PT_SC, ucp_Nko }, - { 419, PT_PC, ucp_Nl }, - { 422, PT_PC, ucp_No }, - { 425, PT_SC, ucp_Ogham }, - { 431, PT_SC, ucp_Old_Italic }, - { 442, PT_SC, ucp_Old_Persian }, - { 454, PT_SC, ucp_Oriya }, - { 460, PT_SC, ucp_Osmanya }, - { 468, PT_GC, ucp_P }, - { 470, PT_PC, ucp_Pc }, - { 473, PT_PC, ucp_Pd }, - { 476, PT_PC, ucp_Pe }, - { 479, PT_PC, ucp_Pf }, - { 482, PT_SC, ucp_Phags_Pa }, - { 491, PT_SC, ucp_Phoenician }, - { 502, PT_PC, ucp_Pi }, - { 505, PT_PC, ucp_Po }, - { 508, PT_PC, ucp_Ps }, - { 511, PT_SC, ucp_Runic }, - { 517, PT_GC, ucp_S }, - { 519, PT_PC, ucp_Sc }, - { 522, PT_SC, ucp_Shavian }, - { 530, PT_SC, ucp_Sinhala }, - { 538, PT_PC, ucp_Sk }, - { 541, PT_PC, ucp_Sm }, - { 544, PT_PC, ucp_So }, - { 547, PT_SC, ucp_Syloti_Nagri }, - { 560, PT_SC, ucp_Syriac }, - { 567, PT_SC, ucp_Tagalog }, - { 575, PT_SC, ucp_Tagbanwa }, - { 584, PT_SC, ucp_Tai_Le }, - { 591, PT_SC, ucp_Tamil }, - { 597, PT_SC, ucp_Telugu }, - { 604, PT_SC, ucp_Thaana }, - { 611, PT_SC, ucp_Thai }, - { 616, PT_SC, ucp_Tibetan }, - { 624, PT_SC, ucp_Tifinagh }, - { 633, PT_SC, ucp_Ugaritic }, - { 642, PT_SC, ucp_Yi }, - { 645, PT_GC, ucp_Z }, - { 647, PT_PC, ucp_Zl }, - { 650, PT_PC, ucp_Zp }, - { 653, PT_PC, ucp_Zs } -}; - -const int _pcre_utt_size = sizeof(_pcre_utt)/sizeof(ucp_type_table); - -#endif /* SUPPORT_UTF8 */ - -/* End of pcre_tables.c */ diff --git a/src/plugins/PCREPlugin/pcre_try_flipped.c b/src/plugins/PCREPlugin/pcre_try_flipped.c deleted file mode 100644 index 412902b..0000000 --- a/src/plugins/PCREPlugin/pcre_try_flipped.c +++ /dev/null @@ -1,137 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains an internal function that tests a compiled pattern to -see if it was compiled with the opposite endianness. If so, it uses an -auxiliary local function to flip the appropriate bytes. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Flip bytes in an integer * -*************************************************/ - -/* This function is called when the magic number in a regex doesn't match, in -order to flip its bytes to see if we are dealing with a pattern that was -compiled on a host of different endianness. If so, this function is used to -flip other byte values. - -Arguments: - value the number to flip - n the number of bytes to flip (assumed to be 2 or 4) - -Returns: the flipped value -*/ - -static unsigned long int -byteflip(unsigned long int value, int n) -{ -if (n == 2) return ((value & 0x00ff) << 8) | ((value & 0xff00) >> 8); -return ((value & 0x000000ff) << 24) | - ((value & 0x0000ff00) << 8) | - ((value & 0x00ff0000) >> 8) | - ((value & 0xff000000) >> 24); -} - - - -/************************************************* -* Test for a byte-flipped compiled regex * -*************************************************/ - -/* This function is called from pcre_exec(), pcre_dfa_exec(), and also from -pcre_fullinfo(). Its job is to test whether the regex is byte-flipped - that -is, it was compiled on a system of opposite endianness. The function is called -only when the native MAGIC_NUMBER test fails. If the regex is indeed flipped, -we flip all the relevant values into a different data block, and return it. - -Arguments: - re points to the regex - study points to study data, or NULL - internal_re points to a new regex block - internal_study points to a new study block - -Returns: the new block if is is indeed a byte-flipped regex - NULL if it is not -*/ - -real_pcre * -_pcre_try_flipped(const real_pcre *re, real_pcre *internal_re, - const pcre_study_data *study, pcre_study_data *internal_study) -{ -if (byteflip(re->magic_number, sizeof(re->magic_number)) != MAGIC_NUMBER) - return NULL; - -*internal_re = *re; /* To copy other fields */ -internal_re->size = byteflip(re->size, sizeof(re->size)); -internal_re->options = byteflip(re->options, sizeof(re->options)); -internal_re->flags = (pcre_uint16)byteflip(re->flags, sizeof(re->flags)); -internal_re->top_bracket = - (pcre_uint16)byteflip(re->top_bracket, sizeof(re->top_bracket)); -internal_re->top_backref = - (pcre_uint16)byteflip(re->top_backref, sizeof(re->top_backref)); -internal_re->first_byte = - (pcre_uint16)byteflip(re->first_byte, sizeof(re->first_byte)); -internal_re->req_byte = - (pcre_uint16)byteflip(re->req_byte, sizeof(re->req_byte)); -internal_re->name_table_offset = - (pcre_uint16)byteflip(re->name_table_offset, sizeof(re->name_table_offset)); -internal_re->name_entry_size = - (pcre_uint16)byteflip(re->name_entry_size, sizeof(re->name_entry_size)); -internal_re->name_count = - (pcre_uint16)byteflip(re->name_count, sizeof(re->name_count)); - -if (study != NULL) - { - *internal_study = *study; /* To copy other fields */ - internal_study->size = byteflip(study->size, sizeof(study->size)); - internal_study->options = byteflip(study->options, sizeof(study->options)); - } - -return internal_re; -} - -/* End of pcre_tryflipped.c */ diff --git a/src/plugins/PCREPlugin/pcre_ucp_searchfuncs.c b/src/plugins/PCREPlugin/pcre_ucp_searchfuncs.c deleted file mode 100644 index 316163e..0000000 --- a/src/plugins/PCREPlugin/pcre_ucp_searchfuncs.c +++ /dev/null @@ -1,179 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains code for searching the table of Unicode character -properties. */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - -#include "ucp.h" /* Category definitions */ -#include "ucpinternal.h" /* Internal table details */ -#include "ucptable.h" /* The table itself */ - - -/* Table to translate from particular type value to the general value. */ - -static const int ucp_gentype[] = { - ucp_C, ucp_C, ucp_C, ucp_C, ucp_C, /* Cc, Cf, Cn, Co, Cs */ - ucp_L, ucp_L, ucp_L, ucp_L, ucp_L, /* Ll, Lu, Lm, Lo, Lt */ - ucp_M, ucp_M, ucp_M, /* Mc, Me, Mn */ - ucp_N, ucp_N, ucp_N, /* Nd, Nl, No */ - ucp_P, ucp_P, ucp_P, ucp_P, ucp_P, /* Pc, Pd, Pe, Pf, Pi */ - ucp_P, ucp_P, /* Ps, Po */ - ucp_S, ucp_S, ucp_S, ucp_S, /* Sc, Sk, Sm, So */ - ucp_Z, ucp_Z, ucp_Z /* Zl, Zp, Zs */ -}; - - - -/************************************************* -* Search table and return type * -*************************************************/ - -/* Three values are returned: the category is ucp_C, ucp_L, etc. The detailed -character type is ucp_Lu, ucp_Nd, etc. The script is ucp_Latin, etc. - -Arguments: - c the character value - type_ptr the detailed character type is returned here - script_ptr the script is returned here - -Returns: the character type category -*/ - -int -_pcre_ucp_findprop(const unsigned int c, int *type_ptr, int *script_ptr) -{ -int bot = 0; -int top = sizeof(ucp_table)/sizeof(cnode); -int mid; - -/* The table is searched using a binary chop. You might think that using -intermediate variables to hold some of the common expressions would speed -things up, but tests with gcc 3.4.4 on Linux showed that, on the contrary, it -makes things a lot slower. */ - -for (;;) - { - if (top <= bot) - { - *type_ptr = ucp_Cn; - *script_ptr = ucp_Common; - return ucp_C; - } - mid = (bot + top) >> 1; - if (c == (ucp_table[mid].f0 & f0_charmask)) break; - if (c < (ucp_table[mid].f0 & f0_charmask)) top = mid; - else - { - if ((ucp_table[mid].f0 & f0_rangeflag) != 0 && - c <= (ucp_table[mid].f0 & f0_charmask) + - (ucp_table[mid].f1 & f1_rangemask)) break; - bot = mid + 1; - } - } - -/* Found an entry in the table. Set the script and detailed type values, and -return the general type. */ - -*script_ptr = (ucp_table[mid].f0 & f0_scriptmask) >> f0_scriptshift; -*type_ptr = (ucp_table[mid].f1 & f1_typemask) >> f1_typeshift; - -return ucp_gentype[*type_ptr]; -} - - - -/************************************************* -* Search table and return other case * -*************************************************/ - -/* If the given character is a letter, and there is another case for the -letter, return the other case. Otherwise, return -1. - -Arguments: - c the character value - -Returns: the other case or NOTACHAR if none -*/ - -unsigned int -_pcre_ucp_othercase(const unsigned int c) -{ -int bot = 0; -int top = sizeof(ucp_table)/sizeof(cnode); -int mid, offset; - -/* The table is searched using a binary chop. You might think that using -intermediate variables to hold some of the common expressions would speed -things up, but tests with gcc 3.4.4 on Linux showed that, on the contrary, it -makes things a lot slower. */ - -for (;;) - { - if (top <= bot) return -1; - mid = (bot + top) >> 1; - if (c == (ucp_table[mid].f0 & f0_charmask)) break; - if (c < (ucp_table[mid].f0 & f0_charmask)) top = mid; - else - { - if ((ucp_table[mid].f0 & f0_rangeflag) != 0 && - c <= (ucp_table[mid].f0 & f0_charmask) + - (ucp_table[mid].f1 & f1_rangemask)) break; - bot = mid + 1; - } - } - -/* Found an entry in the table. Return NOTACHAR for a range entry. Otherwise -return the other case if there is one, else NOTACHAR. */ - -if ((ucp_table[mid].f0 & f0_rangeflag) != 0) return NOTACHAR; - -offset = ucp_table[mid].f1 & f1_casemask; -if ((offset & f1_caseneg) != 0) offset |= f1_caseneg; -return (offset == 0)? NOTACHAR : c + offset; -} - - -/* End of pcre_ucp_searchfuncs.c */ diff --git a/src/plugins/PCREPlugin/pcre_valid_utf8.c b/src/plugins/PCREPlugin/pcre_valid_utf8.c deleted file mode 100644 index 1899142..0000000 --- a/src/plugins/PCREPlugin/pcre_valid_utf8.c +++ /dev/null @@ -1,162 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains an internal function for validating UTF-8 character -strings. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Validate a UTF-8 string * -*************************************************/ - -/* This function is called (optionally) at the start of compile or match, to -validate that a supposed UTF-8 string is actually valid. The early check means -that subsequent code can assume it is dealing with a valid string. The check -can be turned off for maximum performance, but the consequences of supplying -an invalid string are then undefined. - -Originally, this function checked according to RFC 2279, allowing for values in -the range 0 to 0x7fffffff, up to 6 bytes long, but ensuring that they were in -the canonical format. Once somebody had pointed out RFC 3629 to me (it -obsoletes 2279), additional restrictions were applies. The values are now -limited to be between 0 and 0x0010ffff, no more than 4 bytes long, and the -subrange 0xd000 to 0xdfff is excluded. - -Arguments: - string points to the string - length length of string, or -1 if the string is zero-terminated - -Returns: < 0 if the string is a valid UTF-8 string - >= 0 otherwise; the value is the offset of the bad byte -*/ - -int -_pcre_valid_utf8(const uschar *string, int length) -{ -#ifdef SUPPORT_UTF8 -register const uschar *p; - -if (length < 0) - { - for (p = string; *p != 0; p++); - length = p - string; - } - -for (p = string; length-- > 0; p++) - { - register int ab; - register int c = *p; - if (c < 128) continue; - if (c < 0xc0) return p - string; - ab = _pcre_utf8_table4[c & 0x3f]; /* Number of additional bytes */ - if (length < ab || ab > 3) return p - string; - length -= ab; - - /* Check top bits in the second byte */ - if ((*(++p) & 0xc0) != 0x80) return p - string; - - /* Check for overlong sequences for each different length, and for the - excluded range 0xd000 to 0xdfff. */ - - switch (ab) - { - /* Check for xx00 000x (overlong sequence) */ - - case 1: - if ((c & 0x3e) == 0) return p - string; - continue; /* We know there aren't any more bytes to check */ - - /* Check for 1110 0000, xx0x xxxx (overlong sequence) or - 1110 1101, 1010 xxxx (0xd000 - 0xdfff) */ - - case 2: - if ((c == 0xe0 && (*p & 0x20) == 0) || - (c == 0xed && *p >= 0xa0)) - return p - string; - break; - - /* Check for 1111 0000, xx00 xxxx (overlong sequence) or - greater than 0x0010ffff (f4 8f bf bf) */ - - case 3: - if ((c == 0xf0 && (*p & 0x30) == 0) || - (c > 0xf4 ) || - (c == 0xf4 && *p > 0x8f)) - return p - string; - break; - -#if 0 - /* These cases can no longer occur, as we restrict to a maximum of four - bytes nowadays. Leave the code here in case we ever want to add an option - for longer sequences. */ - - /* Check for 1111 1000, xx00 0xxx */ - case 4: - if (c == 0xf8 && (*p & 0x38) == 0) return p - string; - break; - - /* Check for leading 0xfe or 0xff, and then for 1111 1100, xx00 00xx */ - case 5: - if (c == 0xfe || c == 0xff || - (c == 0xfc && (*p & 0x3c) == 0)) return p - string; - break; -#endif - - } - - /* Check for valid bytes after the 2nd, if any; all must start 10 */ - while (--ab > 0) - { - if ((*(++p) & 0xc0) != 0x80) return p - string; - } - } -#endif - -return -1; -} - -/* End of pcre_valid_utf8.c */ diff --git a/src/plugins/PCREPlugin/pcre_version.c b/src/plugins/PCREPlugin/pcre_version.c deleted file mode 100644 index 425ab21..0000000 --- a/src/plugins/PCREPlugin/pcre_version.c +++ /dev/null @@ -1,90 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains the external function pcre_version(), which returns a -string that identifies the PCRE version that is in use. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Return version string * -*************************************************/ - -/* These macros are the standard way of turning unquoted text into C strings. -They allow macros like PCRE_MAJOR to be defined without quotes, which is -convenient for user programs that want to test its value. */ - -#define STRING(a) # a -#define XSTRING(s) STRING(s) - -/* A problem turned up with PCRE_PRERELEASE, which is defined empty for -production releases. Originally, it was used naively in this code: - - return XSTRING(PCRE_MAJOR) - "." XSTRING(PCRE_MINOR) - XSTRING(PCRE_PRERELEASE) - " " XSTRING(PCRE_DATE); - -However, when PCRE_PRERELEASE is empty, this leads to an attempted expansion of -STRING(). The C standard states: "If (before argument substitution) any -argument consists of no preprocessing tokens, the behavior is undefined." It -turns out the gcc treats this case as a single empty string - which is what we -really want - but Visual C grumbles about the lack of an argument for the -macro. Unfortunately, both are within their rights. To cope with both ways of -handling this, I had resort to some messy hackery that does a test at run time. -I could find no way of detecting that a macro is defined as an empty string at -pre-processor time. This hack uses a standard trick for avoiding calling -the STRING macro with an empty argument when doing the test. */ - -PCRE_EXP_DEFN const char * -pcre_version(void) -{ -return (XSTRING(Z PCRE_PRERELEASE)[1] == 0)? - XSTRING(PCRE_MAJOR.PCRE_MINOR PCRE_DATE) : - XSTRING(PCRE_MAJOR.PCRE_MINOR) XSTRING(PCRE_PRERELEASE PCRE_DATE); -} - -/* End of pcre_version.c */ diff --git a/src/plugins/PCREPlugin/pcre_xclass.c b/src/plugins/PCREPlugin/pcre_xclass.c deleted file mode 100644 index cdf1af1..0000000 --- a/src/plugins/PCREPlugin/pcre_xclass.c +++ /dev/null @@ -1,148 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module contains an internal function that is used to match an extended -class (one that contains characters whose values are > 255). It is used by both -pcre_exec() and pcre_def_exec(). */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "pcre_internal.h" - - -/************************************************* -* Match character against an XCLASS * -*************************************************/ - -/* This function is called to match a character against an extended class that -might contain values > 255. - -Arguments: - c the character - data points to the flag byte of the XCLASS data - -Returns: TRUE if character matches, else FALSE -*/ - -BOOL -_pcre_xclass(int c, const uschar *data) -{ -int t; -BOOL negated = (*data & XCL_NOT) != 0; - -/* Character values < 256 are matched against a bitmap, if one is present. If -not, we still carry on, because there may be ranges that start below 256 in the -additional data. */ - -if (c < 256) - { - if ((*data & XCL_MAP) != 0 && (data[1 + c/8] & (1 << (c&7))) != 0) - return !negated; /* char found */ - } - -/* First skip the bit map if present. Then match against the list of Unicode -properties or large chars or ranges that end with a large char. We won't ever -encounter XCL_PROP or XCL_NOTPROP when UCP support is not compiled. */ - -if ((*data++ & XCL_MAP) != 0) data += 32; - -while ((t = *data++) != XCL_END) - { - int x, y; - if (t == XCL_SINGLE) - { - GETCHARINC(x, data); - if (c == x) return !negated; - } - else if (t == XCL_RANGE) - { - GETCHARINC(x, data); - GETCHARINC(y, data); - if (c >= x && c <= y) return !negated; - } - -#ifdef SUPPORT_UCP - else /* XCL_PROP & XCL_NOTPROP */ - { - int chartype, script; - int category = _pcre_ucp_findprop(c, &chartype, &script); - - switch(*data) - { - case PT_ANY: - if (t == XCL_PROP) return !negated; - break; - - case PT_LAMP: - if ((chartype == ucp_Lu || chartype == ucp_Ll || chartype == ucp_Lt) == - (t == XCL_PROP)) return !negated; - break; - - case PT_GC: - if ((data[1] == category) == (t == XCL_PROP)) return !negated; - break; - - case PT_PC: - if ((data[1] == chartype) == (t == XCL_PROP)) return !negated; - break; - - case PT_SC: - if ((data[1] == script) == (t == XCL_PROP)) return !negated; - break; - - /* This should never occur, but compilers may mutter if there is no - default. */ - - default: - return FALSE; - } - - data += 2; - } -#endif /* SUPPORT_UCP */ - } - -return negated; /* char did not match */ -} - -/* End of pcre_xclass.c */ diff --git a/src/plugins/PCREPlugin/pcreposix.c b/src/plugins/PCREPlugin/pcreposix.c deleted file mode 100644 index 0f73774..0000000 --- a/src/plugins/PCREPlugin/pcreposix.c +++ /dev/null @@ -1,337 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -/* PCRE is a library of functions to support regular expressions whose syntax -and semantics are as close as possible to those of the Perl 5 language. - - Written by Philip Hazel - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - - -/* This module is a wrapper that provides a POSIX API to the underlying PCRE -functions. */ - - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - - -/* Ensure that the PCREPOSIX_EXP_xxx macros are set appropriately for -compiling these functions. This must come before including pcreposix.h, where -they are set for an application (using these functions) if they have not -previously been set. */ - -#if defined(_WIN32) && !defined(PCRE_STATIC) -# define PCREPOSIX_EXP_DECL extern __declspec(dllexport) -# define PCREPOSIX_EXP_DEFN __declspec(dllexport) -#endif - -#include "pcre.h" -#include "pcre_internal.h" -#include "pcreposix.h" - - -/* Table to translate PCRE compile time error codes into POSIX error codes. */ - -static const int eint[] = { - 0, /* no error */ - REG_EESCAPE, /* \ at end of pattern */ - REG_EESCAPE, /* \c at end of pattern */ - REG_EESCAPE, /* unrecognized character follows \ */ - REG_BADBR, /* numbers out of order in {} quantifier */ - REG_BADBR, /* number too big in {} quantifier */ - REG_EBRACK, /* missing terminating ] for character class */ - REG_ECTYPE, /* invalid escape sequence in character class */ - REG_ERANGE, /* range out of order in character class */ - REG_BADRPT, /* nothing to repeat */ - REG_BADRPT, /* operand of unlimited repeat could match the empty string */ - REG_ASSERT, /* internal error: unexpected repeat */ - REG_BADPAT, /* unrecognized character after (? */ - REG_BADPAT, /* POSIX named classes are supported only within a class */ - REG_EPAREN, /* missing ) */ - REG_ESUBREG, /* reference to non-existent subpattern */ - REG_INVARG, /* erroffset passed as NULL */ - REG_INVARG, /* unknown option bit(s) set */ - REG_EPAREN, /* missing ) after comment */ - REG_ESIZE, /* parentheses nested too deeply */ - REG_ESIZE, /* regular expression too large */ - REG_ESPACE, /* failed to get memory */ - REG_EPAREN, /* unmatched brackets */ - REG_ASSERT, /* internal error: code overflow */ - REG_BADPAT, /* unrecognized character after (?< */ - REG_BADPAT, /* lookbehind assertion is not fixed length */ - REG_BADPAT, /* malformed number or name after (?( */ - REG_BADPAT, /* conditional group contains more than two branches */ - REG_BADPAT, /* assertion expected after (?( */ - REG_BADPAT, /* (?R or (?[+-]digits must be followed by ) */ - REG_ECTYPE, /* unknown POSIX class name */ - REG_BADPAT, /* POSIX collating elements are not supported */ - REG_INVARG, /* this version of PCRE is not compiled with PCRE_UTF8 support */ - REG_BADPAT, /* spare error */ - REG_BADPAT, /* character value in \x{...} sequence is too large */ - REG_BADPAT, /* invalid condition (?(0) */ - REG_BADPAT, /* \C not allowed in lookbehind assertion */ - REG_EESCAPE, /* PCRE does not support \L, \l, \N, \U, or \u */ - REG_BADPAT, /* number after (?C is > 255 */ - REG_BADPAT, /* closing ) for (?C expected */ - REG_BADPAT, /* recursive call could loop indefinitely */ - REG_BADPAT, /* unrecognized character after (?P */ - REG_BADPAT, /* syntax error in subpattern name (missing terminator) */ - REG_BADPAT, /* two named subpatterns have the same name */ - REG_BADPAT, /* invalid UTF-8 string */ - REG_BADPAT, /* support for \P, \p, and \X has not been compiled */ - REG_BADPAT, /* malformed \P or \p sequence */ - REG_BADPAT, /* unknown property name after \P or \p */ - REG_BADPAT, /* subpattern name is too long (maximum 32 characters) */ - REG_BADPAT, /* too many named subpatterns (maximum 10,000) */ - REG_BADPAT, /* repeated subpattern is too long */ - REG_BADPAT, /* octal value is greater than \377 (not in UTF-8 mode) */ - REG_BADPAT, /* internal error: overran compiling workspace */ - REG_BADPAT, /* internal error: previously-checked referenced subpattern not found */ - REG_BADPAT, /* DEFINE group contains more than one branch */ - REG_BADPAT, /* repeating a DEFINE group is not allowed */ - REG_INVARG, /* inconsistent NEWLINE options */ - REG_BADPAT, /* \g is not followed followed by an (optionally braced) non-zero number */ - REG_BADPAT, /* (?+ or (?- must be followed by a non-zero number */ - REG_BADPAT /* number is too big */ -}; - -/* Table of texts corresponding to POSIX error codes */ - -static const char *const pstring[] = { - "", /* Dummy for value 0 */ - "internal error", /* REG_ASSERT */ - "invalid repeat counts in {}", /* BADBR */ - "pattern error", /* BADPAT */ - "? * + invalid", /* BADRPT */ - "unbalanced {}", /* EBRACE */ - "unbalanced []", /* EBRACK */ - "collation error - not relevant", /* ECOLLATE */ - "bad class", /* ECTYPE */ - "bad escape sequence", /* EESCAPE */ - "empty expression", /* EMPTY */ - "unbalanced ()", /* EPAREN */ - "bad range inside []", /* ERANGE */ - "expression too big", /* ESIZE */ - "failed to get memory", /* ESPACE */ - "bad back reference", /* ESUBREG */ - "bad argument", /* INVARG */ - "match failed" /* NOMATCH */ -}; - - - - -/************************************************* -* Translate error code to string * -*************************************************/ - -PCREPOSIX_EXP_DEFN size_t -regerror(int errcode, const regex_t *preg, char *errbuf, size_t errbuf_size) -{ -const char *message, *addmessage; -size_t length, addlength; - -message = (errcode >= (int)(sizeof(pstring)/sizeof(char *)))? - "unknown error code" : pstring[errcode]; -length = strlen(message) + 1; - -addmessage = " at offset "; -addlength = (preg != NULL && (int)preg->re_erroffset != -1)? - strlen(addmessage) + 6 : 0; - -if (errbuf_size > 0) - { - if (addlength > 0 && errbuf_size >= length + addlength) - sprintf(errbuf, "%s%s%-6d", message, addmessage, (int)preg->re_erroffset); - else - { - strncpy(errbuf, message, errbuf_size - 1); - errbuf[errbuf_size-1] = 0; - } - } - -return length + addlength; -} - - - - -/************************************************* -* Free store held by a regex * -*************************************************/ - -PCREPOSIX_EXP_DEFN void -regfree(regex_t *preg) -{ -(pcre_free)(preg->re_pcre); -} - - - - -/************************************************* -* Compile a regular expression * -*************************************************/ - -/* -Arguments: - preg points to a structure for recording the compiled expression - pattern the pattern to compile - cflags compilation flags - -Returns: 0 on success - various non-zero codes on failure -*/ - -PCREPOSIX_EXP_DEFN int -regcomp(regex_t *preg, const char *pattern, int cflags) -{ -const char *errorptr; -int erroffset; -int errorcode; -int options = 0; - -if ((cflags & REG_ICASE) != 0) options |= PCRE_CASELESS; -if ((cflags & REG_NEWLINE) != 0) options |= PCRE_MULTILINE; -if ((cflags & REG_DOTALL) != 0) options |= PCRE_DOTALL; -if ((cflags & REG_NOSUB) != 0) options |= PCRE_NO_AUTO_CAPTURE; -if ((cflags & REG_UTF8) != 0) options |= PCRE_UTF8; - -preg->re_pcre = pcre_compile2(pattern, options, &errorcode, &errorptr, - &erroffset, NULL); -preg->re_erroffset = erroffset; - -if (preg->re_pcre == NULL) return eint[errorcode]; - -preg->re_nsub = pcre_info((const pcre *)preg->re_pcre, NULL, NULL); -return 0; -} - - - - -/************************************************* -* Match a regular expression * -*************************************************/ - -/* Unfortunately, PCRE requires 3 ints of working space for each captured -substring, so we have to get and release working store instead of just using -the POSIX structures as was done in earlier releases when PCRE needed only 2 -ints. However, if the number of possible capturing brackets is small, use a -block of store on the stack, to reduce the use of malloc/free. The threshold is -in a macro that can be changed at configure time. - -If REG_NOSUB was specified at compile time, the PCRE_NO_AUTO_CAPTURE flag will -be set. When this is the case, the nmatch and pmatch arguments are ignored, and -the only result is yes/no/error. */ - -PCREPOSIX_EXP_DEFN int -regexec(const regex_t *preg, const char *string, size_t nmatch, - regmatch_t pmatch[], int eflags) -{ -int rc; -int options = 0; -int *ovector = NULL; -int small_ovector[POSIX_MALLOC_THRESHOLD * 3]; -BOOL allocated_ovector = FALSE; -BOOL nosub = - (((const pcre *)preg->re_pcre)->options & PCRE_NO_AUTO_CAPTURE) != 0; - -if ((eflags & REG_NOTBOL) != 0) options |= PCRE_NOTBOL; -if ((eflags & REG_NOTEOL) != 0) options |= PCRE_NOTEOL; - -((regex_t *)preg)->re_erroffset = (size_t)(-1); /* Only has meaning after compile */ - -/* When no string data is being returned, ensure that nmatch is zero. -Otherwise, ensure the vector for holding the return data is large enough. */ - -if (nosub) nmatch = 0; - -else if (nmatch > 0) - { - if (nmatch <= POSIX_MALLOC_THRESHOLD) - { - ovector = &(small_ovector[0]); - } - else - { - if (nmatch > INT_MAX/(sizeof(int) * 3)) return REG_ESPACE; - ovector = (int *)malloc(sizeof(int) * nmatch * 3); - if (ovector == NULL) return REG_ESPACE; - allocated_ovector = TRUE; - } - } - -rc = pcre_exec((const pcre *)preg->re_pcre, NULL, string, (int)strlen(string), - 0, options, ovector, nmatch * 3); - -if (rc == 0) rc = nmatch; /* All captured slots were filled in */ - -if (rc >= 0) - { - size_t i; - if (!nosub) - { - for (i = 0; i < (size_t)rc; i++) - { - pmatch[i].rm_so = ovector[i*2]; - pmatch[i].rm_eo = ovector[i*2+1]; - } - if (allocated_ovector) free(ovector); - for (; i < nmatch; i++) pmatch[i].rm_so = pmatch[i].rm_eo = -1; - } - return 0; - } - -else - { - if (allocated_ovector) free(ovector); - switch(rc) - { - case PCRE_ERROR_NOMATCH: return REG_NOMATCH; - case PCRE_ERROR_NULL: return REG_INVARG; - case PCRE_ERROR_BADOPTION: return REG_INVARG; - case PCRE_ERROR_BADMAGIC: return REG_INVARG; - case PCRE_ERROR_UNKNOWN_NODE: return REG_ASSERT; - case PCRE_ERROR_NOMEMORY: return REG_ESPACE; - case PCRE_ERROR_MATCHLIMIT: return REG_ESPACE; - case PCRE_ERROR_BADUTF8: return REG_INVARG; - case PCRE_ERROR_BADUTF8_OFFSET: return REG_INVARG; - default: return REG_ASSERT; - } - } -} - -/* End of pcreposix.c */ diff --git a/src/plugins/PCREPlugin/pcreposix.h b/src/plugins/PCREPlugin/pcreposix.h deleted file mode 100644 index 875e1ff..0000000 --- a/src/plugins/PCREPlugin/pcreposix.h +++ /dev/null @@ -1,142 +0,0 @@ -/************************************************* -* Perl-Compatible Regular Expressions * -*************************************************/ - -#ifndef _PCREPOSIX_H -#define _PCREPOSIX_H - -/* This is the header for the POSIX wrapper interface to the PCRE Perl- -Compatible Regular Expression library. It defines the things POSIX says should -be there. I hope. - - Copyright (c) 1997-2007 University of Cambridge - ------------------------------------------------------------------------------ -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - * Neither the name of the University of Cambridge nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -POSSIBILITY OF SUCH DAMAGE. ------------------------------------------------------------------------------ -*/ - -/* Have to include stdlib.h in order to ensure that size_t is defined. */ - -#include - -/* Allow for C++ users */ - -#ifdef __cplusplus -extern "C" { -#endif - -/* Options, mostly defined by POSIX, but with a couple of extras. */ - -#define REG_ICASE 0x0001 -#define REG_NEWLINE 0x0002 -#define REG_NOTBOL 0x0004 -#define REG_NOTEOL 0x0008 -#define REG_DOTALL 0x0010 /* NOT defined by POSIX. */ -#define REG_NOSUB 0x0020 -#define REG_UTF8 0x0040 /* NOT defined by POSIX. */ - -/* This is not used by PCRE, but by defining it we make it easier -to slot PCRE into existing programs that make POSIX calls. */ - -#define REG_EXTENDED 0 - -/* Error values. Not all these are relevant or used by the wrapper. */ - -enum { - REG_ASSERT = 1, /* internal error ? */ - REG_BADBR, /* invalid repeat counts in {} */ - REG_BADPAT, /* pattern error */ - REG_BADRPT, /* ? * + invalid */ - REG_EBRACE, /* unbalanced {} */ - REG_EBRACK, /* unbalanced [] */ - REG_ECOLLATE, /* collation error - not relevant */ - REG_ECTYPE, /* bad class */ - REG_EESCAPE, /* bad escape sequence */ - REG_EMPTY, /* empty expression */ - REG_EPAREN, /* unbalanced () */ - REG_ERANGE, /* bad range inside [] */ - REG_ESIZE, /* expression too big */ - REG_ESPACE, /* failed to get memory */ - REG_ESUBREG, /* bad back reference */ - REG_INVARG, /* bad argument */ - REG_NOMATCH /* match failed */ -}; - - -/* The structure representing a compiled regular expression. */ - -typedef struct { - void *re_pcre; - size_t re_nsub; - size_t re_erroffset; -} regex_t; - -/* The structure in which a captured offset is returned. */ - -typedef int regoff_t; - -typedef struct { - regoff_t rm_so; - regoff_t rm_eo; -} regmatch_t; - -/* When an application links to a PCRE DLL in Windows, the symbols that are -imported have to be identified as such. When building PCRE, the appropriate -export settings are needed, and are set in pcreposix.c before including this -file. */ - -#if defined(_WIN32) && !defined(PCRE_STATIC) && !defined(PCREPOSIX_EXP_DECL) -# define PCREPOSIX_EXP_DECL extern __declspec(dllimport) -# define PCREPOSIX_EXP_DEFN __declspec(dllimport) -#endif - -/* By default, we use the standard "extern" declarations. */ - -#ifndef PCREPOSIX_EXP_DECL -# ifdef __cplusplus -# define PCREPOSIX_EXP_DECL extern "C" -# define PCREPOSIX_EXP_DEFN extern "C" -# else -# define PCREPOSIX_EXP_DECL extern -# define PCREPOSIX_EXP_DEFN extern -# endif -#endif - -/* The functions */ - -PCREPOSIX_EXP_DECL int regcomp(regex_t *, const char *, int); -PCREPOSIX_EXP_DECL int regexec(const regex_t *, const char *, size_t, - regmatch_t *, int); -PCREPOSIX_EXP_DECL size_t regerror(int, const regex_t *, char *, size_t); -PCREPOSIX_EXP_DECL void regfree(regex_t *); - -#ifdef __cplusplus -} /* extern "C" */ -#endif - -#endif /* End of pcreposix.h */ diff --git a/src/plugins/PCREPlugin/ucp.h b/src/plugins/PCREPlugin/ucp.h deleted file mode 100644 index 3a4179b..0000000 --- a/src/plugins/PCREPlugin/ucp.h +++ /dev/null @@ -1,133 +0,0 @@ -/************************************************* -* Unicode Property Table handler * -*************************************************/ - -#ifndef _UCP_H -#define _UCP_H - -/* This file contains definitions of the property values that are returned by -the function _pcre_ucp_findprop(). New values that are added for new releases -of Unicode should always be at the end of each enum, for backwards -compatibility. */ - -/* These are the general character categories. */ - -enum { - ucp_C, /* Other */ - ucp_L, /* Letter */ - ucp_M, /* Mark */ - ucp_N, /* Number */ - ucp_P, /* Punctuation */ - ucp_S, /* Symbol */ - ucp_Z /* Separator */ -}; - -/* These are the particular character types. */ - -enum { - ucp_Cc, /* Control */ - ucp_Cf, /* Format */ - ucp_Cn, /* Unassigned */ - ucp_Co, /* Private use */ - ucp_Cs, /* Surrogate */ - ucp_Ll, /* Lower case letter */ - ucp_Lm, /* Modifier letter */ - ucp_Lo, /* Other letter */ - ucp_Lt, /* Title case letter */ - ucp_Lu, /* Upper case letter */ - ucp_Mc, /* Spacing mark */ - ucp_Me, /* Enclosing mark */ - ucp_Mn, /* Non-spacing mark */ - ucp_Nd, /* Decimal number */ - ucp_Nl, /* Letter number */ - ucp_No, /* Other number */ - ucp_Pc, /* Connector punctuation */ - ucp_Pd, /* Dash punctuation */ - ucp_Pe, /* Close punctuation */ - ucp_Pf, /* Final punctuation */ - ucp_Pi, /* Initial punctuation */ - ucp_Po, /* Other punctuation */ - ucp_Ps, /* Open punctuation */ - ucp_Sc, /* Currency symbol */ - ucp_Sk, /* Modifier symbol */ - ucp_Sm, /* Mathematical symbol */ - ucp_So, /* Other symbol */ - ucp_Zl, /* Line separator */ - ucp_Zp, /* Paragraph separator */ - ucp_Zs /* Space separator */ -}; - -/* These are the script identifications. */ - -enum { - ucp_Arabic, - ucp_Armenian, - ucp_Bengali, - ucp_Bopomofo, - ucp_Braille, - ucp_Buginese, - ucp_Buhid, - ucp_Canadian_Aboriginal, - ucp_Cherokee, - ucp_Common, - ucp_Coptic, - ucp_Cypriot, - ucp_Cyrillic, - ucp_Deseret, - ucp_Devanagari, - ucp_Ethiopic, - ucp_Georgian, - ucp_Glagolitic, - ucp_Gothic, - ucp_Greek, - ucp_Gujarati, - ucp_Gurmukhi, - ucp_Han, - ucp_Hangul, - ucp_Hanunoo, - ucp_Hebrew, - ucp_Hiragana, - ucp_Inherited, - ucp_Kannada, - ucp_Katakana, - ucp_Kharoshthi, - ucp_Khmer, - ucp_Lao, - ucp_Latin, - ucp_Limbu, - ucp_Linear_B, - ucp_Malayalam, - ucp_Mongolian, - ucp_Myanmar, - ucp_New_Tai_Lue, - ucp_Ogham, - ucp_Old_Italic, - ucp_Old_Persian, - ucp_Oriya, - ucp_Osmanya, - ucp_Runic, - ucp_Shavian, - ucp_Sinhala, - ucp_Syloti_Nagri, - ucp_Syriac, - ucp_Tagalog, - ucp_Tagbanwa, - ucp_Tai_Le, - ucp_Tamil, - ucp_Telugu, - ucp_Thaana, - ucp_Thai, - ucp_Tibetan, - ucp_Tifinagh, - ucp_Ugaritic, - ucp_Yi, - ucp_Balinese, /* New for Unicode 5.0.0 */ - ucp_Cuneiform, /* New for Unicode 5.0.0 */ - ucp_Nko, /* New for Unicode 5.0.0 */ - ucp_Phags_Pa, /* New for Unicode 5.0.0 */ - ucp_Phoenician /* New for Unicode 5.0.0 */ -}; - -#endif - -/* End of ucp.h */ diff --git a/src/plugins/PCREPlugin/ucpinternal.h b/src/plugins/PCREPlugin/ucpinternal.h deleted file mode 100644 index 811a373..0000000 --- a/src/plugins/PCREPlugin/ucpinternal.h +++ /dev/null @@ -1,92 +0,0 @@ -/************************************************* -* Unicode Property Table handler * -*************************************************/ - -#ifndef _UCPINTERNAL_H -#define _UCPINTERNAL_H - -/* Internal header file defining the layout of the bits in each pair of 32-bit -words that form a data item in the table. */ - -typedef struct cnode { - pcre_uint32 f0; - pcre_uint32 f1; -} cnode; - -/* Things for the f0 field */ - -#define f0_scriptmask 0xff000000 /* Mask for script field */ -#define f0_scriptshift 24 /* Shift for script value */ -#define f0_rangeflag 0x00f00000 /* Flag for a range item */ -#define f0_charmask 0x001fffff /* Mask for code point value */ - -/* Things for the f1 field */ - -#define f1_typemask 0xfc000000 /* Mask for char type field */ -#define f1_typeshift 26 /* Shift for the type field */ -#define f1_rangemask 0x0000ffff /* Mask for a range offset */ -#define f1_casemask 0x0000ffff /* Mask for a case offset */ -#define f1_caseneg 0xffff8000 /* Bits for negation */ - -/* The data consists of a vector of structures of type cnode. The two unsigned -32-bit integers are used as follows: - -(f0) (1) The most significant byte holds the script number. The numbers are - defined by the enum in ucp.h. - - (2) The 0x00800000 bit is set if this entry defines a range of characters. - It is not set if this entry defines a single character - - (3) The 0x00600000 bits are spare. - - (4) The 0x001fffff bits contain the code point. No Unicode code point will - ever be greater than 0x0010ffff, so this should be OK for ever. - -(f1) (1) The 0xfc000000 bits contain the character type number. The numbers are - defined by an enum in ucp.h. - - (2) The 0x03ff0000 bits are spare. - - (3) The 0x0000ffff bits contain EITHER the unsigned offset to the top of - range if this entry defines a range, OR the *signed* offset to the - character's "other case" partner if this entry defines a single - character. There is no partner if the value is zero. - -------------------------------------------------------------------------------- -| script (8) |.|.|.| codepoint (21) || type (6) |.|.| spare (8) | offset (16) | -------------------------------------------------------------------------------- - | | | | | - | | |-> spare | |-> spare - | | | - | |-> spare |-> spare - | - |-> range flag - -The upper/lower casing information is set only for characters that come in -pairs. The non-one-to-one mappings in the Unicode data are ignored. - -When searching the data, proceed as follows: - -(1) Set up for a binary chop search. - -(2) If the top is not greater than the bottom, the character is not in the - table. Its type must therefore be "Cn" ("Undefined"). - -(3) Find the middle vector element. - -(4) Extract the code point and compare. If equal, we are done. - -(5) If the test character is smaller, set the top to the current point, and - goto (2). - -(6) If the current entry defines a range, compute the last character by adding - the offset, and see if the test character is within the range. If it is, - we are done. - -(7) Otherwise, set the bottom to one element past the current point and goto - (2). -*/ - -#endif /* _UCPINTERNAL_H */ - -/* End of ucpinternal.h */ diff --git a/src/plugins/PCREPlugin/ucptable.c b/src/plugins/PCREPlugin/ucptable.c deleted file mode 100644 index 0b17906..0000000 --- a/src/plugins/PCREPlugin/ucptable.c +++ /dev/null @@ -1,3068 +0,0 @@ -/* This source module is automatically generated from the Unicode -property table. See ucpinternal.h for a description of the layout. -This version was made from the Unicode 5.0.0 tables. */ - -static cnode ucp_table[] = { - { 0x09800000, 0x0000001f }, - { 0x09000020, 0x74000000 }, - { 0x09800021, 0x54000002 }, - { 0x09000024, 0x5c000000 }, - { 0x09800025, 0x54000002 }, - { 0x09000028, 0x58000000 }, - { 0x09000029, 0x48000000 }, - { 0x0900002a, 0x54000000 }, - { 0x0900002b, 0x64000000 }, - { 0x0900002c, 0x54000000 }, - { 0x0900002d, 0x44000000 }, - { 0x0980002e, 0x54000001 }, - { 0x09800030, 0x34000009 }, - { 0x0980003a, 0x54000001 }, - { 0x0980003c, 0x64000002 }, - { 0x0980003f, 0x54000001 }, - { 0x21000041, 0x24000020 }, - { 0x21000042, 0x24000020 }, - { 0x21000043, 0x24000020 }, - { 0x21000044, 0x24000020 }, - { 0x21000045, 0x24000020 }, - { 0x21000046, 0x24000020 }, - { 0x21000047, 0x24000020 }, - { 0x21000048, 0x24000020 }, - { 0x21000049, 0x24000020 }, - { 0x2100004a, 0x24000020 }, - { 0x2100004b, 0x24000020 }, - { 0x2100004c, 0x24000020 }, - { 0x2100004d, 0x24000020 }, - { 0x2100004e, 0x24000020 }, - { 0x2100004f, 0x24000020 }, - { 0x21000050, 0x24000020 }, - { 0x21000051, 0x24000020 }, - { 0x21000052, 0x24000020 }, - { 0x21000053, 0x24000020 }, - { 0x21000054, 0x24000020 }, - { 0x21000055, 0x24000020 }, - { 0x21000056, 0x24000020 }, - { 0x21000057, 0x24000020 }, - { 0x21000058, 0x24000020 }, - { 0x21000059, 0x24000020 }, - { 0x2100005a, 0x24000020 }, - { 0x0900005b, 0x58000000 }, - { 0x0900005c, 0x54000000 }, - { 0x0900005d, 0x48000000 }, - { 0x0900005e, 0x60000000 }, - { 0x0900005f, 0x40000000 }, - { 0x09000060, 0x60000000 }, - { 0x21000061, 0x1400ffe0 }, - { 0x21000062, 0x1400ffe0 }, - { 0x21000063, 0x1400ffe0 }, - { 0x21000064, 0x1400ffe0 }, - { 0x21000065, 0x1400ffe0 }, - { 0x21000066, 0x1400ffe0 }, - { 0x21000067, 0x1400ffe0 }, - { 0x21000068, 0x1400ffe0 }, - { 0x21000069, 0x1400ffe0 }, - { 0x2100006a, 0x1400ffe0 }, - { 0x2100006b, 0x1400ffe0 }, - { 0x2100006c, 0x1400ffe0 }, - { 0x2100006d, 0x1400ffe0 }, - { 0x2100006e, 0x1400ffe0 }, - { 0x2100006f, 0x1400ffe0 }, - { 0x21000070, 0x1400ffe0 }, - { 0x21000071, 0x1400ffe0 }, - { 0x21000072, 0x1400ffe0 }, - { 0x21000073, 0x1400ffe0 }, - { 0x21000074, 0x1400ffe0 }, - { 0x21000075, 0x1400ffe0 }, - { 0x21000076, 0x1400ffe0 }, - { 0x21000077, 0x1400ffe0 }, - { 0x21000078, 0x1400ffe0 }, - { 0x21000079, 0x1400ffe0 }, - { 0x2100007a, 0x1400ffe0 }, - { 0x0900007b, 0x58000000 }, - { 0x0900007c, 0x64000000 }, - { 0x0900007d, 0x48000000 }, - { 0x0900007e, 0x64000000 }, - { 0x0980007f, 0x00000020 }, - { 0x090000a0, 0x74000000 }, - { 0x090000a1, 0x54000000 }, - { 0x098000a2, 0x5c000003 }, - { 0x098000a6, 0x68000001 }, - { 0x090000a8, 0x60000000 }, - { 0x090000a9, 0x68000000 }, - { 0x210000aa, 0x14000000 }, - { 0x090000ab, 0x50000000 }, - { 0x090000ac, 0x64000000 }, - { 0x090000ad, 0x04000000 }, - { 0x090000ae, 0x68000000 }, - { 0x090000af, 0x60000000 }, - { 0x090000b0, 0x68000000 }, - { 0x090000b1, 0x64000000 }, - { 0x098000b2, 0x3c000001 }, - { 0x090000b4, 0x60000000 }, - { 0x090000b5, 0x140002e7 }, - { 0x090000b6, 0x68000000 }, - { 0x090000b7, 0x54000000 }, - { 0x090000b8, 0x60000000 }, - { 0x090000b9, 0x3c000000 }, - { 0x210000ba, 0x14000000 }, - { 0x090000bb, 0x4c000000 }, - { 0x098000bc, 0x3c000002 }, - { 0x090000bf, 0x54000000 }, - { 0x210000c0, 0x24000020 }, - { 0x210000c1, 0x24000020 }, - { 0x210000c2, 0x24000020 }, - { 0x210000c3, 0x24000020 }, - { 0x210000c4, 0x24000020 }, - { 0x210000c5, 0x24000020 }, - { 0x210000c6, 0x24000020 }, - { 0x210000c7, 0x24000020 }, - { 0x210000c8, 0x24000020 }, - { 0x210000c9, 0x24000020 }, - { 0x210000ca, 0x24000020 }, - { 0x210000cb, 0x24000020 }, - { 0x210000cc, 0x24000020 }, - { 0x210000cd, 0x24000020 }, - { 0x210000ce, 0x24000020 }, - { 0x210000cf, 0x24000020 }, - { 0x210000d0, 0x24000020 }, - { 0x210000d1, 0x24000020 }, - { 0x210000d2, 0x24000020 }, - { 0x210000d3, 0x24000020 }, - { 0x210000d4, 0x24000020 }, - { 0x210000d5, 0x24000020 }, - { 0x210000d6, 0x24000020 }, - { 0x090000d7, 0x64000000 }, - { 0x210000d8, 0x24000020 }, - { 0x210000d9, 0x24000020 }, - { 0x210000da, 0x24000020 }, - { 0x210000db, 0x24000020 }, - { 0x210000dc, 0x24000020 }, - { 0x210000dd, 0x24000020 }, - { 0x210000de, 0x24000020 }, - { 0x210000df, 0x14000000 }, - { 0x210000e0, 0x1400ffe0 }, - { 0x210000e1, 0x1400ffe0 }, - { 0x210000e2, 0x1400ffe0 }, - { 0x210000e3, 0x1400ffe0 }, - { 0x210000e4, 0x1400ffe0 }, - { 0x210000e5, 0x1400ffe0 }, - { 0x210000e6, 0x1400ffe0 }, - { 0x210000e7, 0x1400ffe0 }, - { 0x210000e8, 0x1400ffe0 }, - { 0x210000e9, 0x1400ffe0 }, - { 0x210000ea, 0x1400ffe0 }, - { 0x210000eb, 0x1400ffe0 }, - { 0x210000ec, 0x1400ffe0 }, - { 0x210000ed, 0x1400ffe0 }, - { 0x210000ee, 0x1400ffe0 }, - { 0x210000ef, 0x1400ffe0 }, - { 0x210000f0, 0x1400ffe0 }, - { 0x210000f1, 0x1400ffe0 }, - { 0x210000f2, 0x1400ffe0 }, - { 0x210000f3, 0x1400ffe0 }, - { 0x210000f4, 0x1400ffe0 }, - { 0x210000f5, 0x1400ffe0 }, - { 0x210000f6, 0x1400ffe0 }, - { 0x090000f7, 0x64000000 }, - { 0x210000f8, 0x1400ffe0 }, - { 0x210000f9, 0x1400ffe0 }, - { 0x210000fa, 0x1400ffe0 }, - { 0x210000fb, 0x1400ffe0 }, - { 0x210000fc, 0x1400ffe0 }, - { 0x210000fd, 0x1400ffe0 }, - { 0x210000fe, 0x1400ffe0 }, - { 0x210000ff, 0x14000079 }, - { 0x21000100, 0x24000001 }, - { 0x21000101, 0x1400ffff }, - { 0x21000102, 0x24000001 }, - { 0x21000103, 0x1400ffff }, - { 0x21000104, 0x24000001 }, - { 0x21000105, 0x1400ffff }, - { 0x21000106, 0x24000001 }, - { 0x21000107, 0x1400ffff }, - { 0x21000108, 0x24000001 }, - { 0x21000109, 0x1400ffff }, - { 0x2100010a, 0x24000001 }, - { 0x2100010b, 0x1400ffff }, - { 0x2100010c, 0x24000001 }, - { 0x2100010d, 0x1400ffff }, - { 0x2100010e, 0x24000001 }, - { 0x2100010f, 0x1400ffff }, - { 0x21000110, 0x24000001 }, - { 0x21000111, 0x1400ffff }, - { 0x21000112, 0x24000001 }, - { 0x21000113, 0x1400ffff }, - { 0x21000114, 0x24000001 }, - { 0x21000115, 0x1400ffff }, - { 0x21000116, 0x24000001 }, - { 0x21000117, 0x1400ffff }, - { 0x21000118, 0x24000001 }, - { 0x21000119, 0x1400ffff }, - { 0x2100011a, 0x24000001 }, - { 0x2100011b, 0x1400ffff }, - { 0x2100011c, 0x24000001 }, - { 0x2100011d, 0x1400ffff }, - { 0x2100011e, 0x24000001 }, - { 0x2100011f, 0x1400ffff }, - { 0x21000120, 0x24000001 }, - { 0x21000121, 0x1400ffff }, - { 0x21000122, 0x24000001 }, - { 0x21000123, 0x1400ffff }, - { 0x21000124, 0x24000001 }, - { 0x21000125, 0x1400ffff }, - { 0x21000126, 0x24000001 }, - { 0x21000127, 0x1400ffff }, - { 0x21000128, 0x24000001 }, - { 0x21000129, 0x1400ffff }, - { 0x2100012a, 0x24000001 }, - { 0x2100012b, 0x1400ffff }, - { 0x2100012c, 0x24000001 }, - { 0x2100012d, 0x1400ffff }, - { 0x2100012e, 0x24000001 }, - { 0x2100012f, 0x1400ffff }, - { 0x21000130, 0x2400ff39 }, - { 0x21000131, 0x1400ff18 }, - { 0x21000132, 0x24000001 }, - { 0x21000133, 0x1400ffff }, - { 0x21000134, 0x24000001 }, - { 0x21000135, 0x1400ffff }, - { 0x21000136, 0x24000001 }, - { 0x21000137, 0x1400ffff }, - { 0x21000138, 0x14000000 }, - { 0x21000139, 0x24000001 }, - { 0x2100013a, 0x1400ffff }, - { 0x2100013b, 0x24000001 }, - { 0x2100013c, 0x1400ffff }, - { 0x2100013d, 0x24000001 }, - { 0x2100013e, 0x1400ffff }, - { 0x2100013f, 0x24000001 }, - { 0x21000140, 0x1400ffff }, - { 0x21000141, 0x24000001 }, - { 0x21000142, 0x1400ffff }, - { 0x21000143, 0x24000001 }, - { 0x21000144, 0x1400ffff }, - { 0x21000145, 0x24000001 }, - { 0x21000146, 0x1400ffff }, - { 0x21000147, 0x24000001 }, - { 0x21000148, 0x1400ffff }, - { 0x21000149, 0x14000000 }, - { 0x2100014a, 0x24000001 }, - { 0x2100014b, 0x1400ffff }, - { 0x2100014c, 0x24000001 }, - { 0x2100014d, 0x1400ffff }, - { 0x2100014e, 0x24000001 }, - { 0x2100014f, 0x1400ffff }, - { 0x21000150, 0x24000001 }, - { 0x21000151, 0x1400ffff }, - { 0x21000152, 0x24000001 }, - { 0x21000153, 0x1400ffff }, - { 0x21000154, 0x24000001 }, - { 0x21000155, 0x1400ffff }, - { 0x21000156, 0x24000001 }, - { 0x21000157, 0x1400ffff }, - { 0x21000158, 0x24000001 }, - { 0x21000159, 0x1400ffff }, - { 0x2100015a, 0x24000001 }, - { 0x2100015b, 0x1400ffff }, - { 0x2100015c, 0x24000001 }, - { 0x2100015d, 0x1400ffff }, - { 0x2100015e, 0x24000001 }, - { 0x2100015f, 0x1400ffff }, - { 0x21000160, 0x24000001 }, - { 0x21000161, 0x1400ffff }, - { 0x21000162, 0x24000001 }, - { 0x21000163, 0x1400ffff }, - { 0x21000164, 0x24000001 }, - { 0x21000165, 0x1400ffff }, - { 0x21000166, 0x24000001 }, - { 0x21000167, 0x1400ffff }, - { 0x21000168, 0x24000001 }, - { 0x21000169, 0x1400ffff }, - { 0x2100016a, 0x24000001 }, - { 0x2100016b, 0x1400ffff }, - { 0x2100016c, 0x24000001 }, - { 0x2100016d, 0x1400ffff }, - { 0x2100016e, 0x24000001 }, - { 0x2100016f, 0x1400ffff }, - { 0x21000170, 0x24000001 }, - { 0x21000171, 0x1400ffff }, - { 0x21000172, 0x24000001 }, - { 0x21000173, 0x1400ffff }, - { 0x21000174, 0x24000001 }, - { 0x21000175, 0x1400ffff }, - { 0x21000176, 0x24000001 }, - { 0x21000177, 0x1400ffff }, - { 0x21000178, 0x2400ff87 }, - { 0x21000179, 0x24000001 }, - { 0x2100017a, 0x1400ffff }, - { 0x2100017b, 0x24000001 }, - { 0x2100017c, 0x1400ffff }, - { 0x2100017d, 0x24000001 }, - { 0x2100017e, 0x1400ffff }, - { 0x2100017f, 0x1400fed4 }, - { 0x21000180, 0x140000c3 }, - { 0x21000181, 0x240000d2 }, - { 0x21000182, 0x24000001 }, - { 0x21000183, 0x1400ffff }, - { 0x21000184, 0x24000001 }, - { 0x21000185, 0x1400ffff }, - { 0x21000186, 0x240000ce }, - { 0x21000187, 0x24000001 }, - { 0x21000188, 0x1400ffff }, - { 0x21000189, 0x240000cd }, - { 0x2100018a, 0x240000cd }, - { 0x2100018b, 0x24000001 }, - { 0x2100018c, 0x1400ffff }, - { 0x2100018d, 0x14000000 }, - { 0x2100018e, 0x2400004f }, - { 0x2100018f, 0x240000ca }, - { 0x21000190, 0x240000cb }, - { 0x21000191, 0x24000001 }, - { 0x21000192, 0x1400ffff }, - { 0x21000193, 0x240000cd }, - { 0x21000194, 0x240000cf }, - { 0x21000195, 0x14000061 }, - { 0x21000196, 0x240000d3 }, - { 0x21000197, 0x240000d1 }, - { 0x21000198, 0x24000001 }, - { 0x21000199, 0x1400ffff }, - { 0x2100019a, 0x140000a3 }, - { 0x2100019b, 0x14000000 }, - { 0x2100019c, 0x240000d3 }, - { 0x2100019d, 0x240000d5 }, - { 0x2100019e, 0x14000082 }, - { 0x2100019f, 0x240000d6 }, - { 0x210001a0, 0x24000001 }, - { 0x210001a1, 0x1400ffff }, - { 0x210001a2, 0x24000001 }, - { 0x210001a3, 0x1400ffff }, - { 0x210001a4, 0x24000001 }, - { 0x210001a5, 0x1400ffff }, - { 0x210001a6, 0x240000da }, - { 0x210001a7, 0x24000001 }, - { 0x210001a8, 0x1400ffff }, - { 0x210001a9, 0x240000da }, - { 0x218001aa, 0x14000001 }, - { 0x210001ac, 0x24000001 }, - { 0x210001ad, 0x1400ffff }, - { 0x210001ae, 0x240000da }, - { 0x210001af, 0x24000001 }, - { 0x210001b0, 0x1400ffff }, - { 0x210001b1, 0x240000d9 }, - { 0x210001b2, 0x240000d9 }, - { 0x210001b3, 0x24000001 }, - { 0x210001b4, 0x1400ffff }, - { 0x210001b5, 0x24000001 }, - { 0x210001b6, 0x1400ffff }, - { 0x210001b7, 0x240000db }, - { 0x210001b8, 0x24000001 }, - { 0x210001b9, 0x1400ffff }, - { 0x210001ba, 0x14000000 }, - { 0x210001bb, 0x1c000000 }, - { 0x210001bc, 0x24000001 }, - { 0x210001bd, 0x1400ffff }, - { 0x210001be, 0x14000000 }, - { 0x210001bf, 0x14000038 }, - { 0x218001c0, 0x1c000003 }, - { 0x210001c4, 0x24000002 }, - { 0x210001c5, 0x2000ffff }, - { 0x210001c6, 0x1400fffe }, - { 0x210001c7, 0x24000002 }, - { 0x210001c8, 0x2000ffff }, - { 0x210001c9, 0x1400fffe }, - { 0x210001ca, 0x24000002 }, - { 0x210001cb, 0x2000ffff }, - { 0x210001cc, 0x1400fffe }, - { 0x210001cd, 0x24000001 }, - { 0x210001ce, 0x1400ffff }, - { 0x210001cf, 0x24000001 }, - { 0x210001d0, 0x1400ffff }, - { 0x210001d1, 0x24000001 }, - { 0x210001d2, 0x1400ffff }, - { 0x210001d3, 0x24000001 }, - { 0x210001d4, 0x1400ffff }, - { 0x210001d5, 0x24000001 }, - { 0x210001d6, 0x1400ffff }, - { 0x210001d7, 0x24000001 }, - { 0x210001d8, 0x1400ffff }, - { 0x210001d9, 0x24000001 }, - { 0x210001da, 0x1400ffff }, - { 0x210001db, 0x24000001 }, - { 0x210001dc, 0x1400ffff }, - { 0x210001dd, 0x1400ffb1 }, - { 0x210001de, 0x24000001 }, - { 0x210001df, 0x1400ffff }, - { 0x210001e0, 0x24000001 }, - { 0x210001e1, 0x1400ffff }, - { 0x210001e2, 0x24000001 }, - { 0x210001e3, 0x1400ffff }, - { 0x210001e4, 0x24000001 }, - { 0x210001e5, 0x1400ffff }, - { 0x210001e6, 0x24000001 }, - { 0x210001e7, 0x1400ffff }, - { 0x210001e8, 0x24000001 }, - { 0x210001e9, 0x1400ffff }, - { 0x210001ea, 0x24000001 }, - { 0x210001eb, 0x1400ffff }, - { 0x210001ec, 0x24000001 }, - { 0x210001ed, 0x1400ffff }, - { 0x210001ee, 0x24000001 }, - { 0x210001ef, 0x1400ffff }, - { 0x210001f0, 0x14000000 }, - { 0x210001f1, 0x24000002 }, - { 0x210001f2, 0x2000ffff }, - { 0x210001f3, 0x1400fffe }, - { 0x210001f4, 0x24000001 }, - { 0x210001f5, 0x1400ffff }, - { 0x210001f6, 0x2400ff9f }, - { 0x210001f7, 0x2400ffc8 }, - { 0x210001f8, 0x24000001 }, - { 0x210001f9, 0x1400ffff }, - { 0x210001fa, 0x24000001 }, - { 0x210001fb, 0x1400ffff }, - { 0x210001fc, 0x24000001 }, - { 0x210001fd, 0x1400ffff }, - { 0x210001fe, 0x24000001 }, - { 0x210001ff, 0x1400ffff }, - { 0x21000200, 0x24000001 }, - { 0x21000201, 0x1400ffff }, - { 0x21000202, 0x24000001 }, - { 0x21000203, 0x1400ffff }, - { 0x21000204, 0x24000001 }, - { 0x21000205, 0x1400ffff }, - { 0x21000206, 0x24000001 }, - { 0x21000207, 0x1400ffff }, - { 0x21000208, 0x24000001 }, - { 0x21000209, 0x1400ffff }, - { 0x2100020a, 0x24000001 }, - { 0x2100020b, 0x1400ffff }, - { 0x2100020c, 0x24000001 }, - { 0x2100020d, 0x1400ffff }, - { 0x2100020e, 0x24000001 }, - { 0x2100020f, 0x1400ffff }, - { 0x21000210, 0x24000001 }, - { 0x21000211, 0x1400ffff }, - { 0x21000212, 0x24000001 }, - { 0x21000213, 0x1400ffff }, - { 0x21000214, 0x24000001 }, - { 0x21000215, 0x1400ffff }, - { 0x21000216, 0x24000001 }, - { 0x21000217, 0x1400ffff }, - { 0x21000218, 0x24000001 }, - { 0x21000219, 0x1400ffff }, - { 0x2100021a, 0x24000001 }, - { 0x2100021b, 0x1400ffff }, - { 0x2100021c, 0x24000001 }, - { 0x2100021d, 0x1400ffff }, - { 0x2100021e, 0x24000001 }, - { 0x2100021f, 0x1400ffff }, - { 0x21000220, 0x2400ff7e }, - { 0x21000221, 0x14000000 }, - { 0x21000222, 0x24000001 }, - { 0x21000223, 0x1400ffff }, - { 0x21000224, 0x24000001 }, - { 0x21000225, 0x1400ffff }, - { 0x21000226, 0x24000001 }, - { 0x21000227, 0x1400ffff }, - { 0x21000228, 0x24000001 }, - { 0x21000229, 0x1400ffff }, - { 0x2100022a, 0x24000001 }, - { 0x2100022b, 0x1400ffff }, - { 0x2100022c, 0x24000001 }, - { 0x2100022d, 0x1400ffff }, - { 0x2100022e, 0x24000001 }, - { 0x2100022f, 0x1400ffff }, - { 0x21000230, 0x24000001 }, - { 0x21000231, 0x1400ffff }, - { 0x21000232, 0x24000001 }, - { 0x21000233, 0x1400ffff }, - { 0x21800234, 0x14000005 }, - { 0x2100023a, 0x24002a2b }, - { 0x2100023b, 0x24000001 }, - { 0x2100023c, 0x1400ffff }, - { 0x2100023d, 0x2400ff5d }, - { 0x2100023e, 0x24002a28 }, - { 0x2180023f, 0x14000001 }, - { 0x21000241, 0x24000001 }, - { 0x21000242, 0x1400ffff }, - { 0x21000243, 0x2400ff3d }, - { 0x21000244, 0x24000045 }, - { 0x21000245, 0x24000047 }, - { 0x21000246, 0x24000001 }, - { 0x21000247, 0x1400ffff }, - { 0x21000248, 0x24000001 }, - { 0x21000249, 0x1400ffff }, - { 0x2100024a, 0x24000001 }, - { 0x2100024b, 0x1400ffff }, - { 0x2100024c, 0x24000001 }, - { 0x2100024d, 0x1400ffff }, - { 0x2100024e, 0x24000001 }, - { 0x2100024f, 0x1400ffff }, - { 0x21800250, 0x14000002 }, - { 0x21000253, 0x1400ff2e }, - { 0x21000254, 0x1400ff32 }, - { 0x21000255, 0x14000000 }, - { 0x21000256, 0x1400ff33 }, - { 0x21000257, 0x1400ff33 }, - { 0x21000258, 0x14000000 }, - { 0x21000259, 0x1400ff36 }, - { 0x2100025a, 0x14000000 }, - { 0x2100025b, 0x1400ff35 }, - { 0x2180025c, 0x14000003 }, - { 0x21000260, 0x1400ff33 }, - { 0x21800261, 0x14000001 }, - { 0x21000263, 0x1400ff31 }, - { 0x21800264, 0x14000003 }, - { 0x21000268, 0x1400ff2f }, - { 0x21000269, 0x1400ff2d }, - { 0x2100026a, 0x14000000 }, - { 0x2100026b, 0x140029f7 }, - { 0x2180026c, 0x14000002 }, - { 0x2100026f, 0x1400ff2d }, - { 0x21800270, 0x14000001 }, - { 0x21000272, 0x1400ff2b }, - { 0x21800273, 0x14000001 }, - { 0x21000275, 0x1400ff2a }, - { 0x21800276, 0x14000006 }, - { 0x2100027d, 0x140029e7 }, - { 0x2180027e, 0x14000001 }, - { 0x21000280, 0x1400ff26 }, - { 0x21800281, 0x14000001 }, - { 0x21000283, 0x1400ff26 }, - { 0x21800284, 0x14000003 }, - { 0x21000288, 0x1400ff26 }, - { 0x21000289, 0x1400ffbb }, - { 0x2100028a, 0x1400ff27 }, - { 0x2100028b, 0x1400ff27 }, - { 0x2100028c, 0x1400ffb9 }, - { 0x2180028d, 0x14000004 }, - { 0x21000292, 0x1400ff25 }, - { 0x21000293, 0x14000000 }, - { 0x21000294, 0x1c000000 }, - { 0x21800295, 0x1400001a }, - { 0x218002b0, 0x18000011 }, - { 0x098002c2, 0x60000003 }, - { 0x098002c6, 0x1800000b }, - { 0x098002d2, 0x6000000d }, - { 0x218002e0, 0x18000004 }, - { 0x098002e5, 0x60000008 }, - { 0x090002ee, 0x18000000 }, - { 0x098002ef, 0x60000010 }, - { 0x1b800300, 0x30000044 }, - { 0x1b000345, 0x30000054 }, - { 0x1b800346, 0x30000029 }, - { 0x13800374, 0x60000001 }, - { 0x1300037a, 0x18000000 }, - { 0x1300037b, 0x14000082 }, - { 0x1300037c, 0x14000082 }, - { 0x1300037d, 0x14000082 }, - { 0x0900037e, 0x54000000 }, - { 0x13800384, 0x60000001 }, - { 0x13000386, 0x24000026 }, - { 0x09000387, 0x54000000 }, - { 0x13000388, 0x24000025 }, - { 0x13000389, 0x24000025 }, - { 0x1300038a, 0x24000025 }, - { 0x1300038c, 0x24000040 }, - { 0x1300038e, 0x2400003f }, - { 0x1300038f, 0x2400003f }, - { 0x13000390, 0x14000000 }, - { 0x13000391, 0x24000020 }, - { 0x13000392, 0x24000020 }, - { 0x13000393, 0x24000020 }, - { 0x13000394, 0x24000020 }, - { 0x13000395, 0x24000020 }, - { 0x13000396, 0x24000020 }, - { 0x13000397, 0x24000020 }, - { 0x13000398, 0x24000020 }, - { 0x13000399, 0x24000020 }, - { 0x1300039a, 0x24000020 }, - { 0x1300039b, 0x24000020 }, - { 0x1300039c, 0x24000020 }, - { 0x1300039d, 0x24000020 }, - { 0x1300039e, 0x24000020 }, - { 0x1300039f, 0x24000020 }, - { 0x130003a0, 0x24000020 }, - { 0x130003a1, 0x24000020 }, - { 0x130003a3, 0x24000020 }, - { 0x130003a4, 0x24000020 }, - { 0x130003a5, 0x24000020 }, - { 0x130003a6, 0x24000020 }, - { 0x130003a7, 0x24000020 }, - { 0x130003a8, 0x24000020 }, - { 0x130003a9, 0x24000020 }, - { 0x130003aa, 0x24000020 }, - { 0x130003ab, 0x24000020 }, - { 0x130003ac, 0x1400ffda }, - { 0x130003ad, 0x1400ffdb }, - { 0x130003ae, 0x1400ffdb }, - { 0x130003af, 0x1400ffdb }, - { 0x130003b0, 0x14000000 }, - { 0x130003b1, 0x1400ffe0 }, - { 0x130003b2, 0x1400ffe0 }, - { 0x130003b3, 0x1400ffe0 }, - { 0x130003b4, 0x1400ffe0 }, - { 0x130003b5, 0x1400ffe0 }, - { 0x130003b6, 0x1400ffe0 }, - { 0x130003b7, 0x1400ffe0 }, - { 0x130003b8, 0x1400ffe0 }, - { 0x130003b9, 0x1400ffe0 }, - { 0x130003ba, 0x1400ffe0 }, - { 0x130003bb, 0x1400ffe0 }, - { 0x130003bc, 0x1400ffe0 }, - { 0x130003bd, 0x1400ffe0 }, - { 0x130003be, 0x1400ffe0 }, - { 0x130003bf, 0x1400ffe0 }, - { 0x130003c0, 0x1400ffe0 }, - { 0x130003c1, 0x1400ffe0 }, - { 0x130003c2, 0x1400ffe1 }, - { 0x130003c3, 0x1400ffe0 }, - { 0x130003c4, 0x1400ffe0 }, - { 0x130003c5, 0x1400ffe0 }, - { 0x130003c6, 0x1400ffe0 }, - { 0x130003c7, 0x1400ffe0 }, - { 0x130003c8, 0x1400ffe0 }, - { 0x130003c9, 0x1400ffe0 }, - { 0x130003ca, 0x1400ffe0 }, - { 0x130003cb, 0x1400ffe0 }, - { 0x130003cc, 0x1400ffc0 }, - { 0x130003cd, 0x1400ffc1 }, - { 0x130003ce, 0x1400ffc1 }, - { 0x130003d0, 0x1400ffc2 }, - { 0x130003d1, 0x1400ffc7 }, - { 0x138003d2, 0x24000002 }, - { 0x130003d5, 0x1400ffd1 }, - { 0x130003d6, 0x1400ffca }, - { 0x130003d7, 0x14000000 }, - { 0x130003d8, 0x24000001 }, - { 0x130003d9, 0x1400ffff }, - { 0x130003da, 0x24000001 }, - { 0x130003db, 0x1400ffff }, - { 0x130003dc, 0x24000001 }, - { 0x130003dd, 0x1400ffff }, - { 0x130003de, 0x24000001 }, - { 0x130003df, 0x1400ffff }, - { 0x130003e0, 0x24000001 }, - { 0x130003e1, 0x1400ffff }, - { 0x0a0003e2, 0x24000001 }, - { 0x0a0003e3, 0x1400ffff }, - { 0x0a0003e4, 0x24000001 }, - { 0x0a0003e5, 0x1400ffff }, - { 0x0a0003e6, 0x24000001 }, - { 0x0a0003e7, 0x1400ffff }, - { 0x0a0003e8, 0x24000001 }, - { 0x0a0003e9, 0x1400ffff }, - { 0x0a0003ea, 0x24000001 }, - { 0x0a0003eb, 0x1400ffff }, - { 0x0a0003ec, 0x24000001 }, - { 0x0a0003ed, 0x1400ffff }, - { 0x0a0003ee, 0x24000001 }, - { 0x0a0003ef, 0x1400ffff }, - { 0x130003f0, 0x1400ffaa }, - { 0x130003f1, 0x1400ffb0 }, - { 0x130003f2, 0x14000007 }, - { 0x130003f3, 0x14000000 }, - { 0x130003f4, 0x2400ffc4 }, - { 0x130003f5, 0x1400ffa0 }, - { 0x130003f6, 0x64000000 }, - { 0x130003f7, 0x24000001 }, - { 0x130003f8, 0x1400ffff }, - { 0x130003f9, 0x2400fff9 }, - { 0x130003fa, 0x24000001 }, - { 0x130003fb, 0x1400ffff }, - { 0x130003fc, 0x14000000 }, - { 0x130003fd, 0x2400ff7e }, - { 0x130003fe, 0x2400ff7e }, - { 0x130003ff, 0x2400ff7e }, - { 0x0c000400, 0x24000050 }, - { 0x0c000401, 0x24000050 }, - { 0x0c000402, 0x24000050 }, - { 0x0c000403, 0x24000050 }, - { 0x0c000404, 0x24000050 }, - { 0x0c000405, 0x24000050 }, - { 0x0c000406, 0x24000050 }, - { 0x0c000407, 0x24000050 }, - { 0x0c000408, 0x24000050 }, - { 0x0c000409, 0x24000050 }, - { 0x0c00040a, 0x24000050 }, - { 0x0c00040b, 0x24000050 }, - { 0x0c00040c, 0x24000050 }, - { 0x0c00040d, 0x24000050 }, - { 0x0c00040e, 0x24000050 }, - { 0x0c00040f, 0x24000050 }, - { 0x0c000410, 0x24000020 }, - { 0x0c000411, 0x24000020 }, - { 0x0c000412, 0x24000020 }, - { 0x0c000413, 0x24000020 }, - { 0x0c000414, 0x24000020 }, - { 0x0c000415, 0x24000020 }, - { 0x0c000416, 0x24000020 }, - { 0x0c000417, 0x24000020 }, - { 0x0c000418, 0x24000020 }, - { 0x0c000419, 0x24000020 }, - { 0x0c00041a, 0x24000020 }, - { 0x0c00041b, 0x24000020 }, - { 0x0c00041c, 0x24000020 }, - { 0x0c00041d, 0x24000020 }, - { 0x0c00041e, 0x24000020 }, - { 0x0c00041f, 0x24000020 }, - { 0x0c000420, 0x24000020 }, - { 0x0c000421, 0x24000020 }, - { 0x0c000422, 0x24000020 }, - { 0x0c000423, 0x24000020 }, - { 0x0c000424, 0x24000020 }, - { 0x0c000425, 0x24000020 }, - { 0x0c000426, 0x24000020 }, - { 0x0c000427, 0x24000020 }, - { 0x0c000428, 0x24000020 }, - { 0x0c000429, 0x24000020 }, - { 0x0c00042a, 0x24000020 }, - { 0x0c00042b, 0x24000020 }, - { 0x0c00042c, 0x24000020 }, - { 0x0c00042d, 0x24000020 }, - { 0x0c00042e, 0x24000020 }, - { 0x0c00042f, 0x24000020 }, - { 0x0c000430, 0x1400ffe0 }, - { 0x0c000431, 0x1400ffe0 }, - { 0x0c000432, 0x1400ffe0 }, - { 0x0c000433, 0x1400ffe0 }, - { 0x0c000434, 0x1400ffe0 }, - { 0x0c000435, 0x1400ffe0 }, - { 0x0c000436, 0x1400ffe0 }, - { 0x0c000437, 0x1400ffe0 }, - { 0x0c000438, 0x1400ffe0 }, - { 0x0c000439, 0x1400ffe0 }, - { 0x0c00043a, 0x1400ffe0 }, - { 0x0c00043b, 0x1400ffe0 }, - { 0x0c00043c, 0x1400ffe0 }, - { 0x0c00043d, 0x1400ffe0 }, - { 0x0c00043e, 0x1400ffe0 }, - { 0x0c00043f, 0x1400ffe0 }, - { 0x0c000440, 0x1400ffe0 }, - { 0x0c000441, 0x1400ffe0 }, - { 0x0c000442, 0x1400ffe0 }, - { 0x0c000443, 0x1400ffe0 }, - { 0x0c000444, 0x1400ffe0 }, - { 0x0c000445, 0x1400ffe0 }, - { 0x0c000446, 0x1400ffe0 }, - { 0x0c000447, 0x1400ffe0 }, - { 0x0c000448, 0x1400ffe0 }, - { 0x0c000449, 0x1400ffe0 }, - { 0x0c00044a, 0x1400ffe0 }, - { 0x0c00044b, 0x1400ffe0 }, - { 0x0c00044c, 0x1400ffe0 }, - { 0x0c00044d, 0x1400ffe0 }, - { 0x0c00044e, 0x1400ffe0 }, - { 0x0c00044f, 0x1400ffe0 }, - { 0x0c000450, 0x1400ffb0 }, - { 0x0c000451, 0x1400ffb0 }, - { 0x0c000452, 0x1400ffb0 }, - { 0x0c000453, 0x1400ffb0 }, - { 0x0c000454, 0x1400ffb0 }, - { 0x0c000455, 0x1400ffb0 }, - { 0x0c000456, 0x1400ffb0 }, - { 0x0c000457, 0x1400ffb0 }, - { 0x0c000458, 0x1400ffb0 }, - { 0x0c000459, 0x1400ffb0 }, - { 0x0c00045a, 0x1400ffb0 }, - { 0x0c00045b, 0x1400ffb0 }, - { 0x0c00045c, 0x1400ffb0 }, - { 0x0c00045d, 0x1400ffb0 }, - { 0x0c00045e, 0x1400ffb0 }, - { 0x0c00045f, 0x1400ffb0 }, - { 0x0c000460, 0x24000001 }, - { 0x0c000461, 0x1400ffff }, - { 0x0c000462, 0x24000001 }, - { 0x0c000463, 0x1400ffff }, - { 0x0c000464, 0x24000001 }, - { 0x0c000465, 0x1400ffff }, - { 0x0c000466, 0x24000001 }, - { 0x0c000467, 0x1400ffff }, - { 0x0c000468, 0x24000001 }, - { 0x0c000469, 0x1400ffff }, - { 0x0c00046a, 0x24000001 }, - { 0x0c00046b, 0x1400ffff }, - { 0x0c00046c, 0x24000001 }, - { 0x0c00046d, 0x1400ffff }, - { 0x0c00046e, 0x24000001 }, - { 0x0c00046f, 0x1400ffff }, - { 0x0c000470, 0x24000001 }, - { 0x0c000471, 0x1400ffff }, - { 0x0c000472, 0x24000001 }, - { 0x0c000473, 0x1400ffff }, - { 0x0c000474, 0x24000001 }, - { 0x0c000475, 0x1400ffff }, - { 0x0c000476, 0x24000001 }, - { 0x0c000477, 0x1400ffff }, - { 0x0c000478, 0x24000001 }, - { 0x0c000479, 0x1400ffff }, - { 0x0c00047a, 0x24000001 }, - { 0x0c00047b, 0x1400ffff }, - { 0x0c00047c, 0x24000001 }, - { 0x0c00047d, 0x1400ffff }, - { 0x0c00047e, 0x24000001 }, - { 0x0c00047f, 0x1400ffff }, - { 0x0c000480, 0x24000001 }, - { 0x0c000481, 0x1400ffff }, - { 0x0c000482, 0x68000000 }, - { 0x0c800483, 0x30000003 }, - { 0x0c800488, 0x2c000001 }, - { 0x0c00048a, 0x24000001 }, - { 0x0c00048b, 0x1400ffff }, - { 0x0c00048c, 0x24000001 }, - { 0x0c00048d, 0x1400ffff }, - { 0x0c00048e, 0x24000001 }, - { 0x0c00048f, 0x1400ffff }, - { 0x0c000490, 0x24000001 }, - { 0x0c000491, 0x1400ffff }, - { 0x0c000492, 0x24000001 }, - { 0x0c000493, 0x1400ffff }, - { 0x0c000494, 0x24000001 }, - { 0x0c000495, 0x1400ffff }, - { 0x0c000496, 0x24000001 }, - { 0x0c000497, 0x1400ffff }, - { 0x0c000498, 0x24000001 }, - { 0x0c000499, 0x1400ffff }, - { 0x0c00049a, 0x24000001 }, - { 0x0c00049b, 0x1400ffff }, - { 0x0c00049c, 0x24000001 }, - { 0x0c00049d, 0x1400ffff }, - { 0x0c00049e, 0x24000001 }, - { 0x0c00049f, 0x1400ffff }, - { 0x0c0004a0, 0x24000001 }, - { 0x0c0004a1, 0x1400ffff }, - { 0x0c0004a2, 0x24000001 }, - { 0x0c0004a3, 0x1400ffff }, - { 0x0c0004a4, 0x24000001 }, - { 0x0c0004a5, 0x1400ffff }, - { 0x0c0004a6, 0x24000001 }, - { 0x0c0004a7, 0x1400ffff }, - { 0x0c0004a8, 0x24000001 }, - { 0x0c0004a9, 0x1400ffff }, - { 0x0c0004aa, 0x24000001 }, - { 0x0c0004ab, 0x1400ffff }, - { 0x0c0004ac, 0x24000001 }, - { 0x0c0004ad, 0x1400ffff }, - { 0x0c0004ae, 0x24000001 }, - { 0x0c0004af, 0x1400ffff }, - { 0x0c0004b0, 0x24000001 }, - { 0x0c0004b1, 0x1400ffff }, - { 0x0c0004b2, 0x24000001 }, - { 0x0c0004b3, 0x1400ffff }, - { 0x0c0004b4, 0x24000001 }, - { 0x0c0004b5, 0x1400ffff }, - { 0x0c0004b6, 0x24000001 }, - { 0x0c0004b7, 0x1400ffff }, - { 0x0c0004b8, 0x24000001 }, - { 0x0c0004b9, 0x1400ffff }, - { 0x0c0004ba, 0x24000001 }, - { 0x0c0004bb, 0x1400ffff }, - { 0x0c0004bc, 0x24000001 }, - { 0x0c0004bd, 0x1400ffff }, - { 0x0c0004be, 0x24000001 }, - { 0x0c0004bf, 0x1400ffff }, - { 0x0c0004c0, 0x2400000f }, - { 0x0c0004c1, 0x24000001 }, - { 0x0c0004c2, 0x1400ffff }, - { 0x0c0004c3, 0x24000001 }, - { 0x0c0004c4, 0x1400ffff }, - { 0x0c0004c5, 0x24000001 }, - { 0x0c0004c6, 0x1400ffff }, - { 0x0c0004c7, 0x24000001 }, - { 0x0c0004c8, 0x1400ffff }, - { 0x0c0004c9, 0x24000001 }, - { 0x0c0004ca, 0x1400ffff }, - { 0x0c0004cb, 0x24000001 }, - { 0x0c0004cc, 0x1400ffff }, - { 0x0c0004cd, 0x24000001 }, - { 0x0c0004ce, 0x1400ffff }, - { 0x0c0004cf, 0x1400fff1 }, - { 0x0c0004d0, 0x24000001 }, - { 0x0c0004d1, 0x1400ffff }, - { 0x0c0004d2, 0x24000001 }, - { 0x0c0004d3, 0x1400ffff }, - { 0x0c0004d4, 0x24000001 }, - { 0x0c0004d5, 0x1400ffff }, - { 0x0c0004d6, 0x24000001 }, - { 0x0c0004d7, 0x1400ffff }, - { 0x0c0004d8, 0x24000001 }, - { 0x0c0004d9, 0x1400ffff }, - { 0x0c0004da, 0x24000001 }, - { 0x0c0004db, 0x1400ffff }, - { 0x0c0004dc, 0x24000001 }, - { 0x0c0004dd, 0x1400ffff }, - { 0x0c0004de, 0x24000001 }, - { 0x0c0004df, 0x1400ffff }, - { 0x0c0004e0, 0x24000001 }, - { 0x0c0004e1, 0x1400ffff }, - { 0x0c0004e2, 0x24000001 }, - { 0x0c0004e3, 0x1400ffff }, - { 0x0c0004e4, 0x24000001 }, - { 0x0c0004e5, 0x1400ffff }, - { 0x0c0004e6, 0x24000001 }, - { 0x0c0004e7, 0x1400ffff }, - { 0x0c0004e8, 0x24000001 }, - { 0x0c0004e9, 0x1400ffff }, - { 0x0c0004ea, 0x24000001 }, - { 0x0c0004eb, 0x1400ffff }, - { 0x0c0004ec, 0x24000001 }, - { 0x0c0004ed, 0x1400ffff }, - { 0x0c0004ee, 0x24000001 }, - { 0x0c0004ef, 0x1400ffff }, - { 0x0c0004f0, 0x24000001 }, - { 0x0c0004f1, 0x1400ffff }, - { 0x0c0004f2, 0x24000001 }, - { 0x0c0004f3, 0x1400ffff }, - { 0x0c0004f4, 0x24000001 }, - { 0x0c0004f5, 0x1400ffff }, - { 0x0c0004f6, 0x24000001 }, - { 0x0c0004f7, 0x1400ffff }, - { 0x0c0004f8, 0x24000001 }, - { 0x0c0004f9, 0x1400ffff }, - { 0x0c0004fa, 0x24000001 }, - { 0x0c0004fb, 0x1400ffff }, - { 0x0c0004fc, 0x24000001 }, - { 0x0c0004fd, 0x1400ffff }, - { 0x0c0004fe, 0x24000001 }, - { 0x0c0004ff, 0x1400ffff }, - { 0x0c000500, 0x24000001 }, - { 0x0c000501, 0x1400ffff }, - { 0x0c000502, 0x24000001 }, - { 0x0c000503, 0x1400ffff }, - { 0x0c000504, 0x24000001 }, - { 0x0c000505, 0x1400ffff }, - { 0x0c000506, 0x24000001 }, - { 0x0c000507, 0x1400ffff }, - { 0x0c000508, 0x24000001 }, - { 0x0c000509, 0x1400ffff }, - { 0x0c00050a, 0x24000001 }, - { 0x0c00050b, 0x1400ffff }, - { 0x0c00050c, 0x24000001 }, - { 0x0c00050d, 0x1400ffff }, - { 0x0c00050e, 0x24000001 }, - { 0x0c00050f, 0x1400ffff }, - { 0x0c000510, 0x24000001 }, - { 0x0c000511, 0x1400ffff }, - { 0x0c000512, 0x24000001 }, - { 0x0c000513, 0x1400ffff }, - { 0x01000531, 0x24000030 }, - { 0x01000532, 0x24000030 }, - { 0x01000533, 0x24000030 }, - { 0x01000534, 0x24000030 }, - { 0x01000535, 0x24000030 }, - { 0x01000536, 0x24000030 }, - { 0x01000537, 0x24000030 }, - { 0x01000538, 0x24000030 }, - { 0x01000539, 0x24000030 }, - { 0x0100053a, 0x24000030 }, - { 0x0100053b, 0x24000030 }, - { 0x0100053c, 0x24000030 }, - { 0x0100053d, 0x24000030 }, - { 0x0100053e, 0x24000030 }, - { 0x0100053f, 0x24000030 }, - { 0x01000540, 0x24000030 }, - { 0x01000541, 0x24000030 }, - { 0x01000542, 0x24000030 }, - { 0x01000543, 0x24000030 }, - { 0x01000544, 0x24000030 }, - { 0x01000545, 0x24000030 }, - { 0x01000546, 0x24000030 }, - { 0x01000547, 0x24000030 }, - { 0x01000548, 0x24000030 }, - { 0x01000549, 0x24000030 }, - { 0x0100054a, 0x24000030 }, - { 0x0100054b, 0x24000030 }, - { 0x0100054c, 0x24000030 }, - { 0x0100054d, 0x24000030 }, - { 0x0100054e, 0x24000030 }, - { 0x0100054f, 0x24000030 }, - { 0x01000550, 0x24000030 }, - { 0x01000551, 0x24000030 }, - { 0x01000552, 0x24000030 }, - { 0x01000553, 0x24000030 }, - { 0x01000554, 0x24000030 }, - { 0x01000555, 0x24000030 }, - { 0x01000556, 0x24000030 }, - { 0x01000559, 0x18000000 }, - { 0x0180055a, 0x54000005 }, - { 0x01000561, 0x1400ffd0 }, - { 0x01000562, 0x1400ffd0 }, - { 0x01000563, 0x1400ffd0 }, - { 0x01000564, 0x1400ffd0 }, - { 0x01000565, 0x1400ffd0 }, - { 0x01000566, 0x1400ffd0 }, - { 0x01000567, 0x1400ffd0 }, - { 0x01000568, 0x1400ffd0 }, - { 0x01000569, 0x1400ffd0 }, - { 0x0100056a, 0x1400ffd0 }, - { 0x0100056b, 0x1400ffd0 }, - { 0x0100056c, 0x1400ffd0 }, - { 0x0100056d, 0x1400ffd0 }, - { 0x0100056e, 0x1400ffd0 }, - { 0x0100056f, 0x1400ffd0 }, - { 0x01000570, 0x1400ffd0 }, - { 0x01000571, 0x1400ffd0 }, - { 0x01000572, 0x1400ffd0 }, - { 0x01000573, 0x1400ffd0 }, - { 0x01000574, 0x1400ffd0 }, - { 0x01000575, 0x1400ffd0 }, - { 0x01000576, 0x1400ffd0 }, - { 0x01000577, 0x1400ffd0 }, - { 0x01000578, 0x1400ffd0 }, - { 0x01000579, 0x1400ffd0 }, - { 0x0100057a, 0x1400ffd0 }, - { 0x0100057b, 0x1400ffd0 }, - { 0x0100057c, 0x1400ffd0 }, - { 0x0100057d, 0x1400ffd0 }, - { 0x0100057e, 0x1400ffd0 }, - { 0x0100057f, 0x1400ffd0 }, - { 0x01000580, 0x1400ffd0 }, - { 0x01000581, 0x1400ffd0 }, - { 0x01000582, 0x1400ffd0 }, - { 0x01000583, 0x1400ffd0 }, - { 0x01000584, 0x1400ffd0 }, - { 0x01000585, 0x1400ffd0 }, - { 0x01000586, 0x1400ffd0 }, - { 0x01000587, 0x14000000 }, - { 0x09000589, 0x54000000 }, - { 0x0100058a, 0x44000000 }, - { 0x19800591, 0x3000002c }, - { 0x190005be, 0x54000000 }, - { 0x190005bf, 0x30000000 }, - { 0x190005c0, 0x54000000 }, - { 0x198005c1, 0x30000001 }, - { 0x190005c3, 0x54000000 }, - { 0x198005c4, 0x30000001 }, - { 0x190005c6, 0x54000000 }, - { 0x190005c7, 0x30000000 }, - { 0x198005d0, 0x1c00001a }, - { 0x198005f0, 0x1c000002 }, - { 0x198005f3, 0x54000001 }, - { 0x09800600, 0x04000003 }, - { 0x0000060b, 0x5c000000 }, - { 0x0980060c, 0x54000001 }, - { 0x0080060e, 0x68000001 }, - { 0x00800610, 0x30000005 }, - { 0x0900061b, 0x54000000 }, - { 0x0080061e, 0x54000001 }, - { 0x00800621, 0x1c000019 }, - { 0x09000640, 0x18000000 }, - { 0x00800641, 0x1c000009 }, - { 0x1b80064b, 0x30000013 }, - { 0x09800660, 0x34000009 }, - { 0x0080066a, 0x54000003 }, - { 0x0080066e, 0x1c000001 }, - { 0x1b000670, 0x30000000 }, - { 0x00800671, 0x1c000062 }, - { 0x000006d4, 0x54000000 }, - { 0x000006d5, 0x1c000000 }, - { 0x008006d6, 0x30000006 }, - { 0x090006dd, 0x04000000 }, - { 0x000006de, 0x2c000000 }, - { 0x008006df, 0x30000005 }, - { 0x008006e5, 0x18000001 }, - { 0x008006e7, 0x30000001 }, - { 0x000006e9, 0x68000000 }, - { 0x008006ea, 0x30000003 }, - { 0x008006ee, 0x1c000001 }, - { 0x008006f0, 0x34000009 }, - { 0x008006fa, 0x1c000002 }, - { 0x008006fd, 0x68000001 }, - { 0x000006ff, 0x1c000000 }, - { 0x31800700, 0x5400000d }, - { 0x3100070f, 0x04000000 }, - { 0x31000710, 0x1c000000 }, - { 0x31000711, 0x30000000 }, - { 0x31800712, 0x1c00001d }, - { 0x31800730, 0x3000001a }, - { 0x3180074d, 0x1c000020 }, - { 0x37800780, 0x1c000025 }, - { 0x378007a6, 0x3000000a }, - { 0x370007b1, 0x1c000000 }, - { 0x3f8007c0, 0x34000009 }, - { 0x3f8007ca, 0x1c000020 }, - { 0x3f8007eb, 0x30000008 }, - { 0x3f8007f4, 0x18000001 }, - { 0x3f0007f6, 0x68000000 }, - { 0x3f8007f7, 0x54000002 }, - { 0x3f0007fa, 0x18000000 }, - { 0x0e800901, 0x30000001 }, - { 0x0e000903, 0x28000000 }, - { 0x0e800904, 0x1c000035 }, - { 0x0e00093c, 0x30000000 }, - { 0x0e00093d, 0x1c000000 }, - { 0x0e80093e, 0x28000002 }, - { 0x0e800941, 0x30000007 }, - { 0x0e800949, 0x28000003 }, - { 0x0e00094d, 0x30000000 }, - { 0x0e000950, 0x1c000000 }, - { 0x0e800951, 0x30000003 }, - { 0x0e800958, 0x1c000009 }, - { 0x0e800962, 0x30000001 }, - { 0x09800964, 0x54000001 }, - { 0x0e800966, 0x34000009 }, - { 0x09000970, 0x54000000 }, - { 0x0e80097b, 0x1c000004 }, - { 0x02000981, 0x30000000 }, - { 0x02800982, 0x28000001 }, - { 0x02800985, 0x1c000007 }, - { 0x0280098f, 0x1c000001 }, - { 0x02800993, 0x1c000015 }, - { 0x028009aa, 0x1c000006 }, - { 0x020009b2, 0x1c000000 }, - { 0x028009b6, 0x1c000003 }, - { 0x020009bc, 0x30000000 }, - { 0x020009bd, 0x1c000000 }, - { 0x028009be, 0x28000002 }, - { 0x028009c1, 0x30000003 }, - { 0x028009c7, 0x28000001 }, - { 0x028009cb, 0x28000001 }, - { 0x020009cd, 0x30000000 }, - { 0x020009ce, 0x1c000000 }, - { 0x020009d7, 0x28000000 }, - { 0x028009dc, 0x1c000001 }, - { 0x028009df, 0x1c000002 }, - { 0x028009e2, 0x30000001 }, - { 0x028009e6, 0x34000009 }, - { 0x028009f0, 0x1c000001 }, - { 0x028009f2, 0x5c000001 }, - { 0x028009f4, 0x3c000005 }, - { 0x020009fa, 0x68000000 }, - { 0x15800a01, 0x30000001 }, - { 0x15000a03, 0x28000000 }, - { 0x15800a05, 0x1c000005 }, - { 0x15800a0f, 0x1c000001 }, - { 0x15800a13, 0x1c000015 }, - { 0x15800a2a, 0x1c000006 }, - { 0x15800a32, 0x1c000001 }, - { 0x15800a35, 0x1c000001 }, - { 0x15800a38, 0x1c000001 }, - { 0x15000a3c, 0x30000000 }, - { 0x15800a3e, 0x28000002 }, - { 0x15800a41, 0x30000001 }, - { 0x15800a47, 0x30000001 }, - { 0x15800a4b, 0x30000002 }, - { 0x15800a59, 0x1c000003 }, - { 0x15000a5e, 0x1c000000 }, - { 0x15800a66, 0x34000009 }, - { 0x15800a70, 0x30000001 }, - { 0x15800a72, 0x1c000002 }, - { 0x14800a81, 0x30000001 }, - { 0x14000a83, 0x28000000 }, - { 0x14800a85, 0x1c000008 }, - { 0x14800a8f, 0x1c000002 }, - { 0x14800a93, 0x1c000015 }, - { 0x14800aaa, 0x1c000006 }, - { 0x14800ab2, 0x1c000001 }, - { 0x14800ab5, 0x1c000004 }, - { 0x14000abc, 0x30000000 }, - { 0x14000abd, 0x1c000000 }, - { 0x14800abe, 0x28000002 }, - { 0x14800ac1, 0x30000004 }, - { 0x14800ac7, 0x30000001 }, - { 0x14000ac9, 0x28000000 }, - { 0x14800acb, 0x28000001 }, - { 0x14000acd, 0x30000000 }, - { 0x14000ad0, 0x1c000000 }, - { 0x14800ae0, 0x1c000001 }, - { 0x14800ae2, 0x30000001 }, - { 0x14800ae6, 0x34000009 }, - { 0x14000af1, 0x5c000000 }, - { 0x2b000b01, 0x30000000 }, - { 0x2b800b02, 0x28000001 }, - { 0x2b800b05, 0x1c000007 }, - { 0x2b800b0f, 0x1c000001 }, - { 0x2b800b13, 0x1c000015 }, - { 0x2b800b2a, 0x1c000006 }, - { 0x2b800b32, 0x1c000001 }, - { 0x2b800b35, 0x1c000004 }, - { 0x2b000b3c, 0x30000000 }, - { 0x2b000b3d, 0x1c000000 }, - { 0x2b000b3e, 0x28000000 }, - { 0x2b000b3f, 0x30000000 }, - { 0x2b000b40, 0x28000000 }, - { 0x2b800b41, 0x30000002 }, - { 0x2b800b47, 0x28000001 }, - { 0x2b800b4b, 0x28000001 }, - { 0x2b000b4d, 0x30000000 }, - { 0x2b000b56, 0x30000000 }, - { 0x2b000b57, 0x28000000 }, - { 0x2b800b5c, 0x1c000001 }, - { 0x2b800b5f, 0x1c000002 }, - { 0x2b800b66, 0x34000009 }, - { 0x2b000b70, 0x68000000 }, - { 0x2b000b71, 0x1c000000 }, - { 0x35000b82, 0x30000000 }, - { 0x35000b83, 0x1c000000 }, - { 0x35800b85, 0x1c000005 }, - { 0x35800b8e, 0x1c000002 }, - { 0x35800b92, 0x1c000003 }, - { 0x35800b99, 0x1c000001 }, - { 0x35000b9c, 0x1c000000 }, - { 0x35800b9e, 0x1c000001 }, - { 0x35800ba3, 0x1c000001 }, - { 0x35800ba8, 0x1c000002 }, - { 0x35800bae, 0x1c00000b }, - { 0x35800bbe, 0x28000001 }, - { 0x35000bc0, 0x30000000 }, - { 0x35800bc1, 0x28000001 }, - { 0x35800bc6, 0x28000002 }, - { 0x35800bca, 0x28000002 }, - { 0x35000bcd, 0x30000000 }, - { 0x35000bd7, 0x28000000 }, - { 0x35800be6, 0x34000009 }, - { 0x35800bf0, 0x3c000002 }, - { 0x35800bf3, 0x68000005 }, - { 0x35000bf9, 0x5c000000 }, - { 0x35000bfa, 0x68000000 }, - { 0x36800c01, 0x28000002 }, - { 0x36800c05, 0x1c000007 }, - { 0x36800c0e, 0x1c000002 }, - { 0x36800c12, 0x1c000016 }, - { 0x36800c2a, 0x1c000009 }, - { 0x36800c35, 0x1c000004 }, - { 0x36800c3e, 0x30000002 }, - { 0x36800c41, 0x28000003 }, - { 0x36800c46, 0x30000002 }, - { 0x36800c4a, 0x30000003 }, - { 0x36800c55, 0x30000001 }, - { 0x36800c60, 0x1c000001 }, - { 0x36800c66, 0x34000009 }, - { 0x1c800c82, 0x28000001 }, - { 0x1c800c85, 0x1c000007 }, - { 0x1c800c8e, 0x1c000002 }, - { 0x1c800c92, 0x1c000016 }, - { 0x1c800caa, 0x1c000009 }, - { 0x1c800cb5, 0x1c000004 }, - { 0x1c000cbc, 0x30000000 }, - { 0x1c000cbd, 0x1c000000 }, - { 0x1c000cbe, 0x28000000 }, - { 0x1c000cbf, 0x30000000 }, - { 0x1c800cc0, 0x28000004 }, - { 0x1c000cc6, 0x30000000 }, - { 0x1c800cc7, 0x28000001 }, - { 0x1c800cca, 0x28000001 }, - { 0x1c800ccc, 0x30000001 }, - { 0x1c800cd5, 0x28000001 }, - { 0x1c000cde, 0x1c000000 }, - { 0x1c800ce0, 0x1c000001 }, - { 0x1c800ce2, 0x30000001 }, - { 0x1c800ce6, 0x34000009 }, - { 0x1c800cf1, 0x68000001 }, - { 0x24800d02, 0x28000001 }, - { 0x24800d05, 0x1c000007 }, - { 0x24800d0e, 0x1c000002 }, - { 0x24800d12, 0x1c000016 }, - { 0x24800d2a, 0x1c00000f }, - { 0x24800d3e, 0x28000002 }, - { 0x24800d41, 0x30000002 }, - { 0x24800d46, 0x28000002 }, - { 0x24800d4a, 0x28000002 }, - { 0x24000d4d, 0x30000000 }, - { 0x24000d57, 0x28000000 }, - { 0x24800d60, 0x1c000001 }, - { 0x24800d66, 0x34000009 }, - { 0x2f800d82, 0x28000001 }, - { 0x2f800d85, 0x1c000011 }, - { 0x2f800d9a, 0x1c000017 }, - { 0x2f800db3, 0x1c000008 }, - { 0x2f000dbd, 0x1c000000 }, - { 0x2f800dc0, 0x1c000006 }, - { 0x2f000dca, 0x30000000 }, - { 0x2f800dcf, 0x28000002 }, - { 0x2f800dd2, 0x30000002 }, - { 0x2f000dd6, 0x30000000 }, - { 0x2f800dd8, 0x28000007 }, - { 0x2f800df2, 0x28000001 }, - { 0x2f000df4, 0x54000000 }, - { 0x38800e01, 0x1c00002f }, - { 0x38000e31, 0x30000000 }, - { 0x38800e32, 0x1c000001 }, - { 0x38800e34, 0x30000006 }, - { 0x09000e3f, 0x5c000000 }, - { 0x38800e40, 0x1c000005 }, - { 0x38000e46, 0x18000000 }, - { 0x38800e47, 0x30000007 }, - { 0x38000e4f, 0x54000000 }, - { 0x38800e50, 0x34000009 }, - { 0x38800e5a, 0x54000001 }, - { 0x20800e81, 0x1c000001 }, - { 0x20000e84, 0x1c000000 }, - { 0x20800e87, 0x1c000001 }, - { 0x20000e8a, 0x1c000000 }, - { 0x20000e8d, 0x1c000000 }, - { 0x20800e94, 0x1c000003 }, - { 0x20800e99, 0x1c000006 }, - { 0x20800ea1, 0x1c000002 }, - { 0x20000ea5, 0x1c000000 }, - { 0x20000ea7, 0x1c000000 }, - { 0x20800eaa, 0x1c000001 }, - { 0x20800ead, 0x1c000003 }, - { 0x20000eb1, 0x30000000 }, - { 0x20800eb2, 0x1c000001 }, - { 0x20800eb4, 0x30000005 }, - { 0x20800ebb, 0x30000001 }, - { 0x20000ebd, 0x1c000000 }, - { 0x20800ec0, 0x1c000004 }, - { 0x20000ec6, 0x18000000 }, - { 0x20800ec8, 0x30000005 }, - { 0x20800ed0, 0x34000009 }, - { 0x20800edc, 0x1c000001 }, - { 0x39000f00, 0x1c000000 }, - { 0x39800f01, 0x68000002 }, - { 0x39800f04, 0x5400000e }, - { 0x39800f13, 0x68000004 }, - { 0x39800f18, 0x30000001 }, - { 0x39800f1a, 0x68000005 }, - { 0x39800f20, 0x34000009 }, - { 0x39800f2a, 0x3c000009 }, - { 0x39000f34, 0x68000000 }, - { 0x39000f35, 0x30000000 }, - { 0x39000f36, 0x68000000 }, - { 0x39000f37, 0x30000000 }, - { 0x39000f38, 0x68000000 }, - { 0x39000f39, 0x30000000 }, - { 0x39000f3a, 0x58000000 }, - { 0x39000f3b, 0x48000000 }, - { 0x39000f3c, 0x58000000 }, - { 0x39000f3d, 0x48000000 }, - { 0x39800f3e, 0x28000001 }, - { 0x39800f40, 0x1c000007 }, - { 0x39800f49, 0x1c000021 }, - { 0x39800f71, 0x3000000d }, - { 0x39000f7f, 0x28000000 }, - { 0x39800f80, 0x30000004 }, - { 0x39000f85, 0x54000000 }, - { 0x39800f86, 0x30000001 }, - { 0x39800f88, 0x1c000003 }, - { 0x39800f90, 0x30000007 }, - { 0x39800f99, 0x30000023 }, - { 0x39800fbe, 0x68000007 }, - { 0x39000fc6, 0x30000000 }, - { 0x39800fc7, 0x68000005 }, - { 0x39000fcf, 0x68000000 }, - { 0x39800fd0, 0x54000001 }, - { 0x26801000, 0x1c000021 }, - { 0x26801023, 0x1c000004 }, - { 0x26801029, 0x1c000001 }, - { 0x2600102c, 0x28000000 }, - { 0x2680102d, 0x30000003 }, - { 0x26001031, 0x28000000 }, - { 0x26001032, 0x30000000 }, - { 0x26801036, 0x30000001 }, - { 0x26001038, 0x28000000 }, - { 0x26001039, 0x30000000 }, - { 0x26801040, 0x34000009 }, - { 0x2680104a, 0x54000005 }, - { 0x26801050, 0x1c000005 }, - { 0x26801056, 0x28000001 }, - { 0x26801058, 0x30000001 }, - { 0x100010a0, 0x24001c60 }, - { 0x100010a1, 0x24001c60 }, - { 0x100010a2, 0x24001c60 }, - { 0x100010a3, 0x24001c60 }, - { 0x100010a4, 0x24001c60 }, - { 0x100010a5, 0x24001c60 }, - { 0x100010a6, 0x24001c60 }, - { 0x100010a7, 0x24001c60 }, - { 0x100010a8, 0x24001c60 }, - { 0x100010a9, 0x24001c60 }, - { 0x100010aa, 0x24001c60 }, - { 0x100010ab, 0x24001c60 }, - { 0x100010ac, 0x24001c60 }, - { 0x100010ad, 0x24001c60 }, - { 0x100010ae, 0x24001c60 }, - { 0x100010af, 0x24001c60 }, - { 0x100010b0, 0x24001c60 }, - { 0x100010b1, 0x24001c60 }, - { 0x100010b2, 0x24001c60 }, - { 0x100010b3, 0x24001c60 }, - { 0x100010b4, 0x24001c60 }, - { 0x100010b5, 0x24001c60 }, - { 0x100010b6, 0x24001c60 }, - { 0x100010b7, 0x24001c60 }, - { 0x100010b8, 0x24001c60 }, - { 0x100010b9, 0x24001c60 }, - { 0x100010ba, 0x24001c60 }, - { 0x100010bb, 0x24001c60 }, - { 0x100010bc, 0x24001c60 }, - { 0x100010bd, 0x24001c60 }, - { 0x100010be, 0x24001c60 }, - { 0x100010bf, 0x24001c60 }, - { 0x100010c0, 0x24001c60 }, - { 0x100010c1, 0x24001c60 }, - { 0x100010c2, 0x24001c60 }, - { 0x100010c3, 0x24001c60 }, - { 0x100010c4, 0x24001c60 }, - { 0x100010c5, 0x24001c60 }, - { 0x108010d0, 0x1c00002a }, - { 0x090010fb, 0x54000000 }, - { 0x100010fc, 0x18000000 }, - { 0x17801100, 0x1c000059 }, - { 0x1780115f, 0x1c000043 }, - { 0x178011a8, 0x1c000051 }, - { 0x0f801200, 0x1c000048 }, - { 0x0f80124a, 0x1c000003 }, - { 0x0f801250, 0x1c000006 }, - { 0x0f001258, 0x1c000000 }, - { 0x0f80125a, 0x1c000003 }, - { 0x0f801260, 0x1c000028 }, - { 0x0f80128a, 0x1c000003 }, - { 0x0f801290, 0x1c000020 }, - { 0x0f8012b2, 0x1c000003 }, - { 0x0f8012b8, 0x1c000006 }, - { 0x0f0012c0, 0x1c000000 }, - { 0x0f8012c2, 0x1c000003 }, - { 0x0f8012c8, 0x1c00000e }, - { 0x0f8012d8, 0x1c000038 }, - { 0x0f801312, 0x1c000003 }, - { 0x0f801318, 0x1c000042 }, - { 0x0f00135f, 0x30000000 }, - { 0x0f001360, 0x68000000 }, - { 0x0f801361, 0x54000007 }, - { 0x0f801369, 0x3c000013 }, - { 0x0f801380, 0x1c00000f }, - { 0x0f801390, 0x68000009 }, - { 0x088013a0, 0x1c000054 }, - { 0x07801401, 0x1c00026b }, - { 0x0780166d, 0x54000001 }, - { 0x0780166f, 0x1c000007 }, - { 0x28001680, 0x74000000 }, - { 0x28801681, 0x1c000019 }, - { 0x2800169b, 0x58000000 }, - { 0x2800169c, 0x48000000 }, - { 0x2d8016a0, 0x1c00004a }, - { 0x098016eb, 0x54000002 }, - { 0x2d8016ee, 0x38000002 }, - { 0x32801700, 0x1c00000c }, - { 0x3280170e, 0x1c000003 }, - { 0x32801712, 0x30000002 }, - { 0x18801720, 0x1c000011 }, - { 0x18801732, 0x30000002 }, - { 0x09801735, 0x54000001 }, - { 0x06801740, 0x1c000011 }, - { 0x06801752, 0x30000001 }, - { 0x33801760, 0x1c00000c }, - { 0x3380176e, 0x1c000002 }, - { 0x33801772, 0x30000001 }, - { 0x1f801780, 0x1c000033 }, - { 0x1f8017b4, 0x04000001 }, - { 0x1f0017b6, 0x28000000 }, - { 0x1f8017b7, 0x30000006 }, - { 0x1f8017be, 0x28000007 }, - { 0x1f0017c6, 0x30000000 }, - { 0x1f8017c7, 0x28000001 }, - { 0x1f8017c9, 0x3000000a }, - { 0x1f8017d4, 0x54000002 }, - { 0x1f0017d7, 0x18000000 }, - { 0x1f8017d8, 0x54000002 }, - { 0x1f0017db, 0x5c000000 }, - { 0x1f0017dc, 0x1c000000 }, - { 0x1f0017dd, 0x30000000 }, - { 0x1f8017e0, 0x34000009 }, - { 0x1f8017f0, 0x3c000009 }, - { 0x25801800, 0x54000005 }, - { 0x25001806, 0x44000000 }, - { 0x25801807, 0x54000003 }, - { 0x2580180b, 0x30000002 }, - { 0x2500180e, 0x74000000 }, - { 0x25801810, 0x34000009 }, - { 0x25801820, 0x1c000022 }, - { 0x25001843, 0x18000000 }, - { 0x25801844, 0x1c000033 }, - { 0x25801880, 0x1c000028 }, - { 0x250018a9, 0x30000000 }, - { 0x22801900, 0x1c00001c }, - { 0x22801920, 0x30000002 }, - { 0x22801923, 0x28000003 }, - { 0x22801927, 0x30000001 }, - { 0x22801929, 0x28000002 }, - { 0x22801930, 0x28000001 }, - { 0x22001932, 0x30000000 }, - { 0x22801933, 0x28000005 }, - { 0x22801939, 0x30000002 }, - { 0x22001940, 0x68000000 }, - { 0x22801944, 0x54000001 }, - { 0x22801946, 0x34000009 }, - { 0x34801950, 0x1c00001d }, - { 0x34801970, 0x1c000004 }, - { 0x27801980, 0x1c000029 }, - { 0x278019b0, 0x28000010 }, - { 0x278019c1, 0x1c000006 }, - { 0x278019c8, 0x28000001 }, - { 0x278019d0, 0x34000009 }, - { 0x278019de, 0x54000001 }, - { 0x1f8019e0, 0x6800001f }, - { 0x05801a00, 0x1c000016 }, - { 0x05801a17, 0x30000001 }, - { 0x05801a19, 0x28000002 }, - { 0x05801a1e, 0x54000001 }, - { 0x3d801b00, 0x30000003 }, - { 0x3d001b04, 0x28000000 }, - { 0x3d801b05, 0x1c00002e }, - { 0x3d001b34, 0x30000000 }, - { 0x3d001b35, 0x28000000 }, - { 0x3d801b36, 0x30000004 }, - { 0x3d001b3b, 0x28000000 }, - { 0x3d001b3c, 0x30000000 }, - { 0x3d801b3d, 0x28000004 }, - { 0x3d001b42, 0x30000000 }, - { 0x3d801b43, 0x28000001 }, - { 0x3d801b45, 0x1c000006 }, - { 0x3d801b50, 0x34000009 }, - { 0x3d801b5a, 0x54000006 }, - { 0x3d801b61, 0x68000009 }, - { 0x3d801b6b, 0x30000008 }, - { 0x3d801b74, 0x68000008 }, - { 0x21801d00, 0x1400002b }, - { 0x21801d2c, 0x18000035 }, - { 0x21801d62, 0x14000015 }, - { 0x0c001d78, 0x18000000 }, - { 0x21801d79, 0x14000003 }, - { 0x21001d7d, 0x14000ee6 }, - { 0x21801d7e, 0x1400001c }, - { 0x21801d9b, 0x18000024 }, - { 0x1b801dc0, 0x3000000a }, - { 0x1b801dfe, 0x30000001 }, - { 0x21001e00, 0x24000001 }, - { 0x21001e01, 0x1400ffff }, - { 0x21001e02, 0x24000001 }, - { 0x21001e03, 0x1400ffff }, - { 0x21001e04, 0x24000001 }, - { 0x21001e05, 0x1400ffff }, - { 0x21001e06, 0x24000001 }, - { 0x21001e07, 0x1400ffff }, - { 0x21001e08, 0x24000001 }, - { 0x21001e09, 0x1400ffff }, - { 0x21001e0a, 0x24000001 }, - { 0x21001e0b, 0x1400ffff }, - { 0x21001e0c, 0x24000001 }, - { 0x21001e0d, 0x1400ffff }, - { 0x21001e0e, 0x24000001 }, - { 0x21001e0f, 0x1400ffff }, - { 0x21001e10, 0x24000001 }, - { 0x21001e11, 0x1400ffff }, - { 0x21001e12, 0x24000001 }, - { 0x21001e13, 0x1400ffff }, - { 0x21001e14, 0x24000001 }, - { 0x21001e15, 0x1400ffff }, - { 0x21001e16, 0x24000001 }, - { 0x21001e17, 0x1400ffff }, - { 0x21001e18, 0x24000001 }, - { 0x21001e19, 0x1400ffff }, - { 0x21001e1a, 0x24000001 }, - { 0x21001e1b, 0x1400ffff }, - { 0x21001e1c, 0x24000001 }, - { 0x21001e1d, 0x1400ffff }, - { 0x21001e1e, 0x24000001 }, - { 0x21001e1f, 0x1400ffff }, - { 0x21001e20, 0x24000001 }, - { 0x21001e21, 0x1400ffff }, - { 0x21001e22, 0x24000001 }, - { 0x21001e23, 0x1400ffff }, - { 0x21001e24, 0x24000001 }, - { 0x21001e25, 0x1400ffff }, - { 0x21001e26, 0x24000001 }, - { 0x21001e27, 0x1400ffff }, - { 0x21001e28, 0x24000001 }, - { 0x21001e29, 0x1400ffff }, - { 0x21001e2a, 0x24000001 }, - { 0x21001e2b, 0x1400ffff }, - { 0x21001e2c, 0x24000001 }, - { 0x21001e2d, 0x1400ffff }, - { 0x21001e2e, 0x24000001 }, - { 0x21001e2f, 0x1400ffff }, - { 0x21001e30, 0x24000001 }, - { 0x21001e31, 0x1400ffff }, - { 0x21001e32, 0x24000001 }, - { 0x21001e33, 0x1400ffff }, - { 0x21001e34, 0x24000001 }, - { 0x21001e35, 0x1400ffff }, - { 0x21001e36, 0x24000001 }, - { 0x21001e37, 0x1400ffff }, - { 0x21001e38, 0x24000001 }, - { 0x21001e39, 0x1400ffff }, - { 0x21001e3a, 0x24000001 }, - { 0x21001e3b, 0x1400ffff }, - { 0x21001e3c, 0x24000001 }, - { 0x21001e3d, 0x1400ffff }, - { 0x21001e3e, 0x24000001 }, - { 0x21001e3f, 0x1400ffff }, - { 0x21001e40, 0x24000001 }, - { 0x21001e41, 0x1400ffff }, - { 0x21001e42, 0x24000001 }, - { 0x21001e43, 0x1400ffff }, - { 0x21001e44, 0x24000001 }, - { 0x21001e45, 0x1400ffff }, - { 0x21001e46, 0x24000001 }, - { 0x21001e47, 0x1400ffff }, - { 0x21001e48, 0x24000001 }, - { 0x21001e49, 0x1400ffff }, - { 0x21001e4a, 0x24000001 }, - { 0x21001e4b, 0x1400ffff }, - { 0x21001e4c, 0x24000001 }, - { 0x21001e4d, 0x1400ffff }, - { 0x21001e4e, 0x24000001 }, - { 0x21001e4f, 0x1400ffff }, - { 0x21001e50, 0x24000001 }, - { 0x21001e51, 0x1400ffff }, - { 0x21001e52, 0x24000001 }, - { 0x21001e53, 0x1400ffff }, - { 0x21001e54, 0x24000001 }, - { 0x21001e55, 0x1400ffff }, - { 0x21001e56, 0x24000001 }, - { 0x21001e57, 0x1400ffff }, - { 0x21001e58, 0x24000001 }, - { 0x21001e59, 0x1400ffff }, - { 0x21001e5a, 0x24000001 }, - { 0x21001e5b, 0x1400ffff }, - { 0x21001e5c, 0x24000001 }, - { 0x21001e5d, 0x1400ffff }, - { 0x21001e5e, 0x24000001 }, - { 0x21001e5f, 0x1400ffff }, - { 0x21001e60, 0x24000001 }, - { 0x21001e61, 0x1400ffff }, - { 0x21001e62, 0x24000001 }, - { 0x21001e63, 0x1400ffff }, - { 0x21001e64, 0x24000001 }, - { 0x21001e65, 0x1400ffff }, - { 0x21001e66, 0x24000001 }, - { 0x21001e67, 0x1400ffff }, - { 0x21001e68, 0x24000001 }, - { 0x21001e69, 0x1400ffff }, - { 0x21001e6a, 0x24000001 }, - { 0x21001e6b, 0x1400ffff }, - { 0x21001e6c, 0x24000001 }, - { 0x21001e6d, 0x1400ffff }, - { 0x21001e6e, 0x24000001 }, - { 0x21001e6f, 0x1400ffff }, - { 0x21001e70, 0x24000001 }, - { 0x21001e71, 0x1400ffff }, - { 0x21001e72, 0x24000001 }, - { 0x21001e73, 0x1400ffff }, - { 0x21001e74, 0x24000001 }, - { 0x21001e75, 0x1400ffff }, - { 0x21001e76, 0x24000001 }, - { 0x21001e77, 0x1400ffff }, - { 0x21001e78, 0x24000001 }, - { 0x21001e79, 0x1400ffff }, - { 0x21001e7a, 0x24000001 }, - { 0x21001e7b, 0x1400ffff }, - { 0x21001e7c, 0x24000001 }, - { 0x21001e7d, 0x1400ffff }, - { 0x21001e7e, 0x24000001 }, - { 0x21001e7f, 0x1400ffff }, - { 0x21001e80, 0x24000001 }, - { 0x21001e81, 0x1400ffff }, - { 0x21001e82, 0x24000001 }, - { 0x21001e83, 0x1400ffff }, - { 0x21001e84, 0x24000001 }, - { 0x21001e85, 0x1400ffff }, - { 0x21001e86, 0x24000001 }, - { 0x21001e87, 0x1400ffff }, - { 0x21001e88, 0x24000001 }, - { 0x21001e89, 0x1400ffff }, - { 0x21001e8a, 0x24000001 }, - { 0x21001e8b, 0x1400ffff }, - { 0x21001e8c, 0x24000001 }, - { 0x21001e8d, 0x1400ffff }, - { 0x21001e8e, 0x24000001 }, - { 0x21001e8f, 0x1400ffff }, - { 0x21001e90, 0x24000001 }, - { 0x21001e91, 0x1400ffff }, - { 0x21001e92, 0x24000001 }, - { 0x21001e93, 0x1400ffff }, - { 0x21001e94, 0x24000001 }, - { 0x21001e95, 0x1400ffff }, - { 0x21801e96, 0x14000004 }, - { 0x21001e9b, 0x1400ffc5 }, - { 0x21001ea0, 0x24000001 }, - { 0x21001ea1, 0x1400ffff }, - { 0x21001ea2, 0x24000001 }, - { 0x21001ea3, 0x1400ffff }, - { 0x21001ea4, 0x24000001 }, - { 0x21001ea5, 0x1400ffff }, - { 0x21001ea6, 0x24000001 }, - { 0x21001ea7, 0x1400ffff }, - { 0x21001ea8, 0x24000001 }, - { 0x21001ea9, 0x1400ffff }, - { 0x21001eaa, 0x24000001 }, - { 0x21001eab, 0x1400ffff }, - { 0x21001eac, 0x24000001 }, - { 0x21001ead, 0x1400ffff }, - { 0x21001eae, 0x24000001 }, - { 0x21001eaf, 0x1400ffff }, - { 0x21001eb0, 0x24000001 }, - { 0x21001eb1, 0x1400ffff }, - { 0x21001eb2, 0x24000001 }, - { 0x21001eb3, 0x1400ffff }, - { 0x21001eb4, 0x24000001 }, - { 0x21001eb5, 0x1400ffff }, - { 0x21001eb6, 0x24000001 }, - { 0x21001eb7, 0x1400ffff }, - { 0x21001eb8, 0x24000001 }, - { 0x21001eb9, 0x1400ffff }, - { 0x21001eba, 0x24000001 }, - { 0x21001ebb, 0x1400ffff }, - { 0x21001ebc, 0x24000001 }, - { 0x21001ebd, 0x1400ffff }, - { 0x21001ebe, 0x24000001 }, - { 0x21001ebf, 0x1400ffff }, - { 0x21001ec0, 0x24000001 }, - { 0x21001ec1, 0x1400ffff }, - { 0x21001ec2, 0x24000001 }, - { 0x21001ec3, 0x1400ffff }, - { 0x21001ec4, 0x24000001 }, - { 0x21001ec5, 0x1400ffff }, - { 0x21001ec6, 0x24000001 }, - { 0x21001ec7, 0x1400ffff }, - { 0x21001ec8, 0x24000001 }, - { 0x21001ec9, 0x1400ffff }, - { 0x21001eca, 0x24000001 }, - { 0x21001ecb, 0x1400ffff }, - { 0x21001ecc, 0x24000001 }, - { 0x21001ecd, 0x1400ffff }, - { 0x21001ece, 0x24000001 }, - { 0x21001ecf, 0x1400ffff }, - { 0x21001ed0, 0x24000001 }, - { 0x21001ed1, 0x1400ffff }, - { 0x21001ed2, 0x24000001 }, - { 0x21001ed3, 0x1400ffff }, - { 0x21001ed4, 0x24000001 }, - { 0x21001ed5, 0x1400ffff }, - { 0x21001ed6, 0x24000001 }, - { 0x21001ed7, 0x1400ffff }, - { 0x21001ed8, 0x24000001 }, - { 0x21001ed9, 0x1400ffff }, - { 0x21001eda, 0x24000001 }, - { 0x21001edb, 0x1400ffff }, - { 0x21001edc, 0x24000001 }, - { 0x21001edd, 0x1400ffff }, - { 0x21001ede, 0x24000001 }, - { 0x21001edf, 0x1400ffff }, - { 0x21001ee0, 0x24000001 }, - { 0x21001ee1, 0x1400ffff }, - { 0x21001ee2, 0x24000001 }, - { 0x21001ee3, 0x1400ffff }, - { 0x21001ee4, 0x24000001 }, - { 0x21001ee5, 0x1400ffff }, - { 0x21001ee6, 0x24000001 }, - { 0x21001ee7, 0x1400ffff }, - { 0x21001ee8, 0x24000001 }, - { 0x21001ee9, 0x1400ffff }, - { 0x21001eea, 0x24000001 }, - { 0x21001eeb, 0x1400ffff }, - { 0x21001eec, 0x24000001 }, - { 0x21001eed, 0x1400ffff }, - { 0x21001eee, 0x24000001 }, - { 0x21001eef, 0x1400ffff }, - { 0x21001ef0, 0x24000001 }, - { 0x21001ef1, 0x1400ffff }, - { 0x21001ef2, 0x24000001 }, - { 0x21001ef3, 0x1400ffff }, - { 0x21001ef4, 0x24000001 }, - { 0x21001ef5, 0x1400ffff }, - { 0x21001ef6, 0x24000001 }, - { 0x21001ef7, 0x1400ffff }, - { 0x21001ef8, 0x24000001 }, - { 0x21001ef9, 0x1400ffff }, - { 0x13001f00, 0x14000008 }, - { 0x13001f01, 0x14000008 }, - { 0x13001f02, 0x14000008 }, - { 0x13001f03, 0x14000008 }, - { 0x13001f04, 0x14000008 }, - { 0x13001f05, 0x14000008 }, - { 0x13001f06, 0x14000008 }, - { 0x13001f07, 0x14000008 }, - { 0x13001f08, 0x2400fff8 }, - { 0x13001f09, 0x2400fff8 }, - { 0x13001f0a, 0x2400fff8 }, - { 0x13001f0b, 0x2400fff8 }, - { 0x13001f0c, 0x2400fff8 }, - { 0x13001f0d, 0x2400fff8 }, - { 0x13001f0e, 0x2400fff8 }, - { 0x13001f0f, 0x2400fff8 }, - { 0x13001f10, 0x14000008 }, - { 0x13001f11, 0x14000008 }, - { 0x13001f12, 0x14000008 }, - { 0x13001f13, 0x14000008 }, - { 0x13001f14, 0x14000008 }, - { 0x13001f15, 0x14000008 }, - { 0x13001f18, 0x2400fff8 }, - { 0x13001f19, 0x2400fff8 }, - { 0x13001f1a, 0x2400fff8 }, - { 0x13001f1b, 0x2400fff8 }, - { 0x13001f1c, 0x2400fff8 }, - { 0x13001f1d, 0x2400fff8 }, - { 0x13001f20, 0x14000008 }, - { 0x13001f21, 0x14000008 }, - { 0x13001f22, 0x14000008 }, - { 0x13001f23, 0x14000008 }, - { 0x13001f24, 0x14000008 }, - { 0x13001f25, 0x14000008 }, - { 0x13001f26, 0x14000008 }, - { 0x13001f27, 0x14000008 }, - { 0x13001f28, 0x2400fff8 }, - { 0x13001f29, 0x2400fff8 }, - { 0x13001f2a, 0x2400fff8 }, - { 0x13001f2b, 0x2400fff8 }, - { 0x13001f2c, 0x2400fff8 }, - { 0x13001f2d, 0x2400fff8 }, - { 0x13001f2e, 0x2400fff8 }, - { 0x13001f2f, 0x2400fff8 }, - { 0x13001f30, 0x14000008 }, - { 0x13001f31, 0x14000008 }, - { 0x13001f32, 0x14000008 }, - { 0x13001f33, 0x14000008 }, - { 0x13001f34, 0x14000008 }, - { 0x13001f35, 0x14000008 }, - { 0x13001f36, 0x14000008 }, - { 0x13001f37, 0x14000008 }, - { 0x13001f38, 0x2400fff8 }, - { 0x13001f39, 0x2400fff8 }, - { 0x13001f3a, 0x2400fff8 }, - { 0x13001f3b, 0x2400fff8 }, - { 0x13001f3c, 0x2400fff8 }, - { 0x13001f3d, 0x2400fff8 }, - { 0x13001f3e, 0x2400fff8 }, - { 0x13001f3f, 0x2400fff8 }, - { 0x13001f40, 0x14000008 }, - { 0x13001f41, 0x14000008 }, - { 0x13001f42, 0x14000008 }, - { 0x13001f43, 0x14000008 }, - { 0x13001f44, 0x14000008 }, - { 0x13001f45, 0x14000008 }, - { 0x13001f48, 0x2400fff8 }, - { 0x13001f49, 0x2400fff8 }, - { 0x13001f4a, 0x2400fff8 }, - { 0x13001f4b, 0x2400fff8 }, - { 0x13001f4c, 0x2400fff8 }, - { 0x13001f4d, 0x2400fff8 }, - { 0x13001f50, 0x14000000 }, - { 0x13001f51, 0x14000008 }, - { 0x13001f52, 0x14000000 }, - { 0x13001f53, 0x14000008 }, - { 0x13001f54, 0x14000000 }, - { 0x13001f55, 0x14000008 }, - { 0x13001f56, 0x14000000 }, - { 0x13001f57, 0x14000008 }, - { 0x13001f59, 0x2400fff8 }, - { 0x13001f5b, 0x2400fff8 }, - { 0x13001f5d, 0x2400fff8 }, - { 0x13001f5f, 0x2400fff8 }, - { 0x13001f60, 0x14000008 }, - { 0x13001f61, 0x14000008 }, - { 0x13001f62, 0x14000008 }, - { 0x13001f63, 0x14000008 }, - { 0x13001f64, 0x14000008 }, - { 0x13001f65, 0x14000008 }, - { 0x13001f66, 0x14000008 }, - { 0x13001f67, 0x14000008 }, - { 0x13001f68, 0x2400fff8 }, - { 0x13001f69, 0x2400fff8 }, - { 0x13001f6a, 0x2400fff8 }, - { 0x13001f6b, 0x2400fff8 }, - { 0x13001f6c, 0x2400fff8 }, - { 0x13001f6d, 0x2400fff8 }, - { 0x13001f6e, 0x2400fff8 }, - { 0x13001f6f, 0x2400fff8 }, - { 0x13001f70, 0x1400004a }, - { 0x13001f71, 0x1400004a }, - { 0x13001f72, 0x14000056 }, - { 0x13001f73, 0x14000056 }, - { 0x13001f74, 0x14000056 }, - { 0x13001f75, 0x14000056 }, - { 0x13001f76, 0x14000064 }, - { 0x13001f77, 0x14000064 }, - { 0x13001f78, 0x14000080 }, - { 0x13001f79, 0x14000080 }, - { 0x13001f7a, 0x14000070 }, - { 0x13001f7b, 0x14000070 }, - { 0x13001f7c, 0x1400007e }, - { 0x13001f7d, 0x1400007e }, - { 0x13001f80, 0x14000008 }, - { 0x13001f81, 0x14000008 }, - { 0x13001f82, 0x14000008 }, - { 0x13001f83, 0x14000008 }, - { 0x13001f84, 0x14000008 }, - { 0x13001f85, 0x14000008 }, - { 0x13001f86, 0x14000008 }, - { 0x13001f87, 0x14000008 }, - { 0x13001f88, 0x2000fff8 }, - { 0x13001f89, 0x2000fff8 }, - { 0x13001f8a, 0x2000fff8 }, - { 0x13001f8b, 0x2000fff8 }, - { 0x13001f8c, 0x2000fff8 }, - { 0x13001f8d, 0x2000fff8 }, - { 0x13001f8e, 0x2000fff8 }, - { 0x13001f8f, 0x2000fff8 }, - { 0x13001f90, 0x14000008 }, - { 0x13001f91, 0x14000008 }, - { 0x13001f92, 0x14000008 }, - { 0x13001f93, 0x14000008 }, - { 0x13001f94, 0x14000008 }, - { 0x13001f95, 0x14000008 }, - { 0x13001f96, 0x14000008 }, - { 0x13001f97, 0x14000008 }, - { 0x13001f98, 0x2000fff8 }, - { 0x13001f99, 0x2000fff8 }, - { 0x13001f9a, 0x2000fff8 }, - { 0x13001f9b, 0x2000fff8 }, - { 0x13001f9c, 0x2000fff8 }, - { 0x13001f9d, 0x2000fff8 }, - { 0x13001f9e, 0x2000fff8 }, - { 0x13001f9f, 0x2000fff8 }, - { 0x13001fa0, 0x14000008 }, - { 0x13001fa1, 0x14000008 }, - { 0x13001fa2, 0x14000008 }, - { 0x13001fa3, 0x14000008 }, - { 0x13001fa4, 0x14000008 }, - { 0x13001fa5, 0x14000008 }, - { 0x13001fa6, 0x14000008 }, - { 0x13001fa7, 0x14000008 }, - { 0x13001fa8, 0x2000fff8 }, - { 0x13001fa9, 0x2000fff8 }, - { 0x13001faa, 0x2000fff8 }, - { 0x13001fab, 0x2000fff8 }, - { 0x13001fac, 0x2000fff8 }, - { 0x13001fad, 0x2000fff8 }, - { 0x13001fae, 0x2000fff8 }, - { 0x13001faf, 0x2000fff8 }, - { 0x13001fb0, 0x14000008 }, - { 0x13001fb1, 0x14000008 }, - { 0x13001fb2, 0x14000000 }, - { 0x13001fb3, 0x14000009 }, - { 0x13001fb4, 0x14000000 }, - { 0x13801fb6, 0x14000001 }, - { 0x13001fb8, 0x2400fff8 }, - { 0x13001fb9, 0x2400fff8 }, - { 0x13001fba, 0x2400ffb6 }, - { 0x13001fbb, 0x2400ffb6 }, - { 0x13001fbc, 0x2000fff7 }, - { 0x13001fbd, 0x60000000 }, - { 0x13001fbe, 0x1400e3db }, - { 0x13801fbf, 0x60000002 }, - { 0x13001fc2, 0x14000000 }, - { 0x13001fc3, 0x14000009 }, - { 0x13001fc4, 0x14000000 }, - { 0x13801fc6, 0x14000001 }, - { 0x13001fc8, 0x2400ffaa }, - { 0x13001fc9, 0x2400ffaa }, - { 0x13001fca, 0x2400ffaa }, - { 0x13001fcb, 0x2400ffaa }, - { 0x13001fcc, 0x2000fff7 }, - { 0x13801fcd, 0x60000002 }, - { 0x13001fd0, 0x14000008 }, - { 0x13001fd1, 0x14000008 }, - { 0x13801fd2, 0x14000001 }, - { 0x13801fd6, 0x14000001 }, - { 0x13001fd8, 0x2400fff8 }, - { 0x13001fd9, 0x2400fff8 }, - { 0x13001fda, 0x2400ff9c }, - { 0x13001fdb, 0x2400ff9c }, - { 0x13801fdd, 0x60000002 }, - { 0x13001fe0, 0x14000008 }, - { 0x13001fe1, 0x14000008 }, - { 0x13801fe2, 0x14000002 }, - { 0x13001fe5, 0x14000007 }, - { 0x13801fe6, 0x14000001 }, - { 0x13001fe8, 0x2400fff8 }, - { 0x13001fe9, 0x2400fff8 }, - { 0x13001fea, 0x2400ff90 }, - { 0x13001feb, 0x2400ff90 }, - { 0x13001fec, 0x2400fff9 }, - { 0x13801fed, 0x60000002 }, - { 0x13001ff2, 0x14000000 }, - { 0x13001ff3, 0x14000009 }, - { 0x13001ff4, 0x14000000 }, - { 0x13801ff6, 0x14000001 }, - { 0x13001ff8, 0x2400ff80 }, - { 0x13001ff9, 0x2400ff80 }, - { 0x13001ffa, 0x2400ff82 }, - { 0x13001ffb, 0x2400ff82 }, - { 0x13001ffc, 0x2000fff7 }, - { 0x13801ffd, 0x60000001 }, - { 0x09802000, 0x7400000a }, - { 0x0980200b, 0x04000004 }, - { 0x09802010, 0x44000005 }, - { 0x09802016, 0x54000001 }, - { 0x09002018, 0x50000000 }, - { 0x09002019, 0x4c000000 }, - { 0x0900201a, 0x58000000 }, - { 0x0980201b, 0x50000001 }, - { 0x0900201d, 0x4c000000 }, - { 0x0900201e, 0x58000000 }, - { 0x0900201f, 0x50000000 }, - { 0x09802020, 0x54000007 }, - { 0x09002028, 0x6c000000 }, - { 0x09002029, 0x70000000 }, - { 0x0980202a, 0x04000004 }, - { 0x0900202f, 0x74000000 }, - { 0x09802030, 0x54000008 }, - { 0x09002039, 0x50000000 }, - { 0x0900203a, 0x4c000000 }, - { 0x0980203b, 0x54000003 }, - { 0x0980203f, 0x40000001 }, - { 0x09802041, 0x54000002 }, - { 0x09002044, 0x64000000 }, - { 0x09002045, 0x58000000 }, - { 0x09002046, 0x48000000 }, - { 0x09802047, 0x5400000a }, - { 0x09002052, 0x64000000 }, - { 0x09002053, 0x54000000 }, - { 0x09002054, 0x40000000 }, - { 0x09802055, 0x54000009 }, - { 0x0900205f, 0x74000000 }, - { 0x09802060, 0x04000003 }, - { 0x0980206a, 0x04000005 }, - { 0x09002070, 0x3c000000 }, - { 0x21002071, 0x14000000 }, - { 0x09802074, 0x3c000005 }, - { 0x0980207a, 0x64000002 }, - { 0x0900207d, 0x58000000 }, - { 0x0900207e, 0x48000000 }, - { 0x2100207f, 0x14000000 }, - { 0x09802080, 0x3c000009 }, - { 0x0980208a, 0x64000002 }, - { 0x0900208d, 0x58000000 }, - { 0x0900208e, 0x48000000 }, - { 0x21802090, 0x18000004 }, - { 0x098020a0, 0x5c000015 }, - { 0x1b8020d0, 0x3000000c }, - { 0x1b8020dd, 0x2c000003 }, - { 0x1b0020e1, 0x30000000 }, - { 0x1b8020e2, 0x2c000002 }, - { 0x1b8020e5, 0x3000000a }, - { 0x09802100, 0x68000001 }, - { 0x09002102, 0x24000000 }, - { 0x09802103, 0x68000003 }, - { 0x09002107, 0x24000000 }, - { 0x09802108, 0x68000001 }, - { 0x0900210a, 0x14000000 }, - { 0x0980210b, 0x24000002 }, - { 0x0980210e, 0x14000001 }, - { 0x09802110, 0x24000002 }, - { 0x09002113, 0x14000000 }, - { 0x09002114, 0x68000000 }, - { 0x09002115, 0x24000000 }, - { 0x09802116, 0x68000002 }, - { 0x09802119, 0x24000004 }, - { 0x0980211e, 0x68000005 }, - { 0x09002124, 0x24000000 }, - { 0x09002125, 0x68000000 }, - { 0x13002126, 0x2400e2a3 }, - { 0x09002127, 0x68000000 }, - { 0x09002128, 0x24000000 }, - { 0x09002129, 0x68000000 }, - { 0x2100212a, 0x2400df41 }, - { 0x2100212b, 0x2400dfba }, - { 0x0980212c, 0x24000001 }, - { 0x0900212e, 0x68000000 }, - { 0x0900212f, 0x14000000 }, - { 0x09802130, 0x24000001 }, - { 0x21002132, 0x2400001c }, - { 0x09002133, 0x24000000 }, - { 0x09002134, 0x14000000 }, - { 0x09802135, 0x1c000003 }, - { 0x09002139, 0x14000000 }, - { 0x0980213a, 0x68000001 }, - { 0x0980213c, 0x14000001 }, - { 0x0980213e, 0x24000001 }, - { 0x09802140, 0x64000004 }, - { 0x09002145, 0x24000000 }, - { 0x09802146, 0x14000003 }, - { 0x0900214a, 0x68000000 }, - { 0x0900214b, 0x64000000 }, - { 0x0980214c, 0x68000001 }, - { 0x2100214e, 0x1400ffe4 }, - { 0x09802153, 0x3c00000c }, - { 0x09002160, 0x38000010 }, - { 0x09002161, 0x38000010 }, - { 0x09002162, 0x38000010 }, - { 0x09002163, 0x38000010 }, - { 0x09002164, 0x38000010 }, - { 0x09002165, 0x38000010 }, - { 0x09002166, 0x38000010 }, - { 0x09002167, 0x38000010 }, - { 0x09002168, 0x38000010 }, - { 0x09002169, 0x38000010 }, - { 0x0900216a, 0x38000010 }, - { 0x0900216b, 0x38000010 }, - { 0x0900216c, 0x38000010 }, - { 0x0900216d, 0x38000010 }, - { 0x0900216e, 0x38000010 }, - { 0x0900216f, 0x38000010 }, - { 0x09002170, 0x3800fff0 }, - { 0x09002171, 0x3800fff0 }, - { 0x09002172, 0x3800fff0 }, - { 0x09002173, 0x3800fff0 }, - { 0x09002174, 0x3800fff0 }, - { 0x09002175, 0x3800fff0 }, - { 0x09002176, 0x3800fff0 }, - { 0x09002177, 0x3800fff0 }, - { 0x09002178, 0x3800fff0 }, - { 0x09002179, 0x3800fff0 }, - { 0x0900217a, 0x3800fff0 }, - { 0x0900217b, 0x3800fff0 }, - { 0x0900217c, 0x3800fff0 }, - { 0x0900217d, 0x3800fff0 }, - { 0x0900217e, 0x3800fff0 }, - { 0x0900217f, 0x3800fff0 }, - { 0x09802180, 0x38000002 }, - { 0x09002183, 0x24000001 }, - { 0x21002184, 0x1400ffff }, - { 0x09802190, 0x64000004 }, - { 0x09802195, 0x68000004 }, - { 0x0980219a, 0x64000001 }, - { 0x0980219c, 0x68000003 }, - { 0x090021a0, 0x64000000 }, - { 0x098021a1, 0x68000001 }, - { 0x090021a3, 0x64000000 }, - { 0x098021a4, 0x68000001 }, - { 0x090021a6, 0x64000000 }, - { 0x098021a7, 0x68000006 }, - { 0x090021ae, 0x64000000 }, - { 0x098021af, 0x6800001e }, - { 0x098021ce, 0x64000001 }, - { 0x098021d0, 0x68000001 }, - { 0x090021d2, 0x64000000 }, - { 0x090021d3, 0x68000000 }, - { 0x090021d4, 0x64000000 }, - { 0x098021d5, 0x6800001e }, - { 0x098021f4, 0x6400010b }, - { 0x09802300, 0x68000007 }, - { 0x09802308, 0x64000003 }, - { 0x0980230c, 0x68000013 }, - { 0x09802320, 0x64000001 }, - { 0x09802322, 0x68000006 }, - { 0x09002329, 0x58000000 }, - { 0x0900232a, 0x48000000 }, - { 0x0980232b, 0x68000050 }, - { 0x0900237c, 0x64000000 }, - { 0x0980237d, 0x6800001d }, - { 0x0980239b, 0x64000018 }, - { 0x098023b4, 0x68000027 }, - { 0x098023dc, 0x64000005 }, - { 0x098023e2, 0x68000005 }, - { 0x09802400, 0x68000026 }, - { 0x09802440, 0x6800000a }, - { 0x09802460, 0x3c00003b }, - { 0x0980249c, 0x68000019 }, - { 0x090024b6, 0x6800001a }, - { 0x090024b7, 0x6800001a }, - { 0x090024b8, 0x6800001a }, - { 0x090024b9, 0x6800001a }, - { 0x090024ba, 0x6800001a }, - { 0x090024bb, 0x6800001a }, - { 0x090024bc, 0x6800001a }, - { 0x090024bd, 0x6800001a }, - { 0x090024be, 0x6800001a }, - { 0x090024bf, 0x6800001a }, - { 0x090024c0, 0x6800001a }, - { 0x090024c1, 0x6800001a }, - { 0x090024c2, 0x6800001a }, - { 0x090024c3, 0x6800001a }, - { 0x090024c4, 0x6800001a }, - { 0x090024c5, 0x6800001a }, - { 0x090024c6, 0x6800001a }, - { 0x090024c7, 0x6800001a }, - { 0x090024c8, 0x6800001a }, - { 0x090024c9, 0x6800001a }, - { 0x090024ca, 0x6800001a }, - { 0x090024cb, 0x6800001a }, - { 0x090024cc, 0x6800001a }, - { 0x090024cd, 0x6800001a }, - { 0x090024ce, 0x6800001a }, - { 0x090024cf, 0x6800001a }, - { 0x090024d0, 0x6800ffe6 }, - { 0x090024d1, 0x6800ffe6 }, - { 0x090024d2, 0x6800ffe6 }, - { 0x090024d3, 0x6800ffe6 }, - { 0x090024d4, 0x6800ffe6 }, - { 0x090024d5, 0x6800ffe6 }, - { 0x090024d6, 0x6800ffe6 }, - { 0x090024d7, 0x6800ffe6 }, - { 0x090024d8, 0x6800ffe6 }, - { 0x090024d9, 0x6800ffe6 }, - { 0x090024da, 0x6800ffe6 }, - { 0x090024db, 0x6800ffe6 }, - { 0x090024dc, 0x6800ffe6 }, - { 0x090024dd, 0x6800ffe6 }, - { 0x090024de, 0x6800ffe6 }, - { 0x090024df, 0x6800ffe6 }, - { 0x090024e0, 0x6800ffe6 }, - { 0x090024e1, 0x6800ffe6 }, - { 0x090024e2, 0x6800ffe6 }, - { 0x090024e3, 0x6800ffe6 }, - { 0x090024e4, 0x6800ffe6 }, - { 0x090024e5, 0x6800ffe6 }, - { 0x090024e6, 0x6800ffe6 }, - { 0x090024e7, 0x6800ffe6 }, - { 0x090024e8, 0x6800ffe6 }, - { 0x090024e9, 0x6800ffe6 }, - { 0x098024ea, 0x3c000015 }, - { 0x09802500, 0x680000b6 }, - { 0x090025b7, 0x64000000 }, - { 0x098025b8, 0x68000008 }, - { 0x090025c1, 0x64000000 }, - { 0x098025c2, 0x68000035 }, - { 0x098025f8, 0x64000007 }, - { 0x09802600, 0x6800006e }, - { 0x0900266f, 0x64000000 }, - { 0x09802670, 0x6800002c }, - { 0x098026a0, 0x68000012 }, - { 0x09802701, 0x68000003 }, - { 0x09802706, 0x68000003 }, - { 0x0980270c, 0x6800001b }, - { 0x09802729, 0x68000022 }, - { 0x0900274d, 0x68000000 }, - { 0x0980274f, 0x68000003 }, - { 0x09002756, 0x68000000 }, - { 0x09802758, 0x68000006 }, - { 0x09802761, 0x68000006 }, - { 0x09002768, 0x58000000 }, - { 0x09002769, 0x48000000 }, - { 0x0900276a, 0x58000000 }, - { 0x0900276b, 0x48000000 }, - { 0x0900276c, 0x58000000 }, - { 0x0900276d, 0x48000000 }, - { 0x0900276e, 0x58000000 }, - { 0x0900276f, 0x48000000 }, - { 0x09002770, 0x58000000 }, - { 0x09002771, 0x48000000 }, - { 0x09002772, 0x58000000 }, - { 0x09002773, 0x48000000 }, - { 0x09002774, 0x58000000 }, - { 0x09002775, 0x48000000 }, - { 0x09802776, 0x3c00001d }, - { 0x09002794, 0x68000000 }, - { 0x09802798, 0x68000017 }, - { 0x098027b1, 0x6800000d }, - { 0x098027c0, 0x64000004 }, - { 0x090027c5, 0x58000000 }, - { 0x090027c6, 0x48000000 }, - { 0x098027c7, 0x64000003 }, - { 0x098027d0, 0x64000015 }, - { 0x090027e6, 0x58000000 }, - { 0x090027e7, 0x48000000 }, - { 0x090027e8, 0x58000000 }, - { 0x090027e9, 0x48000000 }, - { 0x090027ea, 0x58000000 }, - { 0x090027eb, 0x48000000 }, - { 0x098027f0, 0x6400000f }, - { 0x04802800, 0x680000ff }, - { 0x09802900, 0x64000082 }, - { 0x09002983, 0x58000000 }, - { 0x09002984, 0x48000000 }, - { 0x09002985, 0x58000000 }, - { 0x09002986, 0x48000000 }, - { 0x09002987, 0x58000000 }, - { 0x09002988, 0x48000000 }, - { 0x09002989, 0x58000000 }, - { 0x0900298a, 0x48000000 }, - { 0x0900298b, 0x58000000 }, - { 0x0900298c, 0x48000000 }, - { 0x0900298d, 0x58000000 }, - { 0x0900298e, 0x48000000 }, - { 0x0900298f, 0x58000000 }, - { 0x09002990, 0x48000000 }, - { 0x09002991, 0x58000000 }, - { 0x09002992, 0x48000000 }, - { 0x09002993, 0x58000000 }, - { 0x09002994, 0x48000000 }, - { 0x09002995, 0x58000000 }, - { 0x09002996, 0x48000000 }, - { 0x09002997, 0x58000000 }, - { 0x09002998, 0x48000000 }, - { 0x09802999, 0x6400003e }, - { 0x090029d8, 0x58000000 }, - { 0x090029d9, 0x48000000 }, - { 0x090029da, 0x58000000 }, - { 0x090029db, 0x48000000 }, - { 0x098029dc, 0x6400001f }, - { 0x090029fc, 0x58000000 }, - { 0x090029fd, 0x48000000 }, - { 0x098029fe, 0x64000101 }, - { 0x09802b00, 0x6800001a }, - { 0x09802b20, 0x68000003 }, - { 0x11002c00, 0x24000030 }, - { 0x11002c01, 0x24000030 }, - { 0x11002c02, 0x24000030 }, - { 0x11002c03, 0x24000030 }, - { 0x11002c04, 0x24000030 }, - { 0x11002c05, 0x24000030 }, - { 0x11002c06, 0x24000030 }, - { 0x11002c07, 0x24000030 }, - { 0x11002c08, 0x24000030 }, - { 0x11002c09, 0x24000030 }, - { 0x11002c0a, 0x24000030 }, - { 0x11002c0b, 0x24000030 }, - { 0x11002c0c, 0x24000030 }, - { 0x11002c0d, 0x24000030 }, - { 0x11002c0e, 0x24000030 }, - { 0x11002c0f, 0x24000030 }, - { 0x11002c10, 0x24000030 }, - { 0x11002c11, 0x24000030 }, - { 0x11002c12, 0x24000030 }, - { 0x11002c13, 0x24000030 }, - { 0x11002c14, 0x24000030 }, - { 0x11002c15, 0x24000030 }, - { 0x11002c16, 0x24000030 }, - { 0x11002c17, 0x24000030 }, - { 0x11002c18, 0x24000030 }, - { 0x11002c19, 0x24000030 }, - { 0x11002c1a, 0x24000030 }, - { 0x11002c1b, 0x24000030 }, - { 0x11002c1c, 0x24000030 }, - { 0x11002c1d, 0x24000030 }, - { 0x11002c1e, 0x24000030 }, - { 0x11002c1f, 0x24000030 }, - { 0x11002c20, 0x24000030 }, - { 0x11002c21, 0x24000030 }, - { 0x11002c22, 0x24000030 }, - { 0x11002c23, 0x24000030 }, - { 0x11002c24, 0x24000030 }, - { 0x11002c25, 0x24000030 }, - { 0x11002c26, 0x24000030 }, - { 0x11002c27, 0x24000030 }, - { 0x11002c28, 0x24000030 }, - { 0x11002c29, 0x24000030 }, - { 0x11002c2a, 0x24000030 }, - { 0x11002c2b, 0x24000030 }, - { 0x11002c2c, 0x24000030 }, - { 0x11002c2d, 0x24000030 }, - { 0x11002c2e, 0x24000030 }, - { 0x11002c30, 0x1400ffd0 }, - { 0x11002c31, 0x1400ffd0 }, - { 0x11002c32, 0x1400ffd0 }, - { 0x11002c33, 0x1400ffd0 }, - { 0x11002c34, 0x1400ffd0 }, - { 0x11002c35, 0x1400ffd0 }, - { 0x11002c36, 0x1400ffd0 }, - { 0x11002c37, 0x1400ffd0 }, - { 0x11002c38, 0x1400ffd0 }, - { 0x11002c39, 0x1400ffd0 }, - { 0x11002c3a, 0x1400ffd0 }, - { 0x11002c3b, 0x1400ffd0 }, - { 0x11002c3c, 0x1400ffd0 }, - { 0x11002c3d, 0x1400ffd0 }, - { 0x11002c3e, 0x1400ffd0 }, - { 0x11002c3f, 0x1400ffd0 }, - { 0x11002c40, 0x1400ffd0 }, - { 0x11002c41, 0x1400ffd0 }, - { 0x11002c42, 0x1400ffd0 }, - { 0x11002c43, 0x1400ffd0 }, - { 0x11002c44, 0x1400ffd0 }, - { 0x11002c45, 0x1400ffd0 }, - { 0x11002c46, 0x1400ffd0 }, - { 0x11002c47, 0x1400ffd0 }, - { 0x11002c48, 0x1400ffd0 }, - { 0x11002c49, 0x1400ffd0 }, - { 0x11002c4a, 0x1400ffd0 }, - { 0x11002c4b, 0x1400ffd0 }, - { 0x11002c4c, 0x1400ffd0 }, - { 0x11002c4d, 0x1400ffd0 }, - { 0x11002c4e, 0x1400ffd0 }, - { 0x11002c4f, 0x1400ffd0 }, - { 0x11002c50, 0x1400ffd0 }, - { 0x11002c51, 0x1400ffd0 }, - { 0x11002c52, 0x1400ffd0 }, - { 0x11002c53, 0x1400ffd0 }, - { 0x11002c54, 0x1400ffd0 }, - { 0x11002c55, 0x1400ffd0 }, - { 0x11002c56, 0x1400ffd0 }, - { 0x11002c57, 0x1400ffd0 }, - { 0x11002c58, 0x1400ffd0 }, - { 0x11002c59, 0x1400ffd0 }, - { 0x11002c5a, 0x1400ffd0 }, - { 0x11002c5b, 0x1400ffd0 }, - { 0x11002c5c, 0x1400ffd0 }, - { 0x11002c5d, 0x1400ffd0 }, - { 0x11002c5e, 0x1400ffd0 }, - { 0x21002c60, 0x24000001 }, - { 0x21002c61, 0x1400ffff }, - { 0x21002c62, 0x2400d609 }, - { 0x21002c63, 0x2400f11a }, - { 0x21002c64, 0x2400d619 }, - { 0x21002c65, 0x1400d5d5 }, - { 0x21002c66, 0x1400d5d8 }, - { 0x21002c67, 0x24000001 }, - { 0x21002c68, 0x1400ffff }, - { 0x21002c69, 0x24000001 }, - { 0x21002c6a, 0x1400ffff }, - { 0x21002c6b, 0x24000001 }, - { 0x21002c6c, 0x1400ffff }, - { 0x21002c74, 0x14000000 }, - { 0x21002c75, 0x24000001 }, - { 0x21002c76, 0x1400ffff }, - { 0x21002c77, 0x14000000 }, - { 0x0a002c80, 0x24000001 }, - { 0x0a002c81, 0x1400ffff }, - { 0x0a002c82, 0x24000001 }, - { 0x0a002c83, 0x1400ffff }, - { 0x0a002c84, 0x24000001 }, - { 0x0a002c85, 0x1400ffff }, - { 0x0a002c86, 0x24000001 }, - { 0x0a002c87, 0x1400ffff }, - { 0x0a002c88, 0x24000001 }, - { 0x0a002c89, 0x1400ffff }, - { 0x0a002c8a, 0x24000001 }, - { 0x0a002c8b, 0x1400ffff }, - { 0x0a002c8c, 0x24000001 }, - { 0x0a002c8d, 0x1400ffff }, - { 0x0a002c8e, 0x24000001 }, - { 0x0a002c8f, 0x1400ffff }, - { 0x0a002c90, 0x24000001 }, - { 0x0a002c91, 0x1400ffff }, - { 0x0a002c92, 0x24000001 }, - { 0x0a002c93, 0x1400ffff }, - { 0x0a002c94, 0x24000001 }, - { 0x0a002c95, 0x1400ffff }, - { 0x0a002c96, 0x24000001 }, - { 0x0a002c97, 0x1400ffff }, - { 0x0a002c98, 0x24000001 }, - { 0x0a002c99, 0x1400ffff }, - { 0x0a002c9a, 0x24000001 }, - { 0x0a002c9b, 0x1400ffff }, - { 0x0a002c9c, 0x24000001 }, - { 0x0a002c9d, 0x1400ffff }, - { 0x0a002c9e, 0x24000001 }, - { 0x0a002c9f, 0x1400ffff }, - { 0x0a002ca0, 0x24000001 }, - { 0x0a002ca1, 0x1400ffff }, - { 0x0a002ca2, 0x24000001 }, - { 0x0a002ca3, 0x1400ffff }, - { 0x0a002ca4, 0x24000001 }, - { 0x0a002ca5, 0x1400ffff }, - { 0x0a002ca6, 0x24000001 }, - { 0x0a002ca7, 0x1400ffff }, - { 0x0a002ca8, 0x24000001 }, - { 0x0a002ca9, 0x1400ffff }, - { 0x0a002caa, 0x24000001 }, - { 0x0a002cab, 0x1400ffff }, - { 0x0a002cac, 0x24000001 }, - { 0x0a002cad, 0x1400ffff }, - { 0x0a002cae, 0x24000001 }, - { 0x0a002caf, 0x1400ffff }, - { 0x0a002cb0, 0x24000001 }, - { 0x0a002cb1, 0x1400ffff }, - { 0x0a002cb2, 0x24000001 }, - { 0x0a002cb3, 0x1400ffff }, - { 0x0a002cb4, 0x24000001 }, - { 0x0a002cb5, 0x1400ffff }, - { 0x0a002cb6, 0x24000001 }, - { 0x0a002cb7, 0x1400ffff }, - { 0x0a002cb8, 0x24000001 }, - { 0x0a002cb9, 0x1400ffff }, - { 0x0a002cba, 0x24000001 }, - { 0x0a002cbb, 0x1400ffff }, - { 0x0a002cbc, 0x24000001 }, - { 0x0a002cbd, 0x1400ffff }, - { 0x0a002cbe, 0x24000001 }, - { 0x0a002cbf, 0x1400ffff }, - { 0x0a002cc0, 0x24000001 }, - { 0x0a002cc1, 0x1400ffff }, - { 0x0a002cc2, 0x24000001 }, - { 0x0a002cc3, 0x1400ffff }, - { 0x0a002cc4, 0x24000001 }, - { 0x0a002cc5, 0x1400ffff }, - { 0x0a002cc6, 0x24000001 }, - { 0x0a002cc7, 0x1400ffff }, - { 0x0a002cc8, 0x24000001 }, - { 0x0a002cc9, 0x1400ffff }, - { 0x0a002cca, 0x24000001 }, - { 0x0a002ccb, 0x1400ffff }, - { 0x0a002ccc, 0x24000001 }, - { 0x0a002ccd, 0x1400ffff }, - { 0x0a002cce, 0x24000001 }, - { 0x0a002ccf, 0x1400ffff }, - { 0x0a002cd0, 0x24000001 }, - { 0x0a002cd1, 0x1400ffff }, - { 0x0a002cd2, 0x24000001 }, - { 0x0a002cd3, 0x1400ffff }, - { 0x0a002cd4, 0x24000001 }, - { 0x0a002cd5, 0x1400ffff }, - { 0x0a002cd6, 0x24000001 }, - { 0x0a002cd7, 0x1400ffff }, - { 0x0a002cd8, 0x24000001 }, - { 0x0a002cd9, 0x1400ffff }, - { 0x0a002cda, 0x24000001 }, - { 0x0a002cdb, 0x1400ffff }, - { 0x0a002cdc, 0x24000001 }, - { 0x0a002cdd, 0x1400ffff }, - { 0x0a002cde, 0x24000001 }, - { 0x0a002cdf, 0x1400ffff }, - { 0x0a002ce0, 0x24000001 }, - { 0x0a002ce1, 0x1400ffff }, - { 0x0a002ce2, 0x24000001 }, - { 0x0a002ce3, 0x1400ffff }, - { 0x0a002ce4, 0x14000000 }, - { 0x0a802ce5, 0x68000005 }, - { 0x0a802cf9, 0x54000003 }, - { 0x0a002cfd, 0x3c000000 }, - { 0x0a802cfe, 0x54000001 }, - { 0x10002d00, 0x1400e3a0 }, - { 0x10002d01, 0x1400e3a0 }, - { 0x10002d02, 0x1400e3a0 }, - { 0x10002d03, 0x1400e3a0 }, - { 0x10002d04, 0x1400e3a0 }, - { 0x10002d05, 0x1400e3a0 }, - { 0x10002d06, 0x1400e3a0 }, - { 0x10002d07, 0x1400e3a0 }, - { 0x10002d08, 0x1400e3a0 }, - { 0x10002d09, 0x1400e3a0 }, - { 0x10002d0a, 0x1400e3a0 }, - { 0x10002d0b, 0x1400e3a0 }, - { 0x10002d0c, 0x1400e3a0 }, - { 0x10002d0d, 0x1400e3a0 }, - { 0x10002d0e, 0x1400e3a0 }, - { 0x10002d0f, 0x1400e3a0 }, - { 0x10002d10, 0x1400e3a0 }, - { 0x10002d11, 0x1400e3a0 }, - { 0x10002d12, 0x1400e3a0 }, - { 0x10002d13, 0x1400e3a0 }, - { 0x10002d14, 0x1400e3a0 }, - { 0x10002d15, 0x1400e3a0 }, - { 0x10002d16, 0x1400e3a0 }, - { 0x10002d17, 0x1400e3a0 }, - { 0x10002d18, 0x1400e3a0 }, - { 0x10002d19, 0x1400e3a0 }, - { 0x10002d1a, 0x1400e3a0 }, - { 0x10002d1b, 0x1400e3a0 }, - { 0x10002d1c, 0x1400e3a0 }, - { 0x10002d1d, 0x1400e3a0 }, - { 0x10002d1e, 0x1400e3a0 }, - { 0x10002d1f, 0x1400e3a0 }, - { 0x10002d20, 0x1400e3a0 }, - { 0x10002d21, 0x1400e3a0 }, - { 0x10002d22, 0x1400e3a0 }, - { 0x10002d23, 0x1400e3a0 }, - { 0x10002d24, 0x1400e3a0 }, - { 0x10002d25, 0x1400e3a0 }, - { 0x3a802d30, 0x1c000035 }, - { 0x3a002d6f, 0x18000000 }, - { 0x0f802d80, 0x1c000016 }, - { 0x0f802da0, 0x1c000006 }, - { 0x0f802da8, 0x1c000006 }, - { 0x0f802db0, 0x1c000006 }, - { 0x0f802db8, 0x1c000006 }, - { 0x0f802dc0, 0x1c000006 }, - { 0x0f802dc8, 0x1c000006 }, - { 0x0f802dd0, 0x1c000006 }, - { 0x0f802dd8, 0x1c000006 }, - { 0x09802e00, 0x54000001 }, - { 0x09002e02, 0x50000000 }, - { 0x09002e03, 0x4c000000 }, - { 0x09002e04, 0x50000000 }, - { 0x09002e05, 0x4c000000 }, - { 0x09802e06, 0x54000002 }, - { 0x09002e09, 0x50000000 }, - { 0x09002e0a, 0x4c000000 }, - { 0x09002e0b, 0x54000000 }, - { 0x09002e0c, 0x50000000 }, - { 0x09002e0d, 0x4c000000 }, - { 0x09802e0e, 0x54000008 }, - { 0x09002e17, 0x44000000 }, - { 0x09002e1c, 0x50000000 }, - { 0x09002e1d, 0x4c000000 }, - { 0x16802e80, 0x68000019 }, - { 0x16802e9b, 0x68000058 }, - { 0x16802f00, 0x680000d5 }, - { 0x09802ff0, 0x6800000b }, - { 0x09003000, 0x74000000 }, - { 0x09803001, 0x54000002 }, - { 0x09003004, 0x68000000 }, - { 0x16003005, 0x18000000 }, - { 0x09003006, 0x1c000000 }, - { 0x16003007, 0x38000000 }, - { 0x09003008, 0x58000000 }, - { 0x09003009, 0x48000000 }, - { 0x0900300a, 0x58000000 }, - { 0x0900300b, 0x48000000 }, - { 0x0900300c, 0x58000000 }, - { 0x0900300d, 0x48000000 }, - { 0x0900300e, 0x58000000 }, - { 0x0900300f, 0x48000000 }, - { 0x09003010, 0x58000000 }, - { 0x09003011, 0x48000000 }, - { 0x09803012, 0x68000001 }, - { 0x09003014, 0x58000000 }, - { 0x09003015, 0x48000000 }, - { 0x09003016, 0x58000000 }, - { 0x09003017, 0x48000000 }, - { 0x09003018, 0x58000000 }, - { 0x09003019, 0x48000000 }, - { 0x0900301a, 0x58000000 }, - { 0x0900301b, 0x48000000 }, - { 0x0900301c, 0x44000000 }, - { 0x0900301d, 0x58000000 }, - { 0x0980301e, 0x48000001 }, - { 0x09003020, 0x68000000 }, - { 0x16803021, 0x38000008 }, - { 0x1b80302a, 0x30000005 }, - { 0x09003030, 0x44000000 }, - { 0x09803031, 0x18000004 }, - { 0x09803036, 0x68000001 }, - { 0x16803038, 0x38000002 }, - { 0x1600303b, 0x18000000 }, - { 0x0900303c, 0x1c000000 }, - { 0x0900303d, 0x54000000 }, - { 0x0980303e, 0x68000001 }, - { 0x1a803041, 0x1c000055 }, - { 0x1b803099, 0x30000001 }, - { 0x0980309b, 0x60000001 }, - { 0x1a80309d, 0x18000001 }, - { 0x1a00309f, 0x1c000000 }, - { 0x090030a0, 0x44000000 }, - { 0x1d8030a1, 0x1c000059 }, - { 0x090030fb, 0x54000000 }, - { 0x098030fc, 0x18000002 }, - { 0x1d0030ff, 0x1c000000 }, - { 0x03803105, 0x1c000027 }, - { 0x17803131, 0x1c00005d }, - { 0x09803190, 0x68000001 }, - { 0x09803192, 0x3c000003 }, - { 0x09803196, 0x68000009 }, - { 0x038031a0, 0x1c000017 }, - { 0x098031c0, 0x6800000f }, - { 0x1d8031f0, 0x1c00000f }, - { 0x17803200, 0x6800001e }, - { 0x09803220, 0x3c000009 }, - { 0x0980322a, 0x68000019 }, - { 0x09003250, 0x68000000 }, - { 0x09803251, 0x3c00000e }, - { 0x17803260, 0x6800001f }, - { 0x09803280, 0x3c000009 }, - { 0x0980328a, 0x68000026 }, - { 0x098032b1, 0x3c00000e }, - { 0x098032c0, 0x6800003e }, - { 0x09803300, 0x680000ff }, - { 0x16803400, 0x1c0019b5 }, - { 0x09804dc0, 0x6800003f }, - { 0x16804e00, 0x1c0051bb }, - { 0x3c80a000, 0x1c000014 }, - { 0x3c00a015, 0x18000000 }, - { 0x3c80a016, 0x1c000476 }, - { 0x3c80a490, 0x68000036 }, - { 0x0980a700, 0x60000016 }, - { 0x0980a717, 0x18000003 }, - { 0x0980a720, 0x60000001 }, - { 0x3080a800, 0x1c000001 }, - { 0x3000a802, 0x28000000 }, - { 0x3080a803, 0x1c000002 }, - { 0x3000a806, 0x30000000 }, - { 0x3080a807, 0x1c000003 }, - { 0x3000a80b, 0x30000000 }, - { 0x3080a80c, 0x1c000016 }, - { 0x3080a823, 0x28000001 }, - { 0x3080a825, 0x30000001 }, - { 0x3000a827, 0x28000000 }, - { 0x3080a828, 0x68000003 }, - { 0x4080a840, 0x1c000033 }, - { 0x4080a874, 0x54000003 }, - { 0x1780ac00, 0x1c002ba3 }, - { 0x0980d800, 0x1000037f }, - { 0x0980db80, 0x1000007f }, - { 0x0980dc00, 0x100003ff }, - { 0x0980e000, 0x0c0018ff }, - { 0x1680f900, 0x1c00012d }, - { 0x1680fa30, 0x1c00003a }, - { 0x1680fa70, 0x1c000069 }, - { 0x2180fb00, 0x14000006 }, - { 0x0180fb13, 0x14000004 }, - { 0x1900fb1d, 0x1c000000 }, - { 0x1900fb1e, 0x30000000 }, - { 0x1980fb1f, 0x1c000009 }, - { 0x1900fb29, 0x64000000 }, - { 0x1980fb2a, 0x1c00000c }, - { 0x1980fb38, 0x1c000004 }, - { 0x1900fb3e, 0x1c000000 }, - { 0x1980fb40, 0x1c000001 }, - { 0x1980fb43, 0x1c000001 }, - { 0x1980fb46, 0x1c00006b }, - { 0x0080fbd3, 0x1c00016a }, - { 0x0900fd3e, 0x58000000 }, - { 0x0900fd3f, 0x48000000 }, - { 0x0080fd50, 0x1c00003f }, - { 0x0080fd92, 0x1c000035 }, - { 0x0080fdf0, 0x1c00000b }, - { 0x0000fdfc, 0x5c000000 }, - { 0x0900fdfd, 0x68000000 }, - { 0x1b80fe00, 0x3000000f }, - { 0x0980fe10, 0x54000006 }, - { 0x0900fe17, 0x58000000 }, - { 0x0900fe18, 0x48000000 }, - { 0x0900fe19, 0x54000000 }, - { 0x1b80fe20, 0x30000003 }, - { 0x0900fe30, 0x54000000 }, - { 0x0980fe31, 0x44000001 }, - { 0x0980fe33, 0x40000001 }, - { 0x0900fe35, 0x58000000 }, - { 0x0900fe36, 0x48000000 }, - { 0x0900fe37, 0x58000000 }, - { 0x0900fe38, 0x48000000 }, - { 0x0900fe39, 0x58000000 }, - { 0x0900fe3a, 0x48000000 }, - { 0x0900fe3b, 0x58000000 }, - { 0x0900fe3c, 0x48000000 }, - { 0x0900fe3d, 0x58000000 }, - { 0x0900fe3e, 0x48000000 }, - { 0x0900fe3f, 0x58000000 }, - { 0x0900fe40, 0x48000000 }, - { 0x0900fe41, 0x58000000 }, - { 0x0900fe42, 0x48000000 }, - { 0x0900fe43, 0x58000000 }, - { 0x0900fe44, 0x48000000 }, - { 0x0980fe45, 0x54000001 }, - { 0x0900fe47, 0x58000000 }, - { 0x0900fe48, 0x48000000 }, - { 0x0980fe49, 0x54000003 }, - { 0x0980fe4d, 0x40000002 }, - { 0x0980fe50, 0x54000002 }, - { 0x0980fe54, 0x54000003 }, - { 0x0900fe58, 0x44000000 }, - { 0x0900fe59, 0x58000000 }, - { 0x0900fe5a, 0x48000000 }, - { 0x0900fe5b, 0x58000000 }, - { 0x0900fe5c, 0x48000000 }, - { 0x0900fe5d, 0x58000000 }, - { 0x0900fe5e, 0x48000000 }, - { 0x0980fe5f, 0x54000002 }, - { 0x0900fe62, 0x64000000 }, - { 0x0900fe63, 0x44000000 }, - { 0x0980fe64, 0x64000002 }, - { 0x0900fe68, 0x54000000 }, - { 0x0900fe69, 0x5c000000 }, - { 0x0980fe6a, 0x54000001 }, - { 0x0080fe70, 0x1c000004 }, - { 0x0080fe76, 0x1c000086 }, - { 0x0900feff, 0x04000000 }, - { 0x0980ff01, 0x54000002 }, - { 0x0900ff04, 0x5c000000 }, - { 0x0980ff05, 0x54000002 }, - { 0x0900ff08, 0x58000000 }, - { 0x0900ff09, 0x48000000 }, - { 0x0900ff0a, 0x54000000 }, - { 0x0900ff0b, 0x64000000 }, - { 0x0900ff0c, 0x54000000 }, - { 0x0900ff0d, 0x44000000 }, - { 0x0980ff0e, 0x54000001 }, - { 0x0980ff10, 0x34000009 }, - { 0x0980ff1a, 0x54000001 }, - { 0x0980ff1c, 0x64000002 }, - { 0x0980ff1f, 0x54000001 }, - { 0x2100ff21, 0x24000020 }, - { 0x2100ff22, 0x24000020 }, - { 0x2100ff23, 0x24000020 }, - { 0x2100ff24, 0x24000020 }, - { 0x2100ff25, 0x24000020 }, - { 0x2100ff26, 0x24000020 }, - { 0x2100ff27, 0x24000020 }, - { 0x2100ff28, 0x24000020 }, - { 0x2100ff29, 0x24000020 }, - { 0x2100ff2a, 0x24000020 }, - { 0x2100ff2b, 0x24000020 }, - { 0x2100ff2c, 0x24000020 }, - { 0x2100ff2d, 0x24000020 }, - { 0x2100ff2e, 0x24000020 }, - { 0x2100ff2f, 0x24000020 }, - { 0x2100ff30, 0x24000020 }, - { 0x2100ff31, 0x24000020 }, - { 0x2100ff32, 0x24000020 }, - { 0x2100ff33, 0x24000020 }, - { 0x2100ff34, 0x24000020 }, - { 0x2100ff35, 0x24000020 }, - { 0x2100ff36, 0x24000020 }, - { 0x2100ff37, 0x24000020 }, - { 0x2100ff38, 0x24000020 }, - { 0x2100ff39, 0x24000020 }, - { 0x2100ff3a, 0x24000020 }, - { 0x0900ff3b, 0x58000000 }, - { 0x0900ff3c, 0x54000000 }, - { 0x0900ff3d, 0x48000000 }, - { 0x0900ff3e, 0x60000000 }, - { 0x0900ff3f, 0x40000000 }, - { 0x0900ff40, 0x60000000 }, - { 0x2100ff41, 0x1400ffe0 }, - { 0x2100ff42, 0x1400ffe0 }, - { 0x2100ff43, 0x1400ffe0 }, - { 0x2100ff44, 0x1400ffe0 }, - { 0x2100ff45, 0x1400ffe0 }, - { 0x2100ff46, 0x1400ffe0 }, - { 0x2100ff47, 0x1400ffe0 }, - { 0x2100ff48, 0x1400ffe0 }, - { 0x2100ff49, 0x1400ffe0 }, - { 0x2100ff4a, 0x1400ffe0 }, - { 0x2100ff4b, 0x1400ffe0 }, - { 0x2100ff4c, 0x1400ffe0 }, - { 0x2100ff4d, 0x1400ffe0 }, - { 0x2100ff4e, 0x1400ffe0 }, - { 0x2100ff4f, 0x1400ffe0 }, - { 0x2100ff50, 0x1400ffe0 }, - { 0x2100ff51, 0x1400ffe0 }, - { 0x2100ff52, 0x1400ffe0 }, - { 0x2100ff53, 0x1400ffe0 }, - { 0x2100ff54, 0x1400ffe0 }, - { 0x2100ff55, 0x1400ffe0 }, - { 0x2100ff56, 0x1400ffe0 }, - { 0x2100ff57, 0x1400ffe0 }, - { 0x2100ff58, 0x1400ffe0 }, - { 0x2100ff59, 0x1400ffe0 }, - { 0x2100ff5a, 0x1400ffe0 }, - { 0x0900ff5b, 0x58000000 }, - { 0x0900ff5c, 0x64000000 }, - { 0x0900ff5d, 0x48000000 }, - { 0x0900ff5e, 0x64000000 }, - { 0x0900ff5f, 0x58000000 }, - { 0x0900ff60, 0x48000000 }, - { 0x0900ff61, 0x54000000 }, - { 0x0900ff62, 0x58000000 }, - { 0x0900ff63, 0x48000000 }, - { 0x0980ff64, 0x54000001 }, - { 0x1d80ff66, 0x1c000009 }, - { 0x0900ff70, 0x18000000 }, - { 0x1d80ff71, 0x1c00002c }, - { 0x0980ff9e, 0x18000001 }, - { 0x1780ffa0, 0x1c00001e }, - { 0x1780ffc2, 0x1c000005 }, - { 0x1780ffca, 0x1c000005 }, - { 0x1780ffd2, 0x1c000005 }, - { 0x1780ffda, 0x1c000002 }, - { 0x0980ffe0, 0x5c000001 }, - { 0x0900ffe2, 0x64000000 }, - { 0x0900ffe3, 0x60000000 }, - { 0x0900ffe4, 0x68000000 }, - { 0x0980ffe5, 0x5c000001 }, - { 0x0900ffe8, 0x68000000 }, - { 0x0980ffe9, 0x64000003 }, - { 0x0980ffed, 0x68000001 }, - { 0x0980fff9, 0x04000002 }, - { 0x0980fffc, 0x68000001 }, - { 0x23810000, 0x1c00000b }, - { 0x2381000d, 0x1c000019 }, - { 0x23810028, 0x1c000012 }, - { 0x2381003c, 0x1c000001 }, - { 0x2381003f, 0x1c00000e }, - { 0x23810050, 0x1c00000d }, - { 0x23810080, 0x1c00007a }, - { 0x09810100, 0x54000001 }, - { 0x09010102, 0x68000000 }, - { 0x09810107, 0x3c00002c }, - { 0x09810137, 0x68000008 }, - { 0x13810140, 0x38000034 }, - { 0x13810175, 0x3c000003 }, - { 0x13810179, 0x68000010 }, - { 0x1301018a, 0x3c000000 }, - { 0x29810300, 0x1c00001e }, - { 0x29810320, 0x3c000003 }, - { 0x12810330, 0x1c000010 }, - { 0x12010341, 0x38000000 }, - { 0x12810342, 0x1c000007 }, - { 0x1201034a, 0x38000000 }, - { 0x3b810380, 0x1c00001d }, - { 0x3b01039f, 0x54000000 }, - { 0x2a8103a0, 0x1c000023 }, - { 0x2a8103c8, 0x1c000007 }, - { 0x2a0103d0, 0x54000000 }, - { 0x2a8103d1, 0x38000004 }, - { 0x0d010400, 0x24000028 }, - { 0x0d010401, 0x24000028 }, - { 0x0d010402, 0x24000028 }, - { 0x0d010403, 0x24000028 }, - { 0x0d010404, 0x24000028 }, - { 0x0d010405, 0x24000028 }, - { 0x0d010406, 0x24000028 }, - { 0x0d010407, 0x24000028 }, - { 0x0d010408, 0x24000028 }, - { 0x0d010409, 0x24000028 }, - { 0x0d01040a, 0x24000028 }, - { 0x0d01040b, 0x24000028 }, - { 0x0d01040c, 0x24000028 }, - { 0x0d01040d, 0x24000028 }, - { 0x0d01040e, 0x24000028 }, - { 0x0d01040f, 0x24000028 }, - { 0x0d010410, 0x24000028 }, - { 0x0d010411, 0x24000028 }, - { 0x0d010412, 0x24000028 }, - { 0x0d010413, 0x24000028 }, - { 0x0d010414, 0x24000028 }, - { 0x0d010415, 0x24000028 }, - { 0x0d010416, 0x24000028 }, - { 0x0d010417, 0x24000028 }, - { 0x0d010418, 0x24000028 }, - { 0x0d010419, 0x24000028 }, - { 0x0d01041a, 0x24000028 }, - { 0x0d01041b, 0x24000028 }, - { 0x0d01041c, 0x24000028 }, - { 0x0d01041d, 0x24000028 }, - { 0x0d01041e, 0x24000028 }, - { 0x0d01041f, 0x24000028 }, - { 0x0d010420, 0x24000028 }, - { 0x0d010421, 0x24000028 }, - { 0x0d010422, 0x24000028 }, - { 0x0d010423, 0x24000028 }, - { 0x0d010424, 0x24000028 }, - { 0x0d010425, 0x24000028 }, - { 0x0d010426, 0x24000028 }, - { 0x0d010427, 0x24000028 }, - { 0x0d010428, 0x1400ffd8 }, - { 0x0d010429, 0x1400ffd8 }, - { 0x0d01042a, 0x1400ffd8 }, - { 0x0d01042b, 0x1400ffd8 }, - { 0x0d01042c, 0x1400ffd8 }, - { 0x0d01042d, 0x1400ffd8 }, - { 0x0d01042e, 0x1400ffd8 }, - { 0x0d01042f, 0x1400ffd8 }, - { 0x0d010430, 0x1400ffd8 }, - { 0x0d010431, 0x1400ffd8 }, - { 0x0d010432, 0x1400ffd8 }, - { 0x0d010433, 0x1400ffd8 }, - { 0x0d010434, 0x1400ffd8 }, - { 0x0d010435, 0x1400ffd8 }, - { 0x0d010436, 0x1400ffd8 }, - { 0x0d010437, 0x1400ffd8 }, - { 0x0d010438, 0x1400ffd8 }, - { 0x0d010439, 0x1400ffd8 }, - { 0x0d01043a, 0x1400ffd8 }, - { 0x0d01043b, 0x1400ffd8 }, - { 0x0d01043c, 0x1400ffd8 }, - { 0x0d01043d, 0x1400ffd8 }, - { 0x0d01043e, 0x1400ffd8 }, - { 0x0d01043f, 0x1400ffd8 }, - { 0x0d010440, 0x1400ffd8 }, - { 0x0d010441, 0x1400ffd8 }, - { 0x0d010442, 0x1400ffd8 }, - { 0x0d010443, 0x1400ffd8 }, - { 0x0d010444, 0x1400ffd8 }, - { 0x0d010445, 0x1400ffd8 }, - { 0x0d010446, 0x1400ffd8 }, - { 0x0d010447, 0x1400ffd8 }, - { 0x0d010448, 0x1400ffd8 }, - { 0x0d010449, 0x1400ffd8 }, - { 0x0d01044a, 0x1400ffd8 }, - { 0x0d01044b, 0x1400ffd8 }, - { 0x0d01044c, 0x1400ffd8 }, - { 0x0d01044d, 0x1400ffd8 }, - { 0x0d01044e, 0x1400ffd8 }, - { 0x0d01044f, 0x1400ffd8 }, - { 0x2e810450, 0x1c00004d }, - { 0x2c8104a0, 0x34000009 }, - { 0x0b810800, 0x1c000005 }, - { 0x0b010808, 0x1c000000 }, - { 0x0b81080a, 0x1c00002b }, - { 0x0b810837, 0x1c000001 }, - { 0x0b01083c, 0x1c000000 }, - { 0x0b01083f, 0x1c000000 }, - { 0x41810900, 0x1c000015 }, - { 0x41810916, 0x3c000003 }, - { 0x4101091f, 0x54000000 }, - { 0x1e010a00, 0x1c000000 }, - { 0x1e810a01, 0x30000002 }, - { 0x1e810a05, 0x30000001 }, - { 0x1e810a0c, 0x30000003 }, - { 0x1e810a10, 0x1c000003 }, - { 0x1e810a15, 0x1c000002 }, - { 0x1e810a19, 0x1c00001a }, - { 0x1e810a38, 0x30000002 }, - { 0x1e010a3f, 0x30000000 }, - { 0x1e810a40, 0x3c000007 }, - { 0x1e810a50, 0x54000008 }, - { 0x3e812000, 0x1c00036e }, - { 0x3e812400, 0x38000062 }, - { 0x3e812470, 0x54000003 }, - { 0x0981d000, 0x680000f5 }, - { 0x0981d100, 0x68000026 }, - { 0x0981d12a, 0x6800003a }, - { 0x0981d165, 0x28000001 }, - { 0x1b81d167, 0x30000002 }, - { 0x0981d16a, 0x68000002 }, - { 0x0981d16d, 0x28000005 }, - { 0x0981d173, 0x04000007 }, - { 0x1b81d17b, 0x30000007 }, - { 0x0981d183, 0x68000001 }, - { 0x1b81d185, 0x30000006 }, - { 0x0981d18c, 0x6800001d }, - { 0x1b81d1aa, 0x30000003 }, - { 0x0981d1ae, 0x6800002f }, - { 0x1381d200, 0x68000041 }, - { 0x1381d242, 0x30000002 }, - { 0x1301d245, 0x68000000 }, - { 0x0981d300, 0x68000056 }, - { 0x0981d360, 0x3c000011 }, - { 0x0981d400, 0x24000019 }, - { 0x0981d41a, 0x14000019 }, - { 0x0981d434, 0x24000019 }, - { 0x0981d44e, 0x14000006 }, - { 0x0981d456, 0x14000011 }, - { 0x0981d468, 0x24000019 }, - { 0x0981d482, 0x14000019 }, - { 0x0901d49c, 0x24000000 }, - { 0x0981d49e, 0x24000001 }, - { 0x0901d4a2, 0x24000000 }, - { 0x0981d4a5, 0x24000001 }, - { 0x0981d4a9, 0x24000003 }, - { 0x0981d4ae, 0x24000007 }, - { 0x0981d4b6, 0x14000003 }, - { 0x0901d4bb, 0x14000000 }, - { 0x0981d4bd, 0x14000006 }, - { 0x0981d4c5, 0x1400000a }, - { 0x0981d4d0, 0x24000019 }, - { 0x0981d4ea, 0x14000019 }, - { 0x0981d504, 0x24000001 }, - { 0x0981d507, 0x24000003 }, - { 0x0981d50d, 0x24000007 }, - { 0x0981d516, 0x24000006 }, - { 0x0981d51e, 0x14000019 }, - { 0x0981d538, 0x24000001 }, - { 0x0981d53b, 0x24000003 }, - { 0x0981d540, 0x24000004 }, - { 0x0901d546, 0x24000000 }, - { 0x0981d54a, 0x24000006 }, - { 0x0981d552, 0x14000019 }, - { 0x0981d56c, 0x24000019 }, - { 0x0981d586, 0x14000019 }, - { 0x0981d5a0, 0x24000019 }, - { 0x0981d5ba, 0x14000019 }, - { 0x0981d5d4, 0x24000019 }, - { 0x0981d5ee, 0x14000019 }, - { 0x0981d608, 0x24000019 }, - { 0x0981d622, 0x14000019 }, - { 0x0981d63c, 0x24000019 }, - { 0x0981d656, 0x14000019 }, - { 0x0981d670, 0x24000019 }, - { 0x0981d68a, 0x1400001b }, - { 0x0981d6a8, 0x24000018 }, - { 0x0901d6c1, 0x64000000 }, - { 0x0981d6c2, 0x14000018 }, - { 0x0901d6db, 0x64000000 }, - { 0x0981d6dc, 0x14000005 }, - { 0x0981d6e2, 0x24000018 }, - { 0x0901d6fb, 0x64000000 }, - { 0x0981d6fc, 0x14000018 }, - { 0x0901d715, 0x64000000 }, - { 0x0981d716, 0x14000005 }, - { 0x0981d71c, 0x24000018 }, - { 0x0901d735, 0x64000000 }, - { 0x0981d736, 0x14000018 }, - { 0x0901d74f, 0x64000000 }, - { 0x0981d750, 0x14000005 }, - { 0x0981d756, 0x24000018 }, - { 0x0901d76f, 0x64000000 }, - { 0x0981d770, 0x14000018 }, - { 0x0901d789, 0x64000000 }, - { 0x0981d78a, 0x14000005 }, - { 0x0981d790, 0x24000018 }, - { 0x0901d7a9, 0x64000000 }, - { 0x0981d7aa, 0x14000018 }, - { 0x0901d7c3, 0x64000000 }, - { 0x0981d7c4, 0x14000005 }, - { 0x0901d7ca, 0x24000000 }, - { 0x0901d7cb, 0x14000000 }, - { 0x0981d7ce, 0x34000031 }, - { 0x16820000, 0x1c00a6d6 }, - { 0x1682f800, 0x1c00021d }, - { 0x090e0001, 0x04000000 }, - { 0x098e0020, 0x0400005f }, - { 0x1b8e0100, 0x300000ef }, - { 0x098f0000, 0x0c00fffd }, - { 0x09900000, 0x0c00fffd }, -}; diff --git a/src/plugins/PCREPlugin/ucptable.h b/src/plugins/PCREPlugin/ucptable.h deleted file mode 100644 index 07eaced..0000000 --- a/src/plugins/PCREPlugin/ucptable.h +++ /dev/null @@ -1,3068 +0,0 @@ -/* This source module is automatically generated from the Unicode -property table. See ucpinternal.h for a description of the layout. -This version was made from the Unicode 5.0.0 tables. */ - -static const cnode ucp_table[] = { - { 0x09800000, 0x0000001f }, - { 0x09000020, 0x74000000 }, - { 0x09800021, 0x54000002 }, - { 0x09000024, 0x5c000000 }, - { 0x09800025, 0x54000002 }, - { 0x09000028, 0x58000000 }, - { 0x09000029, 0x48000000 }, - { 0x0900002a, 0x54000000 }, - { 0x0900002b, 0x64000000 }, - { 0x0900002c, 0x54000000 }, - { 0x0900002d, 0x44000000 }, - { 0x0980002e, 0x54000001 }, - { 0x09800030, 0x34000009 }, - { 0x0980003a, 0x54000001 }, - { 0x0980003c, 0x64000002 }, - { 0x0980003f, 0x54000001 }, - { 0x21000041, 0x24000020 }, - { 0x21000042, 0x24000020 }, - { 0x21000043, 0x24000020 }, - { 0x21000044, 0x24000020 }, - { 0x21000045, 0x24000020 }, - { 0x21000046, 0x24000020 }, - { 0x21000047, 0x24000020 }, - { 0x21000048, 0x24000020 }, - { 0x21000049, 0x24000020 }, - { 0x2100004a, 0x24000020 }, - { 0x2100004b, 0x24000020 }, - { 0x2100004c, 0x24000020 }, - { 0x2100004d, 0x24000020 }, - { 0x2100004e, 0x24000020 }, - { 0x2100004f, 0x24000020 }, - { 0x21000050, 0x24000020 }, - { 0x21000051, 0x24000020 }, - { 0x21000052, 0x24000020 }, - { 0x21000053, 0x24000020 }, - { 0x21000054, 0x24000020 }, - { 0x21000055, 0x24000020 }, - { 0x21000056, 0x24000020 }, - { 0x21000057, 0x24000020 }, - { 0x21000058, 0x24000020 }, - { 0x21000059, 0x24000020 }, - { 0x2100005a, 0x24000020 }, - { 0x0900005b, 0x58000000 }, - { 0x0900005c, 0x54000000 }, - { 0x0900005d, 0x48000000 }, - { 0x0900005e, 0x60000000 }, - { 0x0900005f, 0x40000000 }, - { 0x09000060, 0x60000000 }, - { 0x21000061, 0x1400ffe0 }, - { 0x21000062, 0x1400ffe0 }, - { 0x21000063, 0x1400ffe0 }, - { 0x21000064, 0x1400ffe0 }, - { 0x21000065, 0x1400ffe0 }, - { 0x21000066, 0x1400ffe0 }, - { 0x21000067, 0x1400ffe0 }, - { 0x21000068, 0x1400ffe0 }, - { 0x21000069, 0x1400ffe0 }, - { 0x2100006a, 0x1400ffe0 }, - { 0x2100006b, 0x1400ffe0 }, - { 0x2100006c, 0x1400ffe0 }, - { 0x2100006d, 0x1400ffe0 }, - { 0x2100006e, 0x1400ffe0 }, - { 0x2100006f, 0x1400ffe0 }, - { 0x21000070, 0x1400ffe0 }, - { 0x21000071, 0x1400ffe0 }, - { 0x21000072, 0x1400ffe0 }, - { 0x21000073, 0x1400ffe0 }, - { 0x21000074, 0x1400ffe0 }, - { 0x21000075, 0x1400ffe0 }, - { 0x21000076, 0x1400ffe0 }, - { 0x21000077, 0x1400ffe0 }, - { 0x21000078, 0x1400ffe0 }, - { 0x21000079, 0x1400ffe0 }, - { 0x2100007a, 0x1400ffe0 }, - { 0x0900007b, 0x58000000 }, - { 0x0900007c, 0x64000000 }, - { 0x0900007d, 0x48000000 }, - { 0x0900007e, 0x64000000 }, - { 0x0980007f, 0x00000020 }, - { 0x090000a0, 0x74000000 }, - { 0x090000a1, 0x54000000 }, - { 0x098000a2, 0x5c000003 }, - { 0x098000a6, 0x68000001 }, - { 0x090000a8, 0x60000000 }, - { 0x090000a9, 0x68000000 }, - { 0x210000aa, 0x14000000 }, - { 0x090000ab, 0x50000000 }, - { 0x090000ac, 0x64000000 }, - { 0x090000ad, 0x04000000 }, - { 0x090000ae, 0x68000000 }, - { 0x090000af, 0x60000000 }, - { 0x090000b0, 0x68000000 }, - { 0x090000b1, 0x64000000 }, - { 0x098000b2, 0x3c000001 }, - { 0x090000b4, 0x60000000 }, - { 0x090000b5, 0x140002e7 }, - { 0x090000b6, 0x68000000 }, - { 0x090000b7, 0x54000000 }, - { 0x090000b8, 0x60000000 }, - { 0x090000b9, 0x3c000000 }, - { 0x210000ba, 0x14000000 }, - { 0x090000bb, 0x4c000000 }, - { 0x098000bc, 0x3c000002 }, - { 0x090000bf, 0x54000000 }, - { 0x210000c0, 0x24000020 }, - { 0x210000c1, 0x24000020 }, - { 0x210000c2, 0x24000020 }, - { 0x210000c3, 0x24000020 }, - { 0x210000c4, 0x24000020 }, - { 0x210000c5, 0x24000020 }, - { 0x210000c6, 0x24000020 }, - { 0x210000c7, 0x24000020 }, - { 0x210000c8, 0x24000020 }, - { 0x210000c9, 0x24000020 }, - { 0x210000ca, 0x24000020 }, - { 0x210000cb, 0x24000020 }, - { 0x210000cc, 0x24000020 }, - { 0x210000cd, 0x24000020 }, - { 0x210000ce, 0x24000020 }, - { 0x210000cf, 0x24000020 }, - { 0x210000d0, 0x24000020 }, - { 0x210000d1, 0x24000020 }, - { 0x210000d2, 0x24000020 }, - { 0x210000d3, 0x24000020 }, - { 0x210000d4, 0x24000020 }, - { 0x210000d5, 0x24000020 }, - { 0x210000d6, 0x24000020 }, - { 0x090000d7, 0x64000000 }, - { 0x210000d8, 0x24000020 }, - { 0x210000d9, 0x24000020 }, - { 0x210000da, 0x24000020 }, - { 0x210000db, 0x24000020 }, - { 0x210000dc, 0x24000020 }, - { 0x210000dd, 0x24000020 }, - { 0x210000de, 0x24000020 }, - { 0x210000df, 0x14000000 }, - { 0x210000e0, 0x1400ffe0 }, - { 0x210000e1, 0x1400ffe0 }, - { 0x210000e2, 0x1400ffe0 }, - { 0x210000e3, 0x1400ffe0 }, - { 0x210000e4, 0x1400ffe0 }, - { 0x210000e5, 0x1400ffe0 }, - { 0x210000e6, 0x1400ffe0 }, - { 0x210000e7, 0x1400ffe0 }, - { 0x210000e8, 0x1400ffe0 }, - { 0x210000e9, 0x1400ffe0 }, - { 0x210000ea, 0x1400ffe0 }, - { 0x210000eb, 0x1400ffe0 }, - { 0x210000ec, 0x1400ffe0 }, - { 0x210000ed, 0x1400ffe0 }, - { 0x210000ee, 0x1400ffe0 }, - { 0x210000ef, 0x1400ffe0 }, - { 0x210000f0, 0x1400ffe0 }, - { 0x210000f1, 0x1400ffe0 }, - { 0x210000f2, 0x1400ffe0 }, - { 0x210000f3, 0x1400ffe0 }, - { 0x210000f4, 0x1400ffe0 }, - { 0x210000f5, 0x1400ffe0 }, - { 0x210000f6, 0x1400ffe0 }, - { 0x090000f7, 0x64000000 }, - { 0x210000f8, 0x1400ffe0 }, - { 0x210000f9, 0x1400ffe0 }, - { 0x210000fa, 0x1400ffe0 }, - { 0x210000fb, 0x1400ffe0 }, - { 0x210000fc, 0x1400ffe0 }, - { 0x210000fd, 0x1400ffe0 }, - { 0x210000fe, 0x1400ffe0 }, - { 0x210000ff, 0x14000079 }, - { 0x21000100, 0x24000001 }, - { 0x21000101, 0x1400ffff }, - { 0x21000102, 0x24000001 }, - { 0x21000103, 0x1400ffff }, - { 0x21000104, 0x24000001 }, - { 0x21000105, 0x1400ffff }, - { 0x21000106, 0x24000001 }, - { 0x21000107, 0x1400ffff }, - { 0x21000108, 0x24000001 }, - { 0x21000109, 0x1400ffff }, - { 0x2100010a, 0x24000001 }, - { 0x2100010b, 0x1400ffff }, - { 0x2100010c, 0x24000001 }, - { 0x2100010d, 0x1400ffff }, - { 0x2100010e, 0x24000001 }, - { 0x2100010f, 0x1400ffff }, - { 0x21000110, 0x24000001 }, - { 0x21000111, 0x1400ffff }, - { 0x21000112, 0x24000001 }, - { 0x21000113, 0x1400ffff }, - { 0x21000114, 0x24000001 }, - { 0x21000115, 0x1400ffff }, - { 0x21000116, 0x24000001 }, - { 0x21000117, 0x1400ffff }, - { 0x21000118, 0x24000001 }, - { 0x21000119, 0x1400ffff }, - { 0x2100011a, 0x24000001 }, - { 0x2100011b, 0x1400ffff }, - { 0x2100011c, 0x24000001 }, - { 0x2100011d, 0x1400ffff }, - { 0x2100011e, 0x24000001 }, - { 0x2100011f, 0x1400ffff }, - { 0x21000120, 0x24000001 }, - { 0x21000121, 0x1400ffff }, - { 0x21000122, 0x24000001 }, - { 0x21000123, 0x1400ffff }, - { 0x21000124, 0x24000001 }, - { 0x21000125, 0x1400ffff }, - { 0x21000126, 0x24000001 }, - { 0x21000127, 0x1400ffff }, - { 0x21000128, 0x24000001 }, - { 0x21000129, 0x1400ffff }, - { 0x2100012a, 0x24000001 }, - { 0x2100012b, 0x1400ffff }, - { 0x2100012c, 0x24000001 }, - { 0x2100012d, 0x1400ffff }, - { 0x2100012e, 0x24000001 }, - { 0x2100012f, 0x1400ffff }, - { 0x21000130, 0x2400ff39 }, - { 0x21000131, 0x1400ff18 }, - { 0x21000132, 0x24000001 }, - { 0x21000133, 0x1400ffff }, - { 0x21000134, 0x24000001 }, - { 0x21000135, 0x1400ffff }, - { 0x21000136, 0x24000001 }, - { 0x21000137, 0x1400ffff }, - { 0x21000138, 0x14000000 }, - { 0x21000139, 0x24000001 }, - { 0x2100013a, 0x1400ffff }, - { 0x2100013b, 0x24000001 }, - { 0x2100013c, 0x1400ffff }, - { 0x2100013d, 0x24000001 }, - { 0x2100013e, 0x1400ffff }, - { 0x2100013f, 0x24000001 }, - { 0x21000140, 0x1400ffff }, - { 0x21000141, 0x24000001 }, - { 0x21000142, 0x1400ffff }, - { 0x21000143, 0x24000001 }, - { 0x21000144, 0x1400ffff }, - { 0x21000145, 0x24000001 }, - { 0x21000146, 0x1400ffff }, - { 0x21000147, 0x24000001 }, - { 0x21000148, 0x1400ffff }, - { 0x21000149, 0x14000000 }, - { 0x2100014a, 0x24000001 }, - { 0x2100014b, 0x1400ffff }, - { 0x2100014c, 0x24000001 }, - { 0x2100014d, 0x1400ffff }, - { 0x2100014e, 0x24000001 }, - { 0x2100014f, 0x1400ffff }, - { 0x21000150, 0x24000001 }, - { 0x21000151, 0x1400ffff }, - { 0x21000152, 0x24000001 }, - { 0x21000153, 0x1400ffff }, - { 0x21000154, 0x24000001 }, - { 0x21000155, 0x1400ffff }, - { 0x21000156, 0x24000001 }, - { 0x21000157, 0x1400ffff }, - { 0x21000158, 0x24000001 }, - { 0x21000159, 0x1400ffff }, - { 0x2100015a, 0x24000001 }, - { 0x2100015b, 0x1400ffff }, - { 0x2100015c, 0x24000001 }, - { 0x2100015d, 0x1400ffff }, - { 0x2100015e, 0x24000001 }, - { 0x2100015f, 0x1400ffff }, - { 0x21000160, 0x24000001 }, - { 0x21000161, 0x1400ffff }, - { 0x21000162, 0x24000001 }, - { 0x21000163, 0x1400ffff }, - { 0x21000164, 0x24000001 }, - { 0x21000165, 0x1400ffff }, - { 0x21000166, 0x24000001 }, - { 0x21000167, 0x1400ffff }, - { 0x21000168, 0x24000001 }, - { 0x21000169, 0x1400ffff }, - { 0x2100016a, 0x24000001 }, - { 0x2100016b, 0x1400ffff }, - { 0x2100016c, 0x24000001 }, - { 0x2100016d, 0x1400ffff }, - { 0x2100016e, 0x24000001 }, - { 0x2100016f, 0x1400ffff }, - { 0x21000170, 0x24000001 }, - { 0x21000171, 0x1400ffff }, - { 0x21000172, 0x24000001 }, - { 0x21000173, 0x1400ffff }, - { 0x21000174, 0x24000001 }, - { 0x21000175, 0x1400ffff }, - { 0x21000176, 0x24000001 }, - { 0x21000177, 0x1400ffff }, - { 0x21000178, 0x2400ff87 }, - { 0x21000179, 0x24000001 }, - { 0x2100017a, 0x1400ffff }, - { 0x2100017b, 0x24000001 }, - { 0x2100017c, 0x1400ffff }, - { 0x2100017d, 0x24000001 }, - { 0x2100017e, 0x1400ffff }, - { 0x2100017f, 0x1400fed4 }, - { 0x21000180, 0x140000c3 }, - { 0x21000181, 0x240000d2 }, - { 0x21000182, 0x24000001 }, - { 0x21000183, 0x1400ffff }, - { 0x21000184, 0x24000001 }, - { 0x21000185, 0x1400ffff }, - { 0x21000186, 0x240000ce }, - { 0x21000187, 0x24000001 }, - { 0x21000188, 0x1400ffff }, - { 0x21000189, 0x240000cd }, - { 0x2100018a, 0x240000cd }, - { 0x2100018b, 0x24000001 }, - { 0x2100018c, 0x1400ffff }, - { 0x2100018d, 0x14000000 }, - { 0x2100018e, 0x2400004f }, - { 0x2100018f, 0x240000ca }, - { 0x21000190, 0x240000cb }, - { 0x21000191, 0x24000001 }, - { 0x21000192, 0x1400ffff }, - { 0x21000193, 0x240000cd }, - { 0x21000194, 0x240000cf }, - { 0x21000195, 0x14000061 }, - { 0x21000196, 0x240000d3 }, - { 0x21000197, 0x240000d1 }, - { 0x21000198, 0x24000001 }, - { 0x21000199, 0x1400ffff }, - { 0x2100019a, 0x140000a3 }, - { 0x2100019b, 0x14000000 }, - { 0x2100019c, 0x240000d3 }, - { 0x2100019d, 0x240000d5 }, - { 0x2100019e, 0x14000082 }, - { 0x2100019f, 0x240000d6 }, - { 0x210001a0, 0x24000001 }, - { 0x210001a1, 0x1400ffff }, - { 0x210001a2, 0x24000001 }, - { 0x210001a3, 0x1400ffff }, - { 0x210001a4, 0x24000001 }, - { 0x210001a5, 0x1400ffff }, - { 0x210001a6, 0x240000da }, - { 0x210001a7, 0x24000001 }, - { 0x210001a8, 0x1400ffff }, - { 0x210001a9, 0x240000da }, - { 0x218001aa, 0x14000001 }, - { 0x210001ac, 0x24000001 }, - { 0x210001ad, 0x1400ffff }, - { 0x210001ae, 0x240000da }, - { 0x210001af, 0x24000001 }, - { 0x210001b0, 0x1400ffff }, - { 0x210001b1, 0x240000d9 }, - { 0x210001b2, 0x240000d9 }, - { 0x210001b3, 0x24000001 }, - { 0x210001b4, 0x1400ffff }, - { 0x210001b5, 0x24000001 }, - { 0x210001b6, 0x1400ffff }, - { 0x210001b7, 0x240000db }, - { 0x210001b8, 0x24000001 }, - { 0x210001b9, 0x1400ffff }, - { 0x210001ba, 0x14000000 }, - { 0x210001bb, 0x1c000000 }, - { 0x210001bc, 0x24000001 }, - { 0x210001bd, 0x1400ffff }, - { 0x210001be, 0x14000000 }, - { 0x210001bf, 0x14000038 }, - { 0x218001c0, 0x1c000003 }, - { 0x210001c4, 0x24000002 }, - { 0x210001c5, 0x2000ffff }, - { 0x210001c6, 0x1400fffe }, - { 0x210001c7, 0x24000002 }, - { 0x210001c8, 0x2000ffff }, - { 0x210001c9, 0x1400fffe }, - { 0x210001ca, 0x24000002 }, - { 0x210001cb, 0x2000ffff }, - { 0x210001cc, 0x1400fffe }, - { 0x210001cd, 0x24000001 }, - { 0x210001ce, 0x1400ffff }, - { 0x210001cf, 0x24000001 }, - { 0x210001d0, 0x1400ffff }, - { 0x210001d1, 0x24000001 }, - { 0x210001d2, 0x1400ffff }, - { 0x210001d3, 0x24000001 }, - { 0x210001d4, 0x1400ffff }, - { 0x210001d5, 0x24000001 }, - { 0x210001d6, 0x1400ffff }, - { 0x210001d7, 0x24000001 }, - { 0x210001d8, 0x1400ffff }, - { 0x210001d9, 0x24000001 }, - { 0x210001da, 0x1400ffff }, - { 0x210001db, 0x24000001 }, - { 0x210001dc, 0x1400ffff }, - { 0x210001dd, 0x1400ffb1 }, - { 0x210001de, 0x24000001 }, - { 0x210001df, 0x1400ffff }, - { 0x210001e0, 0x24000001 }, - { 0x210001e1, 0x1400ffff }, - { 0x210001e2, 0x24000001 }, - { 0x210001e3, 0x1400ffff }, - { 0x210001e4, 0x24000001 }, - { 0x210001e5, 0x1400ffff }, - { 0x210001e6, 0x24000001 }, - { 0x210001e7, 0x1400ffff }, - { 0x210001e8, 0x24000001 }, - { 0x210001e9, 0x1400ffff }, - { 0x210001ea, 0x24000001 }, - { 0x210001eb, 0x1400ffff }, - { 0x210001ec, 0x24000001 }, - { 0x210001ed, 0x1400ffff }, - { 0x210001ee, 0x24000001 }, - { 0x210001ef, 0x1400ffff }, - { 0x210001f0, 0x14000000 }, - { 0x210001f1, 0x24000002 }, - { 0x210001f2, 0x2000ffff }, - { 0x210001f3, 0x1400fffe }, - { 0x210001f4, 0x24000001 }, - { 0x210001f5, 0x1400ffff }, - { 0x210001f6, 0x2400ff9f }, - { 0x210001f7, 0x2400ffc8 }, - { 0x210001f8, 0x24000001 }, - { 0x210001f9, 0x1400ffff }, - { 0x210001fa, 0x24000001 }, - { 0x210001fb, 0x1400ffff }, - { 0x210001fc, 0x24000001 }, - { 0x210001fd, 0x1400ffff }, - { 0x210001fe, 0x24000001 }, - { 0x210001ff, 0x1400ffff }, - { 0x21000200, 0x24000001 }, - { 0x21000201, 0x1400ffff }, - { 0x21000202, 0x24000001 }, - { 0x21000203, 0x1400ffff }, - { 0x21000204, 0x24000001 }, - { 0x21000205, 0x1400ffff }, - { 0x21000206, 0x24000001 }, - { 0x21000207, 0x1400ffff }, - { 0x21000208, 0x24000001 }, - { 0x21000209, 0x1400ffff }, - { 0x2100020a, 0x24000001 }, - { 0x2100020b, 0x1400ffff }, - { 0x2100020c, 0x24000001 }, - { 0x2100020d, 0x1400ffff }, - { 0x2100020e, 0x24000001 }, - { 0x2100020f, 0x1400ffff }, - { 0x21000210, 0x24000001 }, - { 0x21000211, 0x1400ffff }, - { 0x21000212, 0x24000001 }, - { 0x21000213, 0x1400ffff }, - { 0x21000214, 0x24000001 }, - { 0x21000215, 0x1400ffff }, - { 0x21000216, 0x24000001 }, - { 0x21000217, 0x1400ffff }, - { 0x21000218, 0x24000001 }, - { 0x21000219, 0x1400ffff }, - { 0x2100021a, 0x24000001 }, - { 0x2100021b, 0x1400ffff }, - { 0x2100021c, 0x24000001 }, - { 0x2100021d, 0x1400ffff }, - { 0x2100021e, 0x24000001 }, - { 0x2100021f, 0x1400ffff }, - { 0x21000220, 0x2400ff7e }, - { 0x21000221, 0x14000000 }, - { 0x21000222, 0x24000001 }, - { 0x21000223, 0x1400ffff }, - { 0x21000224, 0x24000001 }, - { 0x21000225, 0x1400ffff }, - { 0x21000226, 0x24000001 }, - { 0x21000227, 0x1400ffff }, - { 0x21000228, 0x24000001 }, - { 0x21000229, 0x1400ffff }, - { 0x2100022a, 0x24000001 }, - { 0x2100022b, 0x1400ffff }, - { 0x2100022c, 0x24000001 }, - { 0x2100022d, 0x1400ffff }, - { 0x2100022e, 0x24000001 }, - { 0x2100022f, 0x1400ffff }, - { 0x21000230, 0x24000001 }, - { 0x21000231, 0x1400ffff }, - { 0x21000232, 0x24000001 }, - { 0x21000233, 0x1400ffff }, - { 0x21800234, 0x14000005 }, - { 0x2100023a, 0x24002a2b }, - { 0x2100023b, 0x24000001 }, - { 0x2100023c, 0x1400ffff }, - { 0x2100023d, 0x2400ff5d }, - { 0x2100023e, 0x24002a28 }, - { 0x2180023f, 0x14000001 }, - { 0x21000241, 0x24000001 }, - { 0x21000242, 0x1400ffff }, - { 0x21000243, 0x2400ff3d }, - { 0x21000244, 0x24000045 }, - { 0x21000245, 0x24000047 }, - { 0x21000246, 0x24000001 }, - { 0x21000247, 0x1400ffff }, - { 0x21000248, 0x24000001 }, - { 0x21000249, 0x1400ffff }, - { 0x2100024a, 0x24000001 }, - { 0x2100024b, 0x1400ffff }, - { 0x2100024c, 0x24000001 }, - { 0x2100024d, 0x1400ffff }, - { 0x2100024e, 0x24000001 }, - { 0x2100024f, 0x1400ffff }, - { 0x21800250, 0x14000002 }, - { 0x21000253, 0x1400ff2e }, - { 0x21000254, 0x1400ff32 }, - { 0x21000255, 0x14000000 }, - { 0x21000256, 0x1400ff33 }, - { 0x21000257, 0x1400ff33 }, - { 0x21000258, 0x14000000 }, - { 0x21000259, 0x1400ff36 }, - { 0x2100025a, 0x14000000 }, - { 0x2100025b, 0x1400ff35 }, - { 0x2180025c, 0x14000003 }, - { 0x21000260, 0x1400ff33 }, - { 0x21800261, 0x14000001 }, - { 0x21000263, 0x1400ff31 }, - { 0x21800264, 0x14000003 }, - { 0x21000268, 0x1400ff2f }, - { 0x21000269, 0x1400ff2d }, - { 0x2100026a, 0x14000000 }, - { 0x2100026b, 0x140029f7 }, - { 0x2180026c, 0x14000002 }, - { 0x2100026f, 0x1400ff2d }, - { 0x21800270, 0x14000001 }, - { 0x21000272, 0x1400ff2b }, - { 0x21800273, 0x14000001 }, - { 0x21000275, 0x1400ff2a }, - { 0x21800276, 0x14000006 }, - { 0x2100027d, 0x140029e7 }, - { 0x2180027e, 0x14000001 }, - { 0x21000280, 0x1400ff26 }, - { 0x21800281, 0x14000001 }, - { 0x21000283, 0x1400ff26 }, - { 0x21800284, 0x14000003 }, - { 0x21000288, 0x1400ff26 }, - { 0x21000289, 0x1400ffbb }, - { 0x2100028a, 0x1400ff27 }, - { 0x2100028b, 0x1400ff27 }, - { 0x2100028c, 0x1400ffb9 }, - { 0x2180028d, 0x14000004 }, - { 0x21000292, 0x1400ff25 }, - { 0x21000293, 0x14000000 }, - { 0x21000294, 0x1c000000 }, - { 0x21800295, 0x1400001a }, - { 0x218002b0, 0x18000011 }, - { 0x098002c2, 0x60000003 }, - { 0x098002c6, 0x1800000b }, - { 0x098002d2, 0x6000000d }, - { 0x218002e0, 0x18000004 }, - { 0x098002e5, 0x60000008 }, - { 0x090002ee, 0x18000000 }, - { 0x098002ef, 0x60000010 }, - { 0x1b800300, 0x30000044 }, - { 0x1b000345, 0x30000054 }, - { 0x1b800346, 0x30000029 }, - { 0x13800374, 0x60000001 }, - { 0x1300037a, 0x18000000 }, - { 0x1300037b, 0x14000082 }, - { 0x1300037c, 0x14000082 }, - { 0x1300037d, 0x14000082 }, - { 0x0900037e, 0x54000000 }, - { 0x13800384, 0x60000001 }, - { 0x13000386, 0x24000026 }, - { 0x09000387, 0x54000000 }, - { 0x13000388, 0x24000025 }, - { 0x13000389, 0x24000025 }, - { 0x1300038a, 0x24000025 }, - { 0x1300038c, 0x24000040 }, - { 0x1300038e, 0x2400003f }, - { 0x1300038f, 0x2400003f }, - { 0x13000390, 0x14000000 }, - { 0x13000391, 0x24000020 }, - { 0x13000392, 0x24000020 }, - { 0x13000393, 0x24000020 }, - { 0x13000394, 0x24000020 }, - { 0x13000395, 0x24000020 }, - { 0x13000396, 0x24000020 }, - { 0x13000397, 0x24000020 }, - { 0x13000398, 0x24000020 }, - { 0x13000399, 0x24000020 }, - { 0x1300039a, 0x24000020 }, - { 0x1300039b, 0x24000020 }, - { 0x1300039c, 0x24000020 }, - { 0x1300039d, 0x24000020 }, - { 0x1300039e, 0x24000020 }, - { 0x1300039f, 0x24000020 }, - { 0x130003a0, 0x24000020 }, - { 0x130003a1, 0x24000020 }, - { 0x130003a3, 0x24000020 }, - { 0x130003a4, 0x24000020 }, - { 0x130003a5, 0x24000020 }, - { 0x130003a6, 0x24000020 }, - { 0x130003a7, 0x24000020 }, - { 0x130003a8, 0x24000020 }, - { 0x130003a9, 0x24000020 }, - { 0x130003aa, 0x24000020 }, - { 0x130003ab, 0x24000020 }, - { 0x130003ac, 0x1400ffda }, - { 0x130003ad, 0x1400ffdb }, - { 0x130003ae, 0x1400ffdb }, - { 0x130003af, 0x1400ffdb }, - { 0x130003b0, 0x14000000 }, - { 0x130003b1, 0x1400ffe0 }, - { 0x130003b2, 0x1400ffe0 }, - { 0x130003b3, 0x1400ffe0 }, - { 0x130003b4, 0x1400ffe0 }, - { 0x130003b5, 0x1400ffe0 }, - { 0x130003b6, 0x1400ffe0 }, - { 0x130003b7, 0x1400ffe0 }, - { 0x130003b8, 0x1400ffe0 }, - { 0x130003b9, 0x1400ffe0 }, - { 0x130003ba, 0x1400ffe0 }, - { 0x130003bb, 0x1400ffe0 }, - { 0x130003bc, 0x1400ffe0 }, - { 0x130003bd, 0x1400ffe0 }, - { 0x130003be, 0x1400ffe0 }, - { 0x130003bf, 0x1400ffe0 }, - { 0x130003c0, 0x1400ffe0 }, - { 0x130003c1, 0x1400ffe0 }, - { 0x130003c2, 0x1400ffe1 }, - { 0x130003c3, 0x1400ffe0 }, - { 0x130003c4, 0x1400ffe0 }, - { 0x130003c5, 0x1400ffe0 }, - { 0x130003c6, 0x1400ffe0 }, - { 0x130003c7, 0x1400ffe0 }, - { 0x130003c8, 0x1400ffe0 }, - { 0x130003c9, 0x1400ffe0 }, - { 0x130003ca, 0x1400ffe0 }, - { 0x130003cb, 0x1400ffe0 }, - { 0x130003cc, 0x1400ffc0 }, - { 0x130003cd, 0x1400ffc1 }, - { 0x130003ce, 0x1400ffc1 }, - { 0x130003d0, 0x1400ffc2 }, - { 0x130003d1, 0x1400ffc7 }, - { 0x138003d2, 0x24000002 }, - { 0x130003d5, 0x1400ffd1 }, - { 0x130003d6, 0x1400ffca }, - { 0x130003d7, 0x14000000 }, - { 0x130003d8, 0x24000001 }, - { 0x130003d9, 0x1400ffff }, - { 0x130003da, 0x24000001 }, - { 0x130003db, 0x1400ffff }, - { 0x130003dc, 0x24000001 }, - { 0x130003dd, 0x1400ffff }, - { 0x130003de, 0x24000001 }, - { 0x130003df, 0x1400ffff }, - { 0x130003e0, 0x24000001 }, - { 0x130003e1, 0x1400ffff }, - { 0x0a0003e2, 0x24000001 }, - { 0x0a0003e3, 0x1400ffff }, - { 0x0a0003e4, 0x24000001 }, - { 0x0a0003e5, 0x1400ffff }, - { 0x0a0003e6, 0x24000001 }, - { 0x0a0003e7, 0x1400ffff }, - { 0x0a0003e8, 0x24000001 }, - { 0x0a0003e9, 0x1400ffff }, - { 0x0a0003ea, 0x24000001 }, - { 0x0a0003eb, 0x1400ffff }, - { 0x0a0003ec, 0x24000001 }, - { 0x0a0003ed, 0x1400ffff }, - { 0x0a0003ee, 0x24000001 }, - { 0x0a0003ef, 0x1400ffff }, - { 0x130003f0, 0x1400ffaa }, - { 0x130003f1, 0x1400ffb0 }, - { 0x130003f2, 0x14000007 }, - { 0x130003f3, 0x14000000 }, - { 0x130003f4, 0x2400ffc4 }, - { 0x130003f5, 0x1400ffa0 }, - { 0x130003f6, 0x64000000 }, - { 0x130003f7, 0x24000001 }, - { 0x130003f8, 0x1400ffff }, - { 0x130003f9, 0x2400fff9 }, - { 0x130003fa, 0x24000001 }, - { 0x130003fb, 0x1400ffff }, - { 0x130003fc, 0x14000000 }, - { 0x130003fd, 0x2400ff7e }, - { 0x130003fe, 0x2400ff7e }, - { 0x130003ff, 0x2400ff7e }, - { 0x0c000400, 0x24000050 }, - { 0x0c000401, 0x24000050 }, - { 0x0c000402, 0x24000050 }, - { 0x0c000403, 0x24000050 }, - { 0x0c000404, 0x24000050 }, - { 0x0c000405, 0x24000050 }, - { 0x0c000406, 0x24000050 }, - { 0x0c000407, 0x24000050 }, - { 0x0c000408, 0x24000050 }, - { 0x0c000409, 0x24000050 }, - { 0x0c00040a, 0x24000050 }, - { 0x0c00040b, 0x24000050 }, - { 0x0c00040c, 0x24000050 }, - { 0x0c00040d, 0x24000050 }, - { 0x0c00040e, 0x24000050 }, - { 0x0c00040f, 0x24000050 }, - { 0x0c000410, 0x24000020 }, - { 0x0c000411, 0x24000020 }, - { 0x0c000412, 0x24000020 }, - { 0x0c000413, 0x24000020 }, - { 0x0c000414, 0x24000020 }, - { 0x0c000415, 0x24000020 }, - { 0x0c000416, 0x24000020 }, - { 0x0c000417, 0x24000020 }, - { 0x0c000418, 0x24000020 }, - { 0x0c000419, 0x24000020 }, - { 0x0c00041a, 0x24000020 }, - { 0x0c00041b, 0x24000020 }, - { 0x0c00041c, 0x24000020 }, - { 0x0c00041d, 0x24000020 }, - { 0x0c00041e, 0x24000020 }, - { 0x0c00041f, 0x24000020 }, - { 0x0c000420, 0x24000020 }, - { 0x0c000421, 0x24000020 }, - { 0x0c000422, 0x24000020 }, - { 0x0c000423, 0x24000020 }, - { 0x0c000424, 0x24000020 }, - { 0x0c000425, 0x24000020 }, - { 0x0c000426, 0x24000020 }, - { 0x0c000427, 0x24000020 }, - { 0x0c000428, 0x24000020 }, - { 0x0c000429, 0x24000020 }, - { 0x0c00042a, 0x24000020 }, - { 0x0c00042b, 0x24000020 }, - { 0x0c00042c, 0x24000020 }, - { 0x0c00042d, 0x24000020 }, - { 0x0c00042e, 0x24000020 }, - { 0x0c00042f, 0x24000020 }, - { 0x0c000430, 0x1400ffe0 }, - { 0x0c000431, 0x1400ffe0 }, - { 0x0c000432, 0x1400ffe0 }, - { 0x0c000433, 0x1400ffe0 }, - { 0x0c000434, 0x1400ffe0 }, - { 0x0c000435, 0x1400ffe0 }, - { 0x0c000436, 0x1400ffe0 }, - { 0x0c000437, 0x1400ffe0 }, - { 0x0c000438, 0x1400ffe0 }, - { 0x0c000439, 0x1400ffe0 }, - { 0x0c00043a, 0x1400ffe0 }, - { 0x0c00043b, 0x1400ffe0 }, - { 0x0c00043c, 0x1400ffe0 }, - { 0x0c00043d, 0x1400ffe0 }, - { 0x0c00043e, 0x1400ffe0 }, - { 0x0c00043f, 0x1400ffe0 }, - { 0x0c000440, 0x1400ffe0 }, - { 0x0c000441, 0x1400ffe0 }, - { 0x0c000442, 0x1400ffe0 }, - { 0x0c000443, 0x1400ffe0 }, - { 0x0c000444, 0x1400ffe0 }, - { 0x0c000445, 0x1400ffe0 }, - { 0x0c000446, 0x1400ffe0 }, - { 0x0c000447, 0x1400ffe0 }, - { 0x0c000448, 0x1400ffe0 }, - { 0x0c000449, 0x1400ffe0 }, - { 0x0c00044a, 0x1400ffe0 }, - { 0x0c00044b, 0x1400ffe0 }, - { 0x0c00044c, 0x1400ffe0 }, - { 0x0c00044d, 0x1400ffe0 }, - { 0x0c00044e, 0x1400ffe0 }, - { 0x0c00044f, 0x1400ffe0 }, - { 0x0c000450, 0x1400ffb0 }, - { 0x0c000451, 0x1400ffb0 }, - { 0x0c000452, 0x1400ffb0 }, - { 0x0c000453, 0x1400ffb0 }, - { 0x0c000454, 0x1400ffb0 }, - { 0x0c000455, 0x1400ffb0 }, - { 0x0c000456, 0x1400ffb0 }, - { 0x0c000457, 0x1400ffb0 }, - { 0x0c000458, 0x1400ffb0 }, - { 0x0c000459, 0x1400ffb0 }, - { 0x0c00045a, 0x1400ffb0 }, - { 0x0c00045b, 0x1400ffb0 }, - { 0x0c00045c, 0x1400ffb0 }, - { 0x0c00045d, 0x1400ffb0 }, - { 0x0c00045e, 0x1400ffb0 }, - { 0x0c00045f, 0x1400ffb0 }, - { 0x0c000460, 0x24000001 }, - { 0x0c000461, 0x1400ffff }, - { 0x0c000462, 0x24000001 }, - { 0x0c000463, 0x1400ffff }, - { 0x0c000464, 0x24000001 }, - { 0x0c000465, 0x1400ffff }, - { 0x0c000466, 0x24000001 }, - { 0x0c000467, 0x1400ffff }, - { 0x0c000468, 0x24000001 }, - { 0x0c000469, 0x1400ffff }, - { 0x0c00046a, 0x24000001 }, - { 0x0c00046b, 0x1400ffff }, - { 0x0c00046c, 0x24000001 }, - { 0x0c00046d, 0x1400ffff }, - { 0x0c00046e, 0x24000001 }, - { 0x0c00046f, 0x1400ffff }, - { 0x0c000470, 0x24000001 }, - { 0x0c000471, 0x1400ffff }, - { 0x0c000472, 0x24000001 }, - { 0x0c000473, 0x1400ffff }, - { 0x0c000474, 0x24000001 }, - { 0x0c000475, 0x1400ffff }, - { 0x0c000476, 0x24000001 }, - { 0x0c000477, 0x1400ffff }, - { 0x0c000478, 0x24000001 }, - { 0x0c000479, 0x1400ffff }, - { 0x0c00047a, 0x24000001 }, - { 0x0c00047b, 0x1400ffff }, - { 0x0c00047c, 0x24000001 }, - { 0x0c00047d, 0x1400ffff }, - { 0x0c00047e, 0x24000001 }, - { 0x0c00047f, 0x1400ffff }, - { 0x0c000480, 0x24000001 }, - { 0x0c000481, 0x1400ffff }, - { 0x0c000482, 0x68000000 }, - { 0x0c800483, 0x30000003 }, - { 0x0c800488, 0x2c000001 }, - { 0x0c00048a, 0x24000001 }, - { 0x0c00048b, 0x1400ffff }, - { 0x0c00048c, 0x24000001 }, - { 0x0c00048d, 0x1400ffff }, - { 0x0c00048e, 0x24000001 }, - { 0x0c00048f, 0x1400ffff }, - { 0x0c000490, 0x24000001 }, - { 0x0c000491, 0x1400ffff }, - { 0x0c000492, 0x24000001 }, - { 0x0c000493, 0x1400ffff }, - { 0x0c000494, 0x24000001 }, - { 0x0c000495, 0x1400ffff }, - { 0x0c000496, 0x24000001 }, - { 0x0c000497, 0x1400ffff }, - { 0x0c000498, 0x24000001 }, - { 0x0c000499, 0x1400ffff }, - { 0x0c00049a, 0x24000001 }, - { 0x0c00049b, 0x1400ffff }, - { 0x0c00049c, 0x24000001 }, - { 0x0c00049d, 0x1400ffff }, - { 0x0c00049e, 0x24000001 }, - { 0x0c00049f, 0x1400ffff }, - { 0x0c0004a0, 0x24000001 }, - { 0x0c0004a1, 0x1400ffff }, - { 0x0c0004a2, 0x24000001 }, - { 0x0c0004a3, 0x1400ffff }, - { 0x0c0004a4, 0x24000001 }, - { 0x0c0004a5, 0x1400ffff }, - { 0x0c0004a6, 0x24000001 }, - { 0x0c0004a7, 0x1400ffff }, - { 0x0c0004a8, 0x24000001 }, - { 0x0c0004a9, 0x1400ffff }, - { 0x0c0004aa, 0x24000001 }, - { 0x0c0004ab, 0x1400ffff }, - { 0x0c0004ac, 0x24000001 }, - { 0x0c0004ad, 0x1400ffff }, - { 0x0c0004ae, 0x24000001 }, - { 0x0c0004af, 0x1400ffff }, - { 0x0c0004b0, 0x24000001 }, - { 0x0c0004b1, 0x1400ffff }, - { 0x0c0004b2, 0x24000001 }, - { 0x0c0004b3, 0x1400ffff }, - { 0x0c0004b4, 0x24000001 }, - { 0x0c0004b5, 0x1400ffff }, - { 0x0c0004b6, 0x24000001 }, - { 0x0c0004b7, 0x1400ffff }, - { 0x0c0004b8, 0x24000001 }, - { 0x0c0004b9, 0x1400ffff }, - { 0x0c0004ba, 0x24000001 }, - { 0x0c0004bb, 0x1400ffff }, - { 0x0c0004bc, 0x24000001 }, - { 0x0c0004bd, 0x1400ffff }, - { 0x0c0004be, 0x24000001 }, - { 0x0c0004bf, 0x1400ffff }, - { 0x0c0004c0, 0x2400000f }, - { 0x0c0004c1, 0x24000001 }, - { 0x0c0004c2, 0x1400ffff }, - { 0x0c0004c3, 0x24000001 }, - { 0x0c0004c4, 0x1400ffff }, - { 0x0c0004c5, 0x24000001 }, - { 0x0c0004c6, 0x1400ffff }, - { 0x0c0004c7, 0x24000001 }, - { 0x0c0004c8, 0x1400ffff }, - { 0x0c0004c9, 0x24000001 }, - { 0x0c0004ca, 0x1400ffff }, - { 0x0c0004cb, 0x24000001 }, - { 0x0c0004cc, 0x1400ffff }, - { 0x0c0004cd, 0x24000001 }, - { 0x0c0004ce, 0x1400ffff }, - { 0x0c0004cf, 0x1400fff1 }, - { 0x0c0004d0, 0x24000001 }, - { 0x0c0004d1, 0x1400ffff }, - { 0x0c0004d2, 0x24000001 }, - { 0x0c0004d3, 0x1400ffff }, - { 0x0c0004d4, 0x24000001 }, - { 0x0c0004d5, 0x1400ffff }, - { 0x0c0004d6, 0x24000001 }, - { 0x0c0004d7, 0x1400ffff }, - { 0x0c0004d8, 0x24000001 }, - { 0x0c0004d9, 0x1400ffff }, - { 0x0c0004da, 0x24000001 }, - { 0x0c0004db, 0x1400ffff }, - { 0x0c0004dc, 0x24000001 }, - { 0x0c0004dd, 0x1400ffff }, - { 0x0c0004de, 0x24000001 }, - { 0x0c0004df, 0x1400ffff }, - { 0x0c0004e0, 0x24000001 }, - { 0x0c0004e1, 0x1400ffff }, - { 0x0c0004e2, 0x24000001 }, - { 0x0c0004e3, 0x1400ffff }, - { 0x0c0004e4, 0x24000001 }, - { 0x0c0004e5, 0x1400ffff }, - { 0x0c0004e6, 0x24000001 }, - { 0x0c0004e7, 0x1400ffff }, - { 0x0c0004e8, 0x24000001 }, - { 0x0c0004e9, 0x1400ffff }, - { 0x0c0004ea, 0x24000001 }, - { 0x0c0004eb, 0x1400ffff }, - { 0x0c0004ec, 0x24000001 }, - { 0x0c0004ed, 0x1400ffff }, - { 0x0c0004ee, 0x24000001 }, - { 0x0c0004ef, 0x1400ffff }, - { 0x0c0004f0, 0x24000001 }, - { 0x0c0004f1, 0x1400ffff }, - { 0x0c0004f2, 0x24000001 }, - { 0x0c0004f3, 0x1400ffff }, - { 0x0c0004f4, 0x24000001 }, - { 0x0c0004f5, 0x1400ffff }, - { 0x0c0004f6, 0x24000001 }, - { 0x0c0004f7, 0x1400ffff }, - { 0x0c0004f8, 0x24000001 }, - { 0x0c0004f9, 0x1400ffff }, - { 0x0c0004fa, 0x24000001 }, - { 0x0c0004fb, 0x1400ffff }, - { 0x0c0004fc, 0x24000001 }, - { 0x0c0004fd, 0x1400ffff }, - { 0x0c0004fe, 0x24000001 }, - { 0x0c0004ff, 0x1400ffff }, - { 0x0c000500, 0x24000001 }, - { 0x0c000501, 0x1400ffff }, - { 0x0c000502, 0x24000001 }, - { 0x0c000503, 0x1400ffff }, - { 0x0c000504, 0x24000001 }, - { 0x0c000505, 0x1400ffff }, - { 0x0c000506, 0x24000001 }, - { 0x0c000507, 0x1400ffff }, - { 0x0c000508, 0x24000001 }, - { 0x0c000509, 0x1400ffff }, - { 0x0c00050a, 0x24000001 }, - { 0x0c00050b, 0x1400ffff }, - { 0x0c00050c, 0x24000001 }, - { 0x0c00050d, 0x1400ffff }, - { 0x0c00050e, 0x24000001 }, - { 0x0c00050f, 0x1400ffff }, - { 0x0c000510, 0x24000001 }, - { 0x0c000511, 0x1400ffff }, - { 0x0c000512, 0x24000001 }, - { 0x0c000513, 0x1400ffff }, - { 0x01000531, 0x24000030 }, - { 0x01000532, 0x24000030 }, - { 0x01000533, 0x24000030 }, - { 0x01000534, 0x24000030 }, - { 0x01000535, 0x24000030 }, - { 0x01000536, 0x24000030 }, - { 0x01000537, 0x24000030 }, - { 0x01000538, 0x24000030 }, - { 0x01000539, 0x24000030 }, - { 0x0100053a, 0x24000030 }, - { 0x0100053b, 0x24000030 }, - { 0x0100053c, 0x24000030 }, - { 0x0100053d, 0x24000030 }, - { 0x0100053e, 0x24000030 }, - { 0x0100053f, 0x24000030 }, - { 0x01000540, 0x24000030 }, - { 0x01000541, 0x24000030 }, - { 0x01000542, 0x24000030 }, - { 0x01000543, 0x24000030 }, - { 0x01000544, 0x24000030 }, - { 0x01000545, 0x24000030 }, - { 0x01000546, 0x24000030 }, - { 0x01000547, 0x24000030 }, - { 0x01000548, 0x24000030 }, - { 0x01000549, 0x24000030 }, - { 0x0100054a, 0x24000030 }, - { 0x0100054b, 0x24000030 }, - { 0x0100054c, 0x24000030 }, - { 0x0100054d, 0x24000030 }, - { 0x0100054e, 0x24000030 }, - { 0x0100054f, 0x24000030 }, - { 0x01000550, 0x24000030 }, - { 0x01000551, 0x24000030 }, - { 0x01000552, 0x24000030 }, - { 0x01000553, 0x24000030 }, - { 0x01000554, 0x24000030 }, - { 0x01000555, 0x24000030 }, - { 0x01000556, 0x24000030 }, - { 0x01000559, 0x18000000 }, - { 0x0180055a, 0x54000005 }, - { 0x01000561, 0x1400ffd0 }, - { 0x01000562, 0x1400ffd0 }, - { 0x01000563, 0x1400ffd0 }, - { 0x01000564, 0x1400ffd0 }, - { 0x01000565, 0x1400ffd0 }, - { 0x01000566, 0x1400ffd0 }, - { 0x01000567, 0x1400ffd0 }, - { 0x01000568, 0x1400ffd0 }, - { 0x01000569, 0x1400ffd0 }, - { 0x0100056a, 0x1400ffd0 }, - { 0x0100056b, 0x1400ffd0 }, - { 0x0100056c, 0x1400ffd0 }, - { 0x0100056d, 0x1400ffd0 }, - { 0x0100056e, 0x1400ffd0 }, - { 0x0100056f, 0x1400ffd0 }, - { 0x01000570, 0x1400ffd0 }, - { 0x01000571, 0x1400ffd0 }, - { 0x01000572, 0x1400ffd0 }, - { 0x01000573, 0x1400ffd0 }, - { 0x01000574, 0x1400ffd0 }, - { 0x01000575, 0x1400ffd0 }, - { 0x01000576, 0x1400ffd0 }, - { 0x01000577, 0x1400ffd0 }, - { 0x01000578, 0x1400ffd0 }, - { 0x01000579, 0x1400ffd0 }, - { 0x0100057a, 0x1400ffd0 }, - { 0x0100057b, 0x1400ffd0 }, - { 0x0100057c, 0x1400ffd0 }, - { 0x0100057d, 0x1400ffd0 }, - { 0x0100057e, 0x1400ffd0 }, - { 0x0100057f, 0x1400ffd0 }, - { 0x01000580, 0x1400ffd0 }, - { 0x01000581, 0x1400ffd0 }, - { 0x01000582, 0x1400ffd0 }, - { 0x01000583, 0x1400ffd0 }, - { 0x01000584, 0x1400ffd0 }, - { 0x01000585, 0x1400ffd0 }, - { 0x01000586, 0x1400ffd0 }, - { 0x01000587, 0x14000000 }, - { 0x09000589, 0x54000000 }, - { 0x0100058a, 0x44000000 }, - { 0x19800591, 0x3000002c }, - { 0x190005be, 0x54000000 }, - { 0x190005bf, 0x30000000 }, - { 0x190005c0, 0x54000000 }, - { 0x198005c1, 0x30000001 }, - { 0x190005c3, 0x54000000 }, - { 0x198005c4, 0x30000001 }, - { 0x190005c6, 0x54000000 }, - { 0x190005c7, 0x30000000 }, - { 0x198005d0, 0x1c00001a }, - { 0x198005f0, 0x1c000002 }, - { 0x198005f3, 0x54000001 }, - { 0x09800600, 0x04000003 }, - { 0x0000060b, 0x5c000000 }, - { 0x0980060c, 0x54000001 }, - { 0x0080060e, 0x68000001 }, - { 0x00800610, 0x30000005 }, - { 0x0900061b, 0x54000000 }, - { 0x0080061e, 0x54000001 }, - { 0x00800621, 0x1c000019 }, - { 0x09000640, 0x18000000 }, - { 0x00800641, 0x1c000009 }, - { 0x1b80064b, 0x30000013 }, - { 0x09800660, 0x34000009 }, - { 0x0080066a, 0x54000003 }, - { 0x0080066e, 0x1c000001 }, - { 0x1b000670, 0x30000000 }, - { 0x00800671, 0x1c000062 }, - { 0x000006d4, 0x54000000 }, - { 0x000006d5, 0x1c000000 }, - { 0x008006d6, 0x30000006 }, - { 0x090006dd, 0x04000000 }, - { 0x000006de, 0x2c000000 }, - { 0x008006df, 0x30000005 }, - { 0x008006e5, 0x18000001 }, - { 0x008006e7, 0x30000001 }, - { 0x000006e9, 0x68000000 }, - { 0x008006ea, 0x30000003 }, - { 0x008006ee, 0x1c000001 }, - { 0x008006f0, 0x34000009 }, - { 0x008006fa, 0x1c000002 }, - { 0x008006fd, 0x68000001 }, - { 0x000006ff, 0x1c000000 }, - { 0x31800700, 0x5400000d }, - { 0x3100070f, 0x04000000 }, - { 0x31000710, 0x1c000000 }, - { 0x31000711, 0x30000000 }, - { 0x31800712, 0x1c00001d }, - { 0x31800730, 0x3000001a }, - { 0x3180074d, 0x1c000020 }, - { 0x37800780, 0x1c000025 }, - { 0x378007a6, 0x3000000a }, - { 0x370007b1, 0x1c000000 }, - { 0x3f8007c0, 0x34000009 }, - { 0x3f8007ca, 0x1c000020 }, - { 0x3f8007eb, 0x30000008 }, - { 0x3f8007f4, 0x18000001 }, - { 0x3f0007f6, 0x68000000 }, - { 0x3f8007f7, 0x54000002 }, - { 0x3f0007fa, 0x18000000 }, - { 0x0e800901, 0x30000001 }, - { 0x0e000903, 0x28000000 }, - { 0x0e800904, 0x1c000035 }, - { 0x0e00093c, 0x30000000 }, - { 0x0e00093d, 0x1c000000 }, - { 0x0e80093e, 0x28000002 }, - { 0x0e800941, 0x30000007 }, - { 0x0e800949, 0x28000003 }, - { 0x0e00094d, 0x30000000 }, - { 0x0e000950, 0x1c000000 }, - { 0x0e800951, 0x30000003 }, - { 0x0e800958, 0x1c000009 }, - { 0x0e800962, 0x30000001 }, - { 0x09800964, 0x54000001 }, - { 0x0e800966, 0x34000009 }, - { 0x09000970, 0x54000000 }, - { 0x0e80097b, 0x1c000004 }, - { 0x02000981, 0x30000000 }, - { 0x02800982, 0x28000001 }, - { 0x02800985, 0x1c000007 }, - { 0x0280098f, 0x1c000001 }, - { 0x02800993, 0x1c000015 }, - { 0x028009aa, 0x1c000006 }, - { 0x020009b2, 0x1c000000 }, - { 0x028009b6, 0x1c000003 }, - { 0x020009bc, 0x30000000 }, - { 0x020009bd, 0x1c000000 }, - { 0x028009be, 0x28000002 }, - { 0x028009c1, 0x30000003 }, - { 0x028009c7, 0x28000001 }, - { 0x028009cb, 0x28000001 }, - { 0x020009cd, 0x30000000 }, - { 0x020009ce, 0x1c000000 }, - { 0x020009d7, 0x28000000 }, - { 0x028009dc, 0x1c000001 }, - { 0x028009df, 0x1c000002 }, - { 0x028009e2, 0x30000001 }, - { 0x028009e6, 0x34000009 }, - { 0x028009f0, 0x1c000001 }, - { 0x028009f2, 0x5c000001 }, - { 0x028009f4, 0x3c000005 }, - { 0x020009fa, 0x68000000 }, - { 0x15800a01, 0x30000001 }, - { 0x15000a03, 0x28000000 }, - { 0x15800a05, 0x1c000005 }, - { 0x15800a0f, 0x1c000001 }, - { 0x15800a13, 0x1c000015 }, - { 0x15800a2a, 0x1c000006 }, - { 0x15800a32, 0x1c000001 }, - { 0x15800a35, 0x1c000001 }, - { 0x15800a38, 0x1c000001 }, - { 0x15000a3c, 0x30000000 }, - { 0x15800a3e, 0x28000002 }, - { 0x15800a41, 0x30000001 }, - { 0x15800a47, 0x30000001 }, - { 0x15800a4b, 0x30000002 }, - { 0x15800a59, 0x1c000003 }, - { 0x15000a5e, 0x1c000000 }, - { 0x15800a66, 0x34000009 }, - { 0x15800a70, 0x30000001 }, - { 0x15800a72, 0x1c000002 }, - { 0x14800a81, 0x30000001 }, - { 0x14000a83, 0x28000000 }, - { 0x14800a85, 0x1c000008 }, - { 0x14800a8f, 0x1c000002 }, - { 0x14800a93, 0x1c000015 }, - { 0x14800aaa, 0x1c000006 }, - { 0x14800ab2, 0x1c000001 }, - { 0x14800ab5, 0x1c000004 }, - { 0x14000abc, 0x30000000 }, - { 0x14000abd, 0x1c000000 }, - { 0x14800abe, 0x28000002 }, - { 0x14800ac1, 0x30000004 }, - { 0x14800ac7, 0x30000001 }, - { 0x14000ac9, 0x28000000 }, - { 0x14800acb, 0x28000001 }, - { 0x14000acd, 0x30000000 }, - { 0x14000ad0, 0x1c000000 }, - { 0x14800ae0, 0x1c000001 }, - { 0x14800ae2, 0x30000001 }, - { 0x14800ae6, 0x34000009 }, - { 0x14000af1, 0x5c000000 }, - { 0x2b000b01, 0x30000000 }, - { 0x2b800b02, 0x28000001 }, - { 0x2b800b05, 0x1c000007 }, - { 0x2b800b0f, 0x1c000001 }, - { 0x2b800b13, 0x1c000015 }, - { 0x2b800b2a, 0x1c000006 }, - { 0x2b800b32, 0x1c000001 }, - { 0x2b800b35, 0x1c000004 }, - { 0x2b000b3c, 0x30000000 }, - { 0x2b000b3d, 0x1c000000 }, - { 0x2b000b3e, 0x28000000 }, - { 0x2b000b3f, 0x30000000 }, - { 0x2b000b40, 0x28000000 }, - { 0x2b800b41, 0x30000002 }, - { 0x2b800b47, 0x28000001 }, - { 0x2b800b4b, 0x28000001 }, - { 0x2b000b4d, 0x30000000 }, - { 0x2b000b56, 0x30000000 }, - { 0x2b000b57, 0x28000000 }, - { 0x2b800b5c, 0x1c000001 }, - { 0x2b800b5f, 0x1c000002 }, - { 0x2b800b66, 0x34000009 }, - { 0x2b000b70, 0x68000000 }, - { 0x2b000b71, 0x1c000000 }, - { 0x35000b82, 0x30000000 }, - { 0x35000b83, 0x1c000000 }, - { 0x35800b85, 0x1c000005 }, - { 0x35800b8e, 0x1c000002 }, - { 0x35800b92, 0x1c000003 }, - { 0x35800b99, 0x1c000001 }, - { 0x35000b9c, 0x1c000000 }, - { 0x35800b9e, 0x1c000001 }, - { 0x35800ba3, 0x1c000001 }, - { 0x35800ba8, 0x1c000002 }, - { 0x35800bae, 0x1c00000b }, - { 0x35800bbe, 0x28000001 }, - { 0x35000bc0, 0x30000000 }, - { 0x35800bc1, 0x28000001 }, - { 0x35800bc6, 0x28000002 }, - { 0x35800bca, 0x28000002 }, - { 0x35000bcd, 0x30000000 }, - { 0x35000bd7, 0x28000000 }, - { 0x35800be6, 0x34000009 }, - { 0x35800bf0, 0x3c000002 }, - { 0x35800bf3, 0x68000005 }, - { 0x35000bf9, 0x5c000000 }, - { 0x35000bfa, 0x68000000 }, - { 0x36800c01, 0x28000002 }, - { 0x36800c05, 0x1c000007 }, - { 0x36800c0e, 0x1c000002 }, - { 0x36800c12, 0x1c000016 }, - { 0x36800c2a, 0x1c000009 }, - { 0x36800c35, 0x1c000004 }, - { 0x36800c3e, 0x30000002 }, - { 0x36800c41, 0x28000003 }, - { 0x36800c46, 0x30000002 }, - { 0x36800c4a, 0x30000003 }, - { 0x36800c55, 0x30000001 }, - { 0x36800c60, 0x1c000001 }, - { 0x36800c66, 0x34000009 }, - { 0x1c800c82, 0x28000001 }, - { 0x1c800c85, 0x1c000007 }, - { 0x1c800c8e, 0x1c000002 }, - { 0x1c800c92, 0x1c000016 }, - { 0x1c800caa, 0x1c000009 }, - { 0x1c800cb5, 0x1c000004 }, - { 0x1c000cbc, 0x30000000 }, - { 0x1c000cbd, 0x1c000000 }, - { 0x1c000cbe, 0x28000000 }, - { 0x1c000cbf, 0x30000000 }, - { 0x1c800cc0, 0x28000004 }, - { 0x1c000cc6, 0x30000000 }, - { 0x1c800cc7, 0x28000001 }, - { 0x1c800cca, 0x28000001 }, - { 0x1c800ccc, 0x30000001 }, - { 0x1c800cd5, 0x28000001 }, - { 0x1c000cde, 0x1c000000 }, - { 0x1c800ce0, 0x1c000001 }, - { 0x1c800ce2, 0x30000001 }, - { 0x1c800ce6, 0x34000009 }, - { 0x1c800cf1, 0x68000001 }, - { 0x24800d02, 0x28000001 }, - { 0x24800d05, 0x1c000007 }, - { 0x24800d0e, 0x1c000002 }, - { 0x24800d12, 0x1c000016 }, - { 0x24800d2a, 0x1c00000f }, - { 0x24800d3e, 0x28000002 }, - { 0x24800d41, 0x30000002 }, - { 0x24800d46, 0x28000002 }, - { 0x24800d4a, 0x28000002 }, - { 0x24000d4d, 0x30000000 }, - { 0x24000d57, 0x28000000 }, - { 0x24800d60, 0x1c000001 }, - { 0x24800d66, 0x34000009 }, - { 0x2f800d82, 0x28000001 }, - { 0x2f800d85, 0x1c000011 }, - { 0x2f800d9a, 0x1c000017 }, - { 0x2f800db3, 0x1c000008 }, - { 0x2f000dbd, 0x1c000000 }, - { 0x2f800dc0, 0x1c000006 }, - { 0x2f000dca, 0x30000000 }, - { 0x2f800dcf, 0x28000002 }, - { 0x2f800dd2, 0x30000002 }, - { 0x2f000dd6, 0x30000000 }, - { 0x2f800dd8, 0x28000007 }, - { 0x2f800df2, 0x28000001 }, - { 0x2f000df4, 0x54000000 }, - { 0x38800e01, 0x1c00002f }, - { 0x38000e31, 0x30000000 }, - { 0x38800e32, 0x1c000001 }, - { 0x38800e34, 0x30000006 }, - { 0x09000e3f, 0x5c000000 }, - { 0x38800e40, 0x1c000005 }, - { 0x38000e46, 0x18000000 }, - { 0x38800e47, 0x30000007 }, - { 0x38000e4f, 0x54000000 }, - { 0x38800e50, 0x34000009 }, - { 0x38800e5a, 0x54000001 }, - { 0x20800e81, 0x1c000001 }, - { 0x20000e84, 0x1c000000 }, - { 0x20800e87, 0x1c000001 }, - { 0x20000e8a, 0x1c000000 }, - { 0x20000e8d, 0x1c000000 }, - { 0x20800e94, 0x1c000003 }, - { 0x20800e99, 0x1c000006 }, - { 0x20800ea1, 0x1c000002 }, - { 0x20000ea5, 0x1c000000 }, - { 0x20000ea7, 0x1c000000 }, - { 0x20800eaa, 0x1c000001 }, - { 0x20800ead, 0x1c000003 }, - { 0x20000eb1, 0x30000000 }, - { 0x20800eb2, 0x1c000001 }, - { 0x20800eb4, 0x30000005 }, - { 0x20800ebb, 0x30000001 }, - { 0x20000ebd, 0x1c000000 }, - { 0x20800ec0, 0x1c000004 }, - { 0x20000ec6, 0x18000000 }, - { 0x20800ec8, 0x30000005 }, - { 0x20800ed0, 0x34000009 }, - { 0x20800edc, 0x1c000001 }, - { 0x39000f00, 0x1c000000 }, - { 0x39800f01, 0x68000002 }, - { 0x39800f04, 0x5400000e }, - { 0x39800f13, 0x68000004 }, - { 0x39800f18, 0x30000001 }, - { 0x39800f1a, 0x68000005 }, - { 0x39800f20, 0x34000009 }, - { 0x39800f2a, 0x3c000009 }, - { 0x39000f34, 0x68000000 }, - { 0x39000f35, 0x30000000 }, - { 0x39000f36, 0x68000000 }, - { 0x39000f37, 0x30000000 }, - { 0x39000f38, 0x68000000 }, - { 0x39000f39, 0x30000000 }, - { 0x39000f3a, 0x58000000 }, - { 0x39000f3b, 0x48000000 }, - { 0x39000f3c, 0x58000000 }, - { 0x39000f3d, 0x48000000 }, - { 0x39800f3e, 0x28000001 }, - { 0x39800f40, 0x1c000007 }, - { 0x39800f49, 0x1c000021 }, - { 0x39800f71, 0x3000000d }, - { 0x39000f7f, 0x28000000 }, - { 0x39800f80, 0x30000004 }, - { 0x39000f85, 0x54000000 }, - { 0x39800f86, 0x30000001 }, - { 0x39800f88, 0x1c000003 }, - { 0x39800f90, 0x30000007 }, - { 0x39800f99, 0x30000023 }, - { 0x39800fbe, 0x68000007 }, - { 0x39000fc6, 0x30000000 }, - { 0x39800fc7, 0x68000005 }, - { 0x39000fcf, 0x68000000 }, - { 0x39800fd0, 0x54000001 }, - { 0x26801000, 0x1c000021 }, - { 0x26801023, 0x1c000004 }, - { 0x26801029, 0x1c000001 }, - { 0x2600102c, 0x28000000 }, - { 0x2680102d, 0x30000003 }, - { 0x26001031, 0x28000000 }, - { 0x26001032, 0x30000000 }, - { 0x26801036, 0x30000001 }, - { 0x26001038, 0x28000000 }, - { 0x26001039, 0x30000000 }, - { 0x26801040, 0x34000009 }, - { 0x2680104a, 0x54000005 }, - { 0x26801050, 0x1c000005 }, - { 0x26801056, 0x28000001 }, - { 0x26801058, 0x30000001 }, - { 0x100010a0, 0x24001c60 }, - { 0x100010a1, 0x24001c60 }, - { 0x100010a2, 0x24001c60 }, - { 0x100010a3, 0x24001c60 }, - { 0x100010a4, 0x24001c60 }, - { 0x100010a5, 0x24001c60 }, - { 0x100010a6, 0x24001c60 }, - { 0x100010a7, 0x24001c60 }, - { 0x100010a8, 0x24001c60 }, - { 0x100010a9, 0x24001c60 }, - { 0x100010aa, 0x24001c60 }, - { 0x100010ab, 0x24001c60 }, - { 0x100010ac, 0x24001c60 }, - { 0x100010ad, 0x24001c60 }, - { 0x100010ae, 0x24001c60 }, - { 0x100010af, 0x24001c60 }, - { 0x100010b0, 0x24001c60 }, - { 0x100010b1, 0x24001c60 }, - { 0x100010b2, 0x24001c60 }, - { 0x100010b3, 0x24001c60 }, - { 0x100010b4, 0x24001c60 }, - { 0x100010b5, 0x24001c60 }, - { 0x100010b6, 0x24001c60 }, - { 0x100010b7, 0x24001c60 }, - { 0x100010b8, 0x24001c60 }, - { 0x100010b9, 0x24001c60 }, - { 0x100010ba, 0x24001c60 }, - { 0x100010bb, 0x24001c60 }, - { 0x100010bc, 0x24001c60 }, - { 0x100010bd, 0x24001c60 }, - { 0x100010be, 0x24001c60 }, - { 0x100010bf, 0x24001c60 }, - { 0x100010c0, 0x24001c60 }, - { 0x100010c1, 0x24001c60 }, - { 0x100010c2, 0x24001c60 }, - { 0x100010c3, 0x24001c60 }, - { 0x100010c4, 0x24001c60 }, - { 0x100010c5, 0x24001c60 }, - { 0x108010d0, 0x1c00002a }, - { 0x090010fb, 0x54000000 }, - { 0x100010fc, 0x18000000 }, - { 0x17801100, 0x1c000059 }, - { 0x1780115f, 0x1c000043 }, - { 0x178011a8, 0x1c000051 }, - { 0x0f801200, 0x1c000048 }, - { 0x0f80124a, 0x1c000003 }, - { 0x0f801250, 0x1c000006 }, - { 0x0f001258, 0x1c000000 }, - { 0x0f80125a, 0x1c000003 }, - { 0x0f801260, 0x1c000028 }, - { 0x0f80128a, 0x1c000003 }, - { 0x0f801290, 0x1c000020 }, - { 0x0f8012b2, 0x1c000003 }, - { 0x0f8012b8, 0x1c000006 }, - { 0x0f0012c0, 0x1c000000 }, - { 0x0f8012c2, 0x1c000003 }, - { 0x0f8012c8, 0x1c00000e }, - { 0x0f8012d8, 0x1c000038 }, - { 0x0f801312, 0x1c000003 }, - { 0x0f801318, 0x1c000042 }, - { 0x0f00135f, 0x30000000 }, - { 0x0f001360, 0x68000000 }, - { 0x0f801361, 0x54000007 }, - { 0x0f801369, 0x3c000013 }, - { 0x0f801380, 0x1c00000f }, - { 0x0f801390, 0x68000009 }, - { 0x088013a0, 0x1c000054 }, - { 0x07801401, 0x1c00026b }, - { 0x0780166d, 0x54000001 }, - { 0x0780166f, 0x1c000007 }, - { 0x28001680, 0x74000000 }, - { 0x28801681, 0x1c000019 }, - { 0x2800169b, 0x58000000 }, - { 0x2800169c, 0x48000000 }, - { 0x2d8016a0, 0x1c00004a }, - { 0x098016eb, 0x54000002 }, - { 0x2d8016ee, 0x38000002 }, - { 0x32801700, 0x1c00000c }, - { 0x3280170e, 0x1c000003 }, - { 0x32801712, 0x30000002 }, - { 0x18801720, 0x1c000011 }, - { 0x18801732, 0x30000002 }, - { 0x09801735, 0x54000001 }, - { 0x06801740, 0x1c000011 }, - { 0x06801752, 0x30000001 }, - { 0x33801760, 0x1c00000c }, - { 0x3380176e, 0x1c000002 }, - { 0x33801772, 0x30000001 }, - { 0x1f801780, 0x1c000033 }, - { 0x1f8017b4, 0x04000001 }, - { 0x1f0017b6, 0x28000000 }, - { 0x1f8017b7, 0x30000006 }, - { 0x1f8017be, 0x28000007 }, - { 0x1f0017c6, 0x30000000 }, - { 0x1f8017c7, 0x28000001 }, - { 0x1f8017c9, 0x3000000a }, - { 0x1f8017d4, 0x54000002 }, - { 0x1f0017d7, 0x18000000 }, - { 0x1f8017d8, 0x54000002 }, - { 0x1f0017db, 0x5c000000 }, - { 0x1f0017dc, 0x1c000000 }, - { 0x1f0017dd, 0x30000000 }, - { 0x1f8017e0, 0x34000009 }, - { 0x1f8017f0, 0x3c000009 }, - { 0x25801800, 0x54000005 }, - { 0x25001806, 0x44000000 }, - { 0x25801807, 0x54000003 }, - { 0x2580180b, 0x30000002 }, - { 0x2500180e, 0x74000000 }, - { 0x25801810, 0x34000009 }, - { 0x25801820, 0x1c000022 }, - { 0x25001843, 0x18000000 }, - { 0x25801844, 0x1c000033 }, - { 0x25801880, 0x1c000028 }, - { 0x250018a9, 0x30000000 }, - { 0x22801900, 0x1c00001c }, - { 0x22801920, 0x30000002 }, - { 0x22801923, 0x28000003 }, - { 0x22801927, 0x30000001 }, - { 0x22801929, 0x28000002 }, - { 0x22801930, 0x28000001 }, - { 0x22001932, 0x30000000 }, - { 0x22801933, 0x28000005 }, - { 0x22801939, 0x30000002 }, - { 0x22001940, 0x68000000 }, - { 0x22801944, 0x54000001 }, - { 0x22801946, 0x34000009 }, - { 0x34801950, 0x1c00001d }, - { 0x34801970, 0x1c000004 }, - { 0x27801980, 0x1c000029 }, - { 0x278019b0, 0x28000010 }, - { 0x278019c1, 0x1c000006 }, - { 0x278019c8, 0x28000001 }, - { 0x278019d0, 0x34000009 }, - { 0x278019de, 0x54000001 }, - { 0x1f8019e0, 0x6800001f }, - { 0x05801a00, 0x1c000016 }, - { 0x05801a17, 0x30000001 }, - { 0x05801a19, 0x28000002 }, - { 0x05801a1e, 0x54000001 }, - { 0x3d801b00, 0x30000003 }, - { 0x3d001b04, 0x28000000 }, - { 0x3d801b05, 0x1c00002e }, - { 0x3d001b34, 0x30000000 }, - { 0x3d001b35, 0x28000000 }, - { 0x3d801b36, 0x30000004 }, - { 0x3d001b3b, 0x28000000 }, - { 0x3d001b3c, 0x30000000 }, - { 0x3d801b3d, 0x28000004 }, - { 0x3d001b42, 0x30000000 }, - { 0x3d801b43, 0x28000001 }, - { 0x3d801b45, 0x1c000006 }, - { 0x3d801b50, 0x34000009 }, - { 0x3d801b5a, 0x54000006 }, - { 0x3d801b61, 0x68000009 }, - { 0x3d801b6b, 0x30000008 }, - { 0x3d801b74, 0x68000008 }, - { 0x21801d00, 0x1400002b }, - { 0x21801d2c, 0x18000035 }, - { 0x21801d62, 0x14000015 }, - { 0x0c001d78, 0x18000000 }, - { 0x21801d79, 0x14000003 }, - { 0x21001d7d, 0x14000ee6 }, - { 0x21801d7e, 0x1400001c }, - { 0x21801d9b, 0x18000024 }, - { 0x1b801dc0, 0x3000000a }, - { 0x1b801dfe, 0x30000001 }, - { 0x21001e00, 0x24000001 }, - { 0x21001e01, 0x1400ffff }, - { 0x21001e02, 0x24000001 }, - { 0x21001e03, 0x1400ffff }, - { 0x21001e04, 0x24000001 }, - { 0x21001e05, 0x1400ffff }, - { 0x21001e06, 0x24000001 }, - { 0x21001e07, 0x1400ffff }, - { 0x21001e08, 0x24000001 }, - { 0x21001e09, 0x1400ffff }, - { 0x21001e0a, 0x24000001 }, - { 0x21001e0b, 0x1400ffff }, - { 0x21001e0c, 0x24000001 }, - { 0x21001e0d, 0x1400ffff }, - { 0x21001e0e, 0x24000001 }, - { 0x21001e0f, 0x1400ffff }, - { 0x21001e10, 0x24000001 }, - { 0x21001e11, 0x1400ffff }, - { 0x21001e12, 0x24000001 }, - { 0x21001e13, 0x1400ffff }, - { 0x21001e14, 0x24000001 }, - { 0x21001e15, 0x1400ffff }, - { 0x21001e16, 0x24000001 }, - { 0x21001e17, 0x1400ffff }, - { 0x21001e18, 0x24000001 }, - { 0x21001e19, 0x1400ffff }, - { 0x21001e1a, 0x24000001 }, - { 0x21001e1b, 0x1400ffff }, - { 0x21001e1c, 0x24000001 }, - { 0x21001e1d, 0x1400ffff }, - { 0x21001e1e, 0x24000001 }, - { 0x21001e1f, 0x1400ffff }, - { 0x21001e20, 0x24000001 }, - { 0x21001e21, 0x1400ffff }, - { 0x21001e22, 0x24000001 }, - { 0x21001e23, 0x1400ffff }, - { 0x21001e24, 0x24000001 }, - { 0x21001e25, 0x1400ffff }, - { 0x21001e26, 0x24000001 }, - { 0x21001e27, 0x1400ffff }, - { 0x21001e28, 0x24000001 }, - { 0x21001e29, 0x1400ffff }, - { 0x21001e2a, 0x24000001 }, - { 0x21001e2b, 0x1400ffff }, - { 0x21001e2c, 0x24000001 }, - { 0x21001e2d, 0x1400ffff }, - { 0x21001e2e, 0x24000001 }, - { 0x21001e2f, 0x1400ffff }, - { 0x21001e30, 0x24000001 }, - { 0x21001e31, 0x1400ffff }, - { 0x21001e32, 0x24000001 }, - { 0x21001e33, 0x1400ffff }, - { 0x21001e34, 0x24000001 }, - { 0x21001e35, 0x1400ffff }, - { 0x21001e36, 0x24000001 }, - { 0x21001e37, 0x1400ffff }, - { 0x21001e38, 0x24000001 }, - { 0x21001e39, 0x1400ffff }, - { 0x21001e3a, 0x24000001 }, - { 0x21001e3b, 0x1400ffff }, - { 0x21001e3c, 0x24000001 }, - { 0x21001e3d, 0x1400ffff }, - { 0x21001e3e, 0x24000001 }, - { 0x21001e3f, 0x1400ffff }, - { 0x21001e40, 0x24000001 }, - { 0x21001e41, 0x1400ffff }, - { 0x21001e42, 0x24000001 }, - { 0x21001e43, 0x1400ffff }, - { 0x21001e44, 0x24000001 }, - { 0x21001e45, 0x1400ffff }, - { 0x21001e46, 0x24000001 }, - { 0x21001e47, 0x1400ffff }, - { 0x21001e48, 0x24000001 }, - { 0x21001e49, 0x1400ffff }, - { 0x21001e4a, 0x24000001 }, - { 0x21001e4b, 0x1400ffff }, - { 0x21001e4c, 0x24000001 }, - { 0x21001e4d, 0x1400ffff }, - { 0x21001e4e, 0x24000001 }, - { 0x21001e4f, 0x1400ffff }, - { 0x21001e50, 0x24000001 }, - { 0x21001e51, 0x1400ffff }, - { 0x21001e52, 0x24000001 }, - { 0x21001e53, 0x1400ffff }, - { 0x21001e54, 0x24000001 }, - { 0x21001e55, 0x1400ffff }, - { 0x21001e56, 0x24000001 }, - { 0x21001e57, 0x1400ffff }, - { 0x21001e58, 0x24000001 }, - { 0x21001e59, 0x1400ffff }, - { 0x21001e5a, 0x24000001 }, - { 0x21001e5b, 0x1400ffff }, - { 0x21001e5c, 0x24000001 }, - { 0x21001e5d, 0x1400ffff }, - { 0x21001e5e, 0x24000001 }, - { 0x21001e5f, 0x1400ffff }, - { 0x21001e60, 0x24000001 }, - { 0x21001e61, 0x1400ffff }, - { 0x21001e62, 0x24000001 }, - { 0x21001e63, 0x1400ffff }, - { 0x21001e64, 0x24000001 }, - { 0x21001e65, 0x1400ffff }, - { 0x21001e66, 0x24000001 }, - { 0x21001e67, 0x1400ffff }, - { 0x21001e68, 0x24000001 }, - { 0x21001e69, 0x1400ffff }, - { 0x21001e6a, 0x24000001 }, - { 0x21001e6b, 0x1400ffff }, - { 0x21001e6c, 0x24000001 }, - { 0x21001e6d, 0x1400ffff }, - { 0x21001e6e, 0x24000001 }, - { 0x21001e6f, 0x1400ffff }, - { 0x21001e70, 0x24000001 }, - { 0x21001e71, 0x1400ffff }, - { 0x21001e72, 0x24000001 }, - { 0x21001e73, 0x1400ffff }, - { 0x21001e74, 0x24000001 }, - { 0x21001e75, 0x1400ffff }, - { 0x21001e76, 0x24000001 }, - { 0x21001e77, 0x1400ffff }, - { 0x21001e78, 0x24000001 }, - { 0x21001e79, 0x1400ffff }, - { 0x21001e7a, 0x24000001 }, - { 0x21001e7b, 0x1400ffff }, - { 0x21001e7c, 0x24000001 }, - { 0x21001e7d, 0x1400ffff }, - { 0x21001e7e, 0x24000001 }, - { 0x21001e7f, 0x1400ffff }, - { 0x21001e80, 0x24000001 }, - { 0x21001e81, 0x1400ffff }, - { 0x21001e82, 0x24000001 }, - { 0x21001e83, 0x1400ffff }, - { 0x21001e84, 0x24000001 }, - { 0x21001e85, 0x1400ffff }, - { 0x21001e86, 0x24000001 }, - { 0x21001e87, 0x1400ffff }, - { 0x21001e88, 0x24000001 }, - { 0x21001e89, 0x1400ffff }, - { 0x21001e8a, 0x24000001 }, - { 0x21001e8b, 0x1400ffff }, - { 0x21001e8c, 0x24000001 }, - { 0x21001e8d, 0x1400ffff }, - { 0x21001e8e, 0x24000001 }, - { 0x21001e8f, 0x1400ffff }, - { 0x21001e90, 0x24000001 }, - { 0x21001e91, 0x1400ffff }, - { 0x21001e92, 0x24000001 }, - { 0x21001e93, 0x1400ffff }, - { 0x21001e94, 0x24000001 }, - { 0x21001e95, 0x1400ffff }, - { 0x21801e96, 0x14000004 }, - { 0x21001e9b, 0x1400ffc5 }, - { 0x21001ea0, 0x24000001 }, - { 0x21001ea1, 0x1400ffff }, - { 0x21001ea2, 0x24000001 }, - { 0x21001ea3, 0x1400ffff }, - { 0x21001ea4, 0x24000001 }, - { 0x21001ea5, 0x1400ffff }, - { 0x21001ea6, 0x24000001 }, - { 0x21001ea7, 0x1400ffff }, - { 0x21001ea8, 0x24000001 }, - { 0x21001ea9, 0x1400ffff }, - { 0x21001eaa, 0x24000001 }, - { 0x21001eab, 0x1400ffff }, - { 0x21001eac, 0x24000001 }, - { 0x21001ead, 0x1400ffff }, - { 0x21001eae, 0x24000001 }, - { 0x21001eaf, 0x1400ffff }, - { 0x21001eb0, 0x24000001 }, - { 0x21001eb1, 0x1400ffff }, - { 0x21001eb2, 0x24000001 }, - { 0x21001eb3, 0x1400ffff }, - { 0x21001eb4, 0x24000001 }, - { 0x21001eb5, 0x1400ffff }, - { 0x21001eb6, 0x24000001 }, - { 0x21001eb7, 0x1400ffff }, - { 0x21001eb8, 0x24000001 }, - { 0x21001eb9, 0x1400ffff }, - { 0x21001eba, 0x24000001 }, - { 0x21001ebb, 0x1400ffff }, - { 0x21001ebc, 0x24000001 }, - { 0x21001ebd, 0x1400ffff }, - { 0x21001ebe, 0x24000001 }, - { 0x21001ebf, 0x1400ffff }, - { 0x21001ec0, 0x24000001 }, - { 0x21001ec1, 0x1400ffff }, - { 0x21001ec2, 0x24000001 }, - { 0x21001ec3, 0x1400ffff }, - { 0x21001ec4, 0x24000001 }, - { 0x21001ec5, 0x1400ffff }, - { 0x21001ec6, 0x24000001 }, - { 0x21001ec7, 0x1400ffff }, - { 0x21001ec8, 0x24000001 }, - { 0x21001ec9, 0x1400ffff }, - { 0x21001eca, 0x24000001 }, - { 0x21001ecb, 0x1400ffff }, - { 0x21001ecc, 0x24000001 }, - { 0x21001ecd, 0x1400ffff }, - { 0x21001ece, 0x24000001 }, - { 0x21001ecf, 0x1400ffff }, - { 0x21001ed0, 0x24000001 }, - { 0x21001ed1, 0x1400ffff }, - { 0x21001ed2, 0x24000001 }, - { 0x21001ed3, 0x1400ffff }, - { 0x21001ed4, 0x24000001 }, - { 0x21001ed5, 0x1400ffff }, - { 0x21001ed6, 0x24000001 }, - { 0x21001ed7, 0x1400ffff }, - { 0x21001ed8, 0x24000001 }, - { 0x21001ed9, 0x1400ffff }, - { 0x21001eda, 0x24000001 }, - { 0x21001edb, 0x1400ffff }, - { 0x21001edc, 0x24000001 }, - { 0x21001edd, 0x1400ffff }, - { 0x21001ede, 0x24000001 }, - { 0x21001edf, 0x1400ffff }, - { 0x21001ee0, 0x24000001 }, - { 0x21001ee1, 0x1400ffff }, - { 0x21001ee2, 0x24000001 }, - { 0x21001ee3, 0x1400ffff }, - { 0x21001ee4, 0x24000001 }, - { 0x21001ee5, 0x1400ffff }, - { 0x21001ee6, 0x24000001 }, - { 0x21001ee7, 0x1400ffff }, - { 0x21001ee8, 0x24000001 }, - { 0x21001ee9, 0x1400ffff }, - { 0x21001eea, 0x24000001 }, - { 0x21001eeb, 0x1400ffff }, - { 0x21001eec, 0x24000001 }, - { 0x21001eed, 0x1400ffff }, - { 0x21001eee, 0x24000001 }, - { 0x21001eef, 0x1400ffff }, - { 0x21001ef0, 0x24000001 }, - { 0x21001ef1, 0x1400ffff }, - { 0x21001ef2, 0x24000001 }, - { 0x21001ef3, 0x1400ffff }, - { 0x21001ef4, 0x24000001 }, - { 0x21001ef5, 0x1400ffff }, - { 0x21001ef6, 0x24000001 }, - { 0x21001ef7, 0x1400ffff }, - { 0x21001ef8, 0x24000001 }, - { 0x21001ef9, 0x1400ffff }, - { 0x13001f00, 0x14000008 }, - { 0x13001f01, 0x14000008 }, - { 0x13001f02, 0x14000008 }, - { 0x13001f03, 0x14000008 }, - { 0x13001f04, 0x14000008 }, - { 0x13001f05, 0x14000008 }, - { 0x13001f06, 0x14000008 }, - { 0x13001f07, 0x14000008 }, - { 0x13001f08, 0x2400fff8 }, - { 0x13001f09, 0x2400fff8 }, - { 0x13001f0a, 0x2400fff8 }, - { 0x13001f0b, 0x2400fff8 }, - { 0x13001f0c, 0x2400fff8 }, - { 0x13001f0d, 0x2400fff8 }, - { 0x13001f0e, 0x2400fff8 }, - { 0x13001f0f, 0x2400fff8 }, - { 0x13001f10, 0x14000008 }, - { 0x13001f11, 0x14000008 }, - { 0x13001f12, 0x14000008 }, - { 0x13001f13, 0x14000008 }, - { 0x13001f14, 0x14000008 }, - { 0x13001f15, 0x14000008 }, - { 0x13001f18, 0x2400fff8 }, - { 0x13001f19, 0x2400fff8 }, - { 0x13001f1a, 0x2400fff8 }, - { 0x13001f1b, 0x2400fff8 }, - { 0x13001f1c, 0x2400fff8 }, - { 0x13001f1d, 0x2400fff8 }, - { 0x13001f20, 0x14000008 }, - { 0x13001f21, 0x14000008 }, - { 0x13001f22, 0x14000008 }, - { 0x13001f23, 0x14000008 }, - { 0x13001f24, 0x14000008 }, - { 0x13001f25, 0x14000008 }, - { 0x13001f26, 0x14000008 }, - { 0x13001f27, 0x14000008 }, - { 0x13001f28, 0x2400fff8 }, - { 0x13001f29, 0x2400fff8 }, - { 0x13001f2a, 0x2400fff8 }, - { 0x13001f2b, 0x2400fff8 }, - { 0x13001f2c, 0x2400fff8 }, - { 0x13001f2d, 0x2400fff8 }, - { 0x13001f2e, 0x2400fff8 }, - { 0x13001f2f, 0x2400fff8 }, - { 0x13001f30, 0x14000008 }, - { 0x13001f31, 0x14000008 }, - { 0x13001f32, 0x14000008 }, - { 0x13001f33, 0x14000008 }, - { 0x13001f34, 0x14000008 }, - { 0x13001f35, 0x14000008 }, - { 0x13001f36, 0x14000008 }, - { 0x13001f37, 0x14000008 }, - { 0x13001f38, 0x2400fff8 }, - { 0x13001f39, 0x2400fff8 }, - { 0x13001f3a, 0x2400fff8 }, - { 0x13001f3b, 0x2400fff8 }, - { 0x13001f3c, 0x2400fff8 }, - { 0x13001f3d, 0x2400fff8 }, - { 0x13001f3e, 0x2400fff8 }, - { 0x13001f3f, 0x2400fff8 }, - { 0x13001f40, 0x14000008 }, - { 0x13001f41, 0x14000008 }, - { 0x13001f42, 0x14000008 }, - { 0x13001f43, 0x14000008 }, - { 0x13001f44, 0x14000008 }, - { 0x13001f45, 0x14000008 }, - { 0x13001f48, 0x2400fff8 }, - { 0x13001f49, 0x2400fff8 }, - { 0x13001f4a, 0x2400fff8 }, - { 0x13001f4b, 0x2400fff8 }, - { 0x13001f4c, 0x2400fff8 }, - { 0x13001f4d, 0x2400fff8 }, - { 0x13001f50, 0x14000000 }, - { 0x13001f51, 0x14000008 }, - { 0x13001f52, 0x14000000 }, - { 0x13001f53, 0x14000008 }, - { 0x13001f54, 0x14000000 }, - { 0x13001f55, 0x14000008 }, - { 0x13001f56, 0x14000000 }, - { 0x13001f57, 0x14000008 }, - { 0x13001f59, 0x2400fff8 }, - { 0x13001f5b, 0x2400fff8 }, - { 0x13001f5d, 0x2400fff8 }, - { 0x13001f5f, 0x2400fff8 }, - { 0x13001f60, 0x14000008 }, - { 0x13001f61, 0x14000008 }, - { 0x13001f62, 0x14000008 }, - { 0x13001f63, 0x14000008 }, - { 0x13001f64, 0x14000008 }, - { 0x13001f65, 0x14000008 }, - { 0x13001f66, 0x14000008 }, - { 0x13001f67, 0x14000008 }, - { 0x13001f68, 0x2400fff8 }, - { 0x13001f69, 0x2400fff8 }, - { 0x13001f6a, 0x2400fff8 }, - { 0x13001f6b, 0x2400fff8 }, - { 0x13001f6c, 0x2400fff8 }, - { 0x13001f6d, 0x2400fff8 }, - { 0x13001f6e, 0x2400fff8 }, - { 0x13001f6f, 0x2400fff8 }, - { 0x13001f70, 0x1400004a }, - { 0x13001f71, 0x1400004a }, - { 0x13001f72, 0x14000056 }, - { 0x13001f73, 0x14000056 }, - { 0x13001f74, 0x14000056 }, - { 0x13001f75, 0x14000056 }, - { 0x13001f76, 0x14000064 }, - { 0x13001f77, 0x14000064 }, - { 0x13001f78, 0x14000080 }, - { 0x13001f79, 0x14000080 }, - { 0x13001f7a, 0x14000070 }, - { 0x13001f7b, 0x14000070 }, - { 0x13001f7c, 0x1400007e }, - { 0x13001f7d, 0x1400007e }, - { 0x13001f80, 0x14000008 }, - { 0x13001f81, 0x14000008 }, - { 0x13001f82, 0x14000008 }, - { 0x13001f83, 0x14000008 }, - { 0x13001f84, 0x14000008 }, - { 0x13001f85, 0x14000008 }, - { 0x13001f86, 0x14000008 }, - { 0x13001f87, 0x14000008 }, - { 0x13001f88, 0x2000fff8 }, - { 0x13001f89, 0x2000fff8 }, - { 0x13001f8a, 0x2000fff8 }, - { 0x13001f8b, 0x2000fff8 }, - { 0x13001f8c, 0x2000fff8 }, - { 0x13001f8d, 0x2000fff8 }, - { 0x13001f8e, 0x2000fff8 }, - { 0x13001f8f, 0x2000fff8 }, - { 0x13001f90, 0x14000008 }, - { 0x13001f91, 0x14000008 }, - { 0x13001f92, 0x14000008 }, - { 0x13001f93, 0x14000008 }, - { 0x13001f94, 0x14000008 }, - { 0x13001f95, 0x14000008 }, - { 0x13001f96, 0x14000008 }, - { 0x13001f97, 0x14000008 }, - { 0x13001f98, 0x2000fff8 }, - { 0x13001f99, 0x2000fff8 }, - { 0x13001f9a, 0x2000fff8 }, - { 0x13001f9b, 0x2000fff8 }, - { 0x13001f9c, 0x2000fff8 }, - { 0x13001f9d, 0x2000fff8 }, - { 0x13001f9e, 0x2000fff8 }, - { 0x13001f9f, 0x2000fff8 }, - { 0x13001fa0, 0x14000008 }, - { 0x13001fa1, 0x14000008 }, - { 0x13001fa2, 0x14000008 }, - { 0x13001fa3, 0x14000008 }, - { 0x13001fa4, 0x14000008 }, - { 0x13001fa5, 0x14000008 }, - { 0x13001fa6, 0x14000008 }, - { 0x13001fa7, 0x14000008 }, - { 0x13001fa8, 0x2000fff8 }, - { 0x13001fa9, 0x2000fff8 }, - { 0x13001faa, 0x2000fff8 }, - { 0x13001fab, 0x2000fff8 }, - { 0x13001fac, 0x2000fff8 }, - { 0x13001fad, 0x2000fff8 }, - { 0x13001fae, 0x2000fff8 }, - { 0x13001faf, 0x2000fff8 }, - { 0x13001fb0, 0x14000008 }, - { 0x13001fb1, 0x14000008 }, - { 0x13001fb2, 0x14000000 }, - { 0x13001fb3, 0x14000009 }, - { 0x13001fb4, 0x14000000 }, - { 0x13801fb6, 0x14000001 }, - { 0x13001fb8, 0x2400fff8 }, - { 0x13001fb9, 0x2400fff8 }, - { 0x13001fba, 0x2400ffb6 }, - { 0x13001fbb, 0x2400ffb6 }, - { 0x13001fbc, 0x2000fff7 }, - { 0x13001fbd, 0x60000000 }, - { 0x13001fbe, 0x1400e3db }, - { 0x13801fbf, 0x60000002 }, - { 0x13001fc2, 0x14000000 }, - { 0x13001fc3, 0x14000009 }, - { 0x13001fc4, 0x14000000 }, - { 0x13801fc6, 0x14000001 }, - { 0x13001fc8, 0x2400ffaa }, - { 0x13001fc9, 0x2400ffaa }, - { 0x13001fca, 0x2400ffaa }, - { 0x13001fcb, 0x2400ffaa }, - { 0x13001fcc, 0x2000fff7 }, - { 0x13801fcd, 0x60000002 }, - { 0x13001fd0, 0x14000008 }, - { 0x13001fd1, 0x14000008 }, - { 0x13801fd2, 0x14000001 }, - { 0x13801fd6, 0x14000001 }, - { 0x13001fd8, 0x2400fff8 }, - { 0x13001fd9, 0x2400fff8 }, - { 0x13001fda, 0x2400ff9c }, - { 0x13001fdb, 0x2400ff9c }, - { 0x13801fdd, 0x60000002 }, - { 0x13001fe0, 0x14000008 }, - { 0x13001fe1, 0x14000008 }, - { 0x13801fe2, 0x14000002 }, - { 0x13001fe5, 0x14000007 }, - { 0x13801fe6, 0x14000001 }, - { 0x13001fe8, 0x2400fff8 }, - { 0x13001fe9, 0x2400fff8 }, - { 0x13001fea, 0x2400ff90 }, - { 0x13001feb, 0x2400ff90 }, - { 0x13001fec, 0x2400fff9 }, - { 0x13801fed, 0x60000002 }, - { 0x13001ff2, 0x14000000 }, - { 0x13001ff3, 0x14000009 }, - { 0x13001ff4, 0x14000000 }, - { 0x13801ff6, 0x14000001 }, - { 0x13001ff8, 0x2400ff80 }, - { 0x13001ff9, 0x2400ff80 }, - { 0x13001ffa, 0x2400ff82 }, - { 0x13001ffb, 0x2400ff82 }, - { 0x13001ffc, 0x2000fff7 }, - { 0x13801ffd, 0x60000001 }, - { 0x09802000, 0x7400000a }, - { 0x0980200b, 0x04000004 }, - { 0x09802010, 0x44000005 }, - { 0x09802016, 0x54000001 }, - { 0x09002018, 0x50000000 }, - { 0x09002019, 0x4c000000 }, - { 0x0900201a, 0x58000000 }, - { 0x0980201b, 0x50000001 }, - { 0x0900201d, 0x4c000000 }, - { 0x0900201e, 0x58000000 }, - { 0x0900201f, 0x50000000 }, - { 0x09802020, 0x54000007 }, - { 0x09002028, 0x6c000000 }, - { 0x09002029, 0x70000000 }, - { 0x0980202a, 0x04000004 }, - { 0x0900202f, 0x74000000 }, - { 0x09802030, 0x54000008 }, - { 0x09002039, 0x50000000 }, - { 0x0900203a, 0x4c000000 }, - { 0x0980203b, 0x54000003 }, - { 0x0980203f, 0x40000001 }, - { 0x09802041, 0x54000002 }, - { 0x09002044, 0x64000000 }, - { 0x09002045, 0x58000000 }, - { 0x09002046, 0x48000000 }, - { 0x09802047, 0x5400000a }, - { 0x09002052, 0x64000000 }, - { 0x09002053, 0x54000000 }, - { 0x09002054, 0x40000000 }, - { 0x09802055, 0x54000009 }, - { 0x0900205f, 0x74000000 }, - { 0x09802060, 0x04000003 }, - { 0x0980206a, 0x04000005 }, - { 0x09002070, 0x3c000000 }, - { 0x21002071, 0x14000000 }, - { 0x09802074, 0x3c000005 }, - { 0x0980207a, 0x64000002 }, - { 0x0900207d, 0x58000000 }, - { 0x0900207e, 0x48000000 }, - { 0x2100207f, 0x14000000 }, - { 0x09802080, 0x3c000009 }, - { 0x0980208a, 0x64000002 }, - { 0x0900208d, 0x58000000 }, - { 0x0900208e, 0x48000000 }, - { 0x21802090, 0x18000004 }, - { 0x098020a0, 0x5c000015 }, - { 0x1b8020d0, 0x3000000c }, - { 0x1b8020dd, 0x2c000003 }, - { 0x1b0020e1, 0x30000000 }, - { 0x1b8020e2, 0x2c000002 }, - { 0x1b8020e5, 0x3000000a }, - { 0x09802100, 0x68000001 }, - { 0x09002102, 0x24000000 }, - { 0x09802103, 0x68000003 }, - { 0x09002107, 0x24000000 }, - { 0x09802108, 0x68000001 }, - { 0x0900210a, 0x14000000 }, - { 0x0980210b, 0x24000002 }, - { 0x0980210e, 0x14000001 }, - { 0x09802110, 0x24000002 }, - { 0x09002113, 0x14000000 }, - { 0x09002114, 0x68000000 }, - { 0x09002115, 0x24000000 }, - { 0x09802116, 0x68000002 }, - { 0x09802119, 0x24000004 }, - { 0x0980211e, 0x68000005 }, - { 0x09002124, 0x24000000 }, - { 0x09002125, 0x68000000 }, - { 0x13002126, 0x2400e2a3 }, - { 0x09002127, 0x68000000 }, - { 0x09002128, 0x24000000 }, - { 0x09002129, 0x68000000 }, - { 0x2100212a, 0x2400df41 }, - { 0x2100212b, 0x2400dfba }, - { 0x0980212c, 0x24000001 }, - { 0x0900212e, 0x68000000 }, - { 0x0900212f, 0x14000000 }, - { 0x09802130, 0x24000001 }, - { 0x21002132, 0x2400001c }, - { 0x09002133, 0x24000000 }, - { 0x09002134, 0x14000000 }, - { 0x09802135, 0x1c000003 }, - { 0x09002139, 0x14000000 }, - { 0x0980213a, 0x68000001 }, - { 0x0980213c, 0x14000001 }, - { 0x0980213e, 0x24000001 }, - { 0x09802140, 0x64000004 }, - { 0x09002145, 0x24000000 }, - { 0x09802146, 0x14000003 }, - { 0x0900214a, 0x68000000 }, - { 0x0900214b, 0x64000000 }, - { 0x0980214c, 0x68000001 }, - { 0x2100214e, 0x1400ffe4 }, - { 0x09802153, 0x3c00000c }, - { 0x09002160, 0x38000010 }, - { 0x09002161, 0x38000010 }, - { 0x09002162, 0x38000010 }, - { 0x09002163, 0x38000010 }, - { 0x09002164, 0x38000010 }, - { 0x09002165, 0x38000010 }, - { 0x09002166, 0x38000010 }, - { 0x09002167, 0x38000010 }, - { 0x09002168, 0x38000010 }, - { 0x09002169, 0x38000010 }, - { 0x0900216a, 0x38000010 }, - { 0x0900216b, 0x38000010 }, - { 0x0900216c, 0x38000010 }, - { 0x0900216d, 0x38000010 }, - { 0x0900216e, 0x38000010 }, - { 0x0900216f, 0x38000010 }, - { 0x09002170, 0x3800fff0 }, - { 0x09002171, 0x3800fff0 }, - { 0x09002172, 0x3800fff0 }, - { 0x09002173, 0x3800fff0 }, - { 0x09002174, 0x3800fff0 }, - { 0x09002175, 0x3800fff0 }, - { 0x09002176, 0x3800fff0 }, - { 0x09002177, 0x3800fff0 }, - { 0x09002178, 0x3800fff0 }, - { 0x09002179, 0x3800fff0 }, - { 0x0900217a, 0x3800fff0 }, - { 0x0900217b, 0x3800fff0 }, - { 0x0900217c, 0x3800fff0 }, - { 0x0900217d, 0x3800fff0 }, - { 0x0900217e, 0x3800fff0 }, - { 0x0900217f, 0x3800fff0 }, - { 0x09802180, 0x38000002 }, - { 0x09002183, 0x24000001 }, - { 0x21002184, 0x1400ffff }, - { 0x09802190, 0x64000004 }, - { 0x09802195, 0x68000004 }, - { 0x0980219a, 0x64000001 }, - { 0x0980219c, 0x68000003 }, - { 0x090021a0, 0x64000000 }, - { 0x098021a1, 0x68000001 }, - { 0x090021a3, 0x64000000 }, - { 0x098021a4, 0x68000001 }, - { 0x090021a6, 0x64000000 }, - { 0x098021a7, 0x68000006 }, - { 0x090021ae, 0x64000000 }, - { 0x098021af, 0x6800001e }, - { 0x098021ce, 0x64000001 }, - { 0x098021d0, 0x68000001 }, - { 0x090021d2, 0x64000000 }, - { 0x090021d3, 0x68000000 }, - { 0x090021d4, 0x64000000 }, - { 0x098021d5, 0x6800001e }, - { 0x098021f4, 0x6400010b }, - { 0x09802300, 0x68000007 }, - { 0x09802308, 0x64000003 }, - { 0x0980230c, 0x68000013 }, - { 0x09802320, 0x64000001 }, - { 0x09802322, 0x68000006 }, - { 0x09002329, 0x58000000 }, - { 0x0900232a, 0x48000000 }, - { 0x0980232b, 0x68000050 }, - { 0x0900237c, 0x64000000 }, - { 0x0980237d, 0x6800001d }, - { 0x0980239b, 0x64000018 }, - { 0x098023b4, 0x68000027 }, - { 0x098023dc, 0x64000005 }, - { 0x098023e2, 0x68000005 }, - { 0x09802400, 0x68000026 }, - { 0x09802440, 0x6800000a }, - { 0x09802460, 0x3c00003b }, - { 0x0980249c, 0x68000019 }, - { 0x090024b6, 0x6800001a }, - { 0x090024b7, 0x6800001a }, - { 0x090024b8, 0x6800001a }, - { 0x090024b9, 0x6800001a }, - { 0x090024ba, 0x6800001a }, - { 0x090024bb, 0x6800001a }, - { 0x090024bc, 0x6800001a }, - { 0x090024bd, 0x6800001a }, - { 0x090024be, 0x6800001a }, - { 0x090024bf, 0x6800001a }, - { 0x090024c0, 0x6800001a }, - { 0x090024c1, 0x6800001a }, - { 0x090024c2, 0x6800001a }, - { 0x090024c3, 0x6800001a }, - { 0x090024c4, 0x6800001a }, - { 0x090024c5, 0x6800001a }, - { 0x090024c6, 0x6800001a }, - { 0x090024c7, 0x6800001a }, - { 0x090024c8, 0x6800001a }, - { 0x090024c9, 0x6800001a }, - { 0x090024ca, 0x6800001a }, - { 0x090024cb, 0x6800001a }, - { 0x090024cc, 0x6800001a }, - { 0x090024cd, 0x6800001a }, - { 0x090024ce, 0x6800001a }, - { 0x090024cf, 0x6800001a }, - { 0x090024d0, 0x6800ffe6 }, - { 0x090024d1, 0x6800ffe6 }, - { 0x090024d2, 0x6800ffe6 }, - { 0x090024d3, 0x6800ffe6 }, - { 0x090024d4, 0x6800ffe6 }, - { 0x090024d5, 0x6800ffe6 }, - { 0x090024d6, 0x6800ffe6 }, - { 0x090024d7, 0x6800ffe6 }, - { 0x090024d8, 0x6800ffe6 }, - { 0x090024d9, 0x6800ffe6 }, - { 0x090024da, 0x6800ffe6 }, - { 0x090024db, 0x6800ffe6 }, - { 0x090024dc, 0x6800ffe6 }, - { 0x090024dd, 0x6800ffe6 }, - { 0x090024de, 0x6800ffe6 }, - { 0x090024df, 0x6800ffe6 }, - { 0x090024e0, 0x6800ffe6 }, - { 0x090024e1, 0x6800ffe6 }, - { 0x090024e2, 0x6800ffe6 }, - { 0x090024e3, 0x6800ffe6 }, - { 0x090024e4, 0x6800ffe6 }, - { 0x090024e5, 0x6800ffe6 }, - { 0x090024e6, 0x6800ffe6 }, - { 0x090024e7, 0x6800ffe6 }, - { 0x090024e8, 0x6800ffe6 }, - { 0x090024e9, 0x6800ffe6 }, - { 0x098024ea, 0x3c000015 }, - { 0x09802500, 0x680000b6 }, - { 0x090025b7, 0x64000000 }, - { 0x098025b8, 0x68000008 }, - { 0x090025c1, 0x64000000 }, - { 0x098025c2, 0x68000035 }, - { 0x098025f8, 0x64000007 }, - { 0x09802600, 0x6800006e }, - { 0x0900266f, 0x64000000 }, - { 0x09802670, 0x6800002c }, - { 0x098026a0, 0x68000012 }, - { 0x09802701, 0x68000003 }, - { 0x09802706, 0x68000003 }, - { 0x0980270c, 0x6800001b }, - { 0x09802729, 0x68000022 }, - { 0x0900274d, 0x68000000 }, - { 0x0980274f, 0x68000003 }, - { 0x09002756, 0x68000000 }, - { 0x09802758, 0x68000006 }, - { 0x09802761, 0x68000006 }, - { 0x09002768, 0x58000000 }, - { 0x09002769, 0x48000000 }, - { 0x0900276a, 0x58000000 }, - { 0x0900276b, 0x48000000 }, - { 0x0900276c, 0x58000000 }, - { 0x0900276d, 0x48000000 }, - { 0x0900276e, 0x58000000 }, - { 0x0900276f, 0x48000000 }, - { 0x09002770, 0x58000000 }, - { 0x09002771, 0x48000000 }, - { 0x09002772, 0x58000000 }, - { 0x09002773, 0x48000000 }, - { 0x09002774, 0x58000000 }, - { 0x09002775, 0x48000000 }, - { 0x09802776, 0x3c00001d }, - { 0x09002794, 0x68000000 }, - { 0x09802798, 0x68000017 }, - { 0x098027b1, 0x6800000d }, - { 0x098027c0, 0x64000004 }, - { 0x090027c5, 0x58000000 }, - { 0x090027c6, 0x48000000 }, - { 0x098027c7, 0x64000003 }, - { 0x098027d0, 0x64000015 }, - { 0x090027e6, 0x58000000 }, - { 0x090027e7, 0x48000000 }, - { 0x090027e8, 0x58000000 }, - { 0x090027e9, 0x48000000 }, - { 0x090027ea, 0x58000000 }, - { 0x090027eb, 0x48000000 }, - { 0x098027f0, 0x6400000f }, - { 0x04802800, 0x680000ff }, - { 0x09802900, 0x64000082 }, - { 0x09002983, 0x58000000 }, - { 0x09002984, 0x48000000 }, - { 0x09002985, 0x58000000 }, - { 0x09002986, 0x48000000 }, - { 0x09002987, 0x58000000 }, - { 0x09002988, 0x48000000 }, - { 0x09002989, 0x58000000 }, - { 0x0900298a, 0x48000000 }, - { 0x0900298b, 0x58000000 }, - { 0x0900298c, 0x48000000 }, - { 0x0900298d, 0x58000000 }, - { 0x0900298e, 0x48000000 }, - { 0x0900298f, 0x58000000 }, - { 0x09002990, 0x48000000 }, - { 0x09002991, 0x58000000 }, - { 0x09002992, 0x48000000 }, - { 0x09002993, 0x58000000 }, - { 0x09002994, 0x48000000 }, - { 0x09002995, 0x58000000 }, - { 0x09002996, 0x48000000 }, - { 0x09002997, 0x58000000 }, - { 0x09002998, 0x48000000 }, - { 0x09802999, 0x6400003e }, - { 0x090029d8, 0x58000000 }, - { 0x090029d9, 0x48000000 }, - { 0x090029da, 0x58000000 }, - { 0x090029db, 0x48000000 }, - { 0x098029dc, 0x6400001f }, - { 0x090029fc, 0x58000000 }, - { 0x090029fd, 0x48000000 }, - { 0x098029fe, 0x64000101 }, - { 0x09802b00, 0x6800001a }, - { 0x09802b20, 0x68000003 }, - { 0x11002c00, 0x24000030 }, - { 0x11002c01, 0x24000030 }, - { 0x11002c02, 0x24000030 }, - { 0x11002c03, 0x24000030 }, - { 0x11002c04, 0x24000030 }, - { 0x11002c05, 0x24000030 }, - { 0x11002c06, 0x24000030 }, - { 0x11002c07, 0x24000030 }, - { 0x11002c08, 0x24000030 }, - { 0x11002c09, 0x24000030 }, - { 0x11002c0a, 0x24000030 }, - { 0x11002c0b, 0x24000030 }, - { 0x11002c0c, 0x24000030 }, - { 0x11002c0d, 0x24000030 }, - { 0x11002c0e, 0x24000030 }, - { 0x11002c0f, 0x24000030 }, - { 0x11002c10, 0x24000030 }, - { 0x11002c11, 0x24000030 }, - { 0x11002c12, 0x24000030 }, - { 0x11002c13, 0x24000030 }, - { 0x11002c14, 0x24000030 }, - { 0x11002c15, 0x24000030 }, - { 0x11002c16, 0x24000030 }, - { 0x11002c17, 0x24000030 }, - { 0x11002c18, 0x24000030 }, - { 0x11002c19, 0x24000030 }, - { 0x11002c1a, 0x24000030 }, - { 0x11002c1b, 0x24000030 }, - { 0x11002c1c, 0x24000030 }, - { 0x11002c1d, 0x24000030 }, - { 0x11002c1e, 0x24000030 }, - { 0x11002c1f, 0x24000030 }, - { 0x11002c20, 0x24000030 }, - { 0x11002c21, 0x24000030 }, - { 0x11002c22, 0x24000030 }, - { 0x11002c23, 0x24000030 }, - { 0x11002c24, 0x24000030 }, - { 0x11002c25, 0x24000030 }, - { 0x11002c26, 0x24000030 }, - { 0x11002c27, 0x24000030 }, - { 0x11002c28, 0x24000030 }, - { 0x11002c29, 0x24000030 }, - { 0x11002c2a, 0x24000030 }, - { 0x11002c2b, 0x24000030 }, - { 0x11002c2c, 0x24000030 }, - { 0x11002c2d, 0x24000030 }, - { 0x11002c2e, 0x24000030 }, - { 0x11002c30, 0x1400ffd0 }, - { 0x11002c31, 0x1400ffd0 }, - { 0x11002c32, 0x1400ffd0 }, - { 0x11002c33, 0x1400ffd0 }, - { 0x11002c34, 0x1400ffd0 }, - { 0x11002c35, 0x1400ffd0 }, - { 0x11002c36, 0x1400ffd0 }, - { 0x11002c37, 0x1400ffd0 }, - { 0x11002c38, 0x1400ffd0 }, - { 0x11002c39, 0x1400ffd0 }, - { 0x11002c3a, 0x1400ffd0 }, - { 0x11002c3b, 0x1400ffd0 }, - { 0x11002c3c, 0x1400ffd0 }, - { 0x11002c3d, 0x1400ffd0 }, - { 0x11002c3e, 0x1400ffd0 }, - { 0x11002c3f, 0x1400ffd0 }, - { 0x11002c40, 0x1400ffd0 }, - { 0x11002c41, 0x1400ffd0 }, - { 0x11002c42, 0x1400ffd0 }, - { 0x11002c43, 0x1400ffd0 }, - { 0x11002c44, 0x1400ffd0 }, - { 0x11002c45, 0x1400ffd0 }, - { 0x11002c46, 0x1400ffd0 }, - { 0x11002c47, 0x1400ffd0 }, - { 0x11002c48, 0x1400ffd0 }, - { 0x11002c49, 0x1400ffd0 }, - { 0x11002c4a, 0x1400ffd0 }, - { 0x11002c4b, 0x1400ffd0 }, - { 0x11002c4c, 0x1400ffd0 }, - { 0x11002c4d, 0x1400ffd0 }, - { 0x11002c4e, 0x1400ffd0 }, - { 0x11002c4f, 0x1400ffd0 }, - { 0x11002c50, 0x1400ffd0 }, - { 0x11002c51, 0x1400ffd0 }, - { 0x11002c52, 0x1400ffd0 }, - { 0x11002c53, 0x1400ffd0 }, - { 0x11002c54, 0x1400ffd0 }, - { 0x11002c55, 0x1400ffd0 }, - { 0x11002c56, 0x1400ffd0 }, - { 0x11002c57, 0x1400ffd0 }, - { 0x11002c58, 0x1400ffd0 }, - { 0x11002c59, 0x1400ffd0 }, - { 0x11002c5a, 0x1400ffd0 }, - { 0x11002c5b, 0x1400ffd0 }, - { 0x11002c5c, 0x1400ffd0 }, - { 0x11002c5d, 0x1400ffd0 }, - { 0x11002c5e, 0x1400ffd0 }, - { 0x21002c60, 0x24000001 }, - { 0x21002c61, 0x1400ffff }, - { 0x21002c62, 0x2400d609 }, - { 0x21002c63, 0x2400f11a }, - { 0x21002c64, 0x2400d619 }, - { 0x21002c65, 0x1400d5d5 }, - { 0x21002c66, 0x1400d5d8 }, - { 0x21002c67, 0x24000001 }, - { 0x21002c68, 0x1400ffff }, - { 0x21002c69, 0x24000001 }, - { 0x21002c6a, 0x1400ffff }, - { 0x21002c6b, 0x24000001 }, - { 0x21002c6c, 0x1400ffff }, - { 0x21002c74, 0x14000000 }, - { 0x21002c75, 0x24000001 }, - { 0x21002c76, 0x1400ffff }, - { 0x21002c77, 0x14000000 }, - { 0x0a002c80, 0x24000001 }, - { 0x0a002c81, 0x1400ffff }, - { 0x0a002c82, 0x24000001 }, - { 0x0a002c83, 0x1400ffff }, - { 0x0a002c84, 0x24000001 }, - { 0x0a002c85, 0x1400ffff }, - { 0x0a002c86, 0x24000001 }, - { 0x0a002c87, 0x1400ffff }, - { 0x0a002c88, 0x24000001 }, - { 0x0a002c89, 0x1400ffff }, - { 0x0a002c8a, 0x24000001 }, - { 0x0a002c8b, 0x1400ffff }, - { 0x0a002c8c, 0x24000001 }, - { 0x0a002c8d, 0x1400ffff }, - { 0x0a002c8e, 0x24000001 }, - { 0x0a002c8f, 0x1400ffff }, - { 0x0a002c90, 0x24000001 }, - { 0x0a002c91, 0x1400ffff }, - { 0x0a002c92, 0x24000001 }, - { 0x0a002c93, 0x1400ffff }, - { 0x0a002c94, 0x24000001 }, - { 0x0a002c95, 0x1400ffff }, - { 0x0a002c96, 0x24000001 }, - { 0x0a002c97, 0x1400ffff }, - { 0x0a002c98, 0x24000001 }, - { 0x0a002c99, 0x1400ffff }, - { 0x0a002c9a, 0x24000001 }, - { 0x0a002c9b, 0x1400ffff }, - { 0x0a002c9c, 0x24000001 }, - { 0x0a002c9d, 0x1400ffff }, - { 0x0a002c9e, 0x24000001 }, - { 0x0a002c9f, 0x1400ffff }, - { 0x0a002ca0, 0x24000001 }, - { 0x0a002ca1, 0x1400ffff }, - { 0x0a002ca2, 0x24000001 }, - { 0x0a002ca3, 0x1400ffff }, - { 0x0a002ca4, 0x24000001 }, - { 0x0a002ca5, 0x1400ffff }, - { 0x0a002ca6, 0x24000001 }, - { 0x0a002ca7, 0x1400ffff }, - { 0x0a002ca8, 0x24000001 }, - { 0x0a002ca9, 0x1400ffff }, - { 0x0a002caa, 0x24000001 }, - { 0x0a002cab, 0x1400ffff }, - { 0x0a002cac, 0x24000001 }, - { 0x0a002cad, 0x1400ffff }, - { 0x0a002cae, 0x24000001 }, - { 0x0a002caf, 0x1400ffff }, - { 0x0a002cb0, 0x24000001 }, - { 0x0a002cb1, 0x1400ffff }, - { 0x0a002cb2, 0x24000001 }, - { 0x0a002cb3, 0x1400ffff }, - { 0x0a002cb4, 0x24000001 }, - { 0x0a002cb5, 0x1400ffff }, - { 0x0a002cb6, 0x24000001 }, - { 0x0a002cb7, 0x1400ffff }, - { 0x0a002cb8, 0x24000001 }, - { 0x0a002cb9, 0x1400ffff }, - { 0x0a002cba, 0x24000001 }, - { 0x0a002cbb, 0x1400ffff }, - { 0x0a002cbc, 0x24000001 }, - { 0x0a002cbd, 0x1400ffff }, - { 0x0a002cbe, 0x24000001 }, - { 0x0a002cbf, 0x1400ffff }, - { 0x0a002cc0, 0x24000001 }, - { 0x0a002cc1, 0x1400ffff }, - { 0x0a002cc2, 0x24000001 }, - { 0x0a002cc3, 0x1400ffff }, - { 0x0a002cc4, 0x24000001 }, - { 0x0a002cc5, 0x1400ffff }, - { 0x0a002cc6, 0x24000001 }, - { 0x0a002cc7, 0x1400ffff }, - { 0x0a002cc8, 0x24000001 }, - { 0x0a002cc9, 0x1400ffff }, - { 0x0a002cca, 0x24000001 }, - { 0x0a002ccb, 0x1400ffff }, - { 0x0a002ccc, 0x24000001 }, - { 0x0a002ccd, 0x1400ffff }, - { 0x0a002cce, 0x24000001 }, - { 0x0a002ccf, 0x1400ffff }, - { 0x0a002cd0, 0x24000001 }, - { 0x0a002cd1, 0x1400ffff }, - { 0x0a002cd2, 0x24000001 }, - { 0x0a002cd3, 0x1400ffff }, - { 0x0a002cd4, 0x24000001 }, - { 0x0a002cd5, 0x1400ffff }, - { 0x0a002cd6, 0x24000001 }, - { 0x0a002cd7, 0x1400ffff }, - { 0x0a002cd8, 0x24000001 }, - { 0x0a002cd9, 0x1400ffff }, - { 0x0a002cda, 0x24000001 }, - { 0x0a002cdb, 0x1400ffff }, - { 0x0a002cdc, 0x24000001 }, - { 0x0a002cdd, 0x1400ffff }, - { 0x0a002cde, 0x24000001 }, - { 0x0a002cdf, 0x1400ffff }, - { 0x0a002ce0, 0x24000001 }, - { 0x0a002ce1, 0x1400ffff }, - { 0x0a002ce2, 0x24000001 }, - { 0x0a002ce3, 0x1400ffff }, - { 0x0a002ce4, 0x14000000 }, - { 0x0a802ce5, 0x68000005 }, - { 0x0a802cf9, 0x54000003 }, - { 0x0a002cfd, 0x3c000000 }, - { 0x0a802cfe, 0x54000001 }, - { 0x10002d00, 0x1400e3a0 }, - { 0x10002d01, 0x1400e3a0 }, - { 0x10002d02, 0x1400e3a0 }, - { 0x10002d03, 0x1400e3a0 }, - { 0x10002d04, 0x1400e3a0 }, - { 0x10002d05, 0x1400e3a0 }, - { 0x10002d06, 0x1400e3a0 }, - { 0x10002d07, 0x1400e3a0 }, - { 0x10002d08, 0x1400e3a0 }, - { 0x10002d09, 0x1400e3a0 }, - { 0x10002d0a, 0x1400e3a0 }, - { 0x10002d0b, 0x1400e3a0 }, - { 0x10002d0c, 0x1400e3a0 }, - { 0x10002d0d, 0x1400e3a0 }, - { 0x10002d0e, 0x1400e3a0 }, - { 0x10002d0f, 0x1400e3a0 }, - { 0x10002d10, 0x1400e3a0 }, - { 0x10002d11, 0x1400e3a0 }, - { 0x10002d12, 0x1400e3a0 }, - { 0x10002d13, 0x1400e3a0 }, - { 0x10002d14, 0x1400e3a0 }, - { 0x10002d15, 0x1400e3a0 }, - { 0x10002d16, 0x1400e3a0 }, - { 0x10002d17, 0x1400e3a0 }, - { 0x10002d18, 0x1400e3a0 }, - { 0x10002d19, 0x1400e3a0 }, - { 0x10002d1a, 0x1400e3a0 }, - { 0x10002d1b, 0x1400e3a0 }, - { 0x10002d1c, 0x1400e3a0 }, - { 0x10002d1d, 0x1400e3a0 }, - { 0x10002d1e, 0x1400e3a0 }, - { 0x10002d1f, 0x1400e3a0 }, - { 0x10002d20, 0x1400e3a0 }, - { 0x10002d21, 0x1400e3a0 }, - { 0x10002d22, 0x1400e3a0 }, - { 0x10002d23, 0x1400e3a0 }, - { 0x10002d24, 0x1400e3a0 }, - { 0x10002d25, 0x1400e3a0 }, - { 0x3a802d30, 0x1c000035 }, - { 0x3a002d6f, 0x18000000 }, - { 0x0f802d80, 0x1c000016 }, - { 0x0f802da0, 0x1c000006 }, - { 0x0f802da8, 0x1c000006 }, - { 0x0f802db0, 0x1c000006 }, - { 0x0f802db8, 0x1c000006 }, - { 0x0f802dc0, 0x1c000006 }, - { 0x0f802dc8, 0x1c000006 }, - { 0x0f802dd0, 0x1c000006 }, - { 0x0f802dd8, 0x1c000006 }, - { 0x09802e00, 0x54000001 }, - { 0x09002e02, 0x50000000 }, - { 0x09002e03, 0x4c000000 }, - { 0x09002e04, 0x50000000 }, - { 0x09002e05, 0x4c000000 }, - { 0x09802e06, 0x54000002 }, - { 0x09002e09, 0x50000000 }, - { 0x09002e0a, 0x4c000000 }, - { 0x09002e0b, 0x54000000 }, - { 0x09002e0c, 0x50000000 }, - { 0x09002e0d, 0x4c000000 }, - { 0x09802e0e, 0x54000008 }, - { 0x09002e17, 0x44000000 }, - { 0x09002e1c, 0x50000000 }, - { 0x09002e1d, 0x4c000000 }, - { 0x16802e80, 0x68000019 }, - { 0x16802e9b, 0x68000058 }, - { 0x16802f00, 0x680000d5 }, - { 0x09802ff0, 0x6800000b }, - { 0x09003000, 0x74000000 }, - { 0x09803001, 0x54000002 }, - { 0x09003004, 0x68000000 }, - { 0x16003005, 0x18000000 }, - { 0x09003006, 0x1c000000 }, - { 0x16003007, 0x38000000 }, - { 0x09003008, 0x58000000 }, - { 0x09003009, 0x48000000 }, - { 0x0900300a, 0x58000000 }, - { 0x0900300b, 0x48000000 }, - { 0x0900300c, 0x58000000 }, - { 0x0900300d, 0x48000000 }, - { 0x0900300e, 0x58000000 }, - { 0x0900300f, 0x48000000 }, - { 0x09003010, 0x58000000 }, - { 0x09003011, 0x48000000 }, - { 0x09803012, 0x68000001 }, - { 0x09003014, 0x58000000 }, - { 0x09003015, 0x48000000 }, - { 0x09003016, 0x58000000 }, - { 0x09003017, 0x48000000 }, - { 0x09003018, 0x58000000 }, - { 0x09003019, 0x48000000 }, - { 0x0900301a, 0x58000000 }, - { 0x0900301b, 0x48000000 }, - { 0x0900301c, 0x44000000 }, - { 0x0900301d, 0x58000000 }, - { 0x0980301e, 0x48000001 }, - { 0x09003020, 0x68000000 }, - { 0x16803021, 0x38000008 }, - { 0x1b80302a, 0x30000005 }, - { 0x09003030, 0x44000000 }, - { 0x09803031, 0x18000004 }, - { 0x09803036, 0x68000001 }, - { 0x16803038, 0x38000002 }, - { 0x1600303b, 0x18000000 }, - { 0x0900303c, 0x1c000000 }, - { 0x0900303d, 0x54000000 }, - { 0x0980303e, 0x68000001 }, - { 0x1a803041, 0x1c000055 }, - { 0x1b803099, 0x30000001 }, - { 0x0980309b, 0x60000001 }, - { 0x1a80309d, 0x18000001 }, - { 0x1a00309f, 0x1c000000 }, - { 0x090030a0, 0x44000000 }, - { 0x1d8030a1, 0x1c000059 }, - { 0x090030fb, 0x54000000 }, - { 0x098030fc, 0x18000002 }, - { 0x1d0030ff, 0x1c000000 }, - { 0x03803105, 0x1c000027 }, - { 0x17803131, 0x1c00005d }, - { 0x09803190, 0x68000001 }, - { 0x09803192, 0x3c000003 }, - { 0x09803196, 0x68000009 }, - { 0x038031a0, 0x1c000017 }, - { 0x098031c0, 0x6800000f }, - { 0x1d8031f0, 0x1c00000f }, - { 0x17803200, 0x6800001e }, - { 0x09803220, 0x3c000009 }, - { 0x0980322a, 0x68000019 }, - { 0x09003250, 0x68000000 }, - { 0x09803251, 0x3c00000e }, - { 0x17803260, 0x6800001f }, - { 0x09803280, 0x3c000009 }, - { 0x0980328a, 0x68000026 }, - { 0x098032b1, 0x3c00000e }, - { 0x098032c0, 0x6800003e }, - { 0x09803300, 0x680000ff }, - { 0x16803400, 0x1c0019b5 }, - { 0x09804dc0, 0x6800003f }, - { 0x16804e00, 0x1c0051bb }, - { 0x3c80a000, 0x1c000014 }, - { 0x3c00a015, 0x18000000 }, - { 0x3c80a016, 0x1c000476 }, - { 0x3c80a490, 0x68000036 }, - { 0x0980a700, 0x60000016 }, - { 0x0980a717, 0x18000003 }, - { 0x0980a720, 0x60000001 }, - { 0x3080a800, 0x1c000001 }, - { 0x3000a802, 0x28000000 }, - { 0x3080a803, 0x1c000002 }, - { 0x3000a806, 0x30000000 }, - { 0x3080a807, 0x1c000003 }, - { 0x3000a80b, 0x30000000 }, - { 0x3080a80c, 0x1c000016 }, - { 0x3080a823, 0x28000001 }, - { 0x3080a825, 0x30000001 }, - { 0x3000a827, 0x28000000 }, - { 0x3080a828, 0x68000003 }, - { 0x4080a840, 0x1c000033 }, - { 0x4080a874, 0x54000003 }, - { 0x1780ac00, 0x1c002ba3 }, - { 0x0980d800, 0x1000037f }, - { 0x0980db80, 0x1000007f }, - { 0x0980dc00, 0x100003ff }, - { 0x0980e000, 0x0c0018ff }, - { 0x1680f900, 0x1c00012d }, - { 0x1680fa30, 0x1c00003a }, - { 0x1680fa70, 0x1c000069 }, - { 0x2180fb00, 0x14000006 }, - { 0x0180fb13, 0x14000004 }, - { 0x1900fb1d, 0x1c000000 }, - { 0x1900fb1e, 0x30000000 }, - { 0x1980fb1f, 0x1c000009 }, - { 0x1900fb29, 0x64000000 }, - { 0x1980fb2a, 0x1c00000c }, - { 0x1980fb38, 0x1c000004 }, - { 0x1900fb3e, 0x1c000000 }, - { 0x1980fb40, 0x1c000001 }, - { 0x1980fb43, 0x1c000001 }, - { 0x1980fb46, 0x1c00006b }, - { 0x0080fbd3, 0x1c00016a }, - { 0x0900fd3e, 0x58000000 }, - { 0x0900fd3f, 0x48000000 }, - { 0x0080fd50, 0x1c00003f }, - { 0x0080fd92, 0x1c000035 }, - { 0x0080fdf0, 0x1c00000b }, - { 0x0000fdfc, 0x5c000000 }, - { 0x0900fdfd, 0x68000000 }, - { 0x1b80fe00, 0x3000000f }, - { 0x0980fe10, 0x54000006 }, - { 0x0900fe17, 0x58000000 }, - { 0x0900fe18, 0x48000000 }, - { 0x0900fe19, 0x54000000 }, - { 0x1b80fe20, 0x30000003 }, - { 0x0900fe30, 0x54000000 }, - { 0x0980fe31, 0x44000001 }, - { 0x0980fe33, 0x40000001 }, - { 0x0900fe35, 0x58000000 }, - { 0x0900fe36, 0x48000000 }, - { 0x0900fe37, 0x58000000 }, - { 0x0900fe38, 0x48000000 }, - { 0x0900fe39, 0x58000000 }, - { 0x0900fe3a, 0x48000000 }, - { 0x0900fe3b, 0x58000000 }, - { 0x0900fe3c, 0x48000000 }, - { 0x0900fe3d, 0x58000000 }, - { 0x0900fe3e, 0x48000000 }, - { 0x0900fe3f, 0x58000000 }, - { 0x0900fe40, 0x48000000 }, - { 0x0900fe41, 0x58000000 }, - { 0x0900fe42, 0x48000000 }, - { 0x0900fe43, 0x58000000 }, - { 0x0900fe44, 0x48000000 }, - { 0x0980fe45, 0x54000001 }, - { 0x0900fe47, 0x58000000 }, - { 0x0900fe48, 0x48000000 }, - { 0x0980fe49, 0x54000003 }, - { 0x0980fe4d, 0x40000002 }, - { 0x0980fe50, 0x54000002 }, - { 0x0980fe54, 0x54000003 }, - { 0x0900fe58, 0x44000000 }, - { 0x0900fe59, 0x58000000 }, - { 0x0900fe5a, 0x48000000 }, - { 0x0900fe5b, 0x58000000 }, - { 0x0900fe5c, 0x48000000 }, - { 0x0900fe5d, 0x58000000 }, - { 0x0900fe5e, 0x48000000 }, - { 0x0980fe5f, 0x54000002 }, - { 0x0900fe62, 0x64000000 }, - { 0x0900fe63, 0x44000000 }, - { 0x0980fe64, 0x64000002 }, - { 0x0900fe68, 0x54000000 }, - { 0x0900fe69, 0x5c000000 }, - { 0x0980fe6a, 0x54000001 }, - { 0x0080fe70, 0x1c000004 }, - { 0x0080fe76, 0x1c000086 }, - { 0x0900feff, 0x04000000 }, - { 0x0980ff01, 0x54000002 }, - { 0x0900ff04, 0x5c000000 }, - { 0x0980ff05, 0x54000002 }, - { 0x0900ff08, 0x58000000 }, - { 0x0900ff09, 0x48000000 }, - { 0x0900ff0a, 0x54000000 }, - { 0x0900ff0b, 0x64000000 }, - { 0x0900ff0c, 0x54000000 }, - { 0x0900ff0d, 0x44000000 }, - { 0x0980ff0e, 0x54000001 }, - { 0x0980ff10, 0x34000009 }, - { 0x0980ff1a, 0x54000001 }, - { 0x0980ff1c, 0x64000002 }, - { 0x0980ff1f, 0x54000001 }, - { 0x2100ff21, 0x24000020 }, - { 0x2100ff22, 0x24000020 }, - { 0x2100ff23, 0x24000020 }, - { 0x2100ff24, 0x24000020 }, - { 0x2100ff25, 0x24000020 }, - { 0x2100ff26, 0x24000020 }, - { 0x2100ff27, 0x24000020 }, - { 0x2100ff28, 0x24000020 }, - { 0x2100ff29, 0x24000020 }, - { 0x2100ff2a, 0x24000020 }, - { 0x2100ff2b, 0x24000020 }, - { 0x2100ff2c, 0x24000020 }, - { 0x2100ff2d, 0x24000020 }, - { 0x2100ff2e, 0x24000020 }, - { 0x2100ff2f, 0x24000020 }, - { 0x2100ff30, 0x24000020 }, - { 0x2100ff31, 0x24000020 }, - { 0x2100ff32, 0x24000020 }, - { 0x2100ff33, 0x24000020 }, - { 0x2100ff34, 0x24000020 }, - { 0x2100ff35, 0x24000020 }, - { 0x2100ff36, 0x24000020 }, - { 0x2100ff37, 0x24000020 }, - { 0x2100ff38, 0x24000020 }, - { 0x2100ff39, 0x24000020 }, - { 0x2100ff3a, 0x24000020 }, - { 0x0900ff3b, 0x58000000 }, - { 0x0900ff3c, 0x54000000 }, - { 0x0900ff3d, 0x48000000 }, - { 0x0900ff3e, 0x60000000 }, - { 0x0900ff3f, 0x40000000 }, - { 0x0900ff40, 0x60000000 }, - { 0x2100ff41, 0x1400ffe0 }, - { 0x2100ff42, 0x1400ffe0 }, - { 0x2100ff43, 0x1400ffe0 }, - { 0x2100ff44, 0x1400ffe0 }, - { 0x2100ff45, 0x1400ffe0 }, - { 0x2100ff46, 0x1400ffe0 }, - { 0x2100ff47, 0x1400ffe0 }, - { 0x2100ff48, 0x1400ffe0 }, - { 0x2100ff49, 0x1400ffe0 }, - { 0x2100ff4a, 0x1400ffe0 }, - { 0x2100ff4b, 0x1400ffe0 }, - { 0x2100ff4c, 0x1400ffe0 }, - { 0x2100ff4d, 0x1400ffe0 }, - { 0x2100ff4e, 0x1400ffe0 }, - { 0x2100ff4f, 0x1400ffe0 }, - { 0x2100ff50, 0x1400ffe0 }, - { 0x2100ff51, 0x1400ffe0 }, - { 0x2100ff52, 0x1400ffe0 }, - { 0x2100ff53, 0x1400ffe0 }, - { 0x2100ff54, 0x1400ffe0 }, - { 0x2100ff55, 0x1400ffe0 }, - { 0x2100ff56, 0x1400ffe0 }, - { 0x2100ff57, 0x1400ffe0 }, - { 0x2100ff58, 0x1400ffe0 }, - { 0x2100ff59, 0x1400ffe0 }, - { 0x2100ff5a, 0x1400ffe0 }, - { 0x0900ff5b, 0x58000000 }, - { 0x0900ff5c, 0x64000000 }, - { 0x0900ff5d, 0x48000000 }, - { 0x0900ff5e, 0x64000000 }, - { 0x0900ff5f, 0x58000000 }, - { 0x0900ff60, 0x48000000 }, - { 0x0900ff61, 0x54000000 }, - { 0x0900ff62, 0x58000000 }, - { 0x0900ff63, 0x48000000 }, - { 0x0980ff64, 0x54000001 }, - { 0x1d80ff66, 0x1c000009 }, - { 0x0900ff70, 0x18000000 }, - { 0x1d80ff71, 0x1c00002c }, - { 0x0980ff9e, 0x18000001 }, - { 0x1780ffa0, 0x1c00001e }, - { 0x1780ffc2, 0x1c000005 }, - { 0x1780ffca, 0x1c000005 }, - { 0x1780ffd2, 0x1c000005 }, - { 0x1780ffda, 0x1c000002 }, - { 0x0980ffe0, 0x5c000001 }, - { 0x0900ffe2, 0x64000000 }, - { 0x0900ffe3, 0x60000000 }, - { 0x0900ffe4, 0x68000000 }, - { 0x0980ffe5, 0x5c000001 }, - { 0x0900ffe8, 0x68000000 }, - { 0x0980ffe9, 0x64000003 }, - { 0x0980ffed, 0x68000001 }, - { 0x0980fff9, 0x04000002 }, - { 0x0980fffc, 0x68000001 }, - { 0x23810000, 0x1c00000b }, - { 0x2381000d, 0x1c000019 }, - { 0x23810028, 0x1c000012 }, - { 0x2381003c, 0x1c000001 }, - { 0x2381003f, 0x1c00000e }, - { 0x23810050, 0x1c00000d }, - { 0x23810080, 0x1c00007a }, - { 0x09810100, 0x54000001 }, - { 0x09010102, 0x68000000 }, - { 0x09810107, 0x3c00002c }, - { 0x09810137, 0x68000008 }, - { 0x13810140, 0x38000034 }, - { 0x13810175, 0x3c000003 }, - { 0x13810179, 0x68000010 }, - { 0x1301018a, 0x3c000000 }, - { 0x29810300, 0x1c00001e }, - { 0x29810320, 0x3c000003 }, - { 0x12810330, 0x1c000010 }, - { 0x12010341, 0x38000000 }, - { 0x12810342, 0x1c000007 }, - { 0x1201034a, 0x38000000 }, - { 0x3b810380, 0x1c00001d }, - { 0x3b01039f, 0x54000000 }, - { 0x2a8103a0, 0x1c000023 }, - { 0x2a8103c8, 0x1c000007 }, - { 0x2a0103d0, 0x54000000 }, - { 0x2a8103d1, 0x38000004 }, - { 0x0d010400, 0x24000028 }, - { 0x0d010401, 0x24000028 }, - { 0x0d010402, 0x24000028 }, - { 0x0d010403, 0x24000028 }, - { 0x0d010404, 0x24000028 }, - { 0x0d010405, 0x24000028 }, - { 0x0d010406, 0x24000028 }, - { 0x0d010407, 0x24000028 }, - { 0x0d010408, 0x24000028 }, - { 0x0d010409, 0x24000028 }, - { 0x0d01040a, 0x24000028 }, - { 0x0d01040b, 0x24000028 }, - { 0x0d01040c, 0x24000028 }, - { 0x0d01040d, 0x24000028 }, - { 0x0d01040e, 0x24000028 }, - { 0x0d01040f, 0x24000028 }, - { 0x0d010410, 0x24000028 }, - { 0x0d010411, 0x24000028 }, - { 0x0d010412, 0x24000028 }, - { 0x0d010413, 0x24000028 }, - { 0x0d010414, 0x24000028 }, - { 0x0d010415, 0x24000028 }, - { 0x0d010416, 0x24000028 }, - { 0x0d010417, 0x24000028 }, - { 0x0d010418, 0x24000028 }, - { 0x0d010419, 0x24000028 }, - { 0x0d01041a, 0x24000028 }, - { 0x0d01041b, 0x24000028 }, - { 0x0d01041c, 0x24000028 }, - { 0x0d01041d, 0x24000028 }, - { 0x0d01041e, 0x24000028 }, - { 0x0d01041f, 0x24000028 }, - { 0x0d010420, 0x24000028 }, - { 0x0d010421, 0x24000028 }, - { 0x0d010422, 0x24000028 }, - { 0x0d010423, 0x24000028 }, - { 0x0d010424, 0x24000028 }, - { 0x0d010425, 0x24000028 }, - { 0x0d010426, 0x24000028 }, - { 0x0d010427, 0x24000028 }, - { 0x0d010428, 0x1400ffd8 }, - { 0x0d010429, 0x1400ffd8 }, - { 0x0d01042a, 0x1400ffd8 }, - { 0x0d01042b, 0x1400ffd8 }, - { 0x0d01042c, 0x1400ffd8 }, - { 0x0d01042d, 0x1400ffd8 }, - { 0x0d01042e, 0x1400ffd8 }, - { 0x0d01042f, 0x1400ffd8 }, - { 0x0d010430, 0x1400ffd8 }, - { 0x0d010431, 0x1400ffd8 }, - { 0x0d010432, 0x1400ffd8 }, - { 0x0d010433, 0x1400ffd8 }, - { 0x0d010434, 0x1400ffd8 }, - { 0x0d010435, 0x1400ffd8 }, - { 0x0d010436, 0x1400ffd8 }, - { 0x0d010437, 0x1400ffd8 }, - { 0x0d010438, 0x1400ffd8 }, - { 0x0d010439, 0x1400ffd8 }, - { 0x0d01043a, 0x1400ffd8 }, - { 0x0d01043b, 0x1400ffd8 }, - { 0x0d01043c, 0x1400ffd8 }, - { 0x0d01043d, 0x1400ffd8 }, - { 0x0d01043e, 0x1400ffd8 }, - { 0x0d01043f, 0x1400ffd8 }, - { 0x0d010440, 0x1400ffd8 }, - { 0x0d010441, 0x1400ffd8 }, - { 0x0d010442, 0x1400ffd8 }, - { 0x0d010443, 0x1400ffd8 }, - { 0x0d010444, 0x1400ffd8 }, - { 0x0d010445, 0x1400ffd8 }, - { 0x0d010446, 0x1400ffd8 }, - { 0x0d010447, 0x1400ffd8 }, - { 0x0d010448, 0x1400ffd8 }, - { 0x0d010449, 0x1400ffd8 }, - { 0x0d01044a, 0x1400ffd8 }, - { 0x0d01044b, 0x1400ffd8 }, - { 0x0d01044c, 0x1400ffd8 }, - { 0x0d01044d, 0x1400ffd8 }, - { 0x0d01044e, 0x1400ffd8 }, - { 0x0d01044f, 0x1400ffd8 }, - { 0x2e810450, 0x1c00004d }, - { 0x2c8104a0, 0x34000009 }, - { 0x0b810800, 0x1c000005 }, - { 0x0b010808, 0x1c000000 }, - { 0x0b81080a, 0x1c00002b }, - { 0x0b810837, 0x1c000001 }, - { 0x0b01083c, 0x1c000000 }, - { 0x0b01083f, 0x1c000000 }, - { 0x41810900, 0x1c000015 }, - { 0x41810916, 0x3c000003 }, - { 0x4101091f, 0x54000000 }, - { 0x1e010a00, 0x1c000000 }, - { 0x1e810a01, 0x30000002 }, - { 0x1e810a05, 0x30000001 }, - { 0x1e810a0c, 0x30000003 }, - { 0x1e810a10, 0x1c000003 }, - { 0x1e810a15, 0x1c000002 }, - { 0x1e810a19, 0x1c00001a }, - { 0x1e810a38, 0x30000002 }, - { 0x1e010a3f, 0x30000000 }, - { 0x1e810a40, 0x3c000007 }, - { 0x1e810a50, 0x54000008 }, - { 0x3e812000, 0x1c00036e }, - { 0x3e812400, 0x38000062 }, - { 0x3e812470, 0x54000003 }, - { 0x0981d000, 0x680000f5 }, - { 0x0981d100, 0x68000026 }, - { 0x0981d12a, 0x6800003a }, - { 0x0981d165, 0x28000001 }, - { 0x1b81d167, 0x30000002 }, - { 0x0981d16a, 0x68000002 }, - { 0x0981d16d, 0x28000005 }, - { 0x0981d173, 0x04000007 }, - { 0x1b81d17b, 0x30000007 }, - { 0x0981d183, 0x68000001 }, - { 0x1b81d185, 0x30000006 }, - { 0x0981d18c, 0x6800001d }, - { 0x1b81d1aa, 0x30000003 }, - { 0x0981d1ae, 0x6800002f }, - { 0x1381d200, 0x68000041 }, - { 0x1381d242, 0x30000002 }, - { 0x1301d245, 0x68000000 }, - { 0x0981d300, 0x68000056 }, - { 0x0981d360, 0x3c000011 }, - { 0x0981d400, 0x24000019 }, - { 0x0981d41a, 0x14000019 }, - { 0x0981d434, 0x24000019 }, - { 0x0981d44e, 0x14000006 }, - { 0x0981d456, 0x14000011 }, - { 0x0981d468, 0x24000019 }, - { 0x0981d482, 0x14000019 }, - { 0x0901d49c, 0x24000000 }, - { 0x0981d49e, 0x24000001 }, - { 0x0901d4a2, 0x24000000 }, - { 0x0981d4a5, 0x24000001 }, - { 0x0981d4a9, 0x24000003 }, - { 0x0981d4ae, 0x24000007 }, - { 0x0981d4b6, 0x14000003 }, - { 0x0901d4bb, 0x14000000 }, - { 0x0981d4bd, 0x14000006 }, - { 0x0981d4c5, 0x1400000a }, - { 0x0981d4d0, 0x24000019 }, - { 0x0981d4ea, 0x14000019 }, - { 0x0981d504, 0x24000001 }, - { 0x0981d507, 0x24000003 }, - { 0x0981d50d, 0x24000007 }, - { 0x0981d516, 0x24000006 }, - { 0x0981d51e, 0x14000019 }, - { 0x0981d538, 0x24000001 }, - { 0x0981d53b, 0x24000003 }, - { 0x0981d540, 0x24000004 }, - { 0x0901d546, 0x24000000 }, - { 0x0981d54a, 0x24000006 }, - { 0x0981d552, 0x14000019 }, - { 0x0981d56c, 0x24000019 }, - { 0x0981d586, 0x14000019 }, - { 0x0981d5a0, 0x24000019 }, - { 0x0981d5ba, 0x14000019 }, - { 0x0981d5d4, 0x24000019 }, - { 0x0981d5ee, 0x14000019 }, - { 0x0981d608, 0x24000019 }, - { 0x0981d622, 0x14000019 }, - { 0x0981d63c, 0x24000019 }, - { 0x0981d656, 0x14000019 }, - { 0x0981d670, 0x24000019 }, - { 0x0981d68a, 0x1400001b }, - { 0x0981d6a8, 0x24000018 }, - { 0x0901d6c1, 0x64000000 }, - { 0x0981d6c2, 0x14000018 }, - { 0x0901d6db, 0x64000000 }, - { 0x0981d6dc, 0x14000005 }, - { 0x0981d6e2, 0x24000018 }, - { 0x0901d6fb, 0x64000000 }, - { 0x0981d6fc, 0x14000018 }, - { 0x0901d715, 0x64000000 }, - { 0x0981d716, 0x14000005 }, - { 0x0981d71c, 0x24000018 }, - { 0x0901d735, 0x64000000 }, - { 0x0981d736, 0x14000018 }, - { 0x0901d74f, 0x64000000 }, - { 0x0981d750, 0x14000005 }, - { 0x0981d756, 0x24000018 }, - { 0x0901d76f, 0x64000000 }, - { 0x0981d770, 0x14000018 }, - { 0x0901d789, 0x64000000 }, - { 0x0981d78a, 0x14000005 }, - { 0x0981d790, 0x24000018 }, - { 0x0901d7a9, 0x64000000 }, - { 0x0981d7aa, 0x14000018 }, - { 0x0901d7c3, 0x64000000 }, - { 0x0981d7c4, 0x14000005 }, - { 0x0901d7ca, 0x24000000 }, - { 0x0901d7cb, 0x14000000 }, - { 0x0981d7ce, 0x34000031 }, - { 0x16820000, 0x1c00a6d6 }, - { 0x1682f800, 0x1c00021d }, - { 0x090e0001, 0x04000000 }, - { 0x098e0020, 0x0400005f }, - { 0x1b8e0100, 0x300000ef }, - { 0x098f0000, 0x0c00fffd }, - { 0x09900000, 0x0c00fffd }, -}; diff --git a/src/plugins/PamAuth/Makefile b/src/plugins/PamAuth/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/PamAuth/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/PamAuth/Makefile.inc b/src/plugins/PamAuth/Makefile.inc deleted file mode 100644 index 8acd72a..0000000 --- a/src/plugins/PamAuth/Makefile.inc +++ /dev/null @@ -1,7 +0,0 @@ -all: $(BUILDDIR)pamauth$(DLSUFFICS) - -pamauth$(OBJSUFFICS): pamauth.c - $(CC) $(DCFLAGS) $(CFLAGS) pamauth.c - -$(BUILDDIR)pamauth$(DLSUFFICS): pamauth$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)pamauth$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) $(LIBSPREFIX)pam$(LIBSSUFFIX) pamauth$(OBJSUFFICS) diff --git a/src/plugins/PamAuth/PAMAUTH.TXT b/src/plugins/PamAuth/PAMAUTH.TXT deleted file mode 100644 index 82b5bf4..0000000 --- a/src/plugins/PamAuth/PAMAUTH.TXT +++ /dev/null @@ -1,30 +0,0 @@ -рМБЗЙО PAM БЧФПТЙЪБГЙЙ ДМС 3proxy (пу *NIX) -(c) Kirill Lopuchov lopuchov@mail.ru - - - пРЙУБОЙЕ -тБВПФБЕФ ФПМШЛП ОБ *NIX УЙУФЕНБИ . тБВПФПУРПУПВОПУФШ РТПЧЕТСМБУШ ОБ -freebsd 5.2 Й Linux Debian 4. - - - оБУФТПКЛБ PAM - -оБУФТБЙЧБЕН PAM УЕТЧЙУ ДМС 3proxy ОБ РТЙНЕТЕ ДМС Linux debian 4 , УПЪДБЕН ЖБКМ -/etc/pam.d/3proxy. рТПРЙУЩЧБЕН Ч ОЕН УМЕДХАЭХА УФТПЛХ - -@include common-auth - оБУФТПКЛБ РМБЗЙОБ - -----------------------------3proxy.cfg------------------------------- -# start - ЙНС РТПГЕДХТЩ ЙОЙГЙБМЙЪБГЙЙ РМБЗЙОБ -# 3proxy - ЙНС УЕТЧЙУБ PAM - -plugin "pamauth.so" start 3proxy - -# ТЕЛПНЕОДХЕФУС ЧЛМАЮБФШ ЛЕЫЙТПЧБОЙЕ БЧФПТЙЪБГЙЙ -authcache user,password 60 -auth cache pam -allow * -proxy -p3128 - -----------------------------3proxy.cfg------------------------------- \ No newline at end of file diff --git a/src/plugins/PamAuth/pamauth.c b/src/plugins/PamAuth/pamauth.c deleted file mode 100644 index 4e182c6..0000000 --- a/src/plugins/PamAuth/pamauth.c +++ /dev/null @@ -1,140 +0,0 @@ -/* plugin for 3proxy with PAM auth only for *NIX (linux,*bsd) -Kirill Lopuchov - - Compile with: gcc -shared -o pamauth.so pamauth.c -lpam -DNOODBC -*/ - -#include "../../structures.h" -#include -#include -#include -#include -#include - - - - -static int already_loaded = 0; - -static struct auth pamauth; -#ifdef USERCASE -static int usercaselow = 0; -#endif -static unsigned char *service=NULL; -static struct pluginlink * pl; - - - - -static char *password = NULL; - - -static int password_conversation ( int num_msg, const struct pam_message **msg, - struct pam_response **resp, - void *appdata_ptr) - { - if (num_msg != 1 || msg[0]->msg_style != PAM_PROMPT_ECHO_OFF) - { - return PAM_CONV_ERR; - } - if (!appdata_ptr) appdata_ptr = password; - if (!appdata_ptr) - { - return PAM_CONV_ERR; - } - *resp = calloc (num_msg, sizeof (struct pam_response)); - if (!*resp) - { - return PAM_CONV_ERR; - } - (*resp)[0].resp = strdup ((char *) appdata_ptr); - (*resp)[0].resp_retcode = 0; - return ((*resp)[0].resp ? PAM_SUCCESS : PAM_CONV_ERR); - } - -#ifdef USERCASE -static void lower (char *string) -{ - int length, i; - - length = strlen(string); - for (i=0; iusername || !param->password) return 4; - /*if(strlen(param->password)==0) return 4;*/ - - #ifdef USERCASE - if (usercaselow > 0) - { lower(param->username); } - #endif - - /*start process auth */ - conv.appdata_ptr = (char *) param->password; - - if (!pamh) - { - retval = pam_start ((char *)service, "3proxy@" , &conv, &pamh); - } - if (retval == PAM_SUCCESS) - retval = pam_set_item (pamh, PAM_USER, param->username); -/*fprintf(stderr,"pam_set_item1 rc=%d\n",retval);*/ - if (retval == PAM_SUCCESS) - retval = pam_set_item (pamh, PAM_CONV, &conv); -/*fprintf(stderr,"pam_set_item2 rc=%d\n",retval); */ - if (retval == PAM_SUCCESS) - retval = pam_authenticate (pamh, 0); -/*fprintf(stderr,"pam_authenticate rc=%d\n",retval);*/ - - if (retval == PAM_SUCCESS) { /*auth OK*/ rc=0; } - else { /*auth ERR*/ rc=5; } - - if (pamh) - retval = pam_end (pamh, retval); - if (retval != PAM_SUCCESS) - { pamh = NULL; } - - return rc; - -} - -/*------------------------------- MAIN -------------------------------------- - start plugin init */ -int start(struct pluginlink * pluginlink, int argc, unsigned char** argv) -{ - - - if(argc < 2) return 1; - pl = pluginlink; - if(service) pl->myfree(service); - service=(unsigned char *)pl->mystrdup((char *)argv[1]); - - if (already_loaded) { return (0); } - - already_loaded = 1; - - pamauth.authenticate = pamfunc; - pamauth.authorize = pluginlink->checkACL; - pamauth.desc = "pam"; - pamauth.next = pluginlink->authfuncs->next; - pluginlink->authfuncs->next = &pamauth; - - return 0; -} diff --git a/src/plugins/SSLPlugin/Makefile b/src/plugins/SSLPlugin/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/SSLPlugin/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/SSLPlugin/Makefile.inc b/src/plugins/SSLPlugin/Makefile.inc deleted file mode 100644 index 1afc984..0000000 --- a/src/plugins/SSLPlugin/Makefile.inc +++ /dev/null @@ -1,14 +0,0 @@ -all: $(BUILDDIR)SSLPlugin$(DLSUFFICS) - - - -ssl_plugin$(OBJSUFFICS): ssl_plugin.c - $(CC) $(DCFLAGS) $(CFLAGS) ssl_plugin.c - -my_ssl$(OBJSUFFICS): my_ssl.c - $(CC) $(DCFLAGS) $(CFLAGS) my_ssl.c - - -$(BUILDDIR)SSLPlugin$(DLSUFFICS): ssl_plugin$(OBJSUFFICS) my_ssl$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)SSLPlugin$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) ssl_plugin$(OBJSUFFICS) my_ssl$(OBJSUFFICS) $(LIBS) - \ No newline at end of file diff --git a/src/plugins/SSLPlugin/my_ssl.c b/src/plugins/SSLPlugin/my_ssl.c deleted file mode 100644 index 1590cc4..0000000 --- a/src/plugins/SSLPlugin/my_ssl.c +++ /dev/null @@ -1,474 +0,0 @@ - -#define _CRT_SECURE_NO_WARNINGS - -#include "../../structures.h" -#include -#include -#ifndef _WIN32 -#include -#endif - -#include -#include -#include -#include -#include -#include - -#include "../../proxy.h" -#include "my_ssl.h" - - - - -typedef struct _ssl_conn { - SSL_CTX *ctx; - SSL *ssl; -} ssl_conn; - -static X509 *CA_cert = NULL; -static EVP_PKEY *CA_key = NULL; -static EVP_PKEY *server_key = NULL; -static X509_NAME *name = NULL; - -pthread_mutex_t ssl_file_mutex; - - -static char errbuf[256]; - -static char hexMap[] = { - '0', '1', '2', '3', '4', '5', '6', '7', - '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' - }; - -static BIO *bio_err=NULL; - - -static size_t bin2hex (const unsigned char* bin, size_t bin_length, char* str, size_t str_length) -{ - char *p; - size_t i; - - if ( str_length < ( bin_length+1) ) - return 0; - - p = str; - for ( i=0; i < bin_length; ++i ) - { - *p++ = hexMap[*bin >> 4]; - *p++ = hexMap[*bin & 0xf]; - ++bin; - } - - *p = 0; - - return p - str; -} - -static int add_ext(X509 *cert, int nid, char *value) -{ - X509_EXTENSION *ex; - X509V3_CTX ctx; - /* This sets the 'context' of the extensions. */ - /* No configuration database */ - X509V3_set_ctx_nodb(&ctx); - /* Issuer and subject certs: both the target since it is self signed, - * no request and no CRL - */ - X509V3_set_ctx(&ctx, cert, cert, NULL, NULL, 0); - ex = X509V3_EXT_conf_nid(NULL, &ctx, nid, value); - if (!ex) - return 0; - - X509_add_ext(cert,ex,-1); - X509_EXTENSION_free(ex); - return 1; -} - -extern char *cert_path; - -void del_ext(X509 *dst_cert, int nid, int where){ - int ex; - - ex = X509_get_ext_by_NID(dst_cert, nid, where); - if(ex>=0){ - X509_EXTENSION *ext; - if((ext = X509_delete_ext(dst_cert, ex))) X509_EXTENSION_free(ext); - } - -} - -SSL_CERT ssl_copy_cert(SSL_CERT cert) -{ - int err = -1; - FILE *fcache; - X509 *src_cert = (X509 *) cert; - X509 *dst_cert = NULL; - - EVP_PKEY *pk = NULL; - RSA *rsa = NULL; - - unsigned char p1[] = "RU"; - unsigned char p2[] = "3proxy"; - unsigned char p3[] = "3proxy CA"; - - static char hash_name[sizeof(src_cert->sha1_hash)*2 + 1]; - static char cache_name[200]; - - bin2hex(src_cert->sha1_hash, sizeof(src_cert->sha1_hash), hash_name, sizeof(hash_name)); - sprintf(cache_name, "%s%s.pem", cert_path, hash_name); - /* check if certificate is already cached */ - fcache = fopen(cache_name, "rb"); - if ( fcache != NULL ) { -#ifndef _WIN32 - flock(fileno(fcache), LOCK_SH); -#endif - dst_cert = PEM_read_X509(fcache, &dst_cert, NULL, NULL); -#ifndef _WIN32 - flock(fileno(fcache), LOCK_UN); -#endif - fclose(fcache); - if ( dst_cert != NULL ){ - return dst_cert; - } - } - - /* proceed if certificate is not cached */ - dst_cert = X509_dup(src_cert); - if ( dst_cert == NULL ) { - return NULL; - } - del_ext(dst_cert, NID_crl_distribution_points, -1); - del_ext(dst_cert, NID_info_access, -1); - del_ext(dst_cert, NID_authority_key_identifier, -1); - del_ext(dst_cert, NID_certificate_policies, 0); - - err = X509_set_pubkey(dst_cert, server_key); - if ( err == 0 ) { - X509_free(dst_cert); - return NULL; - } - - - /* Its self signed so set the issuer name to be the same as the - * subject. - */ - err = X509_set_issuer_name(dst_cert, name); - if(!err){ - X509_free(dst_cert); - return NULL; - } - err = X509_digest(dst_cert, EVP_sha1(), dst_cert->sha1_hash, NULL); - if(!err){ - X509_free(dst_cert); - return NULL; - } - err = X509_sign(dst_cert, CA_key, EVP_sha1()); - if(!err){ - X509_free(dst_cert); - return NULL; - } - - /* write to cache */ - - fcache = fopen(cache_name, "wb"); - if ( fcache != NULL ) { -#ifndef _WIN32 - flock(fileno(fcache), LOCK_EX); -#endif - PEM_write_X509(fcache, dst_cert); -#ifndef _WIN32 - flock(fileno(fcache), LOCK_UN); -#endif - fclose(fcache); - } - return dst_cert; -} - - -SSL_CONN ssl_handshake_to_server(SOCKET s, char * hostname, SSL_CERT *server_cert, char **errSSL) -{ - int err = 0; - X509 *cert; - ssl_conn *conn; - - *errSSL = NULL; - - conn = (ssl_conn *)malloc(sizeof(ssl_conn)); - if ( conn == NULL ){ - return NULL; - } - - conn->ctx = SSL_CTX_new(SSLv23_client_method()); - if ( conn->ctx == NULL ) { - free(conn); - return NULL; - } - - conn->ssl = SSL_new(conn->ctx); - if ( conn->ssl == NULL ) { - SSL_CTX_free(conn->ctx); - free(conn); - return NULL; - } - - if(!SSL_set_fd(conn->ssl, s)){ - ssl_conn_free(conn); - return NULL; - } - if(hostname && *hostname)SSL_set_tlsext_host_name(conn->ssl, hostname); - err = SSL_connect(conn->ssl); - if ( err == -1 ) { - *errSSL = ERR_error_string(ERR_get_error(), errbuf); - ssl_conn_free(conn); - return NULL; - } - - cert = SSL_get_peer_certificate(conn->ssl); - if(!cert) { - ssl_conn_free(conn); - return NULL; - } - - /* TODO: Verify certificate */ - - *server_cert = cert; - - return conn; -} - -SSL_CONN ssl_handshake_to_client(SOCKET s, SSL_CERT server_cert, char** errSSL) -{ - int err = 0; - X509 *cert; - ssl_conn *conn; - - *errSSL = NULL; - - conn = (ssl_conn *)malloc(sizeof(ssl_conn)); - if ( conn == NULL ) - return NULL; - - conn->ctx = SSL_CTX_new(SSLv23_server_method()); - if ( conn->ctx == NULL ) { - free(conn); - return NULL; - } - - err = SSL_CTX_use_certificate(conn->ctx, (X509 *) server_cert); - if ( err <= 0 ) { - SSL_CTX_free(conn->ctx); - free(conn); - return NULL; - } - - err = SSL_CTX_use_PrivateKey(conn->ctx, server_key); - if ( err <= 0 ) { - SSL_CTX_free(conn->ctx); - free(conn); - return NULL; - } -/* - err = SSL_CTX_load_verify_locations(conn->ctx, "3proxy.pem", - NULL); - if ( err <= 0 ) { - SSL_CTX_free(conn->ctx); - free(conn); - return NULL; - } -*/ - - conn->ssl = SSL_new(conn->ctx); - if ( conn->ssl == NULL ) { - SSL_CTX_free(conn->ctx); - free(conn); - return NULL; - } - - SSL_set_fd(conn->ssl, (int)s); - err = SSL_accept(conn->ssl); - if ( err <= 0 ) { - *errSSL = ERR_error_string(ERR_get_error(), errbuf); - ssl_conn_free(conn); - return NULL; - } - - // - // client certificate - // TODO: is it required? - // - cert = SSL_get_peer_certificate(conn->ssl); - - if ( cert != NULL ) - X509_free(cert); - - return conn; -} - -int ssl_read(SSL_CONN connection, void * buf, int bufsize) -{ - ssl_conn *conn = (ssl_conn *) connection; - - return SSL_read(conn->ssl, buf, bufsize); -} - -int ssl_write(SSL_CONN connection, void * buf, int bufsize) -{ - ssl_conn *conn = (ssl_conn *) connection; - - return SSL_write(conn->ssl, buf, bufsize); -} -int ssl_pending(SSL_CONN connection) -{ - ssl_conn *conn = (ssl_conn *) connection; - - return SSL_pending(conn->ssl); -} - -void ssl_conn_free(SSL_CONN connection) -{ - ssl_conn *conn = (ssl_conn *) connection; - - if(conn){ - if(conn->ssl){ - SSL_shutdown(conn->ssl); - SSL_free(conn->ssl); - } - if(conn->ctx) SSL_CTX_free(conn->ctx); - free(conn); - } -} - -void _ssl_cert_free(SSL_CERT cert) -{ - X509_free((X509 *)cert); -} - - - -/* This array will store all of the mutexes available to OpenSSL. */ -static pthread_mutex_t *mutex_buf= NULL; - - -static void locking_function(int mode, int n, const char * file, int line) -{ - if (mode & CRYPTO_LOCK) - pthread_mutex_lock(mutex_buf + n); - else - pthread_mutex_unlock(mutex_buf + n); -} - -static unsigned long id_function(void) -{ -#ifdef _WIN32 - return ((unsigned long)GetCurrentThreadId()); -#else - return ((unsigned long)pthread_self()); -#endif -} - -int thread_setup(void) -{ - int i; - - mutex_buf = malloc(CRYPTO_num_locks( ) * sizeof(pthread_mutex_t)); - if (!mutex_buf) - return 0; - for (i = 0; i < CRYPTO_num_locks( ); i++) - pthread_mutex_init(mutex_buf +i, NULL); - CRYPTO_set_id_callback(id_function); - CRYPTO_set_locking_callback(locking_function); - return 1; -} - -int thread_cleanup(void) -{ - int i; - - if (!mutex_buf) - return 0; - CRYPTO_set_id_callback(NULL); - CRYPTO_set_locking_callback(NULL); - for (i = 0; i < CRYPTO_num_locks( ); i++) - pthread_mutex_destroy(mutex_buf +i); - free(mutex_buf); - mutex_buf = NULL; - return 1; -} - - - -int ssl_file_init = 0; - - -void ssl_init(void) -{ - FILE *f; - static char fname[200]; - - if(!ssl_file_init++)pthread_mutex_init(&ssl_file_mutex, NULL); - - pthread_mutex_lock(&ssl_file_mutex); - thread_setup(); - - SSLeay_add_ssl_algorithms(); - SSL_load_error_strings(); - - sprintf(fname, "%.128s3proxy.pem", cert_path); - f = fopen(fname, "r"); - if ( f != NULL ) { - PEM_read_X509(f, &CA_cert, NULL, NULL); - fclose(f); - } - else { - fprintf(stderr, "failed to open: %s\n", fname); - } - name = X509_get_subject_name(CA_cert); - - sprintf(fname, "%.128s3proxy.key", cert_path); - f = fopen(fname, "rb"); - if ( f != NULL ) { - CA_key = PEM_read_PrivateKey(f, &CA_key, NULL, NULL); - fclose(f); - } - else { - fprintf(stderr, "failed to open: %s\n", fname); - } - - sprintf(fname, "%.128sserver.key", cert_path); - f = fopen(fname, "rb"); - if ( f != NULL ) { - server_key = PEM_read_PrivateKey(f, &server_key, NULL, NULL); - fclose(f); - } - else { - fprintf(stderr, "failed to open: %s\n", fname); - } - if(!CA_cert || !CA_key || !server_key){ - fprintf(stderr, "failed to init SSL certificate / keys\n"); - } - - bio_err=BIO_new_fp(stderr,BIO_NOCLOSE); - pthread_mutex_unlock(&ssl_file_mutex); -} - -void ssl_release(void) -{ - pthread_mutex_lock(&ssl_file_mutex); - if ( CA_cert != NULL ) { - X509_free(CA_cert); - CA_cert = NULL; - } - - if ( CA_key != NULL ) { - EVP_PKEY_free(CA_key); - CA_key = NULL; - } - - if ( server_key != NULL ) { - EVP_PKEY_free(server_key); - server_key = NULL; - } - thread_cleanup(); - pthread_mutex_unlock(&ssl_file_mutex); -} diff --git a/src/plugins/SSLPlugin/my_ssl.h b/src/plugins/SSLPlugin/my_ssl.h deleted file mode 100644 index 8a89e9e..0000000 --- a/src/plugins/SSLPlugin/my_ssl.h +++ /dev/null @@ -1,43 +0,0 @@ -#ifndef __my_ssl_h__ -#define __my_ssl_h__ - -// -// opaque connection structure -// -typedef void *SSL_CONN; -// -// opaque certificate structure -// -typedef void *SSL_CERT; - -// -// Create copy of certificate signed by "other" CA -// -SSL_CERT ssl_copy_cert(SSL_CERT cert); - -// -// SSL/TLS handshakes -// -SSL_CONN ssl_handshake_to_server(SOCKET s, char * hostname, SSL_CERT *server_cert, char **errSSL); -SSL_CONN ssl_handshake_to_client(SOCKET s, SSL_CERT server_cert, char **errSSL); - -// -// SSL/TLS Read/Write -// -int ssl_read(SSL_CONN connection, void * buf, int bufsize); -int ssl_write(SSL_CONN connection, void * buf, int bufsize); -int ssl_pending(SSL_CONN connection); - -// -// Release of opaque structures -// -void ssl_conn_free(SSL_CONN connection); -void _ssl_cert_free(SSL_CERT cert); - -// -// Global (de)initialization -// -void ssl_init(void); -void ssl_release(void); - -#endif // __my_ssl_h__ \ No newline at end of file diff --git a/src/plugins/SSLPlugin/ssl_plugin.c b/src/plugins/SSLPlugin/ssl_plugin.c deleted file mode 100644 index 0214f5a..0000000 --- a/src/plugins/SSLPlugin/ssl_plugin.c +++ /dev/null @@ -1,414 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2007-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "../../structures.h" -#include /* SSLeay stuff */ -#include -#include -#include -#include -#include "../../proxy.h" -#include "my_ssl.h" - -#ifndef _WIN32 -#define WINAPI -#endif - -#ifdef __cplusplus -extern "C" { -#endif - -#ifndef isnumber -#define isnumber(i_n_arg) ((i_n_arg>='0')&&(i_n_arg<='9')) -#endif - -PROXYFUNC tcppmfunc, proxyfunc, smtppfunc, ftpprfunc; - -static struct pluginlink * pl; - -pthread_mutex_t ssl_mutex; - -static int ssl_loaded = 0; -static int ssl_connect_timeout = 0; -char *cert_path = ""; - -typedef struct _ssl_conn { - struct SSL_CTX *ctx; - struct SSL *ssl; -} ssl_conn; - -struct SSLqueue { - struct SSLqueue *next; - SOCKET s; - SSL_CERT cert; - SSL_CONN conn; - struct clientparam* param; -} *SSLq = NULL; - - -/* - TO DO: use hashtable -*/ -static struct SSLqueue *searchSSL(SOCKET s){ - struct SSLqueue *sslq = NULL; - pthread_mutex_lock(&ssl_mutex); - for(sslq = SSLq; sslq; sslq = sslq->next) - if(sslq->s == s) break; - pthread_mutex_unlock(&ssl_mutex); - return sslq; -} - -static void addSSL(SOCKET s, SSL_CERT cert, SSL_CONN conn, struct clientparam* param){ - struct SSLqueue *sslq; - sslq = (struct SSLqueue *) malloc(sizeof(struct SSLqueue)); - sslq->s = s; - sslq->cert = cert; - sslq->conn = conn; - pthread_mutex_lock(&ssl_mutex); - sslq->next = SSLq; - sslq->param = param; - SSLq = sslq; - pthread_mutex_unlock(&ssl_mutex); -} - -int delSSL(SOCKET s){ - struct SSLqueue *sqi, *sqt = NULL; - if(!SSLq) return 0; - pthread_mutex_lock(&ssl_mutex); - if(SSLq){ - if(SSLq->s == s){ - sqt = SSLq; - SSLq = SSLq->next; - } - else for(sqi = SSLq; sqi->next; sqi = sqi->next){ - if (sqi->next->s == s){ - sqt = sqi->next; - sqi->next = sqt->next; - break; - } - } - } - pthread_mutex_unlock(&ssl_mutex); - if(sqt) { - _ssl_cert_free(sqt->cert); - ssl_conn_free(sqt->conn); - free(sqt); - return 1; - } - return 0; -} - -struct sockfuncs sso; - -#ifdef _WIN32 -static int WINAPI ssl_send(SOCKET s, const void *msg, int len, int flags){ -#else -static int ssl_send(SOCKET s, const void *msg, size_t len, int flags){ -#endif - struct SSLqueue *sslq; - - if ((sslq = searchSSL(s))){ - int i=0, res, err; - do { - if((res = ssl_write(sslq->conn, (void *)msg, len)) < 0) { - err = SSL_get_error((SSL *)((ssl_conn*)sslq->conn)->ssl, res); - usleep(10*SLEEPTIME); - } - } while (res < 0 && (err == SSL_ERROR_WANT_READ || err == SSL_ERROR_WANT_WRITE) && ++i < 100); - return res; - } - - return sso._send(s, msg, len, flags); -} - - -#ifdef _WIN32 -static int WINAPI ssl_sendto(SOCKET s, const void *msg, int len, int flags, const struct sockaddr *to, int tolen){ -#else -static int ssl_sendto(SOCKET s, const void *msg, size_t len, int flags, const struct sockaddr *to, SASIZETYPE tolen){ -#endif - struct SSLqueue *sslq; - - if ((sslq = searchSSL(s))){ - int i=0, res, err; - do { - if((res = ssl_write(sslq->conn, (void *)msg, len)) < 0) { - err = SSL_get_error((SSL *)((ssl_conn*)sslq->conn)->ssl, res); - usleep(10*SLEEPTIME); - } - } while (res < 0 && (err == SSL_ERROR_WANT_READ || err == SSL_ERROR_WANT_WRITE) && ++i < 100); - return res; - } - - return sso._sendto(s, msg, len, flags, to, tolen); -} - -#ifdef _WIN32 -static int WINAPI ssl_recvfrom(SOCKET s, void *msg, int len, int flags, struct sockaddr *from, int *fromlen){ -#else -static int ssl_recvfrom(SOCKET s, void *msg, size_t len, int flags, struct sockaddr *from, SASIZETYPE *fromlen){ -#endif - struct SSLqueue *sslq; - - if ((sslq = searchSSL(s))){ - int i=0, res, err; - do { - if((res = ssl_read(sslq->conn, (void *)msg, len)) < 0) { - err = SSL_get_error((SSL *)((ssl_conn*)sslq->conn)->ssl, res); - usleep(10*SLEEPTIME); - } - } while (res < 0 && (err == SSL_ERROR_WANT_READ || err == SSL_ERROR_WANT_WRITE) && ++i < 100); - return res; - } - - return sso._recvfrom(s, msg, len, flags, from, fromlen); -} - -#ifdef _WIN32 -static int WINAPI ssl_recv(SOCKET s, void *msg, int len, int flags){ -#else -static int WINAPI ssl_recv(SOCKET s, void *msg, size_t len, int flags){ -#endif - struct SSLqueue *sslq; - - if ((sslq = searchSSL(s))){ - int i=0, res, err; - do { - if((res = ssl_read(sslq->conn, (void *)msg, len)) < 0) { - err = SSL_get_error((SSL *)((ssl_conn*)sslq->conn)->ssl, res); - usleep(10*SLEEPTIME); - } - } while (res < 0 && (err == SSL_ERROR_WANT_READ || err == SSL_ERROR_WANT_WRITE) && ++i < 100); - return res; - } - - return sso._recv(s, msg, len, flags); -} - -static int WINAPI ssl_closesocket(SOCKET s){ - delSSL(s); - return sso._closesocket(s); -} - -static int WINAPI ssl_poll(struct pollfd *fds, unsigned int nfds, int timeout){ - struct SSLqueue *sslq = NULL; - unsigned int i; - int ret = 0; - for(i = 0; i < nfds; i++){ - if((fds[i].events & POLLIN) && (sslq = searchSSL(fds[i].fd)) && ssl_pending(sslq->conn)){ - fds[i].revents = POLLIN; - ret++; - } - else fds[i].revents = 0; - } - if(ret) return ret; - - ret = sso._poll(fds, nfds, timeout); - return ret; -} - - -int dossl(struct clientparam* param, SSL_CONN* ServerConnp, SSL_CONN* ClientConnp){ - SSL_CERT ServerCert=NULL, FakeCert=NULL; - SSL_CONN ServerConn, ClientConn; - char *errSSL=NULL; - unsigned long ul; - -#ifdef _WIN32 - ul = 0; - ioctlsocket(param->remsock, FIONBIO, &ul); - ul = 0; - ioctlsocket(param->clisock, FIONBIO, &ul); -#else - fcntl(param->remsock,F_SETFL,0); - fcntl(param->clisock,F_SETFL,0); -#endif - - if(ssl_connect_timeout){ - ul = ((unsigned long)ssl_connect_timeout)*1000; - setsockopt(param->remsock, SOL_SOCKET, SO_RCVTIMEO, (char *)&ul, 4); - ul = ((unsigned long)ssl_connect_timeout)*1000; - setsockopt(param->remsock, SOL_SOCKET, SO_SNDTIMEO, (char *)&ul, 4); - } - ServerConn = ssl_handshake_to_server(param->remsock, (char *)param->hostname, &ServerCert, &errSSL); - if ( ServerConn == NULL || ServerCert == NULL ) { - param->res = 8011; - param->srv->logfunc(param, (unsigned char *)"SSL handshake to server failed"); - if(ServerConn == NULL) param->srv->logfunc(param, (unsigned char *)"ServerConn is NULL"); - if(ServerCert == NULL) param->srv->logfunc(param, (unsigned char *)"ServerCert is NULL"); - if(errSSL)param->srv->logfunc(param, (unsigned char *)errSSL); - return 1; - } - FakeCert = ssl_copy_cert(ServerCert); - if ( FakeCert == NULL ) { - param->res = 8012; - _ssl_cert_free(ServerCert); - param->srv->logfunc(param, (unsigned char *)"Failed to create certificate copy"); - ssl_conn_free(ServerConn); - return 2; - } - ClientConn = ssl_handshake_to_client(param->clisock, FakeCert, &errSSL); - if ( ClientConn == NULL ) { - param->res = 8012; - param->srv->logfunc(param, (unsigned char *)"Handshake to client failed"); - if(errSSL)param->srv->logfunc(param, (unsigned char *)errSSL); - _ssl_cert_free(ServerCert); - _ssl_cert_free(FakeCert); - ssl_conn_free(ServerConn); - return 3; - } - -#ifdef _WIN32 - ul = 1; - ioctlsocket(param->remsock, FIONBIO, &ul); - ul = 1; - ioctlsocket(param->clisock, FIONBIO, &ul); -#else - fcntl(param->remsock,F_SETFL,O_NONBLOCK); - fcntl(param->clisock,F_SETFL,O_NONBLOCK); -#endif - - - SSL_set_mode((SSL *)((ssl_conn *)ServerConn)->ssl, SSL_MODE_ENABLE_PARTIAL_WRITE|SSL_MODE_AUTO_RETRY); - SSL_set_mode((SSL *)((ssl_conn *)ClientConn)->ssl, SSL_MODE_ENABLE_PARTIAL_WRITE|SSL_MODE_AUTO_RETRY); - SSL_set_read_ahead((SSL *)((ssl_conn *)ServerConn)->ssl, 0); - SSL_set_read_ahead((SSL *)((ssl_conn *)ClientConn)->ssl, 0); - addSSL(param->remsock, ServerCert, ServerConn, param); - addSSL(param->clisock, FakeCert, ClientConn, param); - if(ServerConnp)*ServerConnp = ServerConn; - if(ClientConnp)*ClientConnp = ClientConn; - - - return 0; -} - - -static void* ssl_filter_open(void * idata, struct srvparam * param){ - return idata; -} - - - -static FILTER_ACTION ssl_filter_client(void *fo, struct clientparam * param, void** fc){ - return CONTINUE; -} - -static FILTER_ACTION ssl_filter_predata(void *fo, struct clientparam * param){ - if(param->operation != HTTP_CONNECT) return PASS; - if(dossl(param, NULL, NULL)) { - return REJECT; - } - param->redirectfunc = proxyfunc; - return HANDLED; -} - - -static void ssl_filter_clear(void *fo){ -} - -static void ssl_filter_close(void *fo){ -} - -static struct filter ssl_filter = { - NULL, - "ssl filter", - "ssl filter", - ssl_filter_open, - ssl_filter_client, - NULL, NULL, NULL, ssl_filter_predata, NULL, NULL, - ssl_filter_clear, - ssl_filter_close -}; - -int mitm = 0; -int ssl_inited = 0; - -static int h_mitm(int argc, unsigned char **argv){ - if(!ssl_inited) { - ssl_init(); - ssl_inited = 1; - } - if((mitm&1)) return 1; - if(mitm) usleep(100*SLEEPTIME); - ssl_filter.next = pl->conf->filters; - pl->conf->filters = &ssl_filter; - mitm++; - return 0; -} - -static int h_nomitm(int argc, unsigned char **argv){ - struct filter * sf; - if(!(mitm&1)) return 1; - if(mitm) usleep(100*SLEEPTIME); - if(pl->conf->filters == &ssl_filter) pl->conf->filters = ssl_filter.next; - else for(sf = pl->conf->filters; sf && sf->next; sf=sf->next){ - if(sf->next == &ssl_filter) { - sf->next = ssl_filter.next; - break; - } - } - mitm++; - return 0; -} - -static int h_certpath(int argc, unsigned char **argv){ - size_t len; - len = strlen(argv[1]); - if(!len || (argv[1][len - 1] != '/' && argv[1][len - 1] != '\\')) return 1; - if(cert_path && *cert_path) free(cert_path); - cert_path = strdup(argv[1]); - return 0; -} - -static struct commands ssl_commandhandlers[] = { - {ssl_commandhandlers+1, "ssl_mitm", h_mitm, 1, 1}, - {ssl_commandhandlers+2, "ssl_nomitm", h_nomitm, 1, 1}, - {NULL, "ssl_certcache", h_certpath, 2, 2}, -}; - - -#ifdef _WIN32 -__declspec(dllexport) -#endif - - int ssl_plugin (struct pluginlink * pluginlink, - int argc, char** argv){ - pl = pluginlink; - if(!ssl_loaded){ - ssl_loaded = 1; - pthread_mutex_init(&ssl_mutex, NULL); - memcpy(&sso, pl->so, sizeof(struct sockfuncs)); - pl->so->_send = ssl_send; - pl->so->_recv = ssl_recv; - pl->so->_sendto = ssl_sendto; - pl->so->_recvfrom = ssl_recvfrom; - pl->so->_closesocket = ssl_closesocket; - pl->so->_poll = ssl_poll; - ssl_commandhandlers[2].next = pl->commandhandlers->next; - pl->commandhandlers->next = ssl_commandhandlers; - } - else { - ssl_release(); - ssl_inited = 0; - } - - tcppmfunc = (PROXYFUNC)pl->findbyname("tcppm"); - if(!tcppmfunc){return 13;} - proxyfunc = (PROXYFUNC)pl->findbyname("proxy"); - if(!proxyfunc)proxyfunc = tcppmfunc; - smtppfunc = (PROXYFUNC)pl->findbyname("smtpp"); - if(!smtppfunc)smtppfunc = tcppmfunc; - ftpprfunc = (PROXYFUNC)pl->findbyname("ftppr"); - if(!ftpprfunc)ftpprfunc = tcppmfunc; - - return 0; - - } -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/StringsPlugin/Makefile b/src/plugins/StringsPlugin/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/StringsPlugin/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/StringsPlugin/Makefile.inc b/src/plugins/StringsPlugin/Makefile.inc deleted file mode 100644 index 0e43d46..0000000 --- a/src/plugins/StringsPlugin/Makefile.inc +++ /dev/null @@ -1,7 +0,0 @@ -all: $(BUILDDIR)StringsPlugin$(DLSUFFICS) - -StringsPlugin$(OBJSUFFICS): StringsPlugin.c - $(CC) $(DCFLAGS) $(CFLAGS) StringsPlugin.c - -$(BUILDDIR)StringsPlugin$(DLSUFFICS): StringsPlugin$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)StringsPlugin$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) StringsPlugin$(OBJSUFFICS) diff --git a/src/plugins/StringsPlugin/ReadMe.txt b/src/plugins/StringsPlugin/ReadMe.txt deleted file mode 100644 index 39d41c7..0000000 --- a/src/plugins/StringsPlugin/ReadMe.txt +++ /dev/null @@ -1,63 +0,0 @@ --------------------------windows-1251------------------------ -Плагин подменяющий строки в сервере 3proxу (ОС windows,unix) -(c) Lopuchov Kirill lopuchov@mail.ru - - 1. Краткое описание описание - - Используется для руссификации сообщений выдаваемых 3proxy. -Для корректной работы требуется последняя 0.6 версия 3proxy (в интерфейсе -plugin api которой появился job schedule ). Все сообщения были взяты из -дистрибутива 3proxy и вынесенны в отдельный файл. Пример файла rus-win1251.3ps. -Для каждого сервиса существуют свои блоки сообщений. Начало и конец блока -разделены , на пример для сервиса ADMIN начало "[--admin--]" конец [/--admin--]. -Сами сообщения отделены между собой строкой "[end]", новая строка определяется -строкой "\n" . - От версии к версии количество сообщений в 3proxy может менятся. -В этом случае необходимо либо добавить самостоятельно новые строки в -соответсвеющие блоки rus-win1251.3ps, или ждать обновления :) - - -Для компиляции и тестирования под ОС Windows использовался пакет Dev-C++ -http://www.bloodshed.net/dev/ -Для компиляции и тестирования под unix подобными использовался gcc - - -Настройка 3proxy ---------------------- - -plugin "string.dll" start c:\3proxy\rus-win1251.3ps - --------------------------windows-1251------------------------ - ----------------------------KOI8-R--------------------------- -рМБЗЙО РПДНЕОСАЭЙК УФТПЛЙ Ч УЕТЧЕТЕ 3proxХ (пу windows,unix) -(c) Lopuchov Kirill lopuchov@mail.ru - - 1. лТБФЛПЕ ПРЙУБОЙЕ ПРЙУБОЙЕ - - йУРПМШЪХЕФУС ДМС ТХУУЙЖЙЛБГЙЙ УППВЭЕОЙК ЧЩДБЧБЕНЩИ 3proxy. -дМС ЛПТТЕЛФОПК ТБВПФЩ ФТЕВХЕФУС РПУМЕДОСС 0.6 ЧЕТУЙС 3proxy (Ч ЙОФЕТЖЕКУЕ -plugin api ЛПФПТПК РПСЧЙМУС job schedule ). чУЕ УППВЭЕОЙС ВЩМЙ ЧЪСФЩ ЙЪ -ДЙУФТЙВХФЙЧБ 3proxy Й ЧЩОЕУЕООЩ Ч ПФДЕМШОЩК ЖБКМ. рТЙНЕТ ЖБКМБ rus-win1251.3ps. -дМС ЛБЦДПЗП УЕТЧЙУБ УХЭЕУФЧХАФ УЧПЙ ВМПЛЙ УППВЭЕОЙК. оБЮБМП Й ЛПОЕГ ВМПЛБ -ТБЪДЕМЕОЩ , ОБ РТЙНЕТ ДМС УЕТЧЙУБ ADMIN ОБЮБМП "[--admin--]" ЛПОЕГ [/--admin--]. -уБНЙ УППВЭЕОЙС ПФДЕМЕОЩ НЕЦДХ УПВПК УФТПЛПК "[end]", ОПЧБС УФТПЛБ ПРТЕДЕМСЕФУС -УФТПЛПК "\n" . - пФ ЧЕТУЙЙ Л ЧЕТУЙЙ ЛПМЙЮЕУФЧП УППВЭЕОЙК Ч 3proxy НПЦЕФ НЕОСФУС. -ч ЬФПН УМХЮБЕ ОЕПВИПДЙНП МЙВП ДПВБЧЙФШ УБНПУФПСФЕМШОП ОПЧЩЕ УФТПЛЙ Ч -УППФЧЕФУЧЕАЭЙЕ ВМПЛЙ rus-win1251.3ps, ЙМЙ ЦДБФШ ПВОПЧМЕОЙС :) - - -дМС ЛПНРЙМСГЙЙ Й ФЕУФЙТПЧБОЙС РПД пу Windows ЙУРПМШЪПЧБМУС РБЛЕФ Dev-C++ -http://www.bloodshed.net/dev/ -дМС ЛПНРЙМСГЙЙ Й ФЕУФЙТПЧБОЙС РПД unix РПДПВОЩНЙ ЙУРПМШЪПЧБМУС gcc - - -оБУФТПКЛБ 3proxy ---------------------- - -plugin "string.dll" start c:\3proxy\rus-win1251.3ps - ----------------------------KOI8-R--------------------------- - - diff --git a/src/plugins/StringsPlugin/StringsPlugin.c b/src/plugins/StringsPlugin/StringsPlugin.c deleted file mode 100644 index c6c7eb6..0000000 --- a/src/plugins/StringsPlugin/StringsPlugin.c +++ /dev/null @@ -1,254 +0,0 @@ -#include "../../structures.h" -#include -#include -#include -#include - - - -#ifdef __cplusplus -extern "C" { -#endif - -struct pluginlink * mypl; -int count_load_str_proxy_from_file=0,count_load_str_admin_from_file=0; -int count_str_proxy_in_3proxy=0,count_str_admin_in_3proxy=0; -char ** old_proxy_table=NULL; -char ** old_admin_table=NULL; -struct schedule myschedule; - - -char **load_string(FILE *f,int max_count_str, int *countloadstr, - char *start,char *stop,char **table_3proxy) -{ - int cstr=0,i=0; - char tmpbuf1[1024],*rstr,*pt=NULL,*p=NULL; - char **old_table; - - tmpbuf1[0]='\0'; - - fseek(f,0,SEEK_SET); - - /*find start service section*/ - while(!feof(f)) - { - fgets(tmpbuf1, 1023,f); - if ((strstr(tmpbuf1,start))!=NULL) { i++; break; } - tmpbuf1[0]='\0'; - } - - if (i==0){ - fprintf(stderr,"Error StringsPlugin: No start section %s strings! \n",start); - return NULL; - } - - - /*create table for old strings */ - old_table=(char **)mypl->myalloc(max_count_str*sizeof(char *)); - memset(old_table,0,max_count_str*sizeof(char *)); - - /*load from file new strings */ - i=0; - while ( !feof(f) || i< max_count_str) - { - fgets(tmpbuf1, 1023,f); - - if ((strstr(tmpbuf1,stop))!=NULL) { break; } - - if (strstr(tmpbuf1,"[end]")==NULL) - { - /* find and replace \n \r*/ - rstr = tmpbuf1; - while (*rstr!='\0') - { - if (*rstr=='\r' || *rstr=='\n' ) - { *rstr='\0'; rstr++; } - rstr++; - } - - while ((rstr=strstr(tmpbuf1,"\\n"))) - { - if (rstr!=NULL){ *rstr='\r'; rstr++; *rstr='\n'; } - } - - - /* add string */ - if (pt!=NULL) { cstr=cstr+(int)strlen(pt); } - - cstr=cstr+(int)strlen(tmpbuf1)+1; - - p = (char *)mypl->myalloc(cstr); - - if (pt!=NULL) - { - strcpy(p, pt); - strcat(p, tmpbuf1); - mypl->myfree(pt); - } - else - { strcpy(p, tmpbuf1); } - - pt=p; cstr=0; - - } - else - { - /* save old string */ - old_table[i]=table_3proxy[i]; - /* replace string */ - table_3proxy[i]=pt; - pt=NULL; i++; - } - - - } - - - if(pt)mypl->myfree(pt); - *countloadstr=i; - if (i==0) { mypl->myfree(old_table); old_table=NULL; } - - return old_table; - -} - -/*-------------------------------------------------------------------*/ -static int restore_old_table(void * v) -{ - int i; char *p=NULL; - - /* restore old proxy table */ - if(old_proxy_table) - { - - for(i=0; i < count_str_proxy_in_3proxy; i++){ - p=mypl->proxy_table[i]; - mypl->proxy_table[i]=old_proxy_table[i]; - mypl->myfree(p); - } - mypl->myfree(old_proxy_table); - old_proxy_table = NULL; - - } - - p=NULL; - - /* restore old admin table */ - if(old_admin_table) - { - - for(i=0; i < count_str_admin_in_3proxy; i++){ - p=mypl->admin_table[i]; - mypl->admin_table[i]=old_admin_table[i]; - mypl->myfree(p); - } - mypl->myfree(old_admin_table); - old_admin_table = NULL; - } - /*return 1 delete job, 0 no delete!!! :)*/ - return 1; -} -/*-------------------------------------------------------------------*/ - -#ifdef _WIN32 -__declspec(dllexport) int start(struct pluginlink * pluginlink, - int argc, char** argv); -BOOL WINAPI DllMain( HINSTANCE hModule, - DWORD ul_reason_for_call, - LPVOID lpReserved - ) -{ - if (ul_reason_for_call == DLL_PROCESS_DETACH) - { - if(old_proxy_table) { restore_old_table(NULL); } - - } - return TRUE; -} -#else - -int start(struct pluginlink * pluginlink, - int argc, char** argv); - -#endif - - - -/*---------------------- start plugin init ------------------------------ */ -int start(struct pluginlink * pluginlink, int argc, char** argv) -{ - FILE *f=NULL; - - mypl=pluginlink; - - if(old_proxy_table||old_admin_table) restore_old_table(NULL); - - if(!(f=fopen(argv[1],"r"))) return 1001; - - /*count string service PROXY in 3proxy */ - count_str_proxy_in_3proxy=0; - while( mypl->proxy_table[count_str_proxy_in_3proxy] != NULL ) - { count_str_proxy_in_3proxy++; } - - /*count string service ADMIN in 3proxy */ - count_str_admin_in_3proxy=0; - while( mypl->admin_table[count_str_admin_in_3proxy] != NULL ) - { count_str_admin_in_3proxy++; } - - /*---- load string for PROXY service ----*/ - old_proxy_table=load_string(f,count_str_proxy_in_3proxy, - &count_load_str_proxy_from_file, - "[--proxy--]","[/--proxy--]", - mypl->proxy_table); - - - if (old_proxy_table == NULL) - { - fprintf(stderr,"Error StringsPlugin: No load string from file %s \ - for service PROXY !\n",argv[1]); - } - - if(count_str_proxy_in_3proxy!= count_load_str_proxy_from_file) - { - fprintf(stderr,"Warning StringsPlugin: Count string for service PROXY in\ - 3proxy not equality count string in file %s \n",argv[1]); - } - - - /*---- load string for ADMIN service ----*/ - old_admin_table=load_string(f,count_str_admin_in_3proxy, - &count_load_str_admin_from_file, - "[--admin--]","[/--admin--]", - mypl->admin_table); - - - if (old_admin_table == NULL) - { - fprintf(stderr,"Error StringsPlugin: No load string from file %s \ - for service ADMIN !\n",argv[1]); - } - - if(count_str_admin_in_3proxy!= count_load_str_admin_from_file) - { - fprintf(stderr,"Warning StringsPlugin: Count string for service ADMIN in\ - 3proxy not equality count string in file %s\n",argv[1]); - } - - fclose(f); - - /* create job shedule for processing reload */ - if(*pluginlink->schedule!=&myschedule){ - memset(&myschedule,0,sizeof(struct schedule)); - myschedule.type=NONE; - myschedule.function=restore_old_table; - myschedule.next = *pluginlink->schedule; - *pluginlink->schedule=&myschedule; - } - - return 0; -} - - -#ifdef __cplusplus -extern } -#endif diff --git a/src/plugins/TrafficPlugin/Changelog.txt b/src/plugins/TrafficPlugin/Changelog.txt deleted file mode 100644 index 696b2de..0000000 --- a/src/plugins/TrafficPlugin/Changelog.txt +++ /dev/null @@ -1,13 +0,0 @@ -======================================================================== - 3proxy traffic plugin Changelog -======================================================================== -v0.1.2 (2 января 2007 года) -- Плугин обновлён в соответствии с обновлением 3proxy. -- Добавлена опция debug. - -v0.1.1 -- Теперь udp нельзя задавать proxy, tcppm, pop3p -- Исправлена ошибка с выбором типа соединения. - -v0.1.0 beta (10 июля 2006) -Первый релиз. \ No newline at end of file diff --git a/src/plugins/TrafficPlugin/Makefile b/src/plugins/TrafficPlugin/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/TrafficPlugin/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/TrafficPlugin/Makefile.inc b/src/plugins/TrafficPlugin/Makefile.inc deleted file mode 100644 index 4aed3db..0000000 --- a/src/plugins/TrafficPlugin/Makefile.inc +++ /dev/null @@ -1,7 +0,0 @@ -all: $(BUILDDIR)TrafficPlugin$(DLSUFFICS) - -TrafficPlugin$(OBJSUFFICS): TrafficPlugin.c - $(CC) $(DCFLAGS) $(CFLAGS) TrafficPlugin.c - -$(BUILDDIR)TrafficPlugin$(DLSUFFICS): TrafficPlugin$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)TrafficPlugin$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) TrafficPlugin$(OBJSUFFICS) diff --git a/src/plugins/TrafficPlugin/ReadMe.txt b/src/plugins/TrafficPlugin/ReadMe.txt deleted file mode 100644 index c4f4fb1..0000000 --- a/src/plugins/TrafficPlugin/ReadMe.txt +++ /dev/null @@ -1,67 +0,0 @@ -======================================================================== - 3proxy traffic plugin -======================================================================== -Как известно 3proxy считает траффик не сетевой, а прикладной. -Обычно прикладной траффик немного меньше (примерно на 10%) чем сетевой, -однако в некоторых случаях, например когда пользователи сети играют в -игры, сетевой траффик может превысить прикладной в 4-5 раз. Это довольно неприятно, -так как получается, что они за это не платят. - -Происходит это потому, что в каждом посланом пакете есть заголовок+данные. Заголовок -весит порядка 50-60 байт а колличество данных может меняться от 15-20 байт (что характерно для игр) -до 800-900 байт (у IE). Также колличество данных в пакете зависит от загрузки сети, -удалённости сервера и прочих причин. - -Данный плагин может исправить такую ситуацию. Он может умножать счётчик траффика -при окончании соединения на некоторый коэффициент либо добавлять к данным размеры заголовков пакетов, -которые прошли по сети. - -Как использовать плагин: - -загрузка плагина: -plugin "TrafficPlugin.dll" start - -Далее недоходимо добавить правила: -ДЛЯ РЕЖИМА ДОМНОЖЕНИЯ ТРАФФИКА НА ЧИСЛО: -trafcorrect m <сервис> <исходящий порт> <коэффициент> -где: <сервис> может быть proxy, socks4, socks45, socks5, tcppm, udppm, pop3p - если сервис указан неверно то считается, что это может быть любой сервис. - можно использовать *, тогда правило будет считаться для любого сервиса. - <исходящий порт> - порт, к которому подключается прокси сервер. * - любой - <коэффициент> - число на каоторое домнажается траффик. Обязательный параметр. - Должен быть от больше 0 и меньше 100 - -ДЛЯ РЕЖИМА С УЧЁТОМ РАЗМЕРА ЗАГОЛОВКОВ ПАКЕТОВ: -trafcorrect p <сервис> <исходящий порт> [размер пустого пакета] - - протокол, по которому осуществляется соединение. - [размер пакета] - средний размер пустого пакета. Можно определить захватив -данные при помощи такой утилиты как Ethernal. Параметр необязателен. Если отсутствует, -то размер пакета будет считаться равным 66 байт. - -Режимы можно смешивать. -Следует учитывать, что плугин создаёт список всех правил изменения траффика. -Когда происходит окончание соединения выполняется первое подходящее правило. - -Пример: -plugin "TrafficPlugin.dll" start -trafcorrect m socks5 6112 4.5 -trafcorrect m socks5 * 1.1 - -следующее неверно: -plugin "TrafficPlugin.dll" start -trafcorrect m socks5 * 1.1 -trafcorrect m socks5 6112 4.5 -Вторая строчка выполнена никогда не будет. Так как 1 имеет более широкое назначение. - -РЕЖИМ ОТЛАДКИ ПРАВИЛ: -1. Запускает прокси в оконном режиме (чтобы видеть stdout). -2. Загрузка плагина должна выглядеть сл. образом: -plugin "TrafficPlugin.dll" start debug -3. В окне прокси сервера будет написана информация о прохождении правил коррекции траффика. -Правила нумеруются с 1. - -///////////////////////////////////////////////////////////////////////////// -Copyright: - (c) Maslov Michael aka Flexx(rus) All rights reserved. - Plugin was writen on Visual C++ 6.0 SP5 - Using structures.h from 3proxy distr. \ No newline at end of file diff --git a/src/plugins/TrafficPlugin/TrafficPlugin.c b/src/plugins/TrafficPlugin/TrafficPlugin.c deleted file mode 100644 index 09009a0..0000000 --- a/src/plugins/TrafficPlugin/TrafficPlugin.c +++ /dev/null @@ -1,310 +0,0 @@ -/* - 3proxy Traffic correct plugin v0.1 beta - - Написал Maslov Michael aka Flexx(rus) - Формула расчёта траффика по размеру пакета by 3APA3A - email: flexx_rus@mail.ru - ICQ: 299132764 - http://3proxy.ru/ - - Как работает не знаю (многое зависит от ваших настроек). Никаких гарантий. - С плугином можете делать всё, что захочется. - Дожен распростроняться только с исходными кодами или вместе с 3proxy. - Удалять данный Copyright запрещено. -*/ - -#include "../../structures.h" -#include - -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - -int DBGLEVEL = 0; - -int already_loaded = 0; -typedef int (* handler)(int argc, unsigned char ** argv); - -struct extparam * conf; -struct commands * commandhandlers; -struct pluginlink * pl; - -typedef enum { - MULTIPLAY, /* метод коррекции умножением на коффициент */ - IPCORRECT, /* метод коррекции с учётом размера пакета */ -} TRAFCORRECT_TYPE; - -typedef enum { - UDP, - TCP -} CONN_TYPE; - -struct trafcorrect { - struct trafcorrect * next; - TRAFCORRECT_TYPE type; - int port; - PROXYSERVICE p_service; - double coeff; - CONN_TYPE con_type; - int psize; -}; - -struct trafcorrect * firsttrafcorrect = NULL; - -static void addtrafcorrect(struct trafcorrect * tc) { - struct trafcorrect * starttrafcorrect; - if (!firsttrafcorrect) { - firsttrafcorrect = tc; - return; - } - starttrafcorrect = firsttrafcorrect; - for ( ; starttrafcorrect->next ; starttrafcorrect = starttrafcorrect->next); - starttrafcorrect->next = tc; -} - -static void killtrafcorrect() { - struct trafcorrect * p = firsttrafcorrect; - struct trafcorrect * d; - - if (!firsttrafcorrect) return; - firsttrafcorrect = NULL; - while (p) { - d = p; - p = p->next; - pl->myfree(d); - } -} - -struct commands trafcorrect_handler; -int h_trafcorrect(int argc, unsigned char ** argv) { - if (argc < 2) { - if(DBGLEVEL == 1)fprintf(stdout, "See documentation of traffic correct plugin.\n"); - return 1; - } - /* режим умножения траффика на коэффициент */ - if (!strcmp((char *)argv[1], "m")) { - struct trafcorrect * newitem; - if (argc < 5) { - if(DBGLEVEL == 1){ - fprintf(stdout, "USE: trafcorrect m \n"); - fprintf(stdout, "See documentation of traffic correct plugin.\n"); - } - return 1; - } - newitem = (struct trafcorrect *)pl->myalloc(sizeof(struct trafcorrect)); - newitem->next = NULL; - newitem->type = MULTIPLAY; - - newitem->p_service = S_NOSERVICE; - if (!strcmp((char *)argv[2], (char *)"proxy")) newitem->p_service = S_PROXY; - if (!strcmp((char *)argv[2], (char *)"socks4")) newitem->p_service = S_SOCKS4; - if (!strcmp((char *)argv[2], (char *)"socks45")) newitem->p_service = S_SOCKS45; - if (!strcmp((char *)argv[2], (char *)"socks5")) newitem->p_service = S_SOCKS5; - if (!strcmp((char *)argv[2],(char *) "tcppm")) newitem->p_service = S_TCPPM; - if (!strcmp((char *)argv[2],(char *) "udppm")) newitem->p_service = S_UDPPM; - if (!strcmp((char *)argv[2], (char *)"admin")) newitem->p_service = S_ADMIN; - if (!strcmp((char *)argv[2], (char *)"pop3p")) newitem->p_service = S_POP3P; - - newitem->port = atoi((char *)argv[3]); - newitem->coeff = atof((char *)argv[4]); - /* проверка на корректность ввода */ - if ((newitem->port>65535) | (newitem->coeff<=0) | (newitem->coeff>100)) { - pl->myfree(newitem); - if(DBGLEVEL == 1)fprintf(stdout, "Port must be 0 [packet size]\n"); - fprintf(stdout, "See documentation of traffic correct plugin.\n"); - } - return 1; - } - - newitem = (struct trafcorrect *)pl->myalloc(sizeof(struct trafcorrect)); - newitem->next = NULL; - newitem->type = IPCORRECT; - - newitem->p_service = S_NOSERVICE; - if (!strstr((char *)argv[2], "proxy")) newitem->p_service = S_PROXY; - if (!strstr((char *)argv[2], "socks4")) newitem->p_service = S_SOCKS4; - if (!strstr((char *)argv[2], "socks45")) newitem->p_service = S_SOCKS45; - if (!strstr((char *)argv[2], "socks5")) newitem->p_service = S_SOCKS5; - if (!strstr((char *)argv[2], "tcppm")) newitem->p_service = S_TCPPM; - if (!strstr((char *)argv[2], "udppm")) newitem->p_service = S_UDPPM; - if (!strstr((char *)argv[2], "admin")) newitem->p_service = S_ADMIN; - if (!strstr((char *)argv[2], "pop3p")) newitem->p_service = S_POP3P; - - newitem->con_type = TCP; - newitem->psize = 52; - if ((!strcmp((char *)argv[3], "udp")) & (newitem->p_service != S_PROXY) & (newitem->p_service != S_TCPPM) & (newitem->p_service != S_POP3P)) { - newitem->con_type = UDP; - newitem->psize = 48; - } - - newitem->port = atoi((char *)argv[4]); - /* последний необязательный параметр - размер пакета */ - if (argc >= 6) { - newitem->psize = atoi((char *)argv[5]); - } - - if ((newitem->port>65535) | (newitem->psize<=0)) { - pl->myfree(newitem); - if(DBGLEVEL == 1)fprintf(stdout, "Port must be 0> 8); -} - -LOGFUNC origlogfunc; -void mylogfunc(struct clientparam * param, const unsigned char * pz) { - PROXYSERVICE g_s = S_NOSERVICE; - int port; - int rule = 0; - struct trafcorrect * starttrafcorrect = firsttrafcorrect; -#ifndef NOPSTDINT - uint64_t statssrv_before, statscli_before; -#else - unsigned long statssrv_before, statscli_before; -#endif - int ok = 0; - for (;starttrafcorrect != NULL; starttrafcorrect = starttrafcorrect->next) { - port = starttrafcorrect->port; - g_s = starttrafcorrect->p_service; - if (starttrafcorrect->p_service == S_NOSERVICE) g_s = param->service; - if (starttrafcorrect->port <= 0) port = myhtons(*SAPORT(¶m->sinsr)); - -#ifndef NOPSTDINT - statssrv_before = param->statssrv64; - statscli_before = param->statscli64; -#else - statssrv_before = param->statssrv; - statscli_before = param->statscli; -#endif - rule++; - if (((g_s == param->service) && (port == myhtons(*SAPORT(¶m->sinsr)))) || - ( ((starttrafcorrect->type == UDP) && - ((param->operation == UDPASSOC)|| - (param->operation == DNSRESOLVE)|| - (param->operation == BIND)|| - (param->operation == ICMPASSOC)) - )||(starttrafcorrect->type == TCP))) /* TCP support */ - { - /* фильтр подошёл. можно изменять значение траффика - домножаем на число */ - if (starttrafcorrect->type == MULTIPLAY) { -#ifndef NOPSTDINT - param->statssrv64 = (unsigned)((double)param->statssrv64 *starttrafcorrect->coeff); - param->statscli64 = (unsigned)((double)param->statscli64 * starttrafcorrect->coeff); -#else - param->statssrv = (unsigned)((double)param->statssrv *starttrafcorrect->coeff); - param->statscli = (unsigned)((double)param->statscli * starttrafcorrect->coeff); -#endif - } - /* с учётом пакетов */ - if (starttrafcorrect->type == IPCORRECT) { - if (starttrafcorrect->con_type == TCP) { -#ifndef NOPSTDINT - param->statssrv64+=(param->nreads + 3*param->nconnects)*starttrafcorrect->psize; - param->statscli64+=(param->nwrites + 3*param->nconnects)*starttrafcorrect->psize; -#else - param->statssrv+=(param->nreads + 3*param->nconnects)*starttrafcorrect->psize; - param->statscli+=(param->nwrites + 3*param->nconnects)*starttrafcorrect->psize; -#endif - } else { -#ifndef NOPSTDINT - param->statssrv64+=param->nreads*starttrafcorrect->psize; - param->statscli64+=param->nwrites*starttrafcorrect->psize; -#else - param->statssrv+=param->nreads*starttrafcorrect->psize; - param->statscli+=param->nwrites*starttrafcorrect->psize; -#endif - } - } - if (DBGLEVEL == 1) { -#ifndef NOPSTDINT - fprintf(stdout, "Port=%hd; Before: srv=%"PRINTF_INT64_MODIFIER"d, cli=%"PRINTF_INT64_MODIFIER"d; After: srv=%"PRINTF_INT64_MODIFIER"d, cli=%"PRINTF_INT64_MODIFIER"d; nreads=%ld; nwrites=%ld; Rule=%d\n",myhtons(*SAPORT(¶m->sinsr)), statssrv_before, statscli_before, param->statssrv64, param->statscli64,param->nreads,param->nwrites,rule); -#else - fprintf(stdout, "Port=%hd; Before: srv=%lu, cli=%lu; After: srv=%lu, cli=%lu; nreads=%ld; nwrites=%ld; Rule=%d\n",myhtons(param->sins.sin_port), statssrv_before, statscli_before, param->statssrv, param->statscli,param->nreads,param->nwrites,rule); -#endif - } - ok = 1; - break; - } - } - if ((!ok) && (DBGLEVEL == 1)) { - fprintf(stdout, "No rules specifed: service=%d, port=%d, operation=%d", param->service, *SAPORT(¶m->sinsr),param->operation); - } - origlogfunc(param, pz); -} - -#ifdef _WIN32 - -BOOL WINAPI DllMain( HINSTANCE hModule, - DWORD ul_reason_for_call, - LPVOID lpReserved - ) -{ - if (ul_reason_for_call == DLL_PROCESS_DETACH) killtrafcorrect(); - return TRUE; -} - -__declspec(dllexport) - -#endif - - int start(struct pluginlink * pluginlink, int argc, char** argv) { - struct commands * starthandler; - conf = pluginlink->conf; - commandhandlers = pluginlink->commandhandlers; - pl = pluginlink; - - if (argc>1) { - /*for (int i = 0; i< argc; i++) fprintf(stdout,"%s ", argv[i]); */ - if (!strcmp((char *)argv[1], "debug")) { - DBGLEVEL = 1; - fprintf(stdout, "Traffic correct plugin: debug mode enabled.\n"); - } - } - - if (already_loaded) { - killtrafcorrect(); - return 0; - } - already_loaded = 1; - /* добавляем команду "trafcorrect" */ - starthandler = commandhandlers; - for ( ; starthandler->next; starthandler = starthandler->next); - trafcorrect_handler.next = NULL; - trafcorrect_handler.minargs = 1; - trafcorrect_handler.maxargs = 10; - trafcorrect_handler.command = "trafcorrect"; - trafcorrect_handler.handler = h_trafcorrect; - starthandler->next = &trafcorrect_handler; - - /* подменяем conf->logfunc, с целью контролировать траффик */ - origlogfunc = conf->logfunc; - conf->logfunc = mylogfunc; - return 0; -} - -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/TransparentPlugin/Makefile b/src/plugins/TransparentPlugin/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/TransparentPlugin/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/TransparentPlugin/Makefile.inc b/src/plugins/TransparentPlugin/Makefile.inc deleted file mode 100644 index a97f18f..0000000 --- a/src/plugins/TransparentPlugin/Makefile.inc +++ /dev/null @@ -1,10 +0,0 @@ -all: $(BUILDDIR)TransparentPlugin$(DLSUFFICS) - - - -transparent_plugin$(OBJSUFFICS): transparent_plugin.c - $(CC) $(DCFLAGS) $(CFLAGS) transparent_plugin.c - - -$(BUILDDIR)TransparentPlugin$(DLSUFFICS): transparent_plugin$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)TransparentPlugin$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) transparent_plugin$(OBJSUFFICS) diff --git a/src/plugins/TransparentPlugin/transparent_plugin.c b/src/plugins/TransparentPlugin/transparent_plugin.c deleted file mode 100644 index 6bbbdfb..0000000 --- a/src/plugins/TransparentPlugin/transparent_plugin.c +++ /dev/null @@ -1,110 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2007-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include -#include "../../structures.h" -#include "../../proxy.h" -#include -#include -#include -#include - - -#ifdef __cplusplus -extern "C" { -#endif - -#ifndef isnumber -#define isnumber(i_n_arg) ((i_n_arg>='0')&&(i_n_arg<='9')) -#endif - -static struct pluginlink * pl; - -static pthread_mutex_t transparent_mutex; - -static int transparent_loaded = 0; - - -static void* transparent_filter_open(void * idata, struct srvparam * param){ - return idata; -} - - - -static FILTER_ACTION transparent_filter_client(void *fo, struct clientparam * param, void** fc){ - -#ifdef SO_ORIGINAL_DST - struct sockaddr_in addr; - socklen_t len; - unsigned u; - unsigned short p; - char addrbuf[24]; - - len = sizeof(addr); - if(getsockopt(param->clisock, SOL_IP, SO_ORIGINAL_DST,(struct sockaddr *) &addr, &len) || !addr.sin_addr.s_addr){ - return PASS; - } - u = ntohl(addr.sin_addr.s_addr); - p = ntohs(addr.sin_port); - sprintf(addrbuf, "%u.%u.%u.%u:%hu", - ((u&0xFF000000)>>24), - ((u&0x00FF0000)>>16), - ((u&0x0000FF00)>>8), - ((u&0x000000FF)), - p); - - pl->parsehostname(addrbuf, param, 0); - return PASS; -#else -#error No SO_ORIGINAL_DST defined - param->srv->logfunc(param, (unsigned char *)"transparent_plugin: No SO_ORIGINAL_DST defined"); - return REJECT; -#endif - - - return PASS; -} - - -static void transparent_filter_clear(void *fo){ -} - -static void transparent_filter_close(void *fo){ -} - -static struct filter transparent_filter = { - NULL, - "Transparent filter", - "Transparent filter", - transparent_filter_open, - transparent_filter_client, - NULL, NULL, NULL, NULL, NULL, NULL, - transparent_filter_clear, - transparent_filter_close -}; - - -#ifdef _WIN32 -__declspec(dllexport) -#endif - - int transparent_plugin (struct pluginlink * pluginlink, - int argc, char** argv){ - pl = pluginlink; - if(!transparent_loaded){ - transparent_loaded = 1; - pthread_mutex_init(&transparent_mutex, NULL); - transparent_filter.next = pl->conf->filters; - pl->conf->filters = &transparent_filter; - } - return 0; - - } -#ifdef __cplusplus -} -#endif diff --git a/src/plugins/WindowsAuthentication/Makefile b/src/plugins/WindowsAuthentication/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/WindowsAuthentication/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/WindowsAuthentication/Makefile.inc b/src/plugins/WindowsAuthentication/Makefile.inc deleted file mode 100644 index 7634262..0000000 --- a/src/plugins/WindowsAuthentication/Makefile.inc +++ /dev/null @@ -1,8 +0,0 @@ -all: $(BUILDDIR)WindowsAuthentication$(DLSUFFICS) - -WindowsAuthentication$(OBJSUFFICS): WindowsAuthentication.c - $(CC) $(DCFLAGS) $(CFLAGS) WindowsAuthentication.c - -$(BUILDDIR)WindowsAuthentication$(DLSUFFICS): WindowsAuthentication$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)WindowsAuthentication$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) WindowsAuthentication$(OBJSUFFICS) $(LIBS) - diff --git a/src/plugins/WindowsAuthentication/WindowsAuthentication.c b/src/plugins/WindowsAuthentication/WindowsAuthentication.c deleted file mode 100644 index 9224bde..0000000 --- a/src/plugins/WindowsAuthentication/WindowsAuthentication.c +++ /dev/null @@ -1,94 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2007-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "../../structures.h" -#include -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - - __declspec(dllexport) int WindowsAuthentication(struct pluginlink * pluginlink, - int argc, char** argv); - - -static struct auth alwaysauth; - -static char sidbuf[4096]; -static PSID psid = (PSID)sidbuf; - -#ifdef __cplusplus -extern "C" { -#endif - - static int windowsfunc(struct clientparam *param){ - char *dom; - HANDLE h; - DWORD dw, sidlen, i; - char tokenbuf[4096]; - PTOKEN_GROUPS ptg = (PTOKEN_GROUPS)tokenbuf; - - - if(!param->username || !param->password || param->pwtype != 0) return 4; - dom = strchr((char *)param->username, '\\'); - if(dom)*dom++=0; - if(!LogonUser( dom?dom:(char *)param->username, - dom?(char *)param->username:NULL, - (char *)param->password, - LOGON32_LOGON_NETWORK, - LOGON32_PROVIDER_DEFAULT, - &h))return 5; - - if(dom)*(dom-1)='\\'; - if(!GetTokenInformation(h, TokenGroups, ptg, sizeof(tokenbuf), &dw)) return 6; - CloseHandle(h); - sidlen = GetLengthSid(psid); - for(i=0; i < ptg->GroupCount; i++){ - if(GetLengthSid(ptg->Groups[i].Sid)==sidlen){ - if(!memcmp((void *)ptg->Groups[i].Sid, (void *)psid, sidlen)) { - setlocale(LC_CTYPE, ".ACP"); - _strlwr((char *)param->username); - return 0; - } - } - } - return 7; - } - -#ifdef __cplusplus -} -#endif - - -int WindowsAuthentication(struct pluginlink * pluginlink, int argc, char** argv){ - char tmpbuf[4096]; - DWORD dlen, sidlen; - SID_NAME_USE snu; - static int loaded = 0; - - - if(argc != 2) return 11; - dlen = sizeof(tmpbuf)/sizeof(TCHAR); - sidlen = sizeof(sidbuf); - if(!LookupAccountName(NULL, argv[1], psid, &sidlen, - (LPTSTR) tmpbuf, &dlen, &snu)) return 100000 + (int)GetLastError(); - if(snu != SidTypeGroup && snu != SidTypeAlias && snu != SidTypeWellKnownGroup) return 12; - if(!loaded){ - alwaysauth.authenticate = windowsfunc; - alwaysauth.authorize = pluginlink->checkACL; - alwaysauth.desc = "windows"; - alwaysauth.next = pluginlink->authfuncs->next; - pluginlink->authfuncs->next = &alwaysauth; - loaded = 1; - } - return 0; -} - - diff --git a/src/plugins/WindowsAuthentication/copying b/src/plugins/WindowsAuthentication/copying deleted file mode 100644 index 177ffa7..0000000 --- a/src/plugins/WindowsAuthentication/copying +++ /dev/null @@ -1,31 +0,0 @@ -3proxy 0.6 Windows Authentication Plugin Public License Agreement - -This software provided "as is" without any guaranties or support. - -This software is FREEWARE. You can use it under terms of current version -of GNU GPL (General Public License) available from -http://www.gnu.org/licenses/gpl.txt or under conditions below: - -1. You are granted non-exclusive rights to compile, modify, use and -re-distribute this program. -2. In case this software is redistributed in binary form, source code -MUST be available for user for free. -3. In case this software redistributed embedded in hardware device or -pre-installed version of operation system and source code is not available, -documentation MUST refer to http://www.security.nnov.ru/ as a source of -software. -4. In case this software is modified or is used as a part of another project -license MUST NOT be modified. -5. Authors of this software MAY change terms of this license for future -versions of this product. - -(c) 2000-2009 by 3APA3A (3APA3A@security.nnov.ru) -(c) 2000-2009 by SECURITY.NNOV (http://www.security.nnov.ru) -(c) 2000-2009 by Vladimir Dubrovin (vlad@sandy.ru) - - -This software uses: - RSA Data Security, Inc. MD4 Message-Digest Algorithm - RSA Data Security, Inc. MD5 Message-Digest Algorithm - -$Id: copying,v 1.1 2006/02/13 16:08:03 vlad Exp $ diff --git a/src/plugins/utf8tocp1251/Makefile b/src/plugins/utf8tocp1251/Makefile deleted file mode 100644 index e7c51ad..0000000 --- a/src/plugins/utf8tocp1251/Makefile +++ /dev/null @@ -1 +0,0 @@ -include Makefile.var diff --git a/src/plugins/utf8tocp1251/Makefile.inc b/src/plugins/utf8tocp1251/Makefile.inc deleted file mode 100644 index cb29d22..0000000 --- a/src/plugins/utf8tocp1251/Makefile.inc +++ /dev/null @@ -1,8 +0,0 @@ -all: $(BUILDDIR)utf8tocp1251$(DLSUFFICS) - -utf8tocp1251$(OBJSUFFICS): utf8tocp1251.c - $(CC) $(DCFLAGS) $(CFLAGS) utf8tocp1251.c - -$(BUILDDIR)utf8tocp1251$(DLSUFFICS): utf8tocp1251$(OBJSUFFICS) - $(LN) $(LNOUT)../../$(BUILDDIR)utf8tocp1251$(DLSUFFICS) $(LDFLAGS) $(DLFLAGS) utf8tocp1251$(OBJSUFFICS) $(LIBS) - diff --git a/src/plugins/utf8tocp1251/utf8tocp1251.c b/src/plugins/utf8tocp1251/utf8tocp1251.c deleted file mode 100644 index 866cebc..0000000 --- a/src/plugins/utf8tocp1251/utf8tocp1251.c +++ /dev/null @@ -1,88 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2007-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "../../structures.h" -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - - __declspec(dllexport) int utf8tocp1251(struct pluginlink * pluginlink, - int argc, char** argv); - -static struct auth alwaysauth; - - - -#ifdef __cplusplus -extern "C" { -#endif - -unsigned char * conv_utf8_to_cp1251(unsigned char *s){ - int i, j=0, n=(int)strlen((char *)s); - int byte2 = 0; - int c1, new_c1, new_c2, new_i; - for(i = 0; i < n; i++){ - if(byte2 && s[i]>=128 && s[i]<=192){ - new_c2=(c1&3)*64+(s[i]&63); - new_c1=(c1>>2)&5; - new_i=(new_c1*256)+new_c2; - if(new_i == 1025) s[j++] = 168; - else if (new_i==1105) s[j++] = 184; - else if (new_i < (192 + 848) || new_i > (255 + 848)){ - return s; - } - else s[j++] = new_i - 848; - byte2 = 0; - } - else if(byte2){ - return s; - } - else if((s[i]>>5)==6){ - c1 = s[i]; - byte2 = 1; - } - else if(s[i] < 128) s[j++] = s[i]; - else return s; - } - s[j] = 0; - return s; -} - - - static int aufunc(struct clientparam *param){ - if(!param->username || !param->password || param->pwtype != 0) return 4; - conv_utf8_to_cp1251(param->username); - conv_utf8_to_cp1251(param->password); - return 4; - } - -#ifdef __cplusplus -} -#endif - - -int utf8tocp1251(struct pluginlink * pluginlink, int argc, char** argv){ - static int loaded = 0; - - - if(!loaded){ - alwaysauth.authenticate = aufunc; - alwaysauth.authorize = pluginlink->checkACL; - alwaysauth.desc = "utf8tocp1251"; - alwaysauth.next = pluginlink->authfuncs->next; - pluginlink->authfuncs->next = &alwaysauth; - loaded = 1; - } - return 0; -} - - - diff --git a/src/pop3p.c b/src/pop3p.c deleted file mode 100644 index b5f3088..0000000 --- a/src/pop3p.c +++ /dev/null @@ -1,72 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -void * pop3pchild(struct clientparam* param) { - int i=0, res; - unsigned char buf[320]; - unsigned char *se; - - if(socksend(param->clisock, (unsigned char *)"+OK Proxy\r\n", 11, conf.timeouts[STRING_S])!=11) {RETURN (611);} - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - while(i > 4 && strncasecmp((char *)buf, "USER", 4)){ - if(!strncasecmp((char *)buf, "QUIT", 4)){ - socksend(param->clisock, (unsigned char *)"+OK\r\n", 5,conf.timeouts[STRING_S]); - RETURN(0); - } - socksend(param->clisock, (unsigned char *)"-ERR need USER first\r\n", 22, conf.timeouts[STRING_S]); - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - } - if(i<6) {RETURN(612);} - - buf[i] = 0; - if ((se=(unsigned char *)strchr((char *)buf, '\r'))) *se = 0; - if (strncasecmp((char *)buf, "USER ", 5)){RETURN (614);} - if(parseconnusername((char *)buf +5, param, 0, 110)){RETURN(615);} - param->operation = CONNECT; - res = (*param->srv->authfunc)(param); - if(res) {RETURN(res);} - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - if( i < 3 ) {RETURN(621);} - buf[i] = 0; - if(strncasecmp((char *)buf, "+OK", 3)||!strncasecmp((char *)buf+4, "PROXY", 5)){RETURN(622);} - if( socksend(param->remsock, (unsigned char *)"USER ", 5, conf.timeouts[STRING_S])!= 5 || - socksend(param->remsock, param->extusername, (int)strlen((char *)param->extusername), conf.timeouts[STRING_S]) <= 0 || - socksend(param->remsock, (unsigned char *)"\r\n", 2, conf.timeouts[STRING_S])!=2) - {RETURN(623);} - param->statscli64 += (uint64_t)(strlen((char *)param->extusername) + 7); - param->nwrites++; - RETURN (sockmap(param, 180)); -CLEANRET: - - if(param->hostname&¶m->extusername) { - sprintf((char *)buf, "%.128s@%.128s%c%hu", param->extusername, param->hostname, (*SAPORT(¶m->sinsr)==110)?0:':', ntohs(*SAPORT(¶m->sinsr))); - (*param->srv->logfunc)(param, buf); - } - else (*param->srv->logfunc)(param, NULL); - if(param->clisock != INVALID_SOCKET) { - if ((param->res > 0 && param->res < 100) || (param->res > 611 && param->res <700)) socksend(param->clisock, (unsigned char *)"-ERR\r\n", 6,conf.timeouts[STRING_S]); - } - freeparam(param); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - pop3pchild, - 110, - 0, - S_POP3P, - " -hdefault_host[:port] - use this host and port as default if no host specified\n" - -}; -#include "proxymain.c" -#endif diff --git a/src/smtpp.c b/src/smtpp.c deleted file mode 100644 index e40e4ea..0000000 --- a/src/smtpp.c +++ /dev/null @@ -1,316 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -char ehlo[] = "250-Proxy\r\n" - "250-AUTH PLAIN LOGIN\r\n" - "250-8BITMIME\r\n" - "250 DSN\r\n"; - -int readreply (struct clientparam* param) { - unsigned char * buf; - int res, i, bufsize = 640; - - if(!(buf = myalloc(bufsize))) return 0; - do { - i = sockgetlinebuf(param, SERVER, buf, bufsize-1, '\n', conf.timeouts[STRING_L]); - if(i < 1) break; -#ifndef WITHMAIN - res = handlehdrfilterssrv(param, &buf, &bufsize, 0, &i); - if(res != PASS) { - myfree(buf); - return -1; - } -#endif - socksend(param->clisock, buf, i, conf.timeouts[STRING_S]); - } while (i > 3 && buf[3] == '-'); - if(i < 3) { - myfree(buf); - return 0; - } - buf[i] = 0; - res = atoi((char *)buf); - myfree(buf); - return res; -} - -int readcommand (struct clientparam* param) { - unsigned char * buf; - int res, i, bufsize = 320; - int ret = 1; - - if(!(buf = myalloc(bufsize))) return 0; - i = sockgetlinebuf(param, CLIENT, buf, bufsize-1, '\n', conf.timeouts[STRING_L]); - if(i < 4) return 0; -#ifndef WITHMAIN - if(!strncasecmp((char *)buf, "MAIL", 4) || !strncasecmp((char *)buf, "RCPT", 4) || !strncasecmp((char *)buf, "STARTTLS", 8) || !strncasecmp((char *)buf, "TURN", 4)){ - res = handlehdrfilterscli(param, &buf, &bufsize, 0, &i); - if(res != PASS) { - myfree(buf); - if(res == HANDLED) return 2; - return -1; - } - } -#endif - socksend(param->remsock, buf, i, conf.timeouts[STRING_S]); - myfree(buf); - if(!strncasecmp((char *)buf, "STARTTLS", 8) || !strncasecmp((char *)buf, "TURN", 4)){ - ret = 22; - } - return ret; -} - -int readdata (struct clientparam* param) { - unsigned char * buf; - int res, i, bufsize = 4096; - - if(!(buf = myalloc(bufsize))) return 0; - while ((i = sockgetlinebuf(param, CLIENT, buf, bufsize-1, '\n', conf.timeouts[STRING_L])) > 0 && !(i==3 && buf[0] == '.')){ -#ifndef WITHMAIN - res = handledatfltcli(param, &buf, &bufsize, 0, &i); - if(res != PASS) { - myfree(buf); - if(res == HANDLED) return 1; - return -1; - } -#endif - socksendto(param->remsock, (struct sockaddr *)¶m->sinsr, buf, i, conf.timeouts[STRING_S]); - } - if(i < 1) { - myfree(buf); - return 0; - } - socksend(param->remsock, buf, i, conf.timeouts[STRING_S]); - myfree(buf); - return 1; -} - - -void * smtppchild(struct clientparam* param) { - int i=0, res; - unsigned char buf[320]; - unsigned char username[256]; - char * command = NULL; - int login = 0; - - if(socksend(param->clisock, (unsigned char *)"220 Proxy\r\n", 11, conf.timeouts[STRING_S])!=11) {RETURN (611);} - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - while(i > 4 && (strncasecmp((char *)buf, "AUTH PLAIN", 10) || !(login = 2)) && (strncasecmp((char *)buf, "AUTH LOGIN", 10) || !(login = 1))){ - if(!strncasecmp((char *)buf, "QUIT", 4)){ - socksend(param->clisock, (unsigned char *)"221 Proxy\r\n", 11,conf.timeouts[STRING_S]); - RETURN(0); - } - else if(!strncasecmp((char *)buf, "HELO ", 5)){ - socksend(param->clisock, (unsigned char *)"250 Proxy\r\n", 11,conf.timeouts[STRING_S]); - } - else if(!strncasecmp((char *)buf, "EHLO ", 5)){ - socksend(param->clisock, (unsigned char *)ehlo, sizeof(ehlo) - 1,conf.timeouts[STRING_S]); - } - else if(!param->hostname) socksend(param->clisock, (unsigned char *)"571 need AUTH first\r\n", 22, conf.timeouts[STRING_S]); - else { - login = -1; - buf[i] = 0; - command = mystrdup((char *)buf); - break; - } - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - } - if(!login) {RETURN(662);} - if(login == 1){ - socksend(param->clisock, (unsigned char *)"334 VXNlcm5hbWU6\r\n", 18,conf.timeouts[STRING_S]); - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - if(i < 3) {RETURN(663);} - buf[i-2] = 0; - i = de64(buf,username,255); - if(i < 1) {RETURN(664);} - username[i] = 0; - parseconnusername((char *)username, param, 0, 25); - socksend(param->clisock, (unsigned char *)"334 UGFzc3dvcmQ6\r\n", 18,conf.timeouts[STRING_S]); - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - if(i < 2) {RETURN(665);} - buf[i-2] = 0; - i = de64(buf,username,255); - if(i < 0) {RETURN(666);} - username[i] = 0; - if(param->extpassword) myfree(param->extpassword); - param->extpassword = (unsigned char *)mystrdup((char *)username); - } - else if(login == 2){ - if(i > 13) { - buf[i-2] = 0; - i = de64(buf+11,username,255); - } - else { - socksend(param->clisock, (unsigned char *)"334\r\n", 5,conf.timeouts[STRING_S]); - i = sockgetlinebuf(param, CLIENT, buf, sizeof(buf) - 10, '\n', conf.timeouts[STRING_S]); - if(i < 3) {RETURN(667);} - buf[i-2] = 0; - i = de64(buf,username,255); - } - if(i < 3 || *username) {RETURN(668);} - username[i] = 0; - parseconnusername((char *)username+1, param, 0, 25); - res = (int)strlen((char *)username+1) + 2; - if(res < i){ - if(param->extpassword) myfree(param->extpassword); - param->extpassword = (unsigned char *)mystrdup((char *)username + res); - } - } - -#ifndef WITHMAIN - { - int action, reqbufsize, reqsize; - reqbufsize = reqsize = (int)strlen((char *)param->hostname) + 1; - action = handlereqfilters(param, ¶m->hostname, &reqbufsize, 0, &reqsize); - if(action == HANDLED){ - RETURN(0); - } - if(action != PASS) RETURN(617); - } -#endif - - param->operation = CONNECT; - res = (*param->srv->authfunc)(param); - if(res) {RETURN(res);} - do { - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - } while (i > 3 && buf[3] == '-'); - if( i < 3 ) {RETURN(671);} - buf[i] = 0; - if(strncasecmp((char *)buf, "220", 3)||!strncasecmp((char *)buf+4, "PROXY", 5)){RETURN(672);} - i = sprintf((char *)buf, "EHLO ["); - i += myinet_ntop(*SAFAMILY(¶m->sinsl), SAADDR(¶m->sinsl), (char *)buf+strlen((char *)buf), 64); - i += sprintf((char *)buf+strlen((char *)buf), "]\r\n"); - if(socksend(param->remsock, buf, i, conf.timeouts[STRING_S])!= i) {RETURN(673);} - param->statscli64+=i; - param->nwrites++; - login = 0; - do { - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - if(i < 1) break; - buf[i] = 0; - if(strstr((char *)buf, "LOGIN")) login |= 1; - if(strstr((char *)buf, "PLAIN")) login |= 2; - - } while (i > 3 && buf[3] == '-'); - if(i<3) {RETURN(672);} - if(!command || (param->extusername && param->extpassword)){ - if(!param->extusername || !*param->extusername || !param->extpassword || !*param->extpassword || !login){ - socksend(param->clisock, (unsigned char *)"235 auth required\r\n", 19,conf.timeouts[STRING_S]); - } - if ((login & 1)) { - socksend(param->remsock, (unsigned char *)"AUTH LOGIN\r\n", 12, conf.timeouts[STRING_S]); - param->statscli64+=12; - param->nwrites++; - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - if(i<4 || strncasecmp((char *)buf, "334", 3)) {RETURN(680);} - en64(param->extusername, buf, (int)strlen((char *)param->extusername)); - socksend(param->remsock, buf, (int)strlen((char *)buf), conf.timeouts[STRING_S]); - socksend(param->remsock, (unsigned char *)"\r\n", 2, conf.timeouts[STRING_S]); - param->statscli64+=(i+2); - param->nwrites+=2; - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - if(i<4 || strncasecmp((char *)buf, "334", 3)) {RETURN(681);} - en64(param->extpassword, buf, (int)strlen((char *)param->extpassword)); - socksend(param->remsock, buf, (int)strlen((char *)buf), conf.timeouts[STRING_S]); - socksend(param->remsock, (unsigned char *)"\r\n", 2, conf.timeouts[STRING_S]); - param->statscli64+=(i+2); - param->nwrites+=2; - } - else if((login & 2)){ - socksend(param->remsock, (unsigned char *)"AUTH PLAIN\r\n", 12, conf.timeouts[STRING_S]); - param->statscli64+=(12); - param->nwrites++; - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - if(i<4 || strncasecmp((char *)buf, "334", 3)) {RETURN(682);} - *username = 0; - i = (int)strlen((char *)param->extusername) + 1; - memcpy(username+1, param->extusername, i); - i++; - res = (int)strlen((char *)param->extpassword); - memcpy(username + i, param->extpassword, res); - i+=res; - en64(username, buf, i); - i = (int)strlen((char *)buf); - socksend(param->remsock, buf, i, conf.timeouts[STRING_S]); - socksend(param->remsock, (unsigned char *)"\r\n", 2, conf.timeouts[STRING_S]); - param->statscli64+=(i+2); - param->nwrites+=2; - } - if(command) { - i = sockgetlinebuf(param, SERVER, buf, sizeof(buf) - 1, '\n', conf.timeouts[STRING_L]); - } - res = 1; - } - if(command) { - res = 1; -#ifndef WITHMAIN - if(!strncasecmp(command, "MAIL", 4) || !strncasecmp(command, "RCPT", 4) || !strncasecmp(command, "STARTTLS", 8) || !strncasecmp(command, "TURN", 4)){ - res = (int)strlen(command); - command[res] = 0; - res = handlehdrfilterscli(param, (unsigned char **)&command, &res, 0, &res); - if(res != PASS) { - if(res == HANDLED) res = 2; - else RETURN(677); - } - else if(!strncasecmp(command, "STARTTLS", 8) || !strncasecmp(command, "TURN", 4)) - res = 22; - } -#endif - i = (int)strlen(command); - if(res != 2) socksend(param->remsock, (unsigned char *)command, i, conf.timeouts[STRING_S]); - } -#ifndef WITHMAIN - - if(param->nhdrfilterscli || param->nhdrfilterssrv || param->ndatfilterscli || param->ndatfilterssrv){ - do { - if(res == 22) RETURN (sockmap(param, 180)); - if(res != 2 && (res = readreply(param)) <= 0) break; - if(res == 221) RETURN(0); - if(res == 354) res = readdata(param); - else res = readcommand(param); - } while(res > 0); - if(res == 22) - if(res >= 0) RETURN(0); - RETURN(676); - } - else - -#endif - - RETURN (sockmap(param, 180)); - -CLEANRET: - - if(param->hostname&¶m->extusername) { - sprintf((char *)buf, "%.128s@%.128s%c%hu", param->extusername, param->hostname, *SAPORT(¶m->sinsr)==25?0:':',ntohs(*SAPORT(¶m->sinsr))); - (*param->srv->logfunc)(param, buf); - } - else (*param->srv->logfunc)(param, NULL); - if(param->clisock != INVALID_SOCKET) { - if ((param->res > 0 && param->res < 100) || (param->res > 661 && param->res <700)) socksend(param->clisock, (unsigned char *)"571 \r\n", 6,conf.timeouts[STRING_S]); - } - if(command) myfree(command); - freeparam(param); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - smtppchild, - 25, - 0, - S_SMTPP, - " -hdefault_host[:port] - use this host and port as default if no host specified\n" - -}; -#include "proxymain.c" -#endif diff --git a/src/socks.c b/src/socks.c deleted file mode 100644 index 4d048f8..0000000 --- a/src/socks.c +++ /dev/null @@ -1,472 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -unsigned char * commands[] = {(unsigned char *)"UNKNOWN", (unsigned char *)"CONNECT", (unsigned char *)"BIND", (unsigned char *)"UDPMAP"}; - -#define BUFSIZE 1024 -#define LARGEBUFSIZE 67000 - -void * sockschild(struct clientparam* param) { - int res; - unsigned i=0; - SOCKET s; - unsigned size; - SASIZETYPE sasize; - unsigned short port = 0; - unsigned char * buf=NULL; - unsigned char c; - unsigned char command=0; - struct pollfd fds[3]; - int ver=0; - int havepass = 0; -#ifndef NOIPV6 - struct sockaddr_in6 sin = {AF_INET6}; -#else - struct sockaddr_in sin = {AF_INET}; -#endif - int len; - - - param->service = S_SOCKS; - - if(!(buf = myalloc(BUFSIZE))) {RETURN(21);} - memset(buf, 0, BUFSIZE); - if ((ver = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_L], 0)) != 5 && ver != 4) { - RETURN(401); - } /* version */ - param->service = ver; - if(ver == 5){ - if ((i = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(441);} /* nmethods */ - for (; i; i--) { - if ((res = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(441);} - if (res == 2 && param->srv->needuser) { - havepass = res; - } - } - buf[0] = 5; - buf[1] = (param->srv->needuser > 1 && !havepass)? 255 : havepass; - if(socksend(param->clisock, buf, 2, conf.timeouts[STRING_S])!=2){RETURN(401);} - if (param->srv->needuser > 1 && !havepass) RETURN(4); - if (havepass) { - if (((res = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_L], 0))) != 1) { - RETURN(412); - } - if ((i = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(451);} - if (i && (unsigned)(res = sockgetlinebuf(param, CLIENT, buf, i, 0, conf.timeouts[STRING_S])) != i){RETURN(441);}; - buf[i] = 0; - if(!param->username)param->username = (unsigned char *)mystrdup((char *)buf); - if ((i = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(445);} - if (i && (unsigned)(res = sockgetlinebuf(param, CLIENT, buf, i, 0, conf.timeouts[STRING_S])) != i){RETURN(441);}; - buf[i] = 0; - if(!param->password)param->password = (unsigned char *)mystrdup((char *)buf); - buf[0] = 1; - buf[1] = 0; - if(socksend(param->clisock, buf, 2, conf.timeouts[STRING_S])!=2){RETURN(481);} - } - if ((c = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_L], 0)) != 5) { - RETURN(421); - } /* version */ - } - if( (command = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) < 1 || command > 3){command = 0; RETURN(407);} /* command */ - if(ver == 5){ - if (sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0) == EOF) {RETURN(447);} /* reserved */ - c = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0); /* atype */ - } - else { - if ((res = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(441);} - buf[0] = (unsigned char) res; - if ((res = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(441);} - buf[1] = (unsigned char) res; - port = *(unsigned short*)buf; - c = 1; - } - - size = 4; - *SAFAMILY(¶m->sinsr) = *SAFAMILY(¶m->req) = AF_INET; - switch(c) { -#ifndef NOIPV6 - case 4: - if(param->srv->family == 4) RETURN(997); - size = 16; - *SAFAMILY(¶m->sinsr) = *SAFAMILY(¶m->req) = AF_INET6; -#endif - case 1: - for (i = 0; isrv->family==6){ - char prefix[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 255, 255}; - *SAFAMILY(¶m->sinsr) = *SAFAMILY(¶m->req) = AF_INET6; - memcpy(SAADDR(¶m->sinsr), prefix, 12); - memcpy(12 + (char *)SAADDR(¶m->sinsr), buf, 4); - memcpy(SAADDR(¶m->req), prefix, 12); - memcpy(12 + (char *)SAADDR(¶m->req), buf, 4); - } - else { -#endif - memcpy(SAADDR(¶m->sinsr), buf, size); - memcpy(SAADDR(¶m->req), buf, size); -#ifndef NOIPV6 - } -#endif - if(command == 1 && SAISNULL(¶m->req)) { - RETURN(431); - } - myinet_ntop(*SAFAMILY(¶m->sinsr), SAADDR(¶m->sinsr), (char *)buf, 64); - break; - case 3: - if ((size = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(451);} /* nmethods */ - for (i=0; isrv->family, buf, (struct sockaddr *) ¶m->req)) RETURN(100); - param->sinsr = param->req; - break; - default: - RETURN(997); - } - if(param->hostname)myfree(param->hostname); - param->hostname = (unsigned char *)mystrdup((char *)buf); - if (ver == 5) { - if ((res = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(441);} - buf[0] = (unsigned char) res; - if ((res = sockgetcharcli(param, conf.timeouts[SINGLEBYTE_S], 0)) == EOF) {RETURN(441);} - buf[1] = (unsigned char) res; - port = *(unsigned short*)buf; - - } - else { - sockgetlinebuf(param, CLIENT, buf, BUFSIZE - 1, 0, conf.timeouts[STRING_S]); - buf[127] = 0; - if(param->srv->needuser && *buf && !param->username)param->username = (unsigned char *)mystrdup((char *)buf); - if(!memcmp(SAADDR(¶m->req), "\0\0\0", 3)){ - param->service = S_SOCKS45; - sockgetlinebuf(param, CLIENT, buf, BUFSIZE - 1, 0, conf.timeouts[STRING_S]); - buf[127] = 0; - if(param->hostname)myfree(param->hostname); - param->hostname = (unsigned char *)mystrdup((char *)buf); - if(!getip46(param->srv->family, buf, (struct sockaddr *) ¶m->req)) RETURN(100); - param->sinsr = param->req; - } - } - - *SAPORT(¶m->sinsr) = *SAPORT(¶m->req) = port; - if(command == 1 && !*SAPORT(¶m->sinsr)) {RETURN(461);} - switch(command) { - case 1: - param->operation = CONNECT; - break; - case 2: - case 3: - -#ifndef NOIPV6 - param->sinsl = *SAFAMILY(¶m->req)==AF_INET6? param->srv->extsa6 : param->srv->extsa; -#else - param->sinsl = param->srv->extsa; -#endif - if ((param->remsock=so._socket(SASOCK(¶m->req), command == 2? SOCK_STREAM:SOCK_DGRAM, command == 2?IPPROTO_TCP:IPPROTO_UDP)) == INVALID_SOCKET) {RETURN (11);} - param->operation = command == 2?BIND:UDPASSOC; -#ifdef REUSE - if (command == 2){ - int opt; - -#ifdef SO_REUSEADDR - opt = 1; - so._setsockopt(param->remsock, SOL_SOCKET, SO_REUSEADDR, (unsigned char *)&opt, sizeof(int)); -#endif -#ifdef SO_REUSEPORT - opt = 1; - so._setsockopt(param->remsock, SOL_SOCKET, SO_REUSEPORT, (unsigned char *)&opt, sizeof(int)); -#endif - } -#endif - break; - - default: - RETURN(997); - } - - if((res = (*param->srv->authfunc)(param))) { - RETURN(res); - } - - if(command > 1) { - if(so._bind(param->remsock,(struct sockaddr *)¶m->sinsl,SASIZE(¶m->sinsl))) { - *SAPORT(¶m->sinsl) = 0; - if(so._bind(param->remsock,(struct sockaddr *)¶m->sinsl,SASIZE(¶m->sinsl)))RETURN (12); -#if SOCKSTRACE > 0 -fprintf(stderr, "%hu binded to communicate with server\n", *SAPORT(¶m->sins)); -fflush(stderr); -#endif - } - sasize = SASIZE(¶m->sinsl); - so._getsockname(param->remsock, (struct sockaddr *)¶m->sinsl, &sasize); - if(command == 3) { - param->ctrlsock = param->clisock; - param->clisock = so._socket(SASOCK(¶m->sincr), SOCK_DGRAM, IPPROTO_UDP); - if(param->clisock == INVALID_SOCKET) {RETURN(11);} - sin = param->sincl; - *SAPORT(&sin) = 0; - if(so._bind(param->clisock,(struct sockaddr *)&sin,SASIZE(&sin))) {RETURN (12);} -#if SOCKSTRACE > 0 -fprintf(stderr, "%hu binded to communicate with client\n", - ntohs(*SAPORT(&sin)) - ); -fflush(stderr); -#endif - } - } - param->res = 0; - -CLEANRET: - - if(param->clisock != INVALID_SOCKET){ - int repcode; - - sasize = sizeof(sin); - if(command != 3) so._getsockname(param->remsock, (struct sockaddr *)&sin, &sasize); - else so._getsockname(param->clisock, (struct sockaddr *)&sin, &sasize); -#if SOCKSTRACE > 0 -fprintf(stderr, "Sending confirmation to client with code %d for %s with %s:%hu\n", - param->res, - commands[command], - inet_ntoa(sin.sin_addr), - ntohs(sin.sin_port) - ); -fflush(stderr); -#endif - if(!param->res) repcode = 0; - else if(param->res <= 10) repcode = 2; - else if (param->res < 20) repcode = 5; - else if (param->res < 30) repcode = 1; - else if (param->res < 100) repcode = 4; - else repcode = param->res%10; - - if(ver == 5){ - buf[0] = 5; - buf[1] = repcode; - buf[2] = 0; - buf[3] = (*SAFAMILY(&sin) == AF_INET)?1:4; - memcpy(buf+4, SAADDR(&sin), SAADDRLEN(&sin)); - memcpy(buf+4+SAADDRLEN(&sin), SAPORT(&sin), 2); - socksend((command == 3)?param->ctrlsock:param->clisock, buf, 6+SAADDRLEN(&sin), conf.timeouts[STRING_S]); - } - else{ - buf[0] = 0; - buf[1] = 90 + !!(repcode); - memcpy(buf+2, SAPORT(&sin), 2); - memcpy(buf+4, SAADDR(&sin), 4); - socksend(param->clisock, buf, 8, conf.timeouts[STRING_S]); - } - - if (param->res == 0) { - switch(command) { - case 1: - if(param->redirectfunc){ - if(buf)myfree(buf); - return (*param->redirectfunc)(param); - } - param->res = sockmap(param, conf.timeouts[CONNECTION_L]); - break; - case 2: - so._listen (param->remsock, 1); - - fds[0].fd = param->remsock; - fds[1].fd = param->clisock; - fds[0].events = fds[1].events = POLLIN; - res = so._poll(fds, 2, conf.timeouts[CONNECTION_L] * 1000); - if (res < 1 || fds[1].revents) { - res = 460; - break; - } - sasize = sizeof(param->sinsr); - s = so._accept(param->remsock, (struct sockaddr *)¶m->sinsr, &sasize); - so._closesocket(param->remsock); - param->remsock = s; - if(s == INVALID_SOCKET) { - param->res = 462; - break; - } - if(SAISNULL(¶m->req) && - memcmp(SAADDR(¶m->req),SAADDR(¶m->sinsr),SAADDRLEN(¶m->req))) { - param->res = 470; - break; - } -#if SOCKSTRACE > 0 -fprintf(stderr, "Sending incoming connection to client with code %d for %s with %hu\n", - param->res, - commands[command], - *SAPORT(param->sins); - ); -fflush(stderr); -#endif - if(ver == 5){ - buf[3] = (*SAFAMILY(¶m->sinsr) == AF_INET)?1:4; - memcpy(buf+4, SAADDR(¶m->sinsr), SAADDRLEN(¶m->sinsr)); - memcpy(buf+4+SAADDRLEN(¶m->sinsr), SAPORT(¶m->sinsr), 2); - socksend(param->clisock, buf, 6+SAADDRLEN(¶m->sinsr), conf.timeouts[STRING_S]); - } - else { - memcpy (buf+2, SAPORT(¶m->sinsr), 2); - memcpy (buf+4, SAADDR(¶m->sinsr), 4); - socksend(param->clisock, buf, 8, conf.timeouts[STRING_S]); - } - - param->res = sockmap(param, conf.timeouts[CONNECTION_S]); - break; - case 3: - param->sinsr = param->req; - myfree(buf); - if(!(buf = myalloc(LARGEBUFSIZE))) {RETURN(21);} - - for(;;){ - fds[0].fd = param->remsock; - fds[1].fd = param->clisock; - fds[2].fd = param->ctrlsock; - fds[2].events = fds[1].events = fds[0].events = POLLIN; - - res = so._poll(fds, 3, conf.timeouts[CONNECTION_L]*1000); - if(res <= 0) { - param->res = 463; - break; - } - if (fds[2].revents) { - param->res = 0; - break; - } - if (fds[1].revents) { - sasize = sizeof(sin); - if((len = so._recvfrom(param->clisock, (char *)buf, 65535, 0, (struct sockaddr *)&sin, &sasize)) <= 10) { - param->res = 464; - break; - } - if(SAADDRLEN(&sin) != SAADDRLEN(¶m->sincr) || memcmp(SAADDR(&sin), SAADDR(¶m->sincr), SAADDRLEN(&sin))){ - param->res = 465; - break; - } - if(buf[0] || buf[1] || buf[2]) { - param->res = 466; - break; - } - size = 4; - switch(buf[3]) { - case 4: - size = 16; - case 1: - i = 4+size; - memcpy(SAADDR(¶m->sinsr), buf+4, size); - *SAFAMILY(¶m->sinsr) = (size == 4)?AF_INET:AF_INET6; - break; - case 3: - size = buf[4]; - for (i=4; size; i++, size--){ - buf[i] = buf[i+1]; - } - buf[i++] = 0; - if(!getip46(param->srv->family, buf, (struct sockaddr *) ¶m->sinsr)) RETURN(100); - break; - default: - RETURN(997); - } - - memcpy(SAPORT(¶m->sinsr), buf+i, 2); - i+=2; - - sasize = sizeof(param->sinsr); - if(len > (int)i){ - if(socksendto(param->remsock, (struct sockaddr *)¶m->sinsr, buf+i, len - i, conf.timeouts[SINGLEBYTE_L]*1000) <= 0){ - param->res = 467; - break; - } - param->statscli64+=(len - i); - param->nwrites++; -#if SOCKSTRACE > 1 -fprintf(stderr, "UDP packet relayed from client to %s:%hu size %d, header %d\n", - inet_ntoa(param->sins.sin_addr), - ntohs(param->sins.sin_port), - (len - i), - i - ); -fprintf(stderr, "client address is assumed to be %s:%hu\n", - inet_ntoa(sin.sin_addr), - ntohs(sin.sin_port) - ); -fflush(stderr); -#endif - } - - } - if (fds[0].revents) { - sasize = sizeof(param->sinsr); - buf[0]=buf[1]=buf[2]=0; - buf[3]=(*SAFAMILY(¶m->sinsl) == AF_INET)?1:4; - if((len = so._recvfrom(param->remsock, (char *)buf+6+SAADDRLEN(¶m->sinsl), 65535 - 10, 0, (struct sockaddr *)¶m->sinsr, &sasize)) <= 0) { - param->res = 468; - break; - } - param->statssrv64+=len; - param->nreads++; - memcpy(buf+4, SAADDR(¶m->sinsr), SAADDRLEN(¶m->sinsr)); - memcpy(buf+4+SAADDRLEN(¶m->sinsr), SAPORT(¶m->sinsr), 2); - sasize = sizeof(sin); - if(socksendto(param->clisock, (struct sockaddr *)&sin, buf, len + 6 + SAADDRLEN(¶m->sinsr), conf.timeouts[SINGLEBYTE_L]*1000) <=0){ - param->res = 469; - break; - } -#if SOCKSTRACE > 1 -fprintf(stderr, "UDP packet relayed to client from %hu size %d\n", - ntohs(*SAPORT(¶m->sinsr)), - len - ); -fflush(stderr); -#endif - - } - } - break; - default: - param->res = 417; - break; - } - } - } - - if(command > 3) command = 0; - if(buf){ - sprintf((char *)buf, "%s ", commands[command]); - if(param->hostname){ - sprintf((char *)buf + strlen((char *)buf), "%.265s", param->hostname); - } - else - myinet_ntop(*SAFAMILY(¶m->req), SAADDR(¶m->req), (char *)buf + strlen((char *)buf), 64); - sprintf((char *)buf+strlen((char *)buf), ":%hu", ntohs(*SAPORT(¶m->req))); - (*param->srv->logfunc)(param, buf); - myfree(buf); - } - freeparam(param); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - sockschild, - 1080, - 0, - S_SOCKS, - "" -}; -#include "proxymain.c" -#endif diff --git a/src/stringtable.c b/src/stringtable.c deleted file mode 100644 index a8bef1c..0000000 --- a/src/stringtable.c +++ /dev/null @@ -1,80 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include -#include "version.h" - -unsigned char * strings[] = { -/* 00 */ (unsigned char *)"3proxy tiny proxy server " VERSION " stringtable file", -/* 01 */ (unsigned char *)"3proxy", -/* 02 */ (unsigned char *)"3proxy tiny proxy server", -/* 03 */ (unsigned char *)VERSION " (" BUILDDATE ")", -/* 04 */ (unsigned char *)"3proxy allows to share and control Internet connection and count traffic", -/* 05 */ (unsigned char *)"SERVR", -/* 06 */ (unsigned char *)"PROXY", -/* 07 */ (unsigned char *)"TCPPM", -/* 08 */ (unsigned char *)"POP3P", -/* 09 */ (unsigned char *)"SOCK4", -/* 10 */ (unsigned char *)"SOCK5", -/* 11 */ (unsigned char *)"UDPPM", -/* 12 */ (unsigned char *)"SOCKS", -/* 13 */ (unsigned char *)"SOC45", -/* 14 */ (unsigned char *)"ADMIN", -/* 15 */ (unsigned char *)"DNSPR", -/* 16 */ (unsigned char *)"FTPPR", -/* 17 */ (unsigned char *)"SMTPP", -/* 18 */ (unsigned char *)"ICQPR", -/* 19 (unsigned char *)"MSNPR", */ -/* 19 */ (unsigned char *)"ZOMBIE", -/* 20 */ NULL, -/* 21 */ NULL, -/* 22 */ NULL, -/* 23 */ NULL, -/* 24 */ NULL, -#ifndef TPROXY_CONF -#ifndef _WIN32 -/* 25 */ (unsigned char *)"/usr/local/etc/3proxy/3proxy.cfg", -#else -/* 25 */ (unsigned char *)"3proxy.cfg", -#endif -#else -/* 25 */ (unsigned char *)TPROXY_CONF, -#endif -/* 26 */ NULL, -/* 27 */ NULL, -/* 28 */ NULL, -/* 29 */ NULL, -/* 30 */ NULL, -/* 31 */ NULL, -/* 32 */ NULL, -/* 33 */ NULL, -/* 34 */ NULL, -/* 35 */ (unsigned char *) - "
\n" - "

Welcome to 3proxy Web Interface

\n" - "Probably you've noticed interface is very ugly currently.\n" - "It's because you have development version of 3proxy and interface\n" - "is coded right now. What you see is a part of work that is done\n" - "already.\n" - "

Please send all your comments to\n" - "3proxy@security.nnov.ru\n" - "

Documentation:\n" - "http://3proxy.ru/\n" - "

", -/* 36 */ NULL, -/* 37 */ NULL, -/* 38 */ NULL, -/* 39 */ NULL, -/* 40 */ NULL, -/* 41 */ NULL, -/* 42 */ NULL, -/* 43 */ NULL, -/* 44 */ NULL, -}; - -int constants[] = {0,0}; diff --git a/src/tcppm.c b/src/tcppm.c deleted file mode 100644 index 62cdf56..0000000 --- a/src/tcppm.c +++ /dev/null @@ -1,40 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#ifndef PORTMAP -#define PORTMAP -#endif -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -void * tcppmchild(struct clientparam* param) { - int res; - - if(!param->hostname)parsehostname((char *)param->srv->target, param, ntohs(param->srv->targetport)); - param->operation = CONNECT; - res = (*param->srv->authfunc)(param); - if(res) {RETURN(res);} - RETURN (sockmap(param, conf.timeouts[CONNECTION_L])); -CLEANRET: - - (*param->srv->logfunc)(param, NULL); - freeparam(param); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - tcppmchild, - 0, - 0, - S_TCPPM, - "" -}; -#include "proxymain.c" -#endif diff --git a/src/udppm.c b/src/udppm.c deleted file mode 100644 index 7e19828..0000000 --- a/src/udppm.c +++ /dev/null @@ -1,119 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#ifndef PORTMAP -#define PORTMAP -#endif -#ifndef UDP -#define UDP -#endif -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - - -struct udpmap { - struct udpmap *next; - time_t updated; - SOCKET s; - int single; - unsigned long cliip; - unsigned short cliport; -}; - - -void * udppmchild(struct clientparam* param) { - unsigned char *buf = NULL; - int res, i; -#ifdef _WIN32 - SASIZETYPE size; - unsigned long ul = 1; -#endif - struct udpmap *udpmappings = NULL; - struct pollfd fds[256]; - - - if(!param->hostname)parsehostname((char *)param->srv->target, param, ntohs(param->srv->targetport)); - if (SAISNULL(¶m->req)) { - param->srv->fds.events = POLLIN; - RETURN (100); - } - if(!param->clibuf && (!(param->clibuf=myalloc(UDPBUFSIZE)) || !(param->clibufsize = UDPBUFSIZE))){ - param->srv->fds.events = POLLIN; - RETURN (21); - } - param->cliinbuf = param->clioffset = 0; - i = sockrecvfrom(param->srv->srvsock, (struct sockaddr *)¶m->sincr, param->clibuf, param->clibufsize, 0); - if(i<=0){ - param->srv->fds.events = POLLIN; - RETURN (214); - } - param->cliinbuf = i; - -#ifdef _WIN32 - if((param->clisock=so._socket(SASOCK(¶m->sincr), SOCK_DGRAM, IPPROTO_UDP)) == INVALID_SOCKET) { - RETURN(818); - } - if(so._setsockopt(param->clisock, SOL_SOCKET, SO_REUSEADDR, (char *)&ul, sizeof(int))) {RETURN(820);}; - ioctlsocket(param->clisock, FIONBIO, &ul); - size = sizeof(param->sinsl); - if(so._getsockname(param->srv->srvsock, (struct sockaddr *)¶m->sinsl, &size)) {RETURN(21);}; - if(so._bind(param->clisock,(struct sockaddr *)¶m->sinsl,SASIZE(¶m->sinsl))) { - RETURN(822); - } -#else - param->clisock = param->srv->srvsock; -#endif - -#ifndef NOIPV6 - memcpy(¶m->sinsl, *SAFAMILY(¶m->req) == AF_INET? (struct sockaddr *)¶m->srv->extsa : (struct sockaddr *)¶m->srv->extsa6, SASIZE(¶m->req)); -#else - memcpy(¶m->sinsl, ¶m->srv->extsa, SASIZE(¶m->req)); -#endif - *SAPORT(¶m->sinsl) = 0; - if ((param->remsock=so._socket(SASOCK(¶m->sinsl), SOCK_DGRAM, IPPROTO_UDP)) == INVALID_SOCKET) {RETURN (11);} - if(so._bind(param->remsock,(struct sockaddr *)¶m->sinsl,SASIZE(¶m->sinsl))) {RETURN (12);} -#ifdef _WIN32 - ioctlsocket(param->remsock, FIONBIO, &ul); -#else - fcntl(param->remsock,F_SETFL,O_NONBLOCK); -#endif - memcpy(¶m->sinsr, ¶m->req, sizeof(param->req)); - - param->operation = UDPASSOC; - if((res = (*param->srv->authfunc)(param))) {RETURN(res);} - if(param->srv->singlepacket) { - param->srv->fds.events = POLLIN; - } - - param->res = sockmap(param, conf.timeouts[(param->srv->singlepacket)?SINGLEBYTE_L:STRING_L]); - if(!param->srv->singlepacket) { - param->srv->fds.events = POLLIN; - } - -CLEANRET: - - if(buf)myfree(buf); - (*param->srv->logfunc)(param, NULL); -#ifndef _WIN32 - param->clisock = INVALID_SOCKET; -#endif - freeparam(param); - return (NULL); -} - -#ifdef WITHMAIN -struct proxydef childdef = { - udppmchild, - 0, - 1, - S_UDPPM, - " -s single packet UDP service for request/reply (DNS-like) services\n" -}; -#include "proxymain.c" -#endif diff --git a/src/webadmin.c b/src/webadmin.c deleted file mode 100644 index 70b47c4..0000000 --- a/src/webadmin.c +++ /dev/null @@ -1,578 +0,0 @@ -/* - 3APA3A simpliest proxy server - (c) 2002-2008 by ZARAZA <3APA3A@security.nnov.ru> - - please read License Agreement - -*/ - -#include "proxy.h" - -#define RETURN(xxx) { param->res = xxx; goto CLEANRET; } - -#define LINESIZE 2048 - -extern FILE *writable; -FILE * confopen(); -extern void decodeurl(unsigned char *s, int filter); - -struct printparam { - char buf[1024]; - int inbuf; - struct clientparam *cp; -}; - -static void stdpr(struct printparam* pp, char *buf, int inbuf){ - if((pp->inbuf + inbuf > 1024) || !buf) { - socksend(pp->cp->clisock, (unsigned char *)pp->buf, pp->inbuf, conf.timeouts[STRING_S]); - pp->inbuf = 0; - if(!buf) return; - } - if(inbuf >= 1000){ - socksend(pp->cp->clisock, (unsigned char *)buf, inbuf, conf.timeouts[STRING_S]); - } - else { - memcpy(pp->buf + pp->inbuf, buf, inbuf); - pp->inbuf += inbuf; - } -} - -static void stdcbf(void *cb, char *buf, int inbuf){ - int delay = 0; - int i; - - for(i = 0; i < inbuf; i++){ - switch(buf[i]){ - case '&': - if(delay){ - stdpr((struct printparam*)cb, buf+i-delay, delay); - delay = 0; - } - stdpr((struct printparam*)cb, "&", 5); - break; - case '<': - if(delay){ - stdpr((struct printparam*)cb, buf+i-delay, delay); - delay = 0; - } - stdpr((struct printparam*)cb, "<", 4); - break; - case '>': - if(delay){ - stdpr((struct printparam*)cb, buf+i-delay, delay); - delay = 0; - } - stdpr((struct printparam*)cb, ">", 4); - break; - default: - delay++; - break; - } - } - if(delay){ - stdpr((struct printparam*)cb, buf+i-delay, delay); - } -} - -/* -static char * templateprint(struct printparam* pp, int *level, struct dictionary *dict, char * template){ - char *s, *s2; - for(; template && *template; ){ - if(!( s = strchr(template, '<'))){ - stdpr(pp, template, (int)strlen(template)); - return template + strlen(template); - } - if(s[1] != '%' || s[2] == '%'){ - stdpr(pp, template, (int)(s - template) + 1); - template = s + 1; - continue; - } - if(s[2] == '/' && (s2 = strchr(s + 2, '>')) && *(s2 - 1) == '%'){ - if(--*level < 0) return NULL; - return s2 + 1; - } - } - return template; -} -*/ - -static void printstr(struct printparam* pp, char* str){ - stdpr(pp, str, str?(int)strlen(str):0); -} - -static void printval(void *value, int type, int level, struct printparam* pp){ - struct node pn, cn; - struct property *p; - int i; - - pn.iteration = NULL; - pn.parent = NULL; - pn.type = type; - pn.value = value; - - printstr(pp, ""); - for(p = datatypes[type].properties; p; ) { - cn.iteration = NULL; - cn.parent = &pn; - cn.type = p->type; - cn.value = (*p->e_f)(&pn); - if(cn.value){ - for(i = 0; i < level; i++) printstr(pp, "\t"); - if(strcmp(p->name, "next")){ - printstr(pp, ""); - printstr(pp, ""); - printstr(pp, p->name); - printstr(pp, ""); - printstr(pp, ""); - printstr(pp, datatypes[p->type].type); - printstr(pp, ""); - printstr(pp, ""); - printstr(pp, p->description); - printstr(pp, ""); - } - if(datatypes[p->type].p_f){ - printstr(pp, "type].p_f)(&cn, stdcbf, pp); - printstr(pp, "]]>\n"); - printstr(pp, ""); - } - else { - if(!strcmp(p->name, "next")){ -/* printstr(pp, "\n"); */ - printstr(pp, "\n"); - p = datatypes[type].properties; - pn.value = value = cn.value; - continue; - } - else { - printstr(pp, "\n"); - printval(cn.value, cn.type, level+1, pp); - printstr(pp, ""); - } - } - } - p=p->next; - } - printstr(pp, ""); -} - - -char * admin_stringtable[]={ - "HTTP/1.0 401 Authentication Required\r\n" - "WWW-Authenticate: Basic realm=\"proxy\"\r\n" - "Connection: close\r\n" - "Content-type: text/html; charset=us-ascii\r\n" - "\r\n" - "401 Authentication Required\r\n" - "

401 Authentication Required

Access to requested resource disallowed by administrator or you need valid username/password to use this resource

\r\n", - - "HTTP/1.0 200 OK\r\n" - "Connection: close\r\n" - "Expires: Thu, 01 Dec 1994 16:00:00 GMT\r\n" - "Cache-Control: no-cache\r\n" - "Content-type: text/html\r\n" - "\r\n" - "%s configuration page\r\n" - "\r\n" - "
\r\n" - "

         " - "         

\r\n" - "Counters
\r\n" - "Reload
\r\n" - "Running Services
\r\n" - "Config\r\n" - "
" - "

%s %s configuration

", - - "HTTP/1.0 200 OK\r\n" - "Connection: close\r\n" - "Cache-Control: no-cache\r\n" - "Content-type: text/xml\r\n" - "\r\n" - "\r\n" - "\r\n" - "\r\n" - "Services currently running and connected clients\r\n", - - "\r\n", - - - "HTTP/1.0 200 OK\r\n" - "Connection: close\r\n" - "Cache-Control: no-cache\r\n" - "Content-type: text/css\r\n" - "\r\n" - "services {\r\n" - " display: block;\r\n" - " margin: 10px auto 10px auto;\r\n" - " width: 80%;\r\n" - " background: black;\r\n" - " font-family: sans-serif;\r\n" - " font-size: small;\r\n" - " color: silver;\r\n" - " }\r\n" - "item {\r\n" - " display: block;\r\n" - " margin-bottom: 10px;\r\n" - " border: 2px solid #CCC;\r\n" - " padding: 10px;\r\n" - " spacing: 2px;\r\n" - " }\r\n" - "parameter {\r\n" - " display: block;\r\n" - " padding: 2px;\r\n" - " margin-top: 10px;\r\n" - " border: 1px solid grey;\r\n" - " background: #EEE;\r\n" - " color: black;\r\n" - " }\r\n" - "name {\r\n" - " display: inline;\r\n" - " float: left;\r\n" - " margin-right: 5px;\r\n" - " font-weight: bold;\r\n" - " }\r\n" - "type {\r\n" - " display: inline;\r\n" - " font-size: x-small;\r\n" - " margin-right: 5px;\r\n" - " color: #666;\r\n" - " white-space: nowrap;\r\n" - " font-style: italic;\r\n" - " }\r\n" - "description {\r\n" - " display: inline;\r\n" - " margin-right: 5px;\r\n" - " white-space: nowrap;\r\n" - " }\r\n" - "value {\r\n" - " display: block;\r\n" - " margin-right: 5px;\r\n" - " }\r\n", - - - "










\r\n" - "
"
-	COPYRIGHT
-	"\r\n"
-	"
", - - "

Counters

\r\n" - "\r\n" - "" - "" - "" - "" - "\r\n", - - "
DescriptionActiveUsersSource AddressDestination AddressPortLimitUnitsValueResetUpdatedNum
\r\n", - - NULL -}; - -#define authreq admin_stringtable[0] -#define ok admin_stringtable[1] -#define xml admin_stringtable[2] -#define postxml admin_stringtable[3] -#define style admin_stringtable[4] -#define tail admin_stringtable[5] -#define counters admin_stringtable[6] -#define counterstail admin_stringtable[7] - - -static int printportlist(char *buf, int bufsize, struct portlist* pl, char * delim){ - int printed = 0; - - for(; pl; pl = pl->next){ - if(printed > (bufsize - 64)) break; - if(pl->startport != pl->endport) - printed += sprintf(buf+printed, "%hu-%hu%s", pl->startport, pl->endport, pl->next?delim:""); - else { -/* - struct servent *se=NULL; - if(pl->startport)se = getservbyport((int)ntohs(pl->startport), NULL); - printed += sprintf(buf+printed, "%hu(%s)%s", pl->startport, se?se->s_name:"unknown", pl->next?delim:""); -*/ - printed += sprintf(buf+printed, "%hu%s", pl->startport, pl->next?delim:""); - } - if(printed > (bufsize - 64)) { - printed += sprintf(buf+printed, "..."); - break; - } - } - return printed; -} - - -static int printuserlist(char *buf, int bufsize, struct userlist* ul, char * delim){ - int printed = 0; - - for(; ul; ul = ul->next){ - if(printed > (bufsize - 64)) break; - printed += sprintf(buf+printed, "%s%s", ul->user, ul->next?delim:""); - if(printed > (bufsize - 64)) { - printed += sprintf(buf+printed, "..."); - break; - } - } - return printed; -} - - -int printiple(char *buf, struct iplist* ipl); - -static int printiplist(char *buf, int bufsize, struct iplist* ipl, char * delim){ - int printed = 0; - for(; ipl; ipl = ipl->next){ - if(printed > (bufsize - 128)) break; - printed += printiple(buf+printed, ipl); - if(printed > (bufsize - 128)) { - printed += sprintf(buf+printed, "..."); - break; - } - } - return printed; -} - -void * adminchild(struct clientparam* param) { - int i, res; - char * buf; - char username[256]; - char *sb; - char *req = NULL; - struct printparam pp; - int contentlen = 0; - int isform = 0; - - pp.inbuf = 0; - pp.cp = param; - - buf = myalloc(LINESIZE); - if(!buf) {RETURN(555);} - i = sockgetlinebuf(param, CLIENT, (unsigned char *)buf, LINESIZE - 1, '\n', conf.timeouts[STRING_S]); - if(i<5 || ((buf[0]!='G' || buf[1]!='E' || buf[2]!='T' || buf[3]!=' ' || buf[4]!='/') && - (buf[0]!='P' || buf[1]!='O' || buf[2]!='S' || buf[3]!='T' || buf[4]!=' ' || buf[5]!='/'))) - { - RETURN(701); - } - buf[i] = 0; - sb = strchr(buf+5, ' '); - if(!sb){ - RETURN(702); - } - *sb = 0; - req = mystrdup(buf + ((*buf == 'P')? 6 : 5)); - while((i = sockgetlinebuf(param, CLIENT, (unsigned char *)buf, LINESIZE - 1, '\n', conf.timeouts[STRING_S])) > 2){ - buf[i] = 0; - if(i > 19 && (!strncasecmp(buf, "authorization", 13))){ - sb = strchr(buf, ':'); - if(!sb)continue; - ++sb; - while(isspace(*sb))sb++; - if(!*sb || strncasecmp(sb, "basic", 5)){ - continue; - } - sb+=5; - while(isspace(*sb))sb++; - i = de64((unsigned char *)sb, (unsigned char *)username, 255); - if(i<=0)continue; - username[i] = 0; - sb = strchr((char *)username, ':'); - if(sb){ - *sb = 0; - if(param->password)myfree(param->password); - param->password = (unsigned char *)mystrdup(sb+1); - } - if(param->username) myfree(param->username); - param->username = (unsigned char *)mystrdup(username); - continue; - } - else if(i > 15 && (!strncasecmp(buf, "content-length:", 15))){ - sb = buf + 15; - while(isspace(*sb))sb++; - contentlen = atoi(sb); - } - else if(i > 13 && (!strncasecmp(buf, "content-type:", 13))){ - sb = buf + 13; - while(isspace(*sb))sb++; - if(!strncasecmp(sb, "x-www-form-urlencoded", 21)) isform = 1; - } - } - param->operation = ADMIN; - if(isform && contentlen) { - printstr(&pp, "HTTP/1.0 100 Continue\r\n\r\n"); - stdpr(&pp, NULL, 0); - } - res = (*param->srv->authfunc)(param); - if(res && res != 10) { - printstr(&pp, authreq); - RETURN(res); - } - if(param->srv->singlepacket || param->redirected){ - if(*req == 'C') req[1] = 0; - else *req = 0; - } - sprintf(buf, ok, conf.stringtable?(char *)conf.stringtable[2]:"3proxy", conf.stringtable?(char *)conf.stringtable[2]:"3[APA3A] tiny proxy", conf.stringtable?(char *)conf.stringtable[3]:""); - if(*req != 'S') printstr(&pp, buf); - switch(*req){ - case 'C': - printstr(&pp, counters); - { - struct trafcount *cp; - int num = 0; - for(cp = conf.trafcounter; cp; cp = cp->next, num++){ - int inbuf = 0; - - if(cp->ace && (param->srv->singlepacket || param->redirected)){ - if(!ACLmatches(cp->ace, param))continue; - } - if(req[1] == 'S' && atoi(req+2) == num) cp->disabled=0; - if(req[1] == 'D' && atoi(req+2) == num) cp->disabled=1; - inbuf += sprintf(buf, "" - "%s%s", - (cp->comment)?cp->comment:" ", - (cp->disabled)?'S':'D', - num, - (cp->disabled)?"NO":"YES" - ); - if(!cp->ace || !cp->ace->users){ - inbuf += sprintf(buf+inbuf, "
ANY
"); - } - else { - inbuf += printuserlist(buf+inbuf, LINESIZE-800, cp->ace->users, ",
\r\n"); - } - inbuf += sprintf(buf+inbuf, ""); - if(!cp->ace || !cp->ace->src){ - inbuf += sprintf(buf+inbuf, "
ANY
"); - } - else { - inbuf += printiplist(buf+inbuf, LINESIZE-512, cp->ace->src, ",
\r\n"); - } - inbuf += sprintf(buf+inbuf, ""); - if(!cp->ace || !cp->ace->dst){ - inbuf += sprintf(buf+inbuf, "
ANY
"); - } - else { - inbuf += printiplist(buf+inbuf, LINESIZE-512, cp->ace->dst, ",
\r\n"); - } - inbuf += sprintf(buf+inbuf, ""); - if(!cp->ace || !cp->ace->ports){ - inbuf += sprintf(buf+inbuf, "
ANY
"); - } - else { - inbuf += printportlist(buf+inbuf, LINESIZE-128, cp->ace->ports, ",
\r\n"); - } - if(cp->type == NONE) { - inbuf += sprintf(buf+inbuf, - "exclude from limitation\r\n" - ); - } - else { - inbuf += sprintf(buf+inbuf, - "%"PRINTF_INT64_MODIFIER"u" - "MB%s" - "%"PRINTF_INT64_MODIFIER"u" - "%s", - cp->traflim64 / (1024 * 1024), - rotations[cp->type], - cp->traf64, - cp->cleared?ctime(&cp->cleared):"never" - ); - inbuf += sprintf(buf + inbuf, - "%s" - "%i" - "\r\n", - - cp->updated?ctime(&cp->updated):"never", - cp->number - ); - } - printstr(&pp, buf); - } - - } - printstr(&pp, counterstail); - break; - - case 'R': - conf.needreload = 1; - printstr(&pp, "

Reload scheduled

"); - break; - case 'S': - { - if(req[1] == 'X'){ - printstr(&pp, style); - break; - } - printstr(&pp, xml); - printval(conf.services, TYPE_SERVER, 0, &pp); - printstr(&pp, postxml); - } - break; - case 'F': - { - FILE *fp; - char buf[256]; - - fp = confopen(); - if(!fp){ - printstr(&pp, "

Failed to open config file

"); - break; - } - printstr(&pp, "

Please be careful editing config file remotely

"); - printstr(&pp, "

"); - break; - } - case 'U': - { - int l=0; - int error = 0; - - if(!writable || fseek(writable, 0, 0)){ - error = 1; - } - while((i = sockgetlinebuf(param, CLIENT, (unsigned char *)buf, LINESIZE - 1, '+', conf.timeouts[STRING_S])) > 0){ - if(i > (contentlen - l)) i = (contentlen - l); - buf[i] = 0; - if(!l){ - if(strncasecmp(buf, "conffile=", 9)) error = 1; - } - if(!error){ - decodeurl((unsigned char *)buf, 1); - fprintf(writable, "%s", l? buf : buf + 9); - } - l += i; - if(l >= contentlen) break; - } - if(writable && !error){ - fflush(writable); -#ifndef _WINCE - ftruncate(fileno(writable), ftell(writable)); -#endif - } - printstr(&pp, error? "

Config file is not writable

Make sure you have \"writable\" command in configuration file": - "

Configuration updated

"); - - } - break; - default: - printstr(&pp, (char *)conf.stringtable[WEBBANNERS]); - break; - } - if(*req != 'S') printstr(&pp, tail); - -CLEANRET: - - - printstr(&pp, NULL); - if(buf) myfree(buf); - (*param->srv->logfunc)(param, (unsigned char *)req); - if(req)myfree(req); - freeparam(param); - return (NULL); -}