svn commit: samba r6126 - in branches/SAMBA_3_0/examples/libsmbclient: . smbwrapper

derrell at samba.org derrell at samba.org
Wed Mar 30 02:39:22 GMT 2005


Author: derrell
Date: 2005-03-30 02:39:22 +0000 (Wed, 30 Mar 2005)
New Revision: 6126

WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=6126

Log:
added utility for testing smbc_stat()
Added:
   branches/SAMBA_3_0/examples/libsmbclient/teststat.c
Modified:
   branches/SAMBA_3_0/examples/libsmbclient/Makefile
   branches/SAMBA_3_0/examples/libsmbclient/smbwrapper/Makefile


Changeset:
Modified: branches/SAMBA_3_0/examples/libsmbclient/Makefile
===================================================================
--- branches/SAMBA_3_0/examples/libsmbclient/Makefile	2005-03-30 02:35:31 UTC (rev 6125)
+++ branches/SAMBA_3_0/examples/libsmbclient/Makefile	2005-03-30 02:39:22 UTC (rev 6126)
@@ -6,20 +6,17 @@
 	      -I/usr/include/glib-1.2 \
 	      -I/usr/lib/glib/include
 
-CFLAGS = -I$(SAMBA_INCL) $(EXTLIB_INCL)
+DEFS = -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE
+CFLAGS = -O0 -g -I$(SAMBA_INCL) $(EXTLIB_INCL) $(DEFS)
 
-LDFLAGS = -L/usr/lib
+LDFLAGS = -L/usr/local/samba/lib
 
-all: testsmbc tree testacl testbrowse smbsh
+all: testsmbc tree testacl testbrowse teststat smbsh
 
 testsmbc: testsmbc.o 
 	@echo Linking testsmbc
-	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $< -lsmbclient -L/usr/local/lib
+	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $< -lsmbclient
 
-testsmbc-static: testsmbc.o 
-	@echo Linking testsmbc
-	@$(CC) $(CFLAGS) -static $(LDFLAGS) -o $@ $< -lsmbclient -ldl -lnsl
-
 tree: tree.o
 	@echo Linking tree
 	@$(CC) `gtk-config --cflags` $(CFLAGS) $(LDFLAGS) -o $@ `gtk-config --libs` -lsmbclient $<
@@ -32,9 +29,13 @@
 	@echo Linking testbrowse
 	@$(CC) $(CFLAGS) $(LDFLAGS) -o $@ -lsmbclient -lpopt $<
 
+teststat: teststat.o
+	@echo Linking teststat
+	@$(CC) $(CFLAGS) $(LDFLAGS) -o $@ /usr/local/samba/lib/libsmbclient.so -lpopt $<
+
 smbsh:
 	make -C smbwrapper
 
 clean:
-	@rm -f *.o *~ testsmbc tree testacl testbrowse
+	@rm -f *.o *~ testsmbc tree testacl testbrowse teststat
 	@make -C smbwrapper clean

Modified: branches/SAMBA_3_0/examples/libsmbclient/smbwrapper/Makefile
===================================================================
--- branches/SAMBA_3_0/examples/libsmbclient/smbwrapper/Makefile	2005-03-30 02:35:31 UTC (rev 6125)
+++ branches/SAMBA_3_0/examples/libsmbclient/smbwrapper/Makefile	2005-03-30 02:39:22 UTC (rev 6126)
@@ -3,7 +3,7 @@
 
 CFLAGS = -I$(SAMBA_INCL) $(EXTLIB_INCL)
 
-LDFLAGS = -L/usr/lib
+LDFLAGS = -L/usr/local/samba/lib
 
 SMBINCLUDE = -I../../../source/include
 CFLAGS= -fpic -g -O0 $(DEFS) $(SMBINCLUDE)
@@ -22,11 +22,12 @@
 		--export-all-symbols \
 		-o $(BIN)/smbwrapper.so \
 		$(SMBWRAPPER_OBJS) \
+		$(LDFLAGS) \
 		$(LIBS) \
 		-Wl,-soname=`basename $@`
 
 $(BIN)/smbsh: $(SMBSH_OBJS)
-	$(CC) -g -o $(BIN)/smbsh $(SMBSH_OBJS) $(LIBS)
+	$(CC) -g -o $(BIN)/smbsh $(SMBSH_OBJS) $(LIBS) $(LDFLAGS)
 
 opendir_smbsh:	opendir_smbsh.o
 	$(CC) -g -o opendir_smbsh opendir_smbsh.o $(LIBS) $(DMALLOC)

Added: branches/SAMBA_3_0/examples/libsmbclient/teststat.c
===================================================================
--- branches/SAMBA_3_0/examples/libsmbclient/teststat.c	2005-03-30 02:35:31 UTC (rev 6125)
+++ branches/SAMBA_3_0/examples/libsmbclient/teststat.c	2005-03-30 02:39:22 UTC (rev 6126)
@@ -0,0 +1,117 @@
+#include <stdio.h> 
+#include <unistd.h>
+#include <string.h> 
+#include <time.h> 
+#include <libsmbclient.h> 
+
+static void
+get_auth_data_fn(const char * pServer,
+                 const char * pShare,
+                 char * pWorkgroup,
+                 int maxLenWorkgroup,
+                 char * pUsername,
+                 int maxLenUsername,
+                 char * pPassword,
+                 int maxLenPassword)
+    
+{
+    char temp[128];
+    
+    printf("Entered get_auth_data_fn\n");
+
+    fprintf(stdout, "Need password for //%s/%s\n", pServer, pShare);
+    
+    fprintf(stdout, "Username: [%s] ", pUsername);
+    fgets(temp, sizeof(temp), stdin);
+    
+    if (temp[strlen(temp) - 1] == '\n') /* A new line? */
+    {
+        temp[strlen(temp) - 1] = '\0';
+    }
+    
+    if (temp[0] != '\0')
+    {
+        strncpy(pUsername, temp, maxLenUsername - 1);
+    }
+    
+    strcpy(temp, getpass("Password: "));
+    
+    if (temp[strlen(temp) - 1] == '\n') /* A new line? */
+    {
+        temp[strlen(temp) - 1] = '\0';
+    }
+    
+    if (temp[0] != '\0')
+    {
+        strncpy(pPassword, temp, maxLenPassword - 1);
+    }
+
+    fprintf(stdout, "Workgroup: ");
+    fgets(temp, sizeof(temp), stdin);
+    
+    if (temp[strlen(temp) - 1] == '\n') /* A new line? */
+    {
+        temp[strlen(temp) - 1] = '\0';
+    }
+    
+    if (temp[0] != '\0')
+    {
+        strncpy(pWorkgroup, temp, maxLenWorkgroup - 1);
+    }
+
+    putchar('\n');
+}
+
+
+
+int main(int argc, char * argv[]) 
+{ 
+    char            buffer[16384]; 
+    char *          pSmbPath = NULL;
+    char *          pLocalPath = NULL;
+    struct stat     st; 
+    
+    if (argc == 1)
+    {
+        pSmbPath = "smb://RANDOM/Public/small";
+        pLocalPath = "/random/home/samba/small";
+    }
+    else if (argc == 2)
+    {
+        pSmbPath = argv[1];
+        pLocalPath = NULL;
+    }
+    else if (argc == 3)
+    {
+        pSmbPath = argv[1];
+        pLocalPath = argv[2];
+    }
+    else
+    {
+        printf("usage: "
+               "%s [ smb://path/to/file [ /nfs/or/local/path/to/file ] ]\n",
+               argv[0]);
+        return 1;
+    }
+
+    smbc_init(get_auth_data_fn, 0); 
+    
+    int ret = smbc_stat(pSmbPath, &st); 
+    
+    printf("SAMBA\nret=%d,\n mtime:%lu/%s ctime:%lu/%s atime:%lu/%s\n", ret, 
+           st.st_mtime, ctime(&st.st_mtime),
+           st.st_ctime, ctime(&st.st_ctime),
+           st.st_atime, ctime(&st.st_atime)); 
+    
+    if (pLocalPath != NULL)
+    {
+        ret = stat(pLocalPath, &st); 
+        
+        printf("LOCAL\nret=%d,\n mtime:%lu/%s ctime:%lu/%s atime:%lu/%s\n", ret, 
+               st.st_mtime, ctime(&st.st_mtime),
+               st.st_ctime, ctime(&st.st_ctime),
+               st.st_atime, ctime(&st.st_atime));
+    }
+
+    return 0; 
+}



More information about the samba-cvs mailing list