summaryrefslogtreecommitdiff
path: root/devel/umbrello
diff options
context:
space:
mode:
authorjoerg <joerg@pkgsrc.org>2013-11-11 16:47:07 +0000
committerjoerg <joerg@pkgsrc.org>2013-11-11 16:47:07 +0000
commitc31dc9a530240470d38a82d15200a9cd47870983 (patch)
tree284982fb25308cdb4e58783e258f6c9752aa2428 /devel/umbrello
parent91c5c1e7fe4a3fb2aaf0b2d926b72dd2430bd3d0 (diff)
downloadpkgsrc-c31dc9a530240470d38a82d15200a9cd47870983.tar.gz
Merge some changes from upstream to build with Sun PRO and libc++,
from rakuco@FreeBSD.org.
Diffstat (limited to 'devel/umbrello')
-rw-r--r--devel/umbrello/distinfo6
-rw-r--r--devel/umbrello/patches/patch-umbrello_CMakeLists.txt59
-rw-r--r--devel/umbrello/patches/patch-umbrello_codeimport_classimport.cpp30
-rw-r--r--devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_position.h65
-rw-r--r--devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_preprocesslexer.cpp39
5 files changed, 198 insertions, 1 deletions
diff --git a/devel/umbrello/distinfo b/devel/umbrello/distinfo
index 1d912e812a6..b709bae01c7 100644
--- a/devel/umbrello/distinfo
+++ b/devel/umbrello/distinfo
@@ -1,5 +1,9 @@
-$NetBSD: distinfo,v 1.3 2013/11/07 10:42:26 markd Exp $
+$NetBSD: distinfo,v 1.4 2013/11/11 16:47:07 joerg Exp $
SHA1 (umbrello-4.11.3.tar.xz) = 98274cfe91db7b56429a9de0d23ae490adee9ce0
RMD160 (umbrello-4.11.3.tar.xz) = e3455869134019335ac47ce89b4f074fbdb9bc79
Size (umbrello-4.11.3.tar.xz) = 1478632 bytes
+SHA1 (patch-umbrello_CMakeLists.txt) = 9188a7d3b8a0b69def0cdfd2280a4f51eb4cde5b
+SHA1 (patch-umbrello_codeimport_classimport.cpp) = 8c4be72436bba4696d3b3e88bca8b360259123d3
+SHA1 (patch-umbrello_codeimport_kdevcppparser_position.h) = 5a2d2e24df8fbbc56c910f2e800b21083319d8c5
+SHA1 (patch-umbrello_codeimport_kdevcppparser_preprocesslexer.cpp) = 87c6c12c1e19009723aa58c89ef7ca67eedc04f0
diff --git a/devel/umbrello/patches/patch-umbrello_CMakeLists.txt b/devel/umbrello/patches/patch-umbrello_CMakeLists.txt
new file mode 100644
index 00000000000..86db0cab1e0
--- /dev/null
+++ b/devel/umbrello/patches/patch-umbrello_CMakeLists.txt
@@ -0,0 +1,59 @@
+$NetBSD: patch-umbrello_CMakeLists.txt,v 1.1 2013/11/11 16:47:07 joerg Exp $
+
+Patches from upstream.
+
+--- umbrello/CMakeLists.txt.orig 2013-08-28 17:14:58.000000000 +0000
++++ umbrello/CMakeLists.txt
+@@ -268,37 +268,21 @@ set(libcodeimport_SRCS
+ codeimport/csharp/csharpimport.cpp
+ )
+
+-if (WIN32 AND NOT MSVC)
+- # SunPRO CC have a problem with position.h; we try to put a
+- # QChar into a spirit iterator, which, after a bunch of futzing, ends up in
+- # the STL string_ref templates, which use
+- #
+- # union {
+- # size_type _C_size; // Number of actual data values stored
+- # _CharT _C_dummy; // force the alignment of the first char
+- # } _C_size; // named to work around an HP aCC 3.30 bug
+- #
+- # and you can't have a class which requires an initializer in a union.
+- #
+- add_definitions(-DDISABLE_CPP_IMPORT)
+- set(libkdevcppparser_SRCS)
+-else (WIN32 AND NOT MSVC)
+- list(APPEND libcodeimport_SRCS
+- codeimport/cppimport.cpp
+- )
+- set(libkdevcppparser_SRCS
+- codeimport/kdevcppparser/ast.cpp
+- codeimport/kdevcppparser/driver.cpp
+- codeimport/kdevcppparser/errors.cpp
+- codeimport/kdevcppparser/lexer.cpp
+- codeimport/kdevcppparser/lookup.cpp
+- codeimport/kdevcppparser/parser.cpp
+- codeimport/kdevcppparser/preprocesslexer.cpp
+- codeimport/kdevcppparser/tree_parser.cpp
+- codeimport/kdevcppparser/ast_utils.cpp
+- codeimport/kdevcppparser/cpptree2uml.cpp
+- )
+-endif(WIN32 AND NOT MSVC)
++list(APPEND libcodeimport_SRCS
++ codeimport/cppimport.cpp
++)
++set(libkdevcppparser_SRCS
++ codeimport/kdevcppparser/ast.cpp
++ codeimport/kdevcppparser/driver.cpp
++ codeimport/kdevcppparser/errors.cpp
++ codeimport/kdevcppparser/lexer.cpp
++ codeimport/kdevcppparser/lookup.cpp
++ codeimport/kdevcppparser/parser.cpp
++ codeimport/kdevcppparser/preprocesslexer.cpp
++ codeimport/kdevcppparser/tree_parser.cpp
++ codeimport/kdevcppparser/ast_utils.cpp
++ codeimport/kdevcppparser/cpptree2uml.cpp
++)
+
+ set(libclipboard_SRCS
+ clipboard/umldragdata.cpp
diff --git a/devel/umbrello/patches/patch-umbrello_codeimport_classimport.cpp b/devel/umbrello/patches/patch-umbrello_codeimport_classimport.cpp
new file mode 100644
index 00000000000..5ffcc558d3f
--- /dev/null
+++ b/devel/umbrello/patches/patch-umbrello_codeimport_classimport.cpp
@@ -0,0 +1,30 @@
+$NetBSD: patch-umbrello_codeimport_classimport.cpp,v 1.1 2013/11/11 16:47:07 joerg Exp $
+
+Patches from upstream.
+
+--- umbrello/codeimport/classimport.cpp.orig 2013-06-28 18:06:03.000000000 +0000
++++ umbrello/codeimport/classimport.cpp
+@@ -20,9 +20,7 @@
+ #include "javaimport.h"
+ #include "adaimport.h"
+ #include "pascalimport.h"
+-#ifndef DISABLE_CPP_IMPORT
+ #include "cppimport.h"
+-#endif
+ #include "csharpimport.h"
+ #include "codeimpthread.h"
+
+@@ -52,13 +50,8 @@ ClassImport *ClassImport::createImporter
+ classImporter = new PascalImport(thread);
+ else if (fileName.endsWith(QLatin1String(".cs")))
+ classImporter = new CSharpImport(thread);
+-#ifndef DISABLE_CPP_IMPORT
+ else
+ classImporter = new CppImport(thread); // the default.
+-#else
+- else
+- classImporter = 0;
+-#endif
+ return classImporter;
+ }
+
diff --git a/devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_position.h b/devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_position.h
new file mode 100644
index 00000000000..2083bcb175b
--- /dev/null
+++ b/devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_position.h
@@ -0,0 +1,65 @@
+$NetBSD: patch-umbrello_codeimport_kdevcppparser_position.h,v 1.1 2013/11/11 16:47:07 joerg Exp $
+
+Patches from upstream.
+
+--- umbrello/codeimport/kdevcppparser/position.h.orig 2013-06-28 18:06:03.000000000 +0000
++++ umbrello/codeimport/kdevcppparser/position.h
+@@ -20,22 +20,6 @@
+ #ifndef POSITION_H
+ #define POSITION_H
+
+-#ifdef _MSC_VER //Q_CC_MSVC isn't defined here
+-/*
+-workaround for the following msvc error
+-...\Microsoft Visual Studio 8\VC\INCLUDE\xstring(2044) : error C2620:
+- member 'std::basic_string<_Elem>::_Bxty::_Buf ' of union 'std::basic_string<_Elem>::_Bxty'
+- has user-defined constructor or non-trivial default constructor with [ _Elem=QChar]
+-...\Microsoft Visual Studio 8\VC\INCLUDE\xstring(2046) : see reference to class
+- template instantiation 'std::basic_string<_Elem>::_Bxty' being compiled with [ _Elem=QChar]
+-..\umbrello\umbrello\codeimport\kdevcppparser\position.h(49) : see reference to class
+- template instantiation 'std::basic_string<_Elem>' being compiled with [ _Elem=QChar]
+-*/
+-#define union struct
+-#include <xstring>
+-#undef union
+-#endif
+-
+ #include <limits.h>
+ #include <boost/version.hpp>
+ #include <boost/spirit/include/classic.hpp>
+@@ -43,34 +27,7 @@ workaround for the following msvc error
+ #include <QChar>
+ #include <QDebug>
+
+-typedef std::basic_string<QChar> PositionFilenameType;
+-
+-class PositionFilename : public PositionFilenameType
+-{
+-public:
+- PositionFilename()
+- {
+- }
+-
+- explicit PositionFilename(const QString &p) : PositionFilenameType(p.data())
+- {
+- }
+-
+- QString toString() const
+- {
+- QString result;
+- for(unsigned int i = 0; i < size(); i++)
+- result.append(at(i));
+- return result;
+- }
+-};
+-
+-inline QDebug operator<<(QDebug out, const PositionFilename &p)
+-{
+- out << p.toString();
+- return out;
+-}
+-
++typedef QString PositionFilename;
+ typedef boost::spirit::classic::file_position_base<PositionFilename> PositionType;
+
+ class Position : public PositionType
diff --git a/devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_preprocesslexer.cpp b/devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_preprocesslexer.cpp
new file mode 100644
index 00000000000..f220ae548c7
--- /dev/null
+++ b/devel/umbrello/patches/patch-umbrello_codeimport_kdevcppparser_preprocesslexer.cpp
@@ -0,0 +1,39 @@
+$NetBSD: patch-umbrello_codeimport_kdevcppparser_preprocesslexer.cpp,v 1.1 2013/11/11 16:47:07 joerg Exp $
+
+Patches from upstream.
+
+--- umbrello/codeimport/kdevcppparser/preprocesslexer.cpp.orig 2013-06-28 18:06:03.000000000 +0000
++++ umbrello/codeimport/kdevcppparser/preprocesslexer.cpp
+@@ -41,13 +41,11 @@
+
+ #define PREPROCESSLEXER_DEBUG
+
+-#ifdef Q_CC_MSVC
+ template <class _Tp>
+-struct _Identity : public std::unary_function<_Tp,_Tp> {
++struct identity : public std::unary_function<_Tp,_Tp> {
+ _Tp& operator()(_Tp& __x) const { return __x; }
+ const _Tp& operator()(const _Tp& __x) const { return __x; }
+ };
+-#endif
+
+ template <class _Tp>
+ struct tilde : public std::unary_function<_Tp, _Tp> {
+@@ -593,7 +591,7 @@ void PreprocessLexer::dumpToFile()
+ if (!d.exists())
+ d.mkdir(tempPath);
+
+- QString fileName = tempPath + '/' + currentPosition().file.toString().replace(QRegExp("[/:mn]"), "-");
++ QString fileName = tempPath + '/' + currentPosition().file.replace(QRegExp("[/:mn]"), "-");
+ QFile f(fileName);
+ if (f.open(QIODevice::WriteOnly | QIODevice::Text)) {
+ QTextStream out(&f);
+@@ -839,7 +837,7 @@ int PreprocessLexer::macroPrimary()
+ if (!l_hit)
+ result = 0;
+ } else {
+- boost::function < int (int) > l_op = _Identity<int>();
++ boost::function < int (int) > l_op = identity<int>();
+ if (m_source.parse(ch_p('+')
+ | ch_p('-')[var(l_op) = std::negate<int>()]
+ | ch_p('!')[var(l_op) = std::logical_not<int>()]