aboutsummaryrefslogtreecommitdiff
path: root/www/mod_ruby
diff options
context:
space:
mode:
authorDirk Meyer <dinoex@FreeBSD.org>2010-02-18 06:15:09 +0000
committerDirk Meyer <dinoex@FreeBSD.org>2010-02-18 06:15:09 +0000
commita30150ae6c96d4cd27e4a5989e732782f7bf7960 (patch)
treefa5427fb79c490dba7296f7c06dcb69b016c3b2d /www/mod_ruby
parentecccfff8c87befc53d2f32cf787b93535162187e (diff)
downloadports-a30150ae6c96d4cd27e4a5989e732782f7bf7960.tar.gz
ports-a30150ae6c96d4cd27e4a5989e732782f7bf7960.zip
- include new upstream patches
- drop dependency on eruby Suggested by: Ruslan Mahmatkhanov Feature safe: yes
Notes
Notes: svn path=/head/; revision=250024
Diffstat (limited to 'www/mod_ruby')
-rw-r--r--www/mod_ruby/Makefile12
-rw-r--r--www/mod_ruby/files/patch-aa-git171
-rw-r--r--www/mod_ruby/files/patch-connection.c20
3 files changed, 197 insertions, 6 deletions
diff --git a/www/mod_ruby/Makefile b/www/mod_ruby/Makefile
index 6fd6913afd63..4272a0f05a6e 100644
--- a/www/mod_ruby/Makefile
+++ b/www/mod_ruby/Makefile
@@ -7,6 +7,7 @@
PORTNAME= mod_ruby
PORTVERSION= 1.3.0
+PORTREVISION= 1
CATEGORIES= www ruby
MASTER_SITES= http://www.modruby.net/archive/
DIST_SUBDIR= ruby
@@ -14,18 +15,15 @@ DIST_SUBDIR= ruby
MAINTAINER= dinoex@FreeBSD.org
COMMENT= An Apache module that embeds Ruby interpreter within
-LIB_DEPENDS= eruby.10:${PORTSDIR}/textproc/eruby
-
MAKE_JOBS_SAFE= yes
USE_APACHE= 1.3+
USE_RUBY= yes
USE_PERL5_BUILD= yes
-CONFIGURE_ARGS= --with-apxs="${APXS}" \
- --enable-eruby=yes \
- --with-eruby-includes="${LOCALBASE}/include" \
- --with-eruby-libraries="${LOCALBASE}/lib"
+CONFIGURE_ARGS= --with-apxs="${APXS}"
+CFLAGS+= -DONIG_ESCAPE_REGEX_T_COLLISION
+CONFIGURE_ENV+= CFLAGS="${CFLAGS}"
MAKE_ARGS= RUBY="${RUBY}"
INSTALL_TARGET= site-install
@@ -74,4 +72,6 @@ doc-install:
.endif
@${CAT} ${PKGMESSAGE}
+#RUBY_VER=1.9
+
.include <bsd.port.post.mk>
diff --git a/www/mod_ruby/files/patch-aa-git b/www/mod_ruby/files/patch-aa-git
new file mode 100644
index 000000000000..436182678c8c
--- /dev/null
+++ b/www/mod_ruby/files/patch-aa-git
@@ -0,0 +1,171 @@
+diff -ur mod_ruby-1.3.0/Makefile.in mod_ruby/Makefile.in
+--- mod_ruby-1.3.0/Makefile.in 2008-11-08 05:15:36.000000000 +0100
++++ Makefile.in 2010-02-17 14:25:57.000000000 +0100
+@@ -16,6 +16,7 @@
+ bindir = @bindir@
+ datadir = @datadir@
+ libdir = @libdir@
++rubylibprefix = @rubylibprefix@
+ rubylibdir = @rubylibdir@
+ archdir = @archdir@
+ sitedir = @sitedir@
+@@ -29,6 +30,7 @@
+ LD = @LD@
+ RANLIB = @RANLIB@
+ RUBY = @RUBY@
++RUBY_BASE_NAME = @RUBY_BASE_NAME@
+ RM = @RM@
+
+ CFLAGS = @CFLAGS@ -I. -I$(hdrdir) -I$(hdrdir)/$(arch) $(APACHE_INCLUDES) $(LIBAPREQ_INCLUDES) @DEFS@
+diff -ur mod_ruby-1.3.0/autoconf.rb mod_ruby/autoconf.rb
+--- mod_ruby-1.3.0/autoconf.rb 2008-11-08 05:15:36.000000000 +0100
++++ autoconf.rb 2010-02-17 14:25:57.000000000 +0100
+@@ -243,6 +243,8 @@
+ $bindir = CONFIG["bindir"].sub(prefix, "$(exec_prefix)").sub(drive, '')
+ $datadir = CONFIG["datadir"].sub(prefix, "$(prefix)").sub(drive, '')
+ $libdir = CONFIG["libdir"].sub(prefix, "$(exec_prefix)").sub(drive, '')
++$RUBY_BASE_NAME = CONFIG["RUBY_BASE_NAME"]
++$rubylibprefix = CONFIG["rubylibprefix"]
+ $archdir = $archdir.sub(prefix, "$(prefix)").sub(drive, '')
+ $sitelibdir = $sitelibdir.sub(prefix, "$(prefix)").sub(drive, '')
+ $sitearchdir = $sitearchdir.sub(prefix, "$(prefix)").sub(drive, '')
+@@ -416,6 +418,7 @@
+ AC_SUBST("bindir")
+ AC_SUBST("datadir")
+ AC_SUBST("libdir")
++AC_SUBST("rubylibprefix")
+ AC_SUBST("rubylibdir")
+ AC_SUBST("archdir")
+ AC_SUBST("sitedir")
+@@ -429,6 +432,7 @@
+ AC_SUBST("LD")
+ AC_SUBST("RANLIB")
+ AC_SUBST("RUBY")
++AC_SUBST("RUBY_BASE_NAME")
+ AC_SUBST("RM")
+
+ AC_SUBST("CFLAGS")
+diff -ur mod_ruby-1.3.0/configure.rb mod_ruby/configure.rb
+--- mod_ruby-1.3.0/configure.rb 2008-11-08 05:15:36.000000000 +0100
++++ configure.rb 2010-02-17 14:25:57.000000000 +0100
+@@ -221,6 +221,8 @@
+ $bindir = CONFIG["bindir"].sub(prefix, "$(exec_prefix)").sub(drive, '')
+ $datadir = CONFIG["datadir"].sub(prefix, "$(prefix)").sub(drive, '')
+ $libdir = CONFIG["libdir"].sub(prefix, "$(exec_prefix)").sub(drive, '')
++$RUBY_BASE_NAME = CONFIG["RUBY_BASE_NAME"]
++$rubylibprefix = CONFIG["rubylibprefix"]
+ $archdir = $archdir.sub(prefix, "$(prefix)").sub(drive, '')
+ $sitelibdir = $sitelibdir.sub(prefix, "$(prefix)").sub(drive, '')
+ $sitearchdir = $sitearchdir.sub(prefix, "$(prefix)").sub(drive, '')
+@@ -394,6 +396,7 @@
+ AC_SUBST("bindir")
+ AC_SUBST("datadir")
+ AC_SUBST("libdir")
++AC_SUBST("rubylibprefix")
+ AC_SUBST("rubylibdir")
+ AC_SUBST("archdir")
+ AC_SUBST("sitedir")
+@@ -407,6 +410,7 @@
+ AC_SUBST("LD")
+ AC_SUBST("RANLIB")
+ AC_SUBST("RUBY")
++AC_SUBST("RUBY_BASE_NAME")
+ AC_SUBST("RM")
+
+ AC_SUBST("CFLAGS")
+diff -ur mod_ruby-1.3.0/lib/apache/erb-run.rb mod_ruby/lib/apache/erb-run.rb
+--- mod_ruby-1.3.0/lib/apache/erb-run.rb 2005-08-03 03:32:41.000000000 +0200
++++ lib/apache/erb-run.rb 2010-02-17 14:25:57.000000000 +0100
+@@ -97,7 +97,7 @@
+ r.allowed |= (1 << M_POST)
+ return DECLINED
+ end
+- if r.finfo.mode == 0
++ if r.finfo.nil? || r.finfo.mode == 0
+ return NOT_FOUND
+ end
+
+diff -ur mod_ruby-1.3.0/lib/apache/eruby-run.rb mod_ruby/lib/apache/eruby-run.rb
+--- mod_ruby-1.3.0/lib/apache/eruby-run.rb 2007-04-04 10:02:18.000000000 +0200
++++ lib/apache/eruby-run.rb 2010-02-17 14:25:57.000000000 +0100
+@@ -89,7 +89,7 @@
+ r.allowed |= (1 << M_POST)
+ return DECLINED
+ end
+- if r.finfo.mode == 0
++ if r.finfo.nil? || r.finfo.mode == 0
+ return NOT_FOUND
+ end
+ return OK
+diff -ur mod_ruby-1.3.0/lib/apache/ruby-run.rb mod_ruby/lib/apache/ruby-run.rb
+--- mod_ruby-1.3.0/lib/apache/ruby-run.rb 2005-08-03 03:32:41.000000000 +0200
++++ lib/apache/ruby-run.rb 2010-02-17 14:25:57.000000000 +0100
+@@ -62,7 +62,7 @@
+ r.allowed |= (1 << M_POST)
+ return DECLINED
+ end
+- if r.finfo.mode == 0
++ if r.finfo.nil? || r.finfo.mode == 0
+ return NOT_FOUND
+ end
+ if r.allow_options & OPT_EXECCGI == 0
+@@ -80,6 +80,7 @@
+ r.setup_cgi_env
+ filename = r.filename.dup
+ filename.untaint
++ filename.freeze # to avoid SecurityError in 1.9
+ Apache.chdir_file(filename)
+ return filename
+ end
+diff -ur mod_ruby-1.3.0/mod_ruby.c mod_ruby/mod_ruby.c
+--- mod_ruby-1.3.0/mod_ruby.c 2008-11-08 05:34:48.000000000 +0100
++++ mod_ruby.c 2010-02-17 14:25:57.000000000 +0100
+@@ -706,7 +706,7 @@
+ #ifdef RUBY_VM
+ Init_prelude();
+ #endif
+- default_load_path = GET_LOAD_PATH();
++ default_load_path = rb_ary_dup(GET_LOAD_PATH());
+ rb_global_variable(&default_load_path);
+ rb_define_variable("$0", &progname);
+ list = (char **) conf->load_path->elts;
+diff -ur mod_ruby-1.3.0/request.c mod_ruby/request.c
+--- mod_ruby-1.3.0/request.c 2008-11-08 04:57:19.000000000 +0100
++++ request.c 2010-02-17 14:25:57.000000000 +0100
+@@ -788,7 +788,7 @@
+ return data->notes;
+ }
+
+-#ifdef APACHE2
++#if defined(APACHE2) && !defined(RUBY_VM)
+
+ #ifdef WIN32
+ typedef int mode_t;
+@@ -859,12 +859,17 @@
+
+ static VALUE request_finfo(VALUE self)
+ {
+- VALUE cStat;
+ request_data *data;
+- struct stat *st;
+
+ data = get_request_data(self);
+ if (NIL_P(data->finfo)) {
++#ifdef RUBY_VM
++ data->finfo = rb_protect_funcall(rb_cFile, rb_intern("stat"), NULL, 1,
++ rb_str_new2(data->request->filename));
++#else
++ VALUE cStat;
++ struct stat *st;
++
+ cStat = rb_const_get(rb_cFile, rb_intern("Stat"));
+ data->finfo = Data_Make_Struct(cStat, struct stat, NULL, free, st);
+ #ifdef APACHE2
+@@ -884,6 +889,7 @@
+ #else /* Apache 1.x */
+ *st = data->request->finfo;
+ #endif
++#endif
+ }
+ return data->finfo;
+ }
diff --git a/www/mod_ruby/files/patch-connection.c b/www/mod_ruby/files/patch-connection.c
new file mode 100644
index 000000000000..3a38f5506ebf
--- /dev/null
+++ b/www/mod_ruby/files/patch-connection.c
@@ -0,0 +1,20 @@
+--- connection.c.orig 2007-07-31 09:03:53.000000000 +0200
++++ connection.c 2009-06-30 12:55:06.000000000 +0200
+@@ -81,7 +81,7 @@
+ Data_Get_Struct(self, conn_rec, conn);
+ Check_Type(val, T_STRING);
+ conn->user = ap_pstrndup(conn->pool,
+- RSTRING(val)->ptr, RSTRING(val)->len);
++ RSTRING_PTR(val), RSTRING_LEN(val));
+ return val;
+ }
+
+@@ -92,7 +92,7 @@
+ Data_Get_Struct(self, conn_rec, conn);
+ Check_Type(val, T_STRING);
+ conn->ap_auth_type = ap_pstrndup(conn->pool,
+- RSTRING(val)->ptr, RSTRING(val)->len);
++ RSTRING_PTR(val), RSTRING_LEN(val));
+ return val;
+ }
+ #endif