diff options
author | Stuart Herbert <stuart@gentoo.org> | 2005-03-27 17:26:44 +0000 |
---|---|---|
committer | Stuart Herbert <stuart@gentoo.org> | 2005-03-27 17:26:44 +0000 |
commit | 918953de6f3e36f13721bde95e8294e8aa24bcb6 (patch) | |
tree | 1234c6ee02f03a6aeb2bd6f3524154037f72e39e /www-servers | |
parent | Added second revision of php5-sapi eclass (diff) | |
download | historical-918953de6f3e36f13721bde95e8294e8aa24bcb6.tar.gz historical-918953de6f3e36f13721bde95e8294e8aa24bcb6.tar.bz2 historical-918953de6f3e36f13721bde95e8294e8aa24bcb6.zip |
Added php support
Package-Manager: portage-2.0.51.19
Diffstat (limited to 'www-servers')
-rw-r--r-- | www-servers/thttpd/ChangeLog | 10 | ||||
-rw-r--r-- | www-servers/thttpd/Manifest | 2 | ||||
-rw-r--r-- | www-servers/thttpd/files/digest-thttpd-2.25b-r2 | 2 | ||||
-rw-r--r-- | www-servers/thttpd/files/php-5.0.3-IOV.patch | 12 | ||||
-rw-r--r-- | www-servers/thttpd/files/php-5.0.3-missing-arches.patch | 13 | ||||
-rw-r--r-- | www-servers/thttpd/files/php5.0-stdint.diff | 11 | ||||
-rw-r--r-- | www-servers/thttpd/files/php5_soap_persistence_session.diff | 35 | ||||
-rw-r--r-- | www-servers/thttpd/files/thttpd-2.25/php-5.0.3-thttpd-2.25b.patch | 337 | ||||
-rw-r--r-- | www-servers/thttpd/thttpd-2.25b-r2.ebuild | 97 |
9 files changed, 517 insertions, 2 deletions
diff --git a/www-servers/thttpd/ChangeLog b/www-servers/thttpd/ChangeLog index f286998f2fed..225c0d5fadbb 100644 --- a/www-servers/thttpd/ChangeLog +++ b/www-servers/thttpd/ChangeLog @@ -1,6 +1,14 @@ # ChangeLog for www-servers/thttpd # Copyright 2000-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/www-servers/thttpd/ChangeLog,v 1.5 2005/03/08 14:42:54 ka0ttic Exp $ +# $Header: /var/cvsroot/gentoo-x86/www-servers/thttpd/ChangeLog,v 1.6 2005/03/27 17:26:44 stuart Exp $ + +*thttpd-2.25b-r2 (27 Mar 2005) + + 27 Mar 2005; Stuart Herbert <stuart@gentoo.org> +files/php-5.0.3-IOV.patch, + +files/php-5.0.3-missing-arches.patch, +files/php5.0-stdint.diff, + +files/php5_soap_persistence_session.diff, + +files/thttpd-2.25/php-5.0.3-thttpd-2.25b.patch, +thttpd-2.25b-r2.ebuild: + Added php support (requested by Solar) *thttpd-2.25b-r1 (08 Mar 2005) diff --git a/www-servers/thttpd/Manifest b/www-servers/thttpd/Manifest index 9d9704fc5117..7ec3c1612031 100644 --- a/www-servers/thttpd/Manifest +++ b/www-servers/thttpd/Manifest @@ -2,7 +2,7 @@ MD5 a1f47f6df2e0465c19194579f3b8c943 ChangeLog 1947 MD5 4a186842848d9c384e2d12785ba426bc metadata.xml 165 MD5 01cfdda0a52d777aa2c814dcf4ba9d95 thttpd-2.25b.ebuild 1188 MD5 9638e3f16ce376f6259c3963fe78da43 thttpd-2.25b-r1.ebuild 1234 -MD5 28476b1f3d427e754067720238c3fdff thttpd-2.25b-r2.ebuild 2088 +MD5 3275e777a332a1525de88c1b458009c5 thttpd-2.25b-r2.ebuild 2088 MD5 1e6cbba778f6846533ae1d69310e0c4e files/digest-thttpd-2.25b 64 MD5 1e6cbba778f6846533ae1d69310e0c4e files/digest-thttpd-2.25b-r1 64 MD5 6f77a5ae06c1e805c8ba4f18ef210040 files/digest-thttpd-2.25b-r2 126 diff --git a/www-servers/thttpd/files/digest-thttpd-2.25b-r2 b/www-servers/thttpd/files/digest-thttpd-2.25b-r2 new file mode 100644 index 000000000000..70bff3b46360 --- /dev/null +++ b/www-servers/thttpd/files/digest-thttpd-2.25b-r2 @@ -0,0 +1,2 @@ +MD5 a0e9cd87455d3a0ea11e5ea7e947adf6 thttpd-2.25b.tar.gz 132363 +MD5 bf89557056ce34d502e20e24071616c7 php-5.0.3.tar.gz 5666998 diff --git a/www-servers/thttpd/files/php-5.0.3-IOV.patch b/www-servers/thttpd/files/php-5.0.3-IOV.patch new file mode 100644 index 000000000000..abd83e282b46 --- /dev/null +++ b/www-servers/thttpd/files/php-5.0.3-IOV.patch @@ -0,0 +1,12 @@ +diff -u --recursive php-5.0.3-orig/sapi/thttpd/thttpd.c php-5.0.3/sapi/thttpd/thttpd.c +--- php-5.0.3-orig/sapi/thttpd/thttpd.c 2005-03-27 17:25:59.491818008 +0100 ++++ php-5.0.3/sapi/thttpd/thttpd.c 2005-03-27 17:26:36.943124544 +0100 +@@ -107,7 +107,7 @@ + { + int n; + +- assert(nvec <= IOV_MAX); ++ /* assert(nvec <= IOV_MAX); */ + + if (TG(sbuf).c == 0) { + PHP_SYS_CALL(n = writev(TG(hc)->conn_fd, vec, nvec);); diff --git a/www-servers/thttpd/files/php-5.0.3-missing-arches.patch b/www-servers/thttpd/files/php-5.0.3-missing-arches.patch new file mode 100644 index 000000000000..86c5e067401e --- /dev/null +++ b/www-servers/thttpd/files/php-5.0.3-missing-arches.patch @@ -0,0 +1,13 @@ +Silly php devs forgot about poor old ia64/s390 :( + +--- php-5.0.3/Zend/zend_strtod.c ++++ php-5.0.3/Zend/zend_strtod.c +@@ -99,7 +99,7 @@ + defined(__mips__) || defined(__ns32k__) || defined(__alpha__) || \ + defined(__powerpc__) || defined(__ppc__) || defined(__m88k__) || \ + defined(__hppa__) || defined(__x86_64__) || (defined(__arm__) && \ +- defined(__VFP_FP__)) ++ defined(__VFP_FP__)) || defined(__ia64__) || defined(__s390__) + #include <sys/types.h> + #if BYTE_ORDER == BIG_ENDIAN + #define IEEE_BIG_ENDIAN diff --git a/www-servers/thttpd/files/php5.0-stdint.diff b/www-servers/thttpd/files/php5.0-stdint.diff new file mode 100644 index 000000000000..451d7fb44cf3 --- /dev/null +++ b/www-servers/thttpd/files/php5.0-stdint.diff @@ -0,0 +1,11 @@ +diff -Nura php-4.3.10/Zend/zend_strtod.c php-4.3.10.stdint/Zend/zend_strtod.c +--- php-4.3.10/Zend/zend_strtod.c 2004-12-14 05:35:26.000000000 -0300 ++++ php-4.3.10.stdint/Zend/zend_strtod.c 2004-12-16 15:33:47.000000000 -0300 +@@ -128,6 +128,7 @@ + #endif + + #if defined(__sparc__) || defined(__ppc__) ++#include <stdint.h> + #define u_int32_t uint32_t + #endif + diff --git a/www-servers/thttpd/files/php5_soap_persistence_session.diff b/www-servers/thttpd/files/php5_soap_persistence_session.diff new file mode 100644 index 000000000000..626ac67f9081 --- /dev/null +++ b/www-servers/thttpd/files/php5_soap_persistence_session.diff @@ -0,0 +1,35 @@ +diff -ruN php-5.0.0RC3.orig/ext/soap/soap.c php-5.0.0RC3/ext/soap/soap.c +--- php-5.0.0RC3.orig/ext/soap/soap.c 2004-06-22 19:35:59.801348936 +0300 ++++ php-5.0.0RC3/ext/soap/soap.c 2004-06-29 13:39:00.506820928 +0300 +@@ -1341,16 +1341,21 @@ + soap_obj = NULL; + #if HAVE_PHP_SESSION + /* If persistent then set soap_obj from from the previous created session (if available) */ ++ char soapname[32+sizeof("_bogus_session_name")]; //Now we use max 32 chars from class name, must be overwriten with dynamic allocation with exact length!! + if (service->soap_class.persistance == SOAP_PERSISTENCE_SESSION) { + zval **tmp_soap; + ++ bzero(soapname,32+sizeof("_bogus_session_name")); ++ strncpy(soapname,service->soap_class.ce->name,32); ++ strcat(soapname,"_bogus_session_name"); ++ + if (PS(session_status) != php_session_active && + PS(session_status) != php_session_disabled) { + php_session_start(TSRMLS_C); + } + + /* Find the soap object and assign */ +- if (zend_hash_find(Z_ARRVAL_P(PS(http_session_vars)), "_bogus_session_name", sizeof("_bogus_session_name"), (void **) &tmp_soap) == SUCCESS && ++ if (zend_hash_find(Z_ARRVAL_P(PS(http_session_vars)), soapname, sizeof(soapname), (void **) &tmp_soap) == SUCCESS && + Z_TYPE_PP(tmp_soap) == IS_OBJECT && + Z_OBJCE_PP(tmp_soap) == service->soap_class.ce) { + soap_obj = *tmp_soap; +@@ -1432,7 +1437,7 @@ + /* If session then update session hash with new object */ + if (service->soap_class.persistance == SOAP_PERSISTENCE_SESSION) { + zval **tmp_soap_pp; +- if (zend_hash_update(Z_ARRVAL_P(PS(http_session_vars)), "_bogus_session_name", sizeof("_bogus_session_name"), &tmp_soap, sizeof(zval *), (void **)&tmp_soap_pp) == SUCCESS) { ++ if (zend_hash_update(Z_ARRVAL_P(PS(http_session_vars)), soapname, sizeof(soapname), &tmp_soap, sizeof(zval *), (void **)&tmp_soap_pp) == SUCCESS) { + soap_obj = *tmp_soap_pp; + } + } else { diff --git a/www-servers/thttpd/files/thttpd-2.25/php-5.0.3-thttpd-2.25b.patch b/www-servers/thttpd/files/thttpd-2.25/php-5.0.3-thttpd-2.25b.patch new file mode 100644 index 000000000000..f32e1a8ba84e --- /dev/null +++ b/www-servers/thttpd/files/thttpd-2.25/php-5.0.3-thttpd-2.25b.patch @@ -0,0 +1,337 @@ +diff -urN php-5.0.3/configure php-5.0.3-thttpd/configure +--- php-5.0.3/configure 2004-07-13 22:13:15.000000000 +0300 ++++ php-5.0.3-thttpd/configure 2004-07-28 08:05:48.021849513 +0300 +@@ -9573,11 +9573,13 @@ + if grep thttpd.2.21b $withval/version.h >/dev/null; then + patch="test -f $THTTPD/php_patched || \ + (cd $THTTPD && patch -p1 < $abs_srcdir/sapi/thttpd/thttpd_patch && touch php_patched)" +- ++ elif grep thttpd.2.25b $withval/version.h >/dev/null; then ++ patch="test -f $THTTPD/php_patched || \ ++ (cd $THTTPD && patch -p1 < $abs_srcdir/sapi/thttpd/thttpd-2.25b_patch && touch php_patched)" + elif grep Premium $withval/version.h >/dev/null; then + patch= + else +- { echo "configure: error: This version only supports thttpd-2.21b and Premium thttpd" 1>&2; exit 1; } ++ { echo "configure: error: This version only supports thttpd-2.21b, thttpd-2.25b and Premium thttpd" 1>&2; exit 1; } + fi + + if test -n "$GCC"; then +diff -urN php-5.0.3/sapi/thttpd/thttpd-2.25b_patch php-5.0.3-thttpd/sapi/thttpd/thttpd-2.25b_patch +--- php-5.0.3/sapi/thttpd/thttpd-2.25b_patch 1970-01-01 02:00:00.000000000 +0200 ++++ php-5.0.3-thttpd/sapi/thttpd/thttpd-2.25b_patch 2004-07-28 08:02:52.632236518 +0300 +@@ -0,0 +1,314 @@ ++diff -ru thttpd-2.25b.orig/Makefile.in thttpd-2.25b/Makefile.in ++--- thttpd-2.25b.orig/Makefile.in Wed Apr 3 11:49:35 2002 +++++ thttpd-2.25b/Makefile.in Wed Mar 17 17:48:53 2004 ++@@ -46,13 +46,15 @@ ++ ++ # You shouldn't need to edit anything below here. ++ +++include php_makefile +++ ++ CC = @CC@ ++ CCOPT = @V_CCOPT@ ++ DEFS = @DEFS@ ++-INCLS = -I. +++INCLS = -I. $(PHP_CFLAGS) ++ CFLAGS = $(CCOPT) $(DEFS) $(INCLS) ++-LDFLAGS = @LDFLAGS@ ++-LIBS = @LIBS@ +++LDFLAGS = @LDFLAGS@ $(PHP_LDFLAGS) +++LIBS = @LIBS@ $(PHP_LIBS) ++ NETLIBS = @V_NETLIBS@ ++ INSTALL = @INSTALL@ ++ ++@@ -62,7 +64,7 @@ ++ @rm -f $@ ++ $(CC) $(CFLAGS) -c $*.c ++ ++-SRC = thttpd.c libhttpd.c fdwatch.c mmc.c timers.c match.c tdate_parse.c +++SRC = thttpd.c libhttpd.c fdwatch.c mmc.c timers.c match.c tdate_parse.c php_thttpd.c ++ ++ OBJ = $(SRC:.c=.o) @LIBOBJS@ ++ ++@@ -77,7 +79,7 @@ ++ all: this subdirs ++ this: $(ALL) ++ ++-thttpd: $(OBJ) +++thttpd: $(OBJ) libphp5.a ++ @rm -f $@ ++ $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(OBJ) $(LIBS) $(NETLIBS) ++ ++diff -ru thttpd-2.25b.orig/config.h thttpd-2.25b/config.h ++--- thttpd-2.25b.orig/config.h Sun Nov 30 12:40:00 2003 +++++ thttpd-2.25b/config.h Wed Mar 17 18:16:57 2004 ++@@ -333,7 +333,7 @@ ++ /* CONFIGURE: A list of index filenames to check. The files are searched ++ ** for in this order. ++ */ ++-#define INDEX_NAMES "index.html", "index.htm", "index.xhtml", "index.xht", "Default.htm", "index.cgi" +++#define INDEX_NAMES "index.php", "index.html", "index.htm", "index.xhtml", "index.xht", "Default.htm", "index.cgi" ++ ++ /* CONFIGURE: If this is defined then thttpd will automatically generate ++ ** index pages for directories that don't have an explicit index file. ++diff -ru thttpd-2.25b.orig/configure thttpd-2.25b/configure ++--- thttpd-2.25b.orig/configure Fri Dec 26 03:44:33 2003 +++++ thttpd-2.25b/configure Wed Mar 17 17:52:14 2004 ++@@ -1021,7 +1021,7 @@ ++ fi ++ echo "$ac_t""$CPP" 1>&6 ++ ++-for ac_hdr in fcntl.h grp.h memory.h paths.h poll.h sys/poll.h sys/devpoll.h sys/event.h osreldate.h +++for ac_hdr in fcntl.h grp.h memory.h paths.h poll.h sys/poll.h sys/devpoll.h sys/event.h osreldate.h netinet/tcp.h ++ do ++ ac_safe=`echo "$ac_hdr" | sed 'y%./+-%__p_%'` ++ echo $ac_n "checking for $ac_hdr""... $ac_c" 1>&6 ++diff -ru thttpd-2.25b.orig/configure.in thttpd-2.25b/configure.in ++--- thttpd-2.25b.orig/configure.in Fri Dec 26 03:41:13 2003 +++++ thttpd-2.25b/configure.in Wed Mar 17 17:53:20 2004 ++@@ -64,7 +64,7 @@ ++ AC_MSG_RESULT(no) ++ fi ++ ++-AC_CHECK_HEADERS(fcntl.h grp.h memory.h paths.h poll.h sys/poll.h sys/devpoll.h sys/event.h osreldate.h) +++AC_CHECK_HEADERS(fcntl.h grp.h memory.h paths.h poll.h sys/poll.h sys/devpoll.h sys/event.h osreldate.h netinet/tcp.h) ++ AC_HEADER_TIME ++ AC_HEADER_DIRENT ++ ++diff -ru thttpd-2.25b.orig/libhttpd.c thttpd-2.25b/libhttpd.c ++--- thttpd-2.25b.orig/libhttpd.c Fri Dec 26 04:06:05 2003 +++++ thttpd-2.25b/libhttpd.c Sun Mar 21 18:44:02 2004 ++@@ -55,6 +55,10 @@ ++ #include <unistd.h> ++ #include <stdarg.h> ++ +++#ifdef HAVE_NETINET_TCP_H +++#include <netinet/tcp.h> +++#endif +++ ++ #ifdef HAVE_OSRELDATE_H ++ #include <osreldate.h> ++ #endif /* HAVE_OSRELDATE_H */ ++@@ -84,6 +88,8 @@ ++ #include "match.h" ++ #include "tdate_parse.h" ++ +++#include "php_thttpd.h" +++ ++ #ifndef STDIN_FILENO ++ #define STDIN_FILENO 0 ++ #endif ++@@ -214,6 +220,10 @@ ++ free( (void*) hs->cwd ); ++ if ( hs->cgi_pattern != (char*) 0 ) ++ free( (void*) hs->cgi_pattern ); +++ if ( hs->php_pattern != (char*) 0 ) +++ free( (void*) hs->php_pattern ); +++ if ( hs->phps_pattern != (char*) 0 ) +++ free( (void*) hs->phps_pattern ); ++ if ( hs->charset != (char*) 0 ) ++ free( (void*) hs->charset ); ++ if ( hs->p3p != (char*) 0 ) ++@@ -223,6 +233,7 @@ ++ if ( hs->local_pattern != (char*) 0 ) ++ free( (void*) hs->local_pattern ); ++ free( (void*) hs ); +++ thttpd_php_shutdown(); ++ } ++ ++ ++@@ -232,7 +243,7 @@ ++ unsigned short port, char* cgi_pattern, int cgi_limit, char* charset, ++ char* p3p, int max_age, char* cwd, int no_log, FILE* logfp, ++ int no_symlink_check, int vhost, int global_passwd, char* url_pattern, ++- char* local_pattern, int no_empty_referers ) +++ char* local_pattern, int no_empty_referers, char* php_pattern, char* phps_pattern ) ++ { ++ httpd_server* hs; ++ static char ghnbuf[256]; ++@@ -279,6 +290,8 @@ ++ } ++ ++ hs->port = port; +++ hs->php_pattern = strdup(php_pattern); +++ hs->phps_pattern = strdup(phps_pattern); ++ if ( cgi_pattern == (char*) 0 ) ++ hs->cgi_pattern = (char*) 0; ++ else ++@@ -357,6 +370,7 @@ ++ } ++ ++ init_mime(); +++ thttpd_php_init(); ++ ++ /* Done initializing. */ ++ if ( hs->binding_hostname == (char*) 0 ) ++@@ -1380,6 +1394,8 @@ ++ if ( hc->tildemapped ) ++ return 1; ++ +++ if ( hc->hostname[0] == '.' || strchr( hc->hostname, '/' ) != (char*) 0 ) +++ return 0; ++ /* Figure out the host directory. */ ++ #ifdef VHOST_DIRLEVELS ++ httpd_realloc_str( ++@@ -1488,7 +1504,7 @@ ++ restlen = strlen( path ); ++ httpd_realloc_str( &rest, &maxrest, restlen ); ++ (void) strcpy( rest, path ); ++- if ( rest[restlen - 1] == '/' ) +++ if ( restlen > 0 && rest[restlen - 1] == '/' ) ++ rest[--restlen] = '\0'; /* trim trailing slash */ ++ if ( ! tildemapped ) ++ /* Remove any leading slashes. */ ++@@ -2438,7 +2454,9 @@ ++ { ++ make_log_entry( hc, nowP ); ++ ++- if ( hc->file_address != (char*) 0 ) +++ if ( hc->file_address == (char*) 1 ) +++ thttpd_closed_conn(hc->conn_fd); +++ else if ( hc->file_address != (char*) 0 ) ++ { ++ mmc_unmap( hc->file_address, &(hc->sb), nowP ); ++ hc->file_address = (char*) 0; ++@@ -3786,6 +3804,14 @@ ++ ( hc->sb.st_mode & S_IXOTH ) && ++ match( hc->hs->cgi_pattern, hc->expnfilename ) ) ++ return cgi( hc ); +++ +++ if ( hc->hs->php_pattern != (char*) 0 && +++ match( hc->hs->php_pattern, hc->expnfilename ) ) +++ return thttpd_php_request( hc, 0 ); +++ +++ if ( hc->hs->phps_pattern != (char*) 0 && +++ match( hc->hs->phps_pattern, hc->expnfilename ) ) +++ return thttpd_php_request( hc, 1 ); ++ ++ /* It's not CGI. If it's executable or there's pathinfo, someone's ++ ** trying to either serve or run a non-CGI file as CGI. Either case ++diff -ru thttpd-2.25b.orig/libhttpd.h thttpd-2.25b/libhttpd.h ++--- thttpd-2.25b.orig/libhttpd.h Tue Dec 9 01:20:51 2003 +++++ thttpd-2.25b/libhttpd.h Wed Mar 17 20:49:34 2004 ++@@ -73,6 +73,8 @@ ++ char* cgi_pattern; ++ int cgi_limit, cgi_count; ++ char* charset; +++ char* php_pattern; +++ char* phps_pattern; ++ char* p3p; ++ int max_age; ++ char* cwd; ++@@ -174,7 +176,7 @@ ++ unsigned short port, char* cgi_pattern, int cgi_limit, char* charset, ++ char* p3p, int max_age, char* cwd, int no_log, FILE* logfp, ++ int no_symlink_check, int vhost, int global_passwd, char* url_pattern, ++- char* local_pattern, int no_empty_referers ); +++ char* local_pattern, int no_empty_referers, char* php_pattern, char* phps_pattern ); ++ ++ /* Change the log file. */ ++ extern void httpd_set_logfp( httpd_server* hs, FILE* logfp ); ++diff -ru thttpd-2.25b.orig/php_thttpd.c thttpd-2.25b/php_thttpd.c ++--- thttpd-2.25b.orig/php_thttpd.c Sun Mar 21 18:33:30 2004 +++++ thttpd-2.25b/php_thttpd.c Sun Mar 21 20:29:44 2004 ++@@ -220,12 +220,12 @@ ++ h = zend_llist_get_next_ex(&sapi_headers->headers, &pos); ++ } ++ ++- if (TG(seen_cl) && !TG(seen_cn) && TG(hc)->do_keep_alive) { +++ /*if (TG(seen_cl) && !TG(seen_cn) && TG(hc)->do_keep_alive) { ++ ADD_VEC(KA_DO, sizeof(KA_DO)-1); ++ } else { ++ TG(hc)->do_keep_alive = 0; ++ ADD_VEC(KA_NO, sizeof(KA_NO)-1); ++- } +++ }*/ ++ ++ ADD_VEC("\r\n", 2); ++ ++@@ -656,12 +656,12 @@ ++ ++ if (hc->contentlength != -1) { ++ hc->should_linger = 1; ++- hc->do_keep_alive = 0; +++ /*hc->do_keep_alive = 0;*/ ++ } ++ ++ if (hc->contentlength != -1 ++ && SIZEOF_UNCONSUMED_BYTES() < hc->contentlength) { ++- hc->read_body_into_mem = 1; +++ /*hc->read_body_into_mem = 1;*/ ++ return 0; ++ } ++ ++@@ -670,9 +670,9 @@ ++ thttpd_module_main(show_source TSRMLS_CC); ++ ++ /* disable kl, if no content-length was seen or Connection: was set */ ++- if (TG(seen_cl) == 0 || TG(seen_cn) == 1) { +++ /*if (TG(seen_cl) == 0 || TG(seen_cn) == 1) { ++ TG(hc)->do_keep_alive = 0; ++- } +++ }*/ ++ ++ if (TG(sbuf).c != 0) { ++ if (TG(hc)->response) ++diff -ru thttpd-2.25b.orig/thttpd.c thttpd-2.25b/thttpd.c ++--- thttpd-2.25b.orig/thttpd.c Fri Dec 26 04:06:52 2003 +++++ thttpd-2.25b/thttpd.c Sun Mar 21 18:11:33 2004 ++@@ -77,6 +77,8 @@ ++ static int do_chroot, no_log, no_symlink_check, do_vhost, do_global_passwd; ++ static char* cgi_pattern; ++ static int cgi_limit; +++static char* php_pattern; +++static char* phps_pattern; ++ static char* url_pattern; ++ static int no_empty_referers; ++ static char* local_pattern; ++@@ -642,7 +644,7 @@ ++ gotv4 ? &sa4 : (httpd_sockaddr*) 0, gotv6 ? &sa6 : (httpd_sockaddr*) 0, ++ port, cgi_pattern, cgi_limit, charset, p3p, max_age, cwd, no_log, logfp, ++ no_symlink_check, do_vhost, do_global_passwd, url_pattern, ++- local_pattern, no_empty_referers ); +++ local_pattern, no_empty_referers, php_pattern, phps_pattern ); ++ if ( hs == (httpd_server*) 0 ) ++ exit( 1 ); ++ ++@@ -869,6 +871,8 @@ ++ #else /* CGI_LIMIT */ ++ cgi_limit = 0; ++ #endif /* CGI_LIMIT */ +++ php_pattern = "**.php"; +++ phps_pattern = "**.phps"; ++ url_pattern = (char*) 0; ++ no_empty_referers = 0; ++ local_pattern = (char*) 0; ++@@ -1103,6 +1107,16 @@ ++ { ++ value_required( name, value ); ++ cgi_limit = atoi( value ); +++ } +++ else if ( strcasecmp( name, "phppat" ) == 0 ) +++ { +++ value_required( name, value ); +++ php_pattern = e_strdup( value ); +++ } +++ else if ( strcasecmp( name, "phpspat" ) == 0 ) +++ { +++ value_required( name, value ); +++ phps_pattern = e_strdup( value ); ++ } ++ else if ( strcasecmp( name, "urlpat" ) == 0 ) ++ { ++diff -ru thttpd-2.25b.orig/version.h thttpd-2.25b/version.h ++--- thttpd-2.25b.orig/version.h Tue Dec 30 02:02:40 2003 +++++ thttpd-2.25b/version.h Sun Mar 21 22:31:24 2004 ++@@ -3,7 +3,8 @@ ++ #ifndef _VERSION_H_ ++ #define _VERSION_H_ ++ ++-#define SERVER_SOFTWARE "thttpd/2.25b 29dec2003" +++#include "php_version.h" +++#define SERVER_SOFTWARE "thttpd/2.25b PHP/" PHP_VERSION ++ #define SERVER_ADDRESS "http://www.acme.com/software/thttpd/" ++ ++ #endif /* _VERSION_H_ */ diff --git a/www-servers/thttpd/thttpd-2.25b-r2.ebuild b/www-servers/thttpd/thttpd-2.25b-r2.ebuild new file mode 100644 index 000000000000..305208cdd0d6 --- /dev/null +++ b/www-servers/thttpd/thttpd-2.25b-r2.ebuild @@ -0,0 +1,97 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/www-servers/thttpd/thttpd-2.25b-r2.ebuild,v 1.1 2005/03/27 17:26:44 stuart Exp $ + +PHPSAPI="thttpd" + +MY_PHP_P="php-5.0.3" +MY_THTTPD_P="${P%[a-z]*}" + +inherit php5-sapi-r1 flag-o-matic + +DESCRIPTION="Small and fast multiplexing webserver." +HOMEPAGE="http://www.acme.com/software/thttpd/" +SRC_URI="http://www.acme.com/software/thttpd/${P}.tar.gz + php? ( http://www.php.net/distributions/${MY_PHP_P}.tar.gz )" + +LICENSE="BSD" +SLOT="0" +KEYWORDS="~x86 ~ppc" +IUSE="static php" + +DEPEND="virtual/libc" + +PHP_S="${WORKDIR}/${MY_PHP_P}" + +pkg_setup() { + if useq php ; then + php5-sapi-r2_pkg_setup + fi +} + +src_unpack() { + unpack ${A} + + if useq php ; then + cd ${WORKDIR} + epatch ${FILESDIR}/${MY_THTTPD_P}/php-5.0.3-thttpd-2.25b.patch + epatch ${FILESDIR}/php-5.0.3-IOV.patch + php5-sapi-r2_src_unpack + fi +} + +src_compile() { + # compile PHP5 first + if useq php ; then + my_conf="--with-thttpd=${S}" + php5-sapi-r2_src_compile + php5-sapi-r2_src_install + fi + + cd ${S} + + ## TODO: what to do with IPv6? + + append-ldflags -Wl,-z,now + use static && append-ldflags -static + + econf || die "econf failed" + emake || die "emake failed" +} + +src_install () { + if useq php ; then + # we have to do the install again, because Portage wipes anything + # put into $D during src_compile + # + # ideally, we need to improve the eclass + php5-sapi-r2_src_install + fi + + cd ${S} + dodir /usr/share/man/man1 + make prefix=${D}/usr \ + MANDIR=${D}/usr/share/man \ + WEBGROUP=nogroup \ + WEBDIR=${D}/var/www/localhost \ + "$@" install || die "make install failed" + + mv ${D}/usr/sbin/{,th_}htpasswd + mv ${D}/usr/share/man/man1/{,th_}htpasswd.1 + + newinitd ${FILESDIR}/${MY_THTTPD_P}/thttpd.init thttpd + newconfd ${FILESDIR}/${MY_THTTPD_P}/thttpd.confd thttpd + + dodoc README INSTALL TODO + + insinto /etc/thttpd + doins ${FILESDIR}/${MY_THTTPD_P}/thttpd.conf.sample +} + +pkg_postinst() { + if useq php ; then + php5-sapi-r2_pkg_postinst + fi + + einfo "Adjust THTTPD_DOCROOT in /etc/conf.d/thttpd !" +} |