summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Wooding <mdw@distorted.org.uk>2013-01-29 23:45:47 +0000
committerMark Wooding <mdw@distorted.org.uk>2013-02-02 13:29:40 +0000
commit6a3086f1860a27894942124c1ecd62502bb4b670 (patch)
treee6b8af7a74aa2ea2d188541214170f8f50072ce2
parent44a77f4851d3c819f9b364018a9695f332758a71 (diff)
downloaduserv-utils-6a3086f1860a27894942124c1ecd62502bb4b670.tar.gz
www-cgi/: Add some trivial tracing.
The trace goes to standard output, and only happens when debugging is turned on, both operationally (e.g., though the `ucgi-debug' link or USERV_U_DEBUG variable) and at compile time (with the DEBUG macro, which you can set, e.g., with `make DEBUG="-g -DDEBUG"'. Trace output lines start with `;;'. I'll be grateful for this when I start shaking things up.
-rw-r--r--www-cgi/ucgi.c18
-rw-r--r--www-cgi/ucgi.h6
-rw-r--r--www-cgi/ucgitarget.c21
3 files changed, 45 insertions, 0 deletions
diff --git a/www-cgi/ucgi.c b/www-cgi/ucgi.c
index c1239d0..374fea5 100644
--- a/www-cgi/ucgi.c
+++ b/www-cgi/ucgi.c
@@ -46,18 +46,26 @@ int main(int argc, const char **argv) {
if (fputs("Content-Type: text/plain\n\n",stdout)==EOF || fflush(stdout))
syserror("write stdout");
if (dup2(1,2)<0) { perror("dup stdout to stderr"); exit(-1); }
+ D( printf(";;; UCGI\n"); )
}
if (argc > MAX_ARGS) error("too many arguments");
pathi= getenv("PATH_INFO");
if (!pathi) error("PATH_INFO not found");
+ D( if (debugmode) {
+ printf(";; find user name...\n"
+ ";; initial PATH_INFO = `%s'\n",
+ pathi);
+ } )
if (pathi[0] != '/' || pathi[1] != '~') error("PATH_INFO must start with /~");
slash2= strchr(pathi+2,'/'); if (!slash2) error("PATH_INFO must have more than one /");
usernamelen= slash2-(pathi+2);
if (usernamelen > MAX_USERNAME_LEN) error("PATH_INFO username too long");
username= xmalloc(usernamelen+1);
memcpy(username,pathi+2,usernamelen); username[usernamelen]= 0;
+ D( if (debugmode)
+ printf(";; user = `%s'; tail = `%s'\n", username, slash2); )
if (!isalpha(username[0])) error("username 1st character is not alphabetic");
xsetenv("PATH_INFO",slash2,1);
@@ -81,6 +89,7 @@ int main(int argc, const char **argv) {
arguments[nargs++]= 0;
if (debugmode) {
+ D( fflush(stdout); )
child= fork(); if (child==-1) syserror("fork");
if (child) {
rchild= waitpid(child,&status,0);
@@ -90,6 +99,15 @@ int main(int argc, const char **argv) {
}
}
+ D( if (debugmode) {
+ int i;
+
+ printf(";; final command line...\n");
+ for (i = 0; arguments[i]; i++)
+ printf(";; %s\n", arguments[i]);
+ fflush(stdout);
+ } )
+
execvp("userv",(char*const*)arguments);
syserror("exec userv");
return -1;
diff --git a/www-cgi/ucgi.h b/www-cgi/ucgi.h
index 5a51a77..0ab5a49 100644
--- a/www-cgi/ucgi.h
+++ b/www-cgi/ucgi.h
@@ -23,6 +23,12 @@
#include <stdlib.h>
+#ifdef DEBUG
+# define D(x) x
+#else
+# define D(x)
+#endif
+
#define MAX_ARGS 1024
#define MAX_USERNAME_LEN 1024
#define MAX_SCRIPTPATH_LEN 1024
diff --git a/www-cgi/ucgitarget.c b/www-cgi/ucgitarget.c
index e38ad30..9637235 100644
--- a/www-cgi/ucgitarget.c
+++ b/www-cgi/ucgitarget.c
@@ -44,6 +44,7 @@ int main(int argc, const char **argv) {
ev= getenv("USERV_U_DEBUG");
if (ev && *ev) debugmode= 1;
+ D( if (debugmode) printf(";;; UCGITARGET\n"); )
if (argc > MAX_ARGS) error("too many arguments");
if (!*++argv) error("no script directory argument");
@@ -70,6 +71,11 @@ int main(int argc, const char **argv) {
pathi= getenv("PATH_INFO");
if (!pathi) error("PATH_INFO not found");
lastslash= pathi;
+ D( if (debugmode) {
+ printf(";; find script name...\n"
+ ";; PATH_INFO = `%s'\n",
+ pathi);
+ } )
for (;;) {
if (*lastslash != '/') error("PATH_INFO expected slash not found");
if (lastslash[1]=='.' || lastslash[1]=='#' || !lastslash[1]) error("bad char begin");
@@ -84,11 +90,13 @@ int main(int argc, const char **argv) {
memcpy(scriptpath+scriptdirlen,pathi,nextslash-pathi);
scriptpath[scriptpathlen]= 0;
if (scriptpath[scriptpathlen-1]=='~') error("bad char end");
+ D( if (debugmode) printf(";; try `%s'\n", scriptpath); )
r= stat(scriptpath,&stab); if (r) syserror("stat script");
if (S_ISREG(stab.st_mode)) break;
if (!S_ISDIR(stab.st_mode)) error("script not directory or file");
lastslash= nextslash;
}
+ D( if (debugmode) printf(";; found script: tail = `%s'\n", nextslash); )
if (*nextslash) xsetenv("PATH_INFO",nextslash,1);
else unsetenv("PATH_INFO");
@@ -113,6 +121,19 @@ int main(int argc, const char **argv) {
while ((av= (*++argv))) arguments[nargs++]= av;
arguments[nargs++]= 0;
+ D( if (debugmode) {
+ int i;
+
+ printf(";; final environment...\n");
+ for (i = 0; environ[i]; i++)
+ printf(";; %s\n", environ[i]);
+
+ printf(";; final command line...\n");
+ for (i = 0; arguments[i]; i++)
+ printf(";; %s\n", arguments[i]);
+ fflush(stdout);
+ } )
+
execvp(scriptpath,(char*const*)arguments);
syserror("exec script");
return -1;