Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 27 Oct 2015 22:56:56 +0000 (UTC)
From:      Alonso Schaich <alonso@FreeBSD.org>
To:        ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org
Subject:   svn commit: r400360 - head/devel/kdevplatform/files
Message-ID:  <201510272256.t9RMuuaK097737@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: alonso
Date: Tue Oct 27 22:56:56 2015
New Revision: 400360
URL: https://svnweb.freebsd.org/changeset/ports/400360

Log:
  Use tcberner's patch to fix build with recent svn
  
  The subversion port was upgraded to version 1.9. devel/kdevplatform fails to
  build against it.
  
  Bring in the patch attached to the bug tracking system by Tobias C. Berner.
  See #203843 for more information.
  
  PR:		203843
  Submitted by:	Tobias C. Berner (tcberner@gmail.com) via Bug Tracking System
  Approved by:	rakuco (mentor)
  Differential Revision:	https://reviews.freebsd.org/D4003

Added:
  head/devel/kdevplatform/files/
  head/devel/kdevplatform/files/patch-git-fix-subversion-1.9   (contents, props changed)

Added: head/devel/kdevplatform/files/patch-git-fix-subversion-1.9
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/devel/kdevplatform/files/patch-git-fix-subversion-1.9	Tue Oct 27 22:56:56 2015	(r400360)
@@ -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
+



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201510272256.t9RMuuaK097737>