version 1.17.8.1, 2016/08/10 13:59:44
|
version 1.17.8.5, 2016/08/10 15:18:23
|
Line 121 ioPromptRead(int *h, const char *csPrompt, char * __re
|
Line 121 ioPromptRead(int *h, const char *csPrompt, char * __re
|
memset(szLine, 0, BUFSIZ); |
memset(szLine, 0, BUFSIZ); |
if (!fgets(szLine, BUFSIZ, inp)) { |
if (!fgets(szLine, BUFSIZ, inp)) { |
clearerr(inp); |
clearerr(inp); |
|
#ifdef HAVE_FPURGE |
fpurge(out); |
fpurge(out); |
|
#else |
|
__fpurge(out); |
|
#endif |
fflush(out); |
fflush(out); |
return 0; |
return 0; |
} |
} |
Line 152 ioPromptPassword(int *h, const char *csPrompt, char *
|
Line 156 ioPromptPassword(int *h, const char *csPrompt, char *
|
int ret, ok = 0; |
int ret, ok = 0; |
FILE *inp, *out; |
FILE *inp, *out; |
char szLine[2][STRSIZ]; |
char szLine[2][STRSIZ]; |
|
#ifndef __linux__ |
struct sgttyb tty_state; |
struct sgttyb tty_state; |
|
#else |
|
struct termios o; |
|
#endif |
|
|
if (!psPass || !passLen) |
if (!psPass || !passLen) |
return -1; |
return -1; |
Line 168 ioPromptPassword(int *h, const char *csPrompt, char *
|
Line 176 ioPromptPassword(int *h, const char *csPrompt, char *
|
return -1; |
return -1; |
} |
} |
|
|
|
#ifndef __linux__ |
if (ioctl(fileno(inp), TIOCGETP, &tty_state) == -1) { |
if (ioctl(fileno(inp), TIOCGETP, &tty_state) == -1) { |
LOGERR; |
LOGERR; |
return -1; |
return -1; |
Line 178 ioPromptPassword(int *h, const char *csPrompt, char *
|
Line 187 ioPromptPassword(int *h, const char *csPrompt, char *
|
return -1; |
return -1; |
} |
} |
} |
} |
|
#else |
|
if (tcgetattr(fileno(inp), &o) == -1) { |
|
LOGERR; |
|
return -1; |
|
} else { |
|
o.c_lflag &= ~ECHO; |
|
if (tcsetattr(fileno(inp), TCSANOW, &o) == -1) { |
|
LOGERR; |
|
return -1; |
|
} |
|
} |
|
#endif |
|
|
while (!ok) { |
while (!ok) { |
switch ((ret = ioPromptRead(h, (!csPrompt || !*csPrompt) ? "Password:" : csPrompt, |
switch ((ret = ioPromptRead(h, (!csPrompt || !*csPrompt) ? "Password:" : csPrompt, |
Line 214 ioPromptPassword(int *h, const char *csPrompt, char *
|
Line 235 ioPromptPassword(int *h, const char *csPrompt, char *
|
} |
} |
|
|
next: |
next: |
|
#ifndef __linux__ |
tty_state.sg_flags |= ECHO; |
tty_state.sg_flags |= ECHO; |
if (ioctl(fileno(inp), TIOCSETP, &tty_state) == -1) { |
if (ioctl(fileno(inp), TIOCSETP, &tty_state) == -1) { |
LOGERR; |
LOGERR; |
return -1; |
return -1; |
} |
} |
|
#else |
|
o.c_lflag |= ECHO; |
|
if (tcsetattr(fileno(inp), TCSANOW, &o) == -1) { |
|
LOGERR; |
|
return -1; |
|
} |
|
#endif |
|
|
return ok; |
return ok; |
} |
} |
Line 271 end:
|
Line 300 end:
|
return cx; |
return cx; |
} |
} |
|
|
/* | #ifndef __linux__ |
* ioWatchDirLoop() - Function for watching changes in directory and fire callback | static int |
* | watchDirLoop(const char *csDir, int (*callback)(const char *csName, int nOp)) |
* @csDir = Full directory path | |
* @callback = Callback if raise event! nOp -1 delete, 0 change/move, 1 create | |
* return: -1 error, !=-1 ok, number of total signaled events | |
*/ | |
int | |
ioWatchDirLoop(const char *csDir, int (*callback)(const char *csName, int nOp)) | |
{ |
{ |
glob_t g[2] = {{ 0 }, { 0 }}; |
glob_t g[2] = {{ 0 }, { 0 }}; |
int d, kq, n = 0; |
int d, kq, n = 0; |
Line 293 ioWatchDirLoop(const char *csDir, int (*callback)(cons
|
Line 316 ioWatchDirLoop(const char *csDir, int (*callback)(cons
|
strlcpy(str, csDir, MAXPATHLEN); |
strlcpy(str, csDir, MAXPATHLEN); |
strlcat(str, "/*", MAXPATHLEN); |
strlcat(str, "/*", MAXPATHLEN); |
|
|
kq = kqueue(); | d = open(csDir, O_RDONLY); |
if (kq == -1) { | if (d == -1) { |
LOGERR; |
LOGERR; |
return -1; |
return -1; |
} |
} |
d = open(csDir, O_RDONLY); | |
if (d == -1) { | kq = kqueue(); |
| if (kq == -1) { |
LOGERR; |
LOGERR; |
close(kq); | close(d); |
return -1; |
return -1; |
} |
} |
|
|
Line 309 ioWatchDirLoop(const char *csDir, int (*callback)(cons
|
Line 333 ioWatchDirLoop(const char *csDir, int (*callback)(cons
|
|
|
if ((n = glob(str, GLOB_NOCHECK, NULL, &g[0]))) { |
if ((n = glob(str, GLOB_NOCHECK, NULL, &g[0]))) { |
LOGERR; |
LOGERR; |
close(d); |
|
close(kq); |
close(kq); |
|
close(d); |
return -1; |
return -1; |
} /*else |
} /*else |
ioDEBUG(3, "Start files %d in %s\n", g[0].gl_matchc, str);*/ |
ioDEBUG(3, "Start files %d in %s\n", g[0].gl_matchc, str);*/ |
Line 378 ioWatchDirLoop(const char *csDir, int (*callback)(cons
|
Line 402 ioWatchDirLoop(const char *csDir, int (*callback)(cons
|
} |
} |
|
|
globfree(&g[0]); |
globfree(&g[0]); |
close(d); |
|
close(kq); |
close(kq); |
|
close(d); |
return n; |
return n; |
|
} |
|
#else |
|
static int |
|
watchDirLoop(const char *csDir, int (*callback)(const char *csName, int nOp)) |
|
{ |
|
int d, in, rlen, n = 0; |
|
register int i = 0; |
|
struct inotify_event *evt; |
|
char buf[BUFSIZ * (sizeof(struct inotify_event) + 16)]; |
|
|
|
if (!csDir || !callback) |
|
return 0; |
|
|
|
in = inotify_init(); |
|
if (in == -1) { |
|
LOGERR; |
|
return -1; |
|
} |
|
|
|
d = inotify_add_watch(in, csDir, IN_CREATE | IN_DELETE | IN_MOVE); |
|
|
|
while ((rlen = read(in, buf, sizeof buf)) > 0) { |
|
if (i >= rlen) |
|
break; |
|
else |
|
evt = (struct inotify_event*) &buf[i]; |
|
|
|
if (evt->len) { |
|
if (evt->mask & IN_CREATE) { |
|
if (callback(evt->name, 1) < 0) |
|
break; |
|
else |
|
n++; |
|
} else if (evt->mask & IN_DELETE) { |
|
if (callback(evt->name, -1) < 0) |
|
break; |
|
else |
|
n++; |
|
} else if (evt->mask & IN_MOVE) { |
|
if (callback(evt->name, 0) < 0) |
|
break; |
|
else |
|
n++; |
|
} |
|
} |
|
|
|
i += sizeof (struct inotify_event) + evt->len; |
|
} |
|
|
|
inotify_rm_watch(in, d); |
|
close(in); |
|
return n; |
|
} |
|
#endif |
|
|
|
/* |
|
* ioWatchDirLoop() - Function for watching changes in directory and fire callback |
|
* |
|
* @csDir = Full directory path |
|
* @callback = Callback if raise event! nOp -1 delete, 0 change/move, 1 create |
|
* return: -1 error, !=-1 ok, number of total signaled events |
|
*/ |
|
int |
|
ioWatchDirLoop(const char *csDir, int (*callback)(const char *csName, int nOp)) |
|
{ |
|
return watchDirLoop(csDir, callback); |
} |
} |
|
|
/* |
/* |