mirror of
https://github.com/samba-team/samba.git
synced 2024-12-27 03:21:53 +03:00
3e494442de
There's been a problem seen where open/read/close a number of times causes
open failures eventually. This program has been modified to create the
context once and then loop requesting file names to open/read/close.
This program also demonstrates the current error in cli_read() where it
returns an error instead of length 0 upon end of file.
Derrell
(This used to be commit 9d75ea577b
)
68 lines
1.3 KiB
C
68 lines
1.3 KiB
C
#include <sys/types.h>
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <string.h>
|
|
#include <time.h>
|
|
#include <errno.h>
|
|
#include <libsmbclient.h>
|
|
#include "get_auth_data_fn.h"
|
|
|
|
|
|
int main(int argc, char * argv[])
|
|
{
|
|
int i;
|
|
int fd;
|
|
int ret;
|
|
int debug = 0;
|
|
int mode = 0666;
|
|
int savedErrno;
|
|
char buffer[2048];
|
|
char path[2048];
|
|
char * p;
|
|
time_t t0;
|
|
time_t t1;
|
|
struct stat st;
|
|
|
|
smbc_init(get_auth_data_fn, debug);
|
|
|
|
for (;;)
|
|
{
|
|
fprintf(stdout, "Path: ");
|
|
*path = '\0';
|
|
fgets(path, sizeof(path) - 1, stdin);
|
|
if (strlen(path) == 0)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
p = path + strlen(path) - 1;
|
|
if (*p == '\n')
|
|
{
|
|
*p = '\0';
|
|
}
|
|
|
|
if ((fd = smbc_open(path, O_RDONLY, 0)) < 0)
|
|
{
|
|
perror("smbc_open");
|
|
continue;
|
|
}
|
|
|
|
do
|
|
{
|
|
ret = smbc_read(fd, buffer, sizeof(buffer));
|
|
savedErrno = errno;
|
|
if (ret > 0) fwrite(buffer, 1, ret, stdout);
|
|
} while (ret > 0);
|
|
|
|
smbc_close(fd);
|
|
|
|
if (ret < 0)
|
|
{
|
|
errno = savedErrno;
|
|
perror("read");
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|