diff options
author | Lev A. Serebryakov <lev@FreeBSD.org> | 2004-09-26 07:37:00 +0000 |
---|---|---|
committer | Lev A. Serebryakov <lev@FreeBSD.org> | 2004-09-26 07:37:00 +0000 |
commit | f65b6cf84a354b3229ba1777675b3ae4a0bc12a3 (patch) | |
tree | 20c0c31c346fc25a6729f11284e2025263e1ef3d /devel/subversion | |
parent | e5019a7ebb3b44a9267f7be2419093b699eb7fe6 (diff) |
Update to 1.0.8: security fix.
PR: ports/72070
Submitted by: bmah
Approved by: portmgr (Mark Linimon)
Notes
Notes:
svn path=/head/; revision=118438
Diffstat (limited to 'devel/subversion')
-rw-r--r-- | devel/subversion/Makefile | 3 | ||||
-rw-r--r-- | devel/subversion/distinfo | 4 | ||||
-rw-r--r-- | devel/subversion/files/patch-svnperl-memoryleak | 195 | ||||
-rw-r--r-- | devel/subversion/pkg-plist | 2 |
4 files changed, 5 insertions, 199 deletions
diff --git a/devel/subversion/Makefile b/devel/subversion/Makefile index 21a0193d805e..16fb8280792e 100644 --- a/devel/subversion/Makefile +++ b/devel/subversion/Makefile @@ -5,8 +5,7 @@ # $FreeBSD$ PORTNAME= subversion -PORTVERSION= 1.0.6 -PORTREVISION= 2 +PORTVERSION= 1.0.8 CATEGORIES= devel MASTER_SITES= http://subversion.tigris.org/tarballs/ diff --git a/devel/subversion/distinfo b/devel/subversion/distinfo index bb85d5ff12db..7e43c3bfb40b 100644 --- a/devel/subversion/distinfo +++ b/devel/subversion/distinfo @@ -1,2 +1,2 @@ -MD5 (subversion-1.0.6.tar.bz2) = bb05fe041fef7491b3555904d97f5e1c -SIZE (subversion-1.0.6.tar.bz2) = 6022074 +MD5 (subversion-1.0.8.tar.bz2) = b2378b7d9d00653249877531a61ef1db +SIZE (subversion-1.0.8.tar.bz2) = 5978990 diff --git a/devel/subversion/files/patch-svnperl-memoryleak b/devel/subversion/files/patch-svnperl-memoryleak deleted file mode 100644 index 46a202ca6ec9..000000000000 --- a/devel/subversion/files/patch-svnperl-memoryleak +++ /dev/null @@ -1,195 +0,0 @@ ---- subversion/bindings/swig/svn_types.i (revision 10171) -+++ subversion/bindings/swig/svn_types.i (revision 10172) -@@ -316,7 +316,7 @@ - %typemap(perl5, in) (svn_commit_callback_t callback, void *callback_baton) { - $1 = svn_swig_pl_thunk_commit_callback; - $2 = (void *)$input; -- SvREFCNT_inc($input); -+ svn_swig_pl_hold_ref_in_pool (_global_pool, $input); - }; - - /* ----------------------------------------------------------------------- ---- subversion/bindings/swig/swigutil_pl.c (revision 10171) -+++ subversion/bindings/swig/swigutil_pl.c (revision 10172) -@@ -1385,3 +1385,16 @@ apr_file_t *svn_swig_pl_make_file (SV *f - } - return apr_file; - } -+ -+static apr_status_t cleanup_refcnt (void *data) -+{ -+ SV *sv = data; -+ SvREFCNT_dec (sv); -+ return APR_SUCCESS; -+} -+ -+void svn_swig_pl_hold_ref_in_pool (apr_pool_t *pool, SV *sv) -+{ -+ SvREFCNT_inc(sv); -+ apr_pool_cleanup_register (pool, sv, cleanup_refcnt, apr_pool_cleanup_null); -+} ---- subversion/bindings/swig/swigutil_pl.h (revision 10171) -+++ subversion/bindings/swig/swigutil_pl.h (revision 10172) -@@ -231,6 +231,7 @@ SV *svn_swig_pl_from_stream (svn_stream_ - /* apr_file_t * */ - apr_file_t *svn_swig_pl_make_file (SV *file, apr_pool_t *pool); - -+void svn_swig_pl_hold_ref_in_pool (apr_pool_t *pool, SV *sv); - - #ifdef __cplusplus - } ---- subversion/bindings/swig/perl/t/5delta.t (revision 10171) -+++ subversion/bindings/swig/perl/t/5delta.t (revision 10172) -@@ -4,27 +4,19 @@ use Test::More tests => 2; - require SVN::Core; - require SVN::Delta; - --SKIP: { -- eval { require IO::String }; -+my ($srctext, $tgttext, $result) = ('abcd===eflfjgjkx', 'abcd=--ef==lfjffgjx', ''); - -- skip "IO::String not installed", 2 if $@; -- my $srctext = 'abcd===eflfjgjkx'; -- my $tgttext = 'abcd=--ef==lfjffgjx'; -+open my $source, '<', \$srctext; -+open my $target, '<', \$tgttext; -+open my $aresult, '>', \$result; - -- my $source = IO::String->new ($srctext); -- my $target = IO::String->new ($tgttext); -+my $txstream = SVN::TxDelta::new ($source, $target); - -- my $result = ''; -- my $aresult = IO::String->new (\$result); -+isa_ok ($txstream, '_p_svn_txdelta_stream_t'); -+open my $asource, '<', \$srctext; -+my $handle = [SVN::TxDelta::apply ($asource, $aresult, undef, undef)]; - -- my $txstream = SVN::TxDelta::new ($source, $target); -+SVN::TxDelta::send_txstream ($txstream, @$handle); - -- isa_ok ($txstream, '_p_svn_txdelta_stream_t'); -- my $handle = [SVN::TxDelta::apply (IO::String->new ($srctext), -- $aresult, undef, undef)]; -+is ($result, $tgttext, 'delta self test'); - -- SVN::TxDelta::send_txstream ($txstream, @$handle); -- -- is ($result, $tgttext, 'delta self test'); -- --} ---- subversion/bindings/swig/perl/t/1repos.t (revision 10171) -+++ subversion/bindings/swig/perl/t/1repos.t (revision 10172) -@@ -1,6 +1,6 @@ - #!/usr/bin/perl -w - --use Test::More tests => 5; -+use Test::More tests => 6; - use File::Temp qw(tempdir); - use File::Path qw(rmtree); - use strict; -@@ -64,15 +64,20 @@ is_deeply (\@history, [['/tags/foo/filea - 'repos_history'); - - { -+my $pool = SVN::Pool->new_default; -+my $something = bless {}, 'something'; - $editor = SVN::Delta::Editor-> - new (SVN::Repos::get_commit_editor($repos, "file://$repospath", -- '/', 'root', 'FOO', \&committed)); -+ '/', 'root', 'FOO', sub {committed(@_); -+ $something; -+ })); - - my $rootbaton = $editor->open_root(2); - $editor->delete_entry('tags', 2, $rootbaton); - - $editor->close_edit(); - } -+ok ($main::something_destroyed, 'callback properly destroyed'); - - cmp_ok($fs->youngest_rev, '==', 3); - -@@ -80,3 +85,11 @@ END { - diag "cleanup"; - rmtree($repospath); - } -+ -+package something; -+ -+sub DESTROY { -+ $main::something_destroyed++; -+} -+ -+1; ---- subversion/bindings/swig/perl/Delta.pm (revision 10171) -+++ subversion/bindings/swig/perl/Delta.pm (revision 10172) -@@ -143,8 +143,8 @@ sub AUTOLOAD { - return unless $_[0]->{_editor}; - my $class = ref($_[0]); - my $func = $AUTOLOAD; -- $func =~ s/^${class}::(SUPER::)?//; -- return if $func =~ m/^[A-Z]/; -+ $func =~ s/.*:://; -+ return unless $func =~ m/[^A-Z]/; - - my %ebaton = ( set_target_revision => 1, - open_root => 1, ---- subversion/bindings/swig/perl/Base.pm (revision 10171) -+++ subversion/bindings/swig/perl/Base.pm (revision 10172) -@@ -7,7 +7,7 @@ SVN::Base - Base class for importing sym - =head1 SYNOPSIS - - # Load the svn_ra_* functions into the SVN::Ra namespace. -- pacakge SVN::Ra; -+ package SVN::Ra; - use SVN::Base qw(Ra svn_ra_); - - # Load svn_config_t structure accessors in the magic namcespace ---- subversion/bindings/swig/perl/Ra.pm (revision 10171) -+++ subversion/bindings/swig/perl/Ra.pm (revision 10172) -@@ -63,26 +63,25 @@ require SVN::Client; - - my $ralib = init_ra_libs; - -+# Ra methods that returns reporter -+my %reporter = map { $_ => 1 } qw(do_diff do_switch do_status do_update); - our $AUTOLOAD; - - sub AUTOLOAD { - my $class = ref($_[0]); -- $AUTOLOAD =~ s/^${class}::(SUPER::)?//; -- return if $AUTOLOAD =~ m/^[A-Z]/; -+ my $method = $AUTOLOAD; -+ $method =~ s/.*:://; -+ return unless $method =~ m/[^A-Z]/; - - my $self = shift; - no strict 'refs'; - - die "no such method $AUTOLOAD" -- unless $self->can("plugin_invoke_$AUTOLOAD"); -+ unless $self->can("plugin_invoke_$method"); - -- my @ret = &{"plugin_invoke_$AUTOLOAD"}(@{$self}{qw/ra session/}, @_, -- $self->{pool}); -- -- return $ret[0] unless $#ret; -- -- return ($AUTOLOAD eq 'get_commit_editor') ? @ret : -- bless [@ret], 'SVN::Ra::Reporter'; -+ my @ret = &{"plugin_invoke_$method"}(@{$self}{qw/ra session/}, @_); -+ return bless [@ret], 'SVN::Ra::Reporter' if $reporter{$method}; -+ return $#ret == 0 ? $ret[0] : @ret; - } - - sub new { -@@ -106,7 +105,7 @@ sub new { - [SVN::Client::get_username_provider()]); - } - -- my $pool = $self->{pool} ||= SVN::Core::pool_create(undef); -+ my $pool = $self->{pool} ||= SVN::Pool->new; - - $self->{ra} = get_ra_library ($ralib, $self->{url}); - my $callback = 'SVN::Ra::Callbacks'; diff --git a/devel/subversion/pkg-plist b/devel/subversion/pkg-plist index 0d6bd72699b6..2bf600114ed2 100644 --- a/devel/subversion/pkg-plist +++ b/devel/subversion/pkg-plist @@ -73,7 +73,9 @@ lib/libsvn_subr-1.so.0 lib/libsvn_wc-1.a lib/libsvn_wc-1.so lib/libsvn_wc-1.so.0 +%%MOD_DAV_SVN%%libexec/apache2/mod_dav_svn.a %%MOD_DAV_SVN%%libexec/apache2/mod_dav_svn.so +%%MOD_DAV_SVN%%libexec/apache2/mod_authz_svn.a %%MOD_DAV_SVN%%libexec/apache2/mod_authz_svn.so %%MOD_DAV_SVN%%@exec %D/sbin/apxs -e -S LIBEXECDIR=%D/libexec/apache2 -a -n dav libexec/apache2/mod_dav.so %%MOD_DAV_SVN%%@exec %D/sbin/apxs -e -S LIBEXECDIR=%D/libexec/apache2 -a -n dav_svn libexec/apache2/mod_dav_svn.so |