ports/www/mod_ruby/files/patch-aa-git
Dirk Meyer 0cac623a76 - import latest git patches.
PR:		168513
Submitted by:	fluffy (Dima Panov)
2012-06-02 08:55:36 +00:00

247 lines
7.1 KiB
Text

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
@@ -658,7 +658,6 @@
RETSIGTYPE (*sigterm_handler)_((int));
#endif
#ifdef RUBY_VM
- void Init_prelude(void);
RUBY_INIT_STACK;
#else
VALUE stack_start;
@@ -703,12 +702,14 @@
#endif
ruby_init_loadpath();
-#ifdef RUBY_VM
- Init_prelude();
-#endif
- default_load_path = GET_LOAD_PATH();
+ {
+ char *argv[] = { "ruby", "-e", "" };
+ ruby_options(3, argv);
+ }
+ default_load_path = rb_ary_dup(GET_LOAD_PATH());
rb_global_variable(&default_load_path);
rb_define_variable("$0", &progname);
+ rb_define_variable("$PROGRAM_NAME", &progname);
list = (char **) conf->load_path->elts;
n = conf->load_path->nelts;
for (i = 0; i < n; i++) {
@@ -734,6 +735,7 @@
}
}
+#ifndef RUBY_VM
static void dso_unload(void *handle)
{
#if defined(_WIN32)
@@ -747,16 +749,24 @@
#endif
}
-static void ruby_finalize_interpreter()
+static void ruby_unload_libraries()
{
RUBY_EXTERN VALUE ruby_dln_librefs;
int i;
- ruby_finalize();
for (i = 0; i < RARRAY_LEN(ruby_dln_librefs); i++) {
dso_unload((void *) NUM2LONG(RARRAY_PTR(ruby_dln_librefs)[i]));
}
}
+#endif
+
+static void ruby_finalize_interpreter()
+{
+ ruby_finalize();
+#ifndef RUBY_VM
+ ruby_unload_libraries();
+#endif
+}
#if APR_HAS_THREADS
static void* APR_THREAD_FUNC ruby_thread_start(apr_thread_t *t, void *data)
@@ -1006,8 +1016,7 @@
static VALUE kill_threads(VALUE arg)
{
- extern VALUE rb_thread_list();
- VALUE threads = rb_thread_list();
+ VALUE threads = rb_protect_funcall(rb_cThread, rb_intern("list"), NULL, 0);
VALUE main_thread = rb_thread_main();
VALUE th;
int i;
diff -ur mod_ruby-1.3.0/mod_ruby.h mod_ruby/mod_ruby.h
--- mod_ruby-1.3.0/mod_ruby.h 2008-11-08 13:57:19.000000000 +1000
+++ mod_ruby.h 2011-08-09 00:52:48.000000000 +1100
@@ -47,8 +47,7 @@
#define IO_PATH(fptr) (StringValuePtr(fptr->pathv))
-VALUE rb_get_load_path(void);
-#define GET_LOAD_PATH() (rb_get_load_path())
+#define GET_LOAD_PATH() (rb_gv_get("$:"))
#define SET_LOAD_PATH(path) (rb_gv_set("$:", path))
#else
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;
}