FreeBSD Bugzilla – Attachment 162163 Details for
Bug 203843
devel/kdevplatform: fix build with subversion 1.9
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Help
|
New Account
|
Log In
Remember
[x]
|
Forgot Password
Login:
[x]
[patch]
Add files/patch-git-fix-subversion-1.9
devel__kdevplatfrom-svn.diff (text/plain), 5.09 KB, created by
Tobias Berner
on 2015-10-17 19:43:24 UTC
(
hide
)
Description:
Add files/patch-git-fix-subversion-1.9
Filename:
MIME Type:
Creator:
Tobias Berner
Created:
2015-10-17 19:43:24 UTC
Size:
5.09 KB
patch
obsolete
>Index: devel/kdevplatform/files/patch-git-fix-subversion-1.9 >=================================================================== >--- devel/kdevplatform/files/patch-git-fix-subversion-1.9 (nonexistent) >+++ devel/kdevplatform/files/patch-git-fix-subversion-1.9 (working copy) >@@ -0,0 +1,147 @@ >+From 8117ca137b45816865554d6e86b96d9e633a7e08 Mon Sep 17 00:00:00 2001 >+From: Alex Merry <alex.merry@kde.org> >+Date: Sun, 16 Aug 2015 23:59:35 +0100 >+Subject: [PATCH] Make subversion plugin compile with subversion 1.9. >+ >+The plugin was formerly using private API, which was hidden in 1.9. >+ >+REVIEW: 124783 >+(cherry picked from commit cfb7f8d89e4749c7b07c7880b3065bf8a86be22c) >+--- >+ plugins/subversion/kdevsvncpp/client_ls.cpp | 69 +++++++++++++++++++++++++++++ >+ plugins/subversion/kdevsvncpp/dirent.cpp | 4 +- >+ plugins/subversion/kdevsvncpp/dirent.hpp | 2 +- >+ 3 files changed, 72 insertions(+), 3 deletions(-) >+ >+diff --git a/plugins/subversion/kdevsvncpp/client_ls.cpp b/plugins/subversion/kdevsvncpp/client_ls.cpp >+index 6cd79bb..95fd6cb 100644 >+--- plugins/subversion/kdevsvncpp/client_ls.cpp >++++ plugins/subversion/kdevsvncpp/client_ls.cpp >+@@ -29,6 +29,7 @@ >+ #include "svn_client.h" >+ #include "svn_path.h" >+ #include "svn_sorts.h" >++#include "svn_version.h" >+ //#include "svn_utf.h" >+ >+ // svncpp >+@@ -37,6 +38,8 @@ >+ #include "kdevsvncpp/exception.hpp" >+ >+ >++#if SVN_VER_MAJOR == 1 && SVN_VER_MINOR < 8 >++ >+ static int >+ compare_items_as_paths(const svn_sort__item_t *a, const svn_sort__item_t *b) >+ { >+@@ -90,6 +93,72 @@ namespace svn >+ } >+ } >+ >++#else >++ >++#include <algorithm> >++ >++static svn_error_t* store_entry( >++ void *baton, >++ const char *path, >++ const svn_dirent_t *dirent, >++ const svn_lock_t *, >++ const char *abs_path, >++ const char *, >++ const char *, >++ apr_pool_t *scratch_pool) >++{ >++ svn::DirEntries *entries = reinterpret_cast<svn::DirEntries*>(baton); >++ if (path[0] == '\0') { >++ if (dirent->kind == svn_node_file) { >++ // for compatibility with svn_client_ls behaviour, listing a file >++ // stores that file name >++ entries->push_back(svn::DirEntry(svn_path_basename(abs_path, scratch_pool), dirent)); >++ } >++ } else { >++ entries->push_back(svn::DirEntry(path, dirent)); >++ } >++ return SVN_NO_ERROR; >++} >++ >++static bool sort_by_path(svn::DirEntry const& a, svn::DirEntry const& b) >++{ >++ return svn_path_compare_paths(a.name(), b.name()) < 0; >++} >++ >++namespace svn >++{ >++ DirEntries >++ Client::list(const char * pathOrUrl, >++ svn_opt_revision_t * revision, >++ bool recurse) throw(ClientException) >++ { >++ Pool pool; >++ DirEntries entries; >++ >++ svn_error_t * error = >++ svn_client_list3(pathOrUrl, >++ revision, >++ revision, >++ SVN_DEPTH_INFINITY_OR_IMMEDIATES(recurse), >++ SVN_DIRENT_ALL, >++ FALSE, // fetch locks >++ FALSE, // include externals >++ &store_entry, >++ &entries, >++ *m_context, >++ pool); >++ >++ if (error != SVN_NO_ERROR) >++ throw ClientException(error); >++ >++ std::sort(entries.begin(), entries.end(), &sort_by_path); >++ >++ return entries; >++ } >++} >++ >++#endif >++ >+ /* ----------------------------------------------------------------- >+ * local variables: >+ * eval: (load-file "../../rapidsvn-dev.el") >+diff --git a/plugins/subversion/kdevsvncpp/dirent.cpp b/plugins/subversion/kdevsvncpp/dirent.cpp >+index f911e91..75dd29c 100644 >+--- plugins/subversion/kdevsvncpp/dirent.cpp >++++ plugins/subversion/kdevsvncpp/dirent.cpp >+@@ -47,7 +47,7 @@ public: >+ { >+ } >+ >+- Data(const char * _name, svn_dirent_t * dirEntry) >++ Data(const char * _name, const svn_dirent_t * dirEntry) >+ : name(_name), kind(dirEntry->kind), size(dirEntry->size), >+ hasProps(dirEntry->has_props != 0), >+ createdRev(dirEntry->created_rev), time(dirEntry->time) >+@@ -78,7 +78,7 @@ public: >+ { >+ } >+ >+- DirEntry::DirEntry(const char * name, svn_dirent_t * DirEntry) >++ DirEntry::DirEntry(const char * name, const svn_dirent_t * DirEntry) >+ : m(new Data(name, DirEntry)) >+ { >+ } >+diff --git a/plugins/subversion/kdevsvncpp/dirent.hpp b/plugins/subversion/kdevsvncpp/dirent.hpp >+index cabef7e..2f0f8d8 100644 >+--- plugins/subversion/kdevsvncpp/dirent.hpp >++++ plugins/subversion/kdevsvncpp/dirent.hpp >+@@ -41,7 +41,7 @@ namespace svn >+ /** >+ * constructor for existing @a svn_dirent_t entries >+ */ >+- DirEntry(const char * name, svn_dirent_t * dirEntry); >++ DirEntry(const char * name, const svn_dirent_t * dirEntry); >+ >+ /** >+ * copy constructor >+-- >+2.6.1 >+ > >Property changes on: devel/kdevplatform/files/patch-git-fix-subversion-1.9 >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 203843
: 162163