dbxml: init at 6.1.4
Website: https://www.oracle.com/database/berkeley-db/xml.html Changelog: http://download.oracle.com/otndocs/products/berkeleydb/html/dbxml614.html
This commit is contained in:
parent
fec22d4ff4
commit
52e7494186
|
@ -862,6 +862,11 @@
|
||||||
github = "danharaj";
|
github = "danharaj";
|
||||||
name = "Dan Haraj";
|
name = "Dan Haraj";
|
||||||
};
|
};
|
||||||
|
danieldk = {
|
||||||
|
email = "me@danieldk.eu";
|
||||||
|
github = "danieldk";
|
||||||
|
name = "Daniël de Kok";
|
||||||
|
};
|
||||||
danielfullmer = {
|
danielfullmer = {
|
||||||
email = "danielrf12@gmail.com";
|
email = "danielrf12@gmail.com";
|
||||||
github = "danielfullmer";
|
github = "danielfullmer";
|
||||||
|
|
|
@ -0,0 +1,59 @@
|
||||||
|
diff -urN dbxml-6.1.4.orig/dbxml/src/dbxml/nodeStore/NsUpdate.cpp dbxml-6.1.4/dbxml/src/dbxml/nodeStore/NsUpdate.cpp
|
||||||
|
--- dbxml-6.1.4.orig/dbxml/src/dbxml/nodeStore/NsUpdate.cpp 2017-05-01 16:05:29.000000000 +0100
|
||||||
|
+++ dbxml-6.1.4/dbxml/src/dbxml/nodeStore/NsUpdate.cpp 2017-09-04 11:50:20.000000000 +0100
|
||||||
|
@@ -1359,21 +1359,13 @@
|
||||||
|
void NsUpdate::attributeRemoved(const DbXmlNodeImpl &node)
|
||||||
|
{
|
||||||
|
string key = makeKey(node);
|
||||||
|
-#if defined(_MSC_VER) && (_MSC_VER>1600)
|
||||||
|
attrMap_.insert(make_pair(key,node.getIndex()));
|
||||||
|
-#else
|
||||||
|
- attrMap_.insert(make_pair<const std::string, int>(key,node.getIndex()));
|
||||||
|
-#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void NsUpdate::textRemoved(const DbXmlNodeImpl &node)
|
||||||
|
{
|
||||||
|
string key = makeKey(node);
|
||||||
|
-#if defined(_MSC_VER) && (_MSC_VER>1600)
|
||||||
|
textDeleteMap_.insert(make_pair(key,node.getIndex()));
|
||||||
|
-#else
|
||||||
|
- textDeleteMap_.insert(make_pair<const std::string, int>(key,node.getIndex()));
|
||||||
|
-#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void NsUpdate::textRemoved(int index, const NsNid &nid,
|
||||||
|
@@ -1381,21 +1373,13 @@
|
||||||
|
const std::string &cname)
|
||||||
|
{
|
||||||
|
string key = makeKey(nid, did, cname);
|
||||||
|
-#if defined(_MSC_VER) && (_MSC_VER>1600)
|
||||||
|
textDeleteMap_.insert(make_pair(key,index));
|
||||||
|
-#else
|
||||||
|
- textDeleteMap_.insert(make_pair<const std::string, int>(key,index));
|
||||||
|
-#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void NsUpdate::textInserted(int index, const DbXmlNodeImpl &node)
|
||||||
|
{
|
||||||
|
string key = makeKey(node);
|
||||||
|
-#if defined(_MSC_VER) && (_MSC_VER>1600)
|
||||||
|
textInsertMap_.insert(make_pair(key,index));
|
||||||
|
-#else
|
||||||
|
- textInsertMap_.insert(make_pair<const std::string, int>(key,index));
|
||||||
|
-#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void NsUpdate::textInserted(int index, const NsNid &nid,
|
||||||
|
@@ -1403,11 +1387,7 @@
|
||||||
|
const std::string &cname)
|
||||||
|
{
|
||||||
|
string key = makeKey(nid, did, cname);
|
||||||
|
-#if defined(_MSC_VER) && (_MSC_VER>1600)
|
||||||
|
textInsertMap_.insert(make_pair(key,index));
|
||||||
|
-#else
|
||||||
|
- textInsertMap_.insert(make_pair<const std::string, int>(key,index));
|
||||||
|
-#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
|
@ -0,0 +1,38 @@
|
||||||
|
{ stdenv, fetchurl, db62, xercesc, xqilla }:
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
name = "dbxml-${version}";
|
||||||
|
version = "6.1.4";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "http://download.oracle.com/berkeley-db/${name}.tar.gz";
|
||||||
|
sha256 = "a8fc8f5e0c3b6e42741fa4dfc3b878c982ff8f5e5f14843f6a7e20d22e64251a";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
./cxx11.patch
|
||||||
|
./incorrect-optimization.patch
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
db62 xercesc xqilla
|
||||||
|
];
|
||||||
|
|
||||||
|
configureFlags = [
|
||||||
|
"--with-berkeleydb=${db62.out}"
|
||||||
|
"--with-xerces=${xercesc}"
|
||||||
|
"--with-xqilla=${xqilla}"
|
||||||
|
];
|
||||||
|
|
||||||
|
preConfigure = ''
|
||||||
|
cd dbxml
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with stdenv.lib; {
|
||||||
|
homepage = https://www.oracle.com/database/berkeley-db/xml.html;
|
||||||
|
description = "Embeddable XML database based on Berkeley DB";
|
||||||
|
license = licenses.agpl3;
|
||||||
|
maintainers = with maintainers; [ danieldk ];
|
||||||
|
platforms = platforms.unix;
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,34 @@
|
||||||
|
Patch provided by Lauren Foutz. See:
|
||||||
|
https://community.oracle.com/thread/4093422
|
||||||
|
|
||||||
|
--- dbxml-6.1.4-orig/dbxml/src/dbxml/query/ParentOfChildJoinQP.cpp
|
||||||
|
+++ dbxml-6.1.4/dbxml/src/dbxml/query/ParentOfChildJoinQP.cpp
|
||||||
|
@@ -139,28 +139,16 @@ bool ParentOfChildIterator::doJoin(Dynam
|
||||||
|
|
||||||
|
// Invarient 4: When ancestorStack_ is empty we can output the
|
||||||
|
// buffered results_, since any more results will come after them in
|
||||||
|
// document order.
|
||||||
|
|
||||||
|
while(true) {
|
||||||
|
context->testInterrupt();
|
||||||
|
|
||||||
|
- /*
|
||||||
|
- * If current parent's node level already be larger than
|
||||||
|
- * childen's, abandon current parent and move to next one.
|
||||||
|
- */
|
||||||
|
- if (parents_ != NULL &&
|
||||||
|
- parents_->getNodeLevel() > children_->getNodeLevel()) {
|
||||||
|
- if(!parents_->next(context)) {
|
||||||
|
- delete parents_;
|
||||||
|
- parents_ = 0;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
int cmp = parents_ == 0 ? -1 : isDescendantOf(children_, parents_, /*orSelf*/false);
|
||||||
|
if(cmp < 0) {
|
||||||
|
if(!ancestorStack_.empty()) {
|
||||||
|
// We've found the closest ancestor - is it a parent?
|
||||||
|
if(ancestorStack_.back()->getNodeLevel() == (children_->getNodeLevel() - 1)) {
|
||||||
|
// Maintain invarient 3
|
||||||
|
if(results_.empty() || NodeInfo::compare(results_.back(), ancestorStack_.back()) < 0)
|
||||||
|
results_.push_back(ancestorStack_.back());
|
|
@ -8987,6 +8987,8 @@ with pkgs;
|
||||||
db60 = callPackage ../development/libraries/db/db-6.0.nix { };
|
db60 = callPackage ../development/libraries/db/db-6.0.nix { };
|
||||||
db62 = callPackage ../development/libraries/db/db-6.2.nix { };
|
db62 = callPackage ../development/libraries/db/db-6.2.nix { };
|
||||||
|
|
||||||
|
dbxml = callPackage ../development/libraries/dbxml { };
|
||||||
|
|
||||||
dbus = callPackage ../development/libraries/dbus { };
|
dbus = callPackage ../development/libraries/dbus { };
|
||||||
dbus_cplusplus = callPackage ../development/libraries/dbus-cplusplus { };
|
dbus_cplusplus = callPackage ../development/libraries/dbus-cplusplus { };
|
||||||
dbus-glib = callPackage ../development/libraries/dbus-glib { };
|
dbus-glib = callPackage ../development/libraries/dbus-glib { };
|
||||||
|
|
Loading…
Reference in New Issue