diff options
author | mi <mi@FreeBSD.org> | 2001-03-13 02:50:33 +0800 |
---|---|---|
committer | mi <mi@FreeBSD.org> | 2001-03-13 02:50:33 +0800 |
commit | 7aefd0f4c7d1adac3f8ef871a4fbe95f85f9c119 (patch) | |
tree | 187f4b5a2c088502d508569c52b3370d07117d23 /net-mgmt/scotty3/files | |
parent | 0f05889fd452e74003ca21e50023980e7fee4aed (diff) | |
download | freebsd-ports-gnome-7aefd0f4c7d1adac3f8ef871a4fbe95f85f9c119.tar.gz freebsd-ports-gnome-7aefd0f4c7d1adac3f8ef871a4fbe95f85f9c119.tar.zst freebsd-ports-gnome-7aefd0f4c7d1adac3f8ef871a4fbe95f85f9c119.zip |
A number of changes and fixes:
. build with or without TK (triggered by the NO_X knob)
. build against TCL-8.3 -- with or without stubs
. fix some bugs in the core Scotty code -- most notably
a bug in the icmp-command implementation, where an off-by-one
error in the argument processing loop resulted in random
crashes; all this fixes are grouped into a single file
patch-fixes
. make scotty executable itself as small as it needs to be
Approved by: maintainer
Perhaps, some day the security officer will tell me what _exactly_ is
wrong with regular Scotty (this one is beta of the new version), and
I'll be able to freshen that one up too and remove the FORBIDDEN.
Diffstat (limited to 'net-mgmt/scotty3/files')
-rw-r--r-- | net-mgmt/scotty3/files/patch-ac | 33 | ||||
-rw-r--r-- | net-mgmt/scotty3/files/patch-ad | 59 | ||||
-rw-r--r-- | net-mgmt/scotty3/files/patch-fixes | 38 | ||||
-rw-r--r-- | net-mgmt/scotty3/files/scotty.c | 27 |
4 files changed, 137 insertions, 20 deletions
diff --git a/net-mgmt/scotty3/files/patch-ac b/net-mgmt/scotty3/files/patch-ac index 777ab9f94780..cc564591c641 100644 --- a/net-mgmt/scotty3/files/patch-ac +++ b/net-mgmt/scotty3/files/patch-ac @@ -1,22 +1,23 @@ ---- Makefile.in.orig Thu Feb 17 01:08:00 2000 -+++ Makefile.in Wed Jun 7 16:07:39 2000 -@@ -500,11 +500,11 @@ - pwd=`pwd`; cd $(TNM_TEST_DIR); $$pwd/scotty all.tcl +--- Makefile.in Wed Feb 16 11:08:00 2000 ++++ Makefile.in Thu Mar 8 19:20:25 2001 +@@ -56,7 +56,7 @@ - install: @INSTALL_TARGETS@ -- @echo "" -- @echo "The Tnm extension includes two programs (nmicmpd, nmtrapd)" -- @echo "which require root permissions. Please get root permissions" -- @echo "and type >> make sinstall << to install them setuid root." -- @echo "" -+# @echo "" -+# @echo "The Tnm extension includes two programs (nmicmpd, nmtrapd)" -+# @echo "which require root permissions. Please get root permissions" -+# @echo "and type >> make sinstall << to install them setuid root." -+# @echo "" + # To change the compiler switches, for example to change from -O + # to -g, change the following line: +-CFLAGS = -O ++CFLAGS = @CFLAGS@ - install-bin: tnm-install-bin tki-install-bin + # NMICMPD should contain the full path to the installed nmicmpd binary. + NMICMPD = $(BIN_INSTALL_DIR)/nmicmpd +@@ -473,7 +473,7 @@ + $(LD) $(LD_FLAGS) $(LD_SEARCH_FLAGS) -o scotty scotty.o $(TCL_LIB_SPEC) $(LIBS) $(DL_LIBS) -lm + tnm$(SHLIB_SUFFIX): $(TNM_OBJS) +- $(SHLIB_LD) $(TNM_OBJS) -o tnm$(SHLIB_SUFFIX) $(LIBS) ++ $(SHLIB_LD) $(TNM_OBJS) -o tnm$(SHLIB_SUFFIX) @NEED_TCL_LIB@ $(LIBS) + + tkined: tkined$(SHLIB_SUFFIX) $(UNIX_DIR)/tkined.in + @sed -e 's+%WISH%+$(TK_WISH)+' \ @@ -528,7 +528,7 @@ @$(INSTALL_PROGRAM) scotty $(BIN_INSTALL_DIR)/scotty$(TNM_VERSION) @$(INSTALL_DATA) tnm$(SHLIB_SUFFIX) $(LIB_RUNTIME_DIR)/tnm$(TNM_VERSION)$(SHLIB_SUFFIX) diff --git a/net-mgmt/scotty3/files/patch-ad b/net-mgmt/scotty3/files/patch-ad index 4b43418fdc26..e09d45dc0d54 100644 --- a/net-mgmt/scotty3/files/patch-ad +++ b/net-mgmt/scotty3/files/patch-ad @@ -1,6 +1,6 @@ ---- configure.orig Wed Feb 16 19:08:00 2000 -+++ configure Tue Jun 6 03:36:37 2000 -@@ -749,7 +749,7 @@ +--- configure Wed Feb 16 11:08:00 2000 ++++ configure Thu Mar 8 19:22:52 2001 +@@ -749,9 +749,14 @@ LD_FLAGS=$TCL_LD_FLAGS LD_SEARCH_FLAGS=$TCL_LD_SEARCH_FLAGS TCL_EXEC_PREFIX=$TCL_EXEC_PREFIX @@ -8,8 +8,34 @@ +TCL_INCLUDES=-I$TCL_PREFIX/include/tcl$TCL_VERSION TK_EXEC_PREFIX=$TK_EXEC_PREFIX ++if /usr/bin/ldd ${prefix}/bin/tclsh$TCL_VERSION | fgrep -qv libtcl; then ++ CFLAGS="$CFLAGS -DUSE_TCL_STUBS" ++ NEED_TCL_LIB=$TCL_LIB_SPEC ++fi ++ if test $TCL_SHARED_BUILD -ne 1 ; then -@@ -842,7 +842,7 @@ + { echo "configure: error: Tcl is not configured with --enable-shared" 1>&2; exit 1; } + fi +@@ -763,8 +767,8 @@ + echo $ac_n "checking for tcl version""... $ac_c" 1>&6 + echo "configure:765: checking for tcl version" >&5 + echo "$ac_t"""$TCL_VERSION"" 1>&6 +-if test "$TCL_VERSION" != "8.2" ; then +- { echo "configure: error: "Tcl version 8.2 needed"" 1>&2; exit 1; } ++if test "$TCL_VERSION" \< "8.2" ; then ++ { echo "configure: error: "Tcl version at least 8.2 needed"" 1>&2; exit 1; } + fi + + BUILD_TARGETS="$BUILD_TARGETS scotty" +@@ -821,6 +825,7 @@ + fi + + ++if test x$tnm_path_tk_config != xno; then + dirs="$tnm_path_tk_config $wish_prefix/lib $prefix/lib /usr/local/lib" + + found=0 +@@ -842,7 +847,7 @@ echo "configure: warning: "will not build tkined"" 1>&2 else . $tnm_cv_path_tk_config/tkConfig.sh @@ -18,3 +44,28 @@ if test "$TK_INCLUDES" = "$TCL_INCLUDES" ; then TK_INCLUDES="" fi +@@ -850,13 +855,14 @@ + echo $ac_n "checking for tk version""... $ac_c" 1>&6 + echo "configure:852: checking for tk version" >&5 + echo "$ac_t"""$TK_VERSION"" 1>&6 +- if test "$TK_VERSION" != "8.2" ; then +- { echo "configure: error: "Tk version 8.2 needed"" 1>&2; exit 1; } ++ if test "$TK_VERSION" \< "8.2" ; then ++ { echo "configure: error: "Tk version at least 8.2 needed"" 1>&2; exit 1; } + fi + + BUILD_TARGETS="$BUILD_TARGETS tkined" + INSTALL_TARGETS="$INSTALL_TARGETS tki-install" + fi ++fi # --with-tk=<something other than ``no''> + + #---------------------------------------------------------------------------- + # Check for some basic stuff. We don't check for the compiler. +@@ -3318,6 +3324,7 @@ + s%@DEFS@%$DEFS%g + s%@LDFLAGS@%$LDFLAGS%g + s%@LIBS@%$LIBS%g ++s%@NEED_TCL_LIB@%$NEED_TCL_LIB%g + s%@exec_prefix@%$exec_prefix%g + s%@prefix@%$prefix%g + s%@program_transform_name@%$program_transform_name%g diff --git a/net-mgmt/scotty3/files/patch-fixes b/net-mgmt/scotty3/files/patch-fixes new file mode 100644 index 000000000000..0940c7e0c6cd --- /dev/null +++ b/net-mgmt/scotty3/files/patch-fixes @@ -0,0 +1,38 @@ +This patches fix actual BUGS in the Scotty code: + . any Tcl above 8.2 will also work fine; + . icmp.test no longer causes crashes -- an off-by-one + error in argument parsing code was the reason for + occasional segfaults + . TUBS-REGISTRATION was renamed to TUBS-SMI, but the + mibs.test did not know about it +There still are some test failures, but I think (hope), they are due to +mistakes in the tests themselves. + + -mi + +--- ../tnm/generic/tnmInit.c Wed Oct 6 05:35:57 1999 ++++ ../tnm/generic/tnmInit.c Thu Mar 8 19:49:33 2001 +@@ -431,3 +431,3 @@ + #ifdef USE_TCL_STUBS +- if (Tcl_InitStubs(interp, "8.2", 1) == NULL) { ++ if (Tcl_InitStubs(interp, TCL_VERSION, 0) == NULL) { + return TCL_ERROR; +--- ../tnm/generic/tnmIcmp.c Wed Oct 6 05:07:04 1999 ++++ ../tnm/generic/tnmIcmp.c Fri Mar 9 17:58:05 2001 +@@ -273,6 +273,6 @@ + * Parse the options. + */ + +- while (1) { ++ while (x < objc) { + code = TnmGetTableKeyFromObj(interp, icmpOptionTable, + objv[x], "option"); +--- ../tnm/tests/mib.test Fri Feb 11 14:43:38 2000 ++++ ../tnm/tests/mib.test Fri Mar 9 18:25:48 2001 +@@ -30,1 +30,1 @@ +-lappend tnm(mibs) TUBS-REGISTRATION TUBS-IBR-TEST-MIB ++lappend tnm(mibs) TUBS-SMI TUBS-IBR-TEST-MIB +@@ -689,2 +689,2 @@ + mib info files *SMI +-} {RFC1155-SMI SNMPv2-SMI} ++} {RFC1155-SMI SNMPv2-SMI TUBS-SMI} diff --git a/net-mgmt/scotty3/files/scotty.c b/net-mgmt/scotty3/files/scotty.c new file mode 100644 index 000000000000..375cd2a7529e --- /dev/null +++ b/net-mgmt/scotty3/files/scotty.c @@ -0,0 +1,27 @@ +/* All that's needed for bin/scotty, really... -mi */ + +#include "tnmInt.h" + +static int +Tcl_AppInit(interp) + Tcl_Interp *interp; +{ + if (Tcl_Init(interp) != TCL_OK) { + return TCL_ERROR; + } + + if (Tcl_PkgRequire(interp, "Tnm", TNM_VERSION, 1) == NULL) { + return TCL_ERROR; + } + + Tcl_SetVar(interp, "tcl_rcFileName", "~/.tclshrc", TCL_GLOBAL_ONLY); + return TCL_OK; +} + +int +main(argc, argv) + int argc; + char **argv; +{ + Tcl_Main(argc, argv, Tcl_AppInit); +} |