Removed genereating of FCGI.xs
[catagits/fcgi2.git] / examples / threaded.c
index 8b817b5..3e860ec 100755 (executable)
@@ -3,53 +3,67 @@
  */
 
 #ifndef lint
-static const char rcsid[] = "$Id: threaded.c,v 1.2 1999/07/28 00:34:49 roberts Exp $";
+static const char rcsid[] = "$Id: threaded.c,v 1.9 2001/11/20 03:23:21 robs Exp $";
 #endif /* not lint */
 
 #include "fcgi_config.h"
 
 #include <pthread.h>
+#include <sys/types.h>
 
 #ifdef HAVE_UNISTD_H
 #include <unistd.h>
 #endif
 
-#ifdef _WIN32
-#include <process.h>
-#endif
-
 #include "fcgiapp.h"
 
 
 #define THREAD_COUNT 20
 
-int count[THREAD_COUNT];
+static int counts[THREAD_COUNT];
 
 static void *doit(void *a)
 {
-    int i, k = (int)a;
+    int rc, i, thread_id = (int)a;
+    pid_t pid = getpid();
     FCGX_Request request;
-    FCGX_Stream *in, *out, *err;
-    FCGX_ParamArray envp;
     char *server_name;
 
-    FCGX_InitRequest(&request);
+    FCGX_InitRequest(&request, 0, 0);
 
-    while (FCGX_Accept_r(&in, &out, &err, &envp, &request) >= 0)
+    for (;;)
     {
-        server_name = FCGX_GetParam("SERVER_NAME", envp);
+        static pthread_mutex_t accept_mutex = PTHREAD_MUTEX_INITIALIZER;
+        static pthread_mutex_t counts_mutex = PTHREAD_MUTEX_INITIALIZER;
+
+        /* Some platforms require accept() serialization, some don't.. */
+        pthread_mutex_lock(&accept_mutex);
+        rc = FCGX_Accept_r(&request);
+        pthread_mutex_unlock(&accept_mutex);
+
+        if (rc < 0)
+            break;
 
-        FCGX_FPrintF(out,
+        server_name = FCGX_GetParam("SERVER_NAME", request.envp);
+
+        FCGX_FPrintF(request.out,
             "Content-type: text/html\r\n"
             "\r\n"
             "<title>FastCGI Hello! (multi-threaded C, fcgiapp library)</title>"
             "<h1>FastCGI Hello! (multi-threaded C, fcgiapp library)</h1>"
-            "Thread %d, Request %d<p>"
+            "Thread %d, Process %ld<p>"
             "Request counts for %d threads running on host <i>%s</i><p><code>",
-            k, ++count[k], THREAD_COUNT, server_name ? server_name : "?");
+            thread_id, pid, THREAD_COUNT, server_name ? server_name : "?");
+
+        sleep(2);
 
+        pthread_mutex_lock(&counts_mutex);
+        ++counts[thread_id];
         for (i = 0; i < THREAD_COUNT; i++)
-            FCGX_FPrintF(out, "%5d " , count[i]);
+            FCGX_FPrintF(request.out, "%5d " , counts[i]);
+        pthread_mutex_unlock(&counts_mutex);
+
+        FCGX_Finish_r(&request);
     }
 
     return NULL;
@@ -62,14 +76,11 @@ int main(void)
 
     FCGX_Init();
 
-    for (i = 0; i < THREAD_COUNT; i++)
-        count[i] = 0;
-
     for (i = 1; i < THREAD_COUNT; i++)
         pthread_create(&id[i], NULL, doit, (void*)i);
 
     doit(0);
 
-    exit(0);
+    return 0;
 }