The branch, master has been updated
       via  6dd6000... s3:add split_tokens, a cmdline tool to test 
next_token_talloc()
       via  92547d2... s3:fix linking of the t_str* test programs
       via  b82f685... s3:fix linking of libbigballofmud (on my box at least)
       via  350352c... s3:torture: make t_stringoverflow.c compile at least 
(pstring is long gone)
      from  8303bc4... Restructure the connect function code to always call 
down to NEXT-> before initializing. This allows us to do cleanup (by calling 
DISCONNECT) if initialization fails. Also fix vfs_acl_xattr which was failing 
to call the NEXT connect function. Jeremy.

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master


- Log -----------------------------------------------------------------
commit 6dd60008c4bebf42795d4a030b3724ce610bbeeb
Author: Michael Adam <ob...@samba.org>
Date:   Tue Dec 1 00:53:03 2009 +0100

    s3:add split_tokens, a cmdline tool to test next_token_talloc()
    
    Michael

commit 92547d2873b357b3d6ea21edff646a66f1d22368
Author: Michael Adam <ob...@samba.org>
Date:   Fri Nov 20 18:25:27 2009 +0100

    s3:fix linking of the t_str* test programs
    
    Michael

commit b82f6855a2762df6240caf100fe775aa06392c40
Author: Michael Adam <ob...@samba.org>
Date:   Fri Nov 20 18:24:53 2009 +0100

    s3:fix linking of libbigballofmud (on my box at least)
    
    Michael

commit 350352cf38bccfa6ef60db1840bd09a4798a392e
Author: Michael Adam <ob...@samba.org>
Date:   Fri Nov 20 17:48:18 2009 +0100

    s3:torture: make t_stringoverflow.c compile at least (pstring is long gone)
    
    I don't know whether these t_* programs are used at all any more, but this
    one was using pstrcpy...
    
    Michael

-----------------------------------------------------------------------

Summary of changes:
 source3/Makefile.in                |   28 ++++++++++---
 source3/torture/t_stringoverflow.c |    4 +-
 source3/utils/split_tokens.c       |   78 ++++++++++++++++++++++++++++++++++++
 3 files changed, 101 insertions(+), 9 deletions(-)
 create mode 100644 source3/utils/split_tokens.c


Changeset truncated at 500 lines:

diff --git a/source3/Makefile.in b/source3/Makefile.in
index 29a5b3d..b1f1658 100644
--- a/source3/Makefile.in
+++ b/source3/Makefile.in
@@ -1344,6 +1344,12 @@ DBWRAP_TORTURE_OBJ = utils/dbwrap_torture.o \
                     $(LIBSAMBA_OBJ) \
                     $(POPT_LIB_OBJ)
 
+SPLIT_TOKENS_OBJ = utils/split_tokens.o \
+                   $(PARAM_OBJ) \
+                  $(LIB_NONSMBD_OBJ) \
+                  $(POPT_LIB_OBJ) \
+                  $(LIBSAMBA_OBJ)
+
 ######################################################################
 # now the rules...
 ######################################################################
@@ -2419,11 +2425,11 @@ showlibs:: showlibsmbsharemodes
 #-------------------------------------------------------------------
 
 # This is probably wrong for anything other than the GNU linker.
-bin/libbigballofm...@shlibext@: $(BINARY_PREREQS) $(LIBBIGBALLOFMUD_OBJ) 
$(LIBTALLOC)
+bin/libbigballofm...@shlibext@: $(BINARY_PREREQS) $(LIBBIGBALLOFMUD_OBJ) 
$(LIBTALLOC) $(LIBTDB) $(LIBWBCLIENT)
        @echo Linking shared library $@
        @$(SHLD) $(LDSHFLAGS) -o $@ $(LIBBIGBALLOFMUD_OBJ) \
-               $(LIBS) $(LIBTALLOC_LIBS) \
-               $(PASSDB_LIBS) $(IDMAP_LIBS) $(KRB5LIBS) $(LDAP_LIBS) \
+               $(LIBS) $(LIBTALLOC_LIBS) $(LIBTDB_LIBS) $(LIBWBCLIENT_LIBS) \
+               $(PASSDB_LIBS) $(IDMAP_LIBS) $(KRB5LIBS) $(LDAP_LIBS) -lz \
                @sonamef...@`basename $...@`.$(LIBBIGBALLOFMUD_MAJOR)
        ln -snf libbigballofmud.so bin/libbigballofmud.so.0
 
@@ -2875,19 +2881,19 @@ bin/tdbtort...@exeext@: $(BINARY_PREREQS) 
$(TDBTORTURE_OBJ) $(LIBTALLOC) $(LIBTD
 
 bin/t_str...@exeext@: $(BINARY_PREREQS) $(LIBTALLOC) 
bin/libbigballofm...@shlibext@ torture/t_strcmp.o
        $(CC) -o $@ $(DYNEXP) $(LIBS) $(LIBTALLOC_LIBS) \
-               torture/t_strcmp.o -L ./bin -lbigballofmud
+               torture/t_strcmp.o -L ./bin -lbigballofmud $(LIBWBCLIENT_LIBS)
 
 bin/t_str...@exeext@: $(BINARY_PREREQS) $(LIBTALLOC) 
bin/libbigballofm...@shlibext@ torture/t_strstr.o
        $(CC) -o $@ $(DYNEXP) $(LIBS) $(LIBTALLOC_LIBS) \
-               torture/t_strstr.o -L ./bin -lbigballofmud
+               torture/t_strstr.o -L ./bin -lbigballofmud $(LIBWBCLIENT_LIBS)
 
 bin/t_strapp...@exeext@: $(BINARY_PREREQS) $(LIBTALLOC) 
bin/libbigballofm...@shlibext@ torture/t_strappend.o
        $(CC) -o $@ $(DYNEXP) $(LIBS) $(LIBTALLOC_LIBS) \
-               torture/t_strappend.o -L ./bin -lbigballofmud
+               torture/t_strappend.o -L ./bin -lbigballofmud 
$(LIBWBCLIENT_LIBS)
 
 bin/t_stringoverf...@exeext@: $(BINARY_PREREQS) bin/libbigballofm...@shlibext@ 
torture/t_stringoverflow.o
        $(CC) -o $@ $(DYNEXP) torture/t_stringoverflow.o \
-               -L./bin -lbigballofmud
+               -L./bin -lbigballofmud $(LIBWBCLIENT_LIBS)
 
 bin/timeli...@exeext@: script/tests/timelimit.o
        @echo Linking $@
@@ -2927,6 +2933,14 @@ bin/dbwrap_tort...@exeext@: $(DBWRAP_TORTURE_OBJ) 
$(LIBTALLOC) $(LIBTDB)
 install-dbwrap_torture:: bin/dbwrap_tort...@exeext@
        @$(SHELL) script/installbin.sh $(INSTALLPERMS_BIN) $(DESTDIR) $(prefix) 
$(BINDIR) $<
 
+bin/split_tok...@exeext@: $(BINARY_PREREQS) $(SPLIT_TOKENS_OBJ) @BUILD_POPT@ 
$(LIBTALLOC) $(LIBTDB)
+       @echo "Linking $@"
+       @$(CC) -o $@ $(SPLIT_TOKENS_OBJ) \
+               $(LDFLAGS) $(DYNEEXP) \
+               $(LIBS) $(POPT_LIBS) \
+               $(LDAP_LIBS) \
+               $(LIBTALLOC_LIBS) $(LIBTDB_LIBS)
+
 install:: installservers installbin @INSTALL_CIFSMOUNT@ @INSTALL_CIFSUMOUNT@ 
@INSTALL_CIFSUPCALL@ installman \
                installscripts installdat installmodules @SWAT_INSTALL_TARGETS@ 
\
                @INSTALL_PAM_MODULES@ installlibs installmo
diff --git a/source3/torture/t_stringoverflow.c 
b/source3/torture/t_stringoverflow.c
index ec14d81..17765e6 100644
--- a/source3/torture/t_stringoverflow.c
+++ b/source3/torture/t_stringoverflow.c
@@ -2,7 +2,7 @@
 
  int main(void)
 {
-       fstring dest;
+       char dest[100];
        char *ptr = dest;
 
        printf("running on valgrind? %d\n", RUNNING_ON_VALGRIND);
@@ -17,7 +17,7 @@
        pstrcpy(dest, "hello");
 #endif /* 0 */
 
-       pstrcpy(ptr, "hello!");
+       fstrcpy(ptr, "hello!");
 
        return 0;
 }
diff --git a/source3/utils/split_tokens.c b/source3/utils/split_tokens.c
new file mode 100644
index 0000000..ac4f726
--- /dev/null
+++ b/source3/utils/split_tokens.c
@@ -0,0 +1,78 @@
+/*
+   Unix SMB/CIFS implementation.
+   test program for the next_token() function
+
+   Copyright (C) 2009 Michael Adam
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+/*
+ * Diagnostic output for "next_token()".
+ */
+
+#include "includes.h"
+
+extern bool AllowDebugChange;
+
+int main(int argc, const char *argv[])
+{
+       const char *config_file = get_dyn_CONFIGFILE();
+       const char *sequence = "";
+       poptContext pc;
+       char *buff;
+       TALLOC_CTX *ctx = talloc_stackframe();
+
+       struct poptOption long_options[] = {
+               POPT_AUTOHELP
+               POPT_COMMON_VERSION
+               POPT_TABLEEND
+       };
+
+       load_case_tables();
+
+       pc = poptGetContext(NULL, argc, argv, long_options,
+                           POPT_CONTEXT_KEEP_FIRST);
+       poptSetOtherOptionHelp(pc, "[OPTION...] <sequence-string>");
+
+       while(poptGetNextOpt(pc) != -1);
+
+       setup_logging(poptGetArg(pc), true);
+
+       sequence = poptGetArg(pc);
+
+       if (sequence == NULL) {
+               fprintf(stderr, "ERROR: missing sequence string\n");
+               return 1;
+       }
+
+       dbf = x_stderr;
+       DEBUGLEVEL = 0;
+       AllowDebugChange = false;
+
+       if (!lp_load(config_file,false,true,false,true)) {
+               fprintf(stderr,"Error loading services.\n");
+               return 1;
+       }
+
+       while(next_token_talloc(ctx, &sequence, &buff, NULL)) {
+               printf("[%s]\n", buff);
+       }
+
+       talloc_free(ctx);
+
+       return 0;
+}
+


-- 
Samba Shared Repository

Reply via email to