diff options
Diffstat (limited to 'testsuite/libsmbclient/src/closedir/closedir_1.c')
-rw-r--r-- | testsuite/libsmbclient/src/closedir/closedir_1.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/testsuite/libsmbclient/src/closedir/closedir_1.c b/testsuite/libsmbclient/src/closedir/closedir_1.c new file mode 100644 index 0000000000..702b92c24a --- /dev/null +++ b/testsuite/libsmbclient/src/closedir/closedir_1.c @@ -0,0 +1,65 @@ +#include <stdio.h> +#include <string.h> +#include <errno.h> +#include <libsmbclient.h> + +#define MAX_BUFF_SIZE 255 +char g_workgroup[MAX_BUFF_SIZE]; +char g_username[MAX_BUFF_SIZE]; +char g_password[MAX_BUFF_SIZE]; +char g_server[MAX_BUFF_SIZE]; +char g_share[MAX_BUFF_SIZE]; + + +void auth_fn(const char *server, const char *share, char *workgroup, int wgmaxlen, + char *username, int unmaxlen, char *password, int pwmaxlen) +{ + + strncpy(workgroup, g_workgroup, wgmaxlen - 1); + + strncpy(username, g_username, unmaxlen - 1); + + strncpy(password, g_password, pwmaxlen - 1); + + strcpy(g_server, server); + strcpy(g_share, share); + +} + +int main(int argc, char** argv) +{ + int err = -1; + int dh = 0; + char url[MAX_BUFF_SIZE]; + + bzero(g_workgroup,MAX_BUFF_SIZE); + bzero(url,MAX_BUFF_SIZE); + + if ( argc == 5 ) + { + + strncpy(g_workgroup,argv[1],strlen(argv[1])); + strncpy(g_username,argv[2],strlen(argv[2])); + strncpy(g_password,argv[3],strlen(argv[3])); + strncpy(url,argv[4],strlen(argv[4])); + + smbc_init(auth_fn, 0); + smbc_rmdir(url); + smbc_mkdir(url,0666); + dh = smbc_opendir(url); + /* printf("directory handle: %i\n",dh); */ + err = smbc_closedir(dh); + + if ( err < 0 ) + err = 1; + + else + err = 0; + + + } + + return err; + +} + |