#include <doldaconnect/uimisc.h>
#include <doldaconnect/utils.h>
+int interactive = 0;
int verbose = 0;
int dcfd;
int (*handler)(int argc, wchar_t **argv);
};
+void wcslimit(wchar_t *wcs, int limit) {
+ int i;
+
+ if(wcslen(wcs) > limit) {
+ for(i = limit - 3; i < limit; i++)
+ wcs[i] = L'.';
+ wcs[i] = L'\0';
+ }
+}
+
+void wcslimitr(wchar_t *wcs, int limit) {
+ int i;
+
+ if((i = wcslen(wcs)) > limit) {
+ memmove(wcs + 3, wcs + (i - limit + 3), sizeof(wchar_t) * (limit - 2));
+ for(i = 0; i < 3; i++)
+ wcs[i] = L'.';
+ }
+}
+
int cmd_lsnodes(int argc, wchar_t **argv)
{
- int i;
struct dc_response *resp;
struct dc_intresp *ires;
resp = dc_gettaggedrespsync(dc_queuecmd(NULL, NULL, L"lsnodes", NULL));
if(resp->code == 200) {
- printf(" ID NET USERS S NAME\n");
+ if(interactive) {
+ printf("ID NET USERS S NAME\n");
+ printf("----- ---- ------ - ----------------------------------------------------------\n");
+ }
while((ires = dc_interpret(resp)) != NULL) {
- if(wcslen(ires->argv[2].val.str) > 58) {
- for(i = 55; i < 58; i++)
- ires->argv[2].val.str[i] = L'.';
- ires->argv[2].val.str[i] = L'\0';
+ if(interactive)
+ wcslimit(ires->argv[2].val.str, 58);
+ printf("%-5i %-4ls %-6i %c %ls\n", ires->argv[0].val.num, ires->argv[1].val.str, ires->argv[3].val.num, "SHED"[ires->argv[4].val.num], ires->argv[2].val.str);
+ dc_freeires(ires);
+ }
+ } else if(resp->code == 201) {
+ } else {
+ fprintf(stderr, "dcsh: %ls\n", resp->rlines[0].argv[0]);
+ return(1);
+ }
+ return(0);
+}
+
+int cmd_lsdl(int argc, wchar_t **argv)
+{
+ struct dc_response *resp;
+ struct dc_intresp *ires;
+
+ resp = dc_gettaggedrespsync(dc_queuecmd(NULL, NULL, L"lstrans", NULL));
+ if(resp->code == 200) {
+ if(interactive) {
+ printf("ID S USER FILE\n");
+ printf("------- - --------------- ----------------------------------------------------\n");
+ }
+ while((ires = dc_interpret(resp)) != NULL) {
+ if(ires->argv[1].val.num == DC_TRNSD_DOWN) {
+ if(interactive) {
+ wcslimit(ires->argv[4].val.str, 15);
+ wcslimitr(ires->argv[5].val.str, 52);
+ }
+ printf("%-7i %c %-15ls %ls\n", ires->argv[0].val.num, "SHED"[ires->argv[2].val.num], ires->argv[4].val.str, ires->argv[5].val.str);
}
- printf("%5i %4ls %6i %c %ls\n", ires->argv[0].val.num, ires->argv[1].val.str, ires->argv[3].val.num, "SHED"[ires->argv[4].val.num], ires->argv[2].val.str);
dc_freeires(ires);
}
} else if(resp->code == 201) {
} else {
fprintf(stderr, "dcsh: %ls\n", resp->rlines[0].argv[0]);
+ return(1);
}
return(0);
}
struct cmd commands[] = {
{L"hubs", cmd_lsnodes},
+ {L"lsdl", cmd_lsdl},
{NULL, NULL}
};
int cmddata;
struct pollfd pfd[2];
+ if(interactive) {
+ fprintf(stderr, "dcsh> ");
+ fflush(stderr);
+ }
cmddata = 0;
while(1) {
pfd[0].fd = dcfd;
fprintf(stderr, "dcsh: stdin: %s\n", strerror(errno));
return(1);
} else if(ret == 0) {
+ if(interactive)
+ fprintf(stderr, "\n");
return(0);
}
cmddata += ret;
dc_freewcsarr(argv);
}
memmove(cmdbuf, p, cmddata -= (p - cmdbuf));
+ if(interactive) {
+ fprintf(stderr, "dcsh> ");
+ fflush(stderr);
+ }
}
}
}
}
if(verbose)
fprintf(stderr, "done\n");
- if(optind < argc)
+ if(optind < argc) {
+ interactive = isatty(1);
rv = runchar(argc - optind, argv + optind);
- else
+ } else {
+ interactive = isatty(0);
rv = shell();
+ }
return(rv);
}