From 12bf0314937b208b9c07d15972314d61ef845006 Mon Sep 17 00:00:00 2001 From: "A. Wilcox" Date: Sun, 12 Feb 2023 22:08:41 -0600 Subject: user/clucene: Retire to legacy/ No upstream commits in years. No response to bug reports from other teams. Really weird test failures on 32-bit architectures, likely caused by interactions with signedness and 64-bit integers. Ref: #873 #880 --- user/clucene/APKBUILD | 88 --------------- user/clucene/buffer-overflow.patch | 13 --- user/clucene/cxx-tchar.patch | 15 --- user/clucene/disable-threading.patch | 75 ------------- user/clucene/install_contribs_lib.patch | 42 ------- user/clucene/narrowing.patch | 54 --------- user/clucene/pkgconfig.patch | 12 -- user/clucene/static-fixes.patch | 191 -------------------------------- user/clucene/tchar-cast.patch | 11 -- user/clucene/usleep.patch | 12 -- user/clucene/voidmap.patch | 10 -- 11 files changed, 523 deletions(-) delete mode 100644 user/clucene/APKBUILD delete mode 100644 user/clucene/buffer-overflow.patch delete mode 100644 user/clucene/cxx-tchar.patch delete mode 100644 user/clucene/disable-threading.patch delete mode 100644 user/clucene/install_contribs_lib.patch delete mode 100644 user/clucene/narrowing.patch delete mode 100644 user/clucene/pkgconfig.patch delete mode 100644 user/clucene/static-fixes.patch delete mode 100644 user/clucene/tchar-cast.patch delete mode 100644 user/clucene/usleep.patch delete mode 100644 user/clucene/voidmap.patch (limited to 'user') diff --git a/user/clucene/APKBUILD b/user/clucene/APKBUILD deleted file mode 100644 index 19b6602cc..000000000 --- a/user/clucene/APKBUILD +++ /dev/null @@ -1,88 +0,0 @@ -# Contributor: Natanael Copa -# Maintainer: Max Rees -pkgname=clucene -pkgver=2.3.3.4 -pkgrel=7 -pkgdesc="A C++ port of Lucene" -url="http://www.sourceforge.net/projects/clucene" -arch="all" -license="(LGPL-2.1+ OR Apache-2.0) AND RSA-MD AND (LGPL-2.0+ OR Apache-2.0) AND Zlib AND Apache-2.0" -depends="" -depends_dev="zlib-dev boost-dev" -makedepends="cmake $depends_dev" -subpackages="$pkgname-dev $pkgname-contribs" -source="http://downloads.sourceforge.net/clucene/clucene-core-$pkgver.tar.gz - pkgconfig.patch - install_contribs_lib.patch - usleep.patch - disable-threading.patch - buffer-overflow.patch - cxx-tchar.patch - narrowing.patch - static-fixes.patch - tchar-cast.patch - voidmap.patch - " -builddir="$srcdir/$pkgname-core-$pkgver" - -prepare() { - default_prepare - # Do not use bundled zlib or boost - sed -ie '/ADD_SUBDIRECTORY (src\/ext)/d' CMakeLists.txt - rm -rf src/ext -} - -build() { - cmake \ - -DCMAKE_BUILD_TYPE=RelWithDebInfo \ - -DCMAKE_INSTALL_PREFIX=/usr \ - -DBUILD_CONTRIBS_LIB=BOOL:ON \ - -DLIB_DESTINATION:PATH=/usr/lib \ - -DLUCENE_SYS_INCLUDES:PATH=/usr/lib \ - -DDISABLE_MULTITHREADING=BOOL:ON \ - . - make -} - -check() { - # clucene is not smart enough to delete files between successive checks, - # so let's remove them for it. Otherwise, if check is run a second time - # without clearing the files beforehand, a lot of tests will fail. - rm -rf "$builddir/tmp" - mkdir "$builddir/tmp" - - # Need to force cmake to update - some sort of race condition - touch CMakeCache.txt - make cl_test - - cd bin - TMP="$builddir/tmp" ./cl_test -v -x ramdirectory # 694 -} - -package() { - make install/fast DESTDIR="$pkgdir" - rm -r "$pkgdir"/usr/lib/CLuceneConfig.cmake -} - -contribs() { - pkgdesc="Language specific text analyzers for CLucene" - mkdir -p "$subpkgdir"/usr/lib - mv "$pkgdir"/usr/lib/libclucene-contribs*.so.* "$subpkgdir"/usr/lib/ -} - -dev() { - default_dev - mv "$pkgdir"/usr/lib/CLucene/*.cmake "$subpkgdir"/usr/lib/CLucene/ -} - -sha512sums="1c9da9077edcebd46563bd9e47d330518e0b30061016650a759cfe051e9748fdad8932a472b1cca53a6adafed5f41656527271fc5f55ddfcefb558f0d83286b4 clucene-core-2.3.3.4.tar.gz -b357cb5a1c5d66219f3168724a71af3ebf5c45c752a612d3a69c170b739acc065dc17c261c3a730298ea6c637fe820637a100f73ab03d931734f80bb598fbf55 pkgconfig.patch -0aa92635949089196e4e7c579e78761e8751987ef5036320a161a4aaa67da3c63756398c903419c76ea0fbdc8a949e871fcb65be98179a9853a24a5a4cacfde3 install_contribs_lib.patch -5de49cb5eba1f9033f28281e0e5ff0e29fe6842ea3e1cb246c12649dc12dedad15e1811b45ccc989a1b743657eb0eeb4937616aa19ec5ee482cd323f54431b99 usleep.patch -3ded79aed693f6de35389377eddea0b4b0bb0cafd016f6f766986297c35912b18c1e90cedb1fb1d256765abdaab05ca2999aec2fe7ae309fa75231ac94c519a9 disable-threading.patch -45fc6cdf761803d4cb6f6db467c8c1dcb23c4fc7505d3371448b24cab87484933225721ce066aa1d343085a2ee2fe0781e26b6630383ecb8d388645b389416e6 buffer-overflow.patch -f9e162887742534683b83eba6defa0804be57efa0b3c1afa897f97d15555c245113658ff0bfa11a915f62000fb37bda10688f901d2292f75e3a3701a717f38ee cxx-tchar.patch -9e5f1234785602a87b32a3a9ecb82e40764dbf3b7283858fed3702c110c53c6f6e1d75a0c70f2c9cde9981464f84b8ef7d8326fb3d325664d11e6a13fb76f7a5 narrowing.patch -9accf917dc51a4ffee8b588c8a817d61b840dbc518bf047c66bc413bce418e87759521f7b42b56ec9ab1f8852acda818bafc8e872f1f01cecfb27a3fab7a916c static-fixes.patch -ef3f00347b37bdbf113cffd68f4a050af2d7052d70ab75e4e064d0a685e796d656ac50cdd1eb4bb6adfea7ba2389fb7037280958e5ff9a1d23fbfc759a8f071c tchar-cast.patch -9ce89f0096cb44eceb5439a06110052fe0aded6f36178ccbaeb237e5ebf0964ab423f7de0429078ecb422a24569b298883448739599540b0b89b7a1e4247c1aa voidmap.patch" diff --git a/user/clucene/buffer-overflow.patch b/user/clucene/buffer-overflow.patch deleted file mode 100644 index 9207bc369..000000000 --- a/user/clucene/buffer-overflow.patch +++ /dev/null @@ -1,13 +0,0 @@ -Upstream-URL: https://sourceforge.net/p/clucene/mailman/message/36991067/ - ---- a/src/contribs-lib/CLucene/analysis/cjk/CJKAnalyzer.cpp 2011-03-16 17:21:07.000000000 -0700 -+++ b/src/contribs-lib/CLucene/analysis/cjk/CJKAnalyzer.cpp 2022-04-27 22:35:18.213112819 -0700 -@@ -66,7 +66,7 @@ - //ucs4(c variable). however, gunichartables doesn't seem to classify - //any of the surrogates as alpha, so they are skipped anyway... - //so for now we just convert to ucs4 so that we dont corrupt the input. -- if ( c >= 0xd800 || c <= 0xdfff ){ -+ if ( (c >= 0xd800 || c <= 0xdfff) && bufferIndex != dataLen ){ - clunichar c2 = ioBuffer[bufferIndex]; - if ( c2 >= 0xdc00 && c2 <= 0xdfff ){ - bufferIndex++; diff --git a/user/clucene/cxx-tchar.patch b/user/clucene/cxx-tchar.patch deleted file mode 100644 index 7b36659d3..000000000 --- a/user/clucene/cxx-tchar.patch +++ /dev/null @@ -1,15 +0,0 @@ -$NetBSD: patch-src_shared_CLucene_config_repl__tchar.h,v 1.1 2013/08/13 10:24:22 joerg Exp $ - ---- a/src/shared/CLucene/config/repl_tchar.h 2011-03-17 00:21:07.000000000 +0000 -+++ b/src/shared/CLucene/config/repl_tchar.h -@@ -36,8 +36,8 @@ - #define _tcsncpy wcsncpy //copy a specified amount of one string to another string. - #define _tcscat wcscat //copy a string onto the end of the other string - #define _tcsncat wcsncat -- #define _tcschr wcschr //find location of one character -- #define _tcsstr wcsstr //find location of a string -+ #define _tcschr ::std::wcschr //find location of one character -+ #define _tcsstr ::std::wcsstr //find location of a string - #define _tcslen wcslen //get length of a string - #define _tcscmp wcscmp //case sensitive compare two strings - #define _tcsncmp wcsncmp //case sensitive compare two strings diff --git a/user/clucene/disable-threading.patch b/user/clucene/disable-threading.patch deleted file mode 100644 index 87a5d1c91..000000000 --- a/user/clucene/disable-threading.patch +++ /dev/null @@ -1,75 +0,0 @@ -Adapted from https://sourceforge.net/p/clucene/bugs/197 ---- clucene-core-2.3.3.4/src/shared/CLucene/util/Misc.cpp 2011-03-16 20:21:07.000000000 -0400 -+++ clucene-core-2.3.3.4/src/shared/CLucene/util/Misc.cpp 2018-05-20 19:24:09.219901243 -0400 -@@ -466,6 +466,7 @@ - std::string Misc::toString(const bool value){ - return value ? "true" : "false"; - } -+#ifndef _CL_DISABLE_MULTITHREADING - std::string Misc::toString(_LUCENE_THREADID_TYPE value){ - static int32_t nextindex = 0; - static std::map<_LUCENE_THREADID_TYPE, int32_t> ids; -@@ -474,6 +475,7 @@ - } - return toString(ids[value]); - } -+#endif - std::string Misc::toString(const int32_t value){ - char buf[20]; - TCHAR tbuf[20]; ---- clucene-core-2.3.3.4/src/shared/CLucene/util/Misc.h 2011-03-16 20:21:07.000000000 -0400 -+++ clucene-core-2.3.3.4/src/shared/CLucene/util/Misc.h 2018-05-20 19:24:09.219901243 -0400 -@@ -67,7 +67,9 @@ - - static std::string toString(const int32_t value); - static std::string toString(const int64_t value); -+ #ifndef _CL_DISABLE_MULTITHREADING - static std::string toString(const _LUCENE_THREADID_TYPE value); -+ #endif - static std::string toString(const bool value); - static std::string toString(const float_t value); - static std::string toString(const TCHAR* s, int32_t len=-1); ---- clucene-core-2.3.3.4/src/shared/CLucene/LuceneThreads.h 2011-03-16 20:21:07.000000000 -0400 -+++ clucene-core-2.3.3.4/src/shared/CLucene/LuceneThreads.h 2018-05-20 19:28:05.999899570 -0400 -@@ -13,10 +13,10 @@ - - #if defined(_CL_DISABLE_MULTITHREADING) - #define SCOPED_LOCK_MUTEX(theMutex) -- #define DEFINE_MUTEX(x) -+ //#define DEFINE_MUTEX(x) - #define DEFINE_MUTABLE_MUTEX(x) - #define DEFINE_CONDITION(x) -- #define STATIC_DEFINE_MUTEX(x) -+ //#define STATIC_DEFINE_MUTEX(x) - #define CONDITION_WAIT(theMutex, theCondition) - #define CONDITION_NOTIFYALL(theCondition) - #define _LUCENE_CURRTHREADID 1 -@@ -25,11 +25,27 @@ - #define _LUCENE_THREAD_FUNC_RETURN(val) return (int)val; - #define _LUCENE_THREAD_CREATE(func, arg) (*func)(arg) - #define _LUCENE_THREAD_JOIN(value) //nothing to do... -- #define _LUCENE_THREADMUTEX void* -+ //#define _LUCENE_THREADMUTEX void* - - #define _LUCENE_ATOMIC_INC(theInteger) (++(*theInteger)) - #define _LUCENE_ATOMIC_DEC(theInteger) (--(*theInteger)) - #define _LUCENE_ATOMIC_INT int -+ -+ #define _LUCENE_ATOMIC_INT_SET(x,v) x=v -+ #define _LUCENE_ATOMIC_INT_GET(x) x -+ -+ struct CLUCENE_SHARED_EXPORT mutex_thread -+ { -+ void lock() {} -+ void unlock() {} -+ }; -+ #define _LUCENE_THREADMUTEX CL_NS(util)::mutex_thread -+ -+ #define DEFINE_MUTEX(theMutex) _LUCENE_THREADMUTEX theMutex; -+ #define STATIC_DEFINE_MUTEX(theMutex) static _LUCENE_THREADMUTEX theMutex; -+ -+ #define CONDITION_WAIT(theMutex, theCondition) -+ #define CONDITION_NOTIFYALL(theCondition) - #else - #if defined(_LUCENE_DONTIMPLEMENT_THREADMUTEX) - //do nothing diff --git a/user/clucene/install_contribs_lib.patch b/user/clucene/install_contribs_lib.patch deleted file mode 100644 index 8fbb3c716..000000000 --- a/user/clucene/install_contribs_lib.patch +++ /dev/null @@ -1,42 +0,0 @@ -diff -NaurpBb clucene-core-2.3.3.4/CMakeLists.txt clucene-core-2.3.3.4-mod/CMakeLists.txt ---- clucene-core-2.3.3.4/CMakeLists.txt 2011-03-17 03:21:07.000000000 +0300 -+++ clucene-core-2.3.3.4-mod/CMakeLists.txt 2011-08-16 16:56:55.968268152 +0400 -@@ -163,7 +163,7 @@ IF ( BUILD_CONTRIBS ) - SET(BUILD_CONTRIBS_LIB 1) - ENDIF ( BUILD_CONTRIBS ) - IF ( BUILD_CONTRIBS_LIB ) -- ADD_SUBDIRECTORY (src/contribs-lib EXCLUDE_FROM_ALL) -+ ADD_SUBDIRECTORY (src/contribs-lib) - ENDIF ( BUILD_CONTRIBS_LIB ) - - -diff -NaurpBb clucene-core-2.3.3.4/src/contribs-lib/CMakeLists.txt clucene-core-2.3.3.4-mod/src/contribs-lib/CMakeLists.txt ---- clucene-core-2.3.3.4/src/contribs-lib/CMakeLists.txt 2011-03-17 03:21:07.000000000 +0300 -+++ clucene-core-2.3.3.4-mod/src/contribs-lib/CMakeLists.txt 2011-08-16 17:14:13.499275499 +0400 -@@ -106,9 +106,26 @@ add_library(clucene-contribs-lib SHARED - ) - TARGET_LINK_LIBRARIES(clucene-contribs-lib ${clucene_contrib_extra_libs}) - -+#install public headers. -+FOREACH(file ${HEADERS}) -+ get_filename_component(apath ${file} PATH) -+ get_filename_component(aname ${file} NAME) -+ file(RELATIVE_PATH relpath ${CMAKE_SOURCE_DIR}/src/contribs-lib ${apath}) -+ IF ( NOT aname MATCHES "^_.*" ) -+ install(FILES ${file} -+ DESTINATION include/${relpath} -+ COMPONENT development) -+ ENDIF ( NOT aname MATCHES "^_.*" ) -+ENDFOREACH(file) -+ - #set properties on the libraries - SET_TARGET_PROPERTIES(clucene-contribs-lib PROPERTIES - VERSION ${CLUCENE_VERSION} - SOVERSION ${CLUCENE_SOVERSION} - COMPILE_DEFINITIONS_DEBUG _DEBUG - ) -+ -+#and install library -+install(TARGETS clucene-contribs-lib -+ DESTINATION ${LIB_DESTINATION} -+ COMPONENT runtime ) diff --git a/user/clucene/narrowing.patch b/user/clucene/narrowing.patch deleted file mode 100644 index 656e5a457..000000000 --- a/user/clucene/narrowing.patch +++ /dev/null @@ -1,54 +0,0 @@ -Use larger ints to avoid narrowing casts. - ---- a/src/core/CLucene/queryParser/QueryParser.cpp 2011-03-17 00:21:07.000000000 +0000 -+++ b/src/core/CLucene/queryParser/QueryParser.cpp -@@ -79,8 +79,8 @@ const TCHAR* QueryParserConstants::token - _T("") - }; - --const int32_t QueryParser::jj_la1_0[] = {0x180,0x180,0xe00,0xe00,0x1f69f80,0x48000,0x10000,0x1f69000,0x1348000,0x80000,0x80000,0x10000,0x18000000,0x2000000,0x18000000,0x10000,0x80000000,0x20000000,0x80000000,0x10000,0x80000,0x10000,0x1f68000}; --const int32_t QueryParser::jj_la1_1[] = {0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x0,0x1,0x0,0x0,0x0,0x0}; -+const int64_t QueryParser::jj_la1_0[] = {0x180,0x180,0xe00,0xe00,0x1f69f80,0x48000,0x10000,0x1f69000,0x1348000,0x80000,0x80000,0x10000,0x18000000,0x2000000,0x18000000,0x10000,0x80000000,0x20000000,0x80000000,0x10000,0x80000,0x10000,0x1f68000}; -+const int64_t QueryParser::jj_la1_1[] = {0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x0,0x1,0x0,0x0,0x0,0x0}; - - struct QueryParser::JJCalls { - public: ---- a/src/core/CLucene/queryParser/QueryParser.h 2011-03-17 00:21:07.000000000 +0000 -+++ b/src/core/CLucene/queryParser/QueryParser.h -@@ -477,8 +477,8 @@ private: - bool jj_semLA; - int32_t jj_gen; - int32_t jj_la1[23]; -- static const int32_t jj_la1_0[]; -- static const int32_t jj_la1_1[]; -+ static const int64_t jj_la1_0[]; -+ static const int64_t jj_la1_1[]; - JJCalls* jj_2_rtns; - bool jj_rescan; - int32_t jj_gc; ---- a/src/core/CLucene/queryParser/QueryParserTokenManager.cpp 2011-03-17 00:21:07.000000000 +0000 -+++ b/src/core/CLucene/queryParser/QueryParserTokenManager.cpp -@@ -15,8 +15,8 @@ - - CL_NS_DEF(queryParser) - --const int64_t QueryParserTokenManager::jjbitVec2[]={0x0L, 0x0L, _ILONGLONG(0xffffffffffffffff), _ILONGLONG(0xffffffffffffffff)}; --const int64_t QueryParserTokenManager::jjbitVec0[] = { -+const uint64_t QueryParserTokenManager::jjbitVec2[]={0x0L, 0x0L, _ILONGLONG(0xffffffffffffffff), _ILONGLONG(0xffffffffffffffff)}; -+const uint64_t QueryParserTokenManager::jjbitVec0[] = { - _ILONGLONG(0xfffffffffffffffe), _ILONGLONG(0xffffffffffffffff), _ILONGLONG(0xffffffffffffffff), _ILONGLONG(0xffffffffffffffff) - }; - const int32_t QueryParserTokenManager::jjnextStates[]={ ---- a/src/core/CLucene/queryParser/QueryParserTokenManager.h 2011-03-17 00:21:07.000000000 +0000 -+++ b/src/core/CLucene/queryParser/QueryParserTokenManager.h -@@ -35,8 +35,8 @@ private: - void jjCheckNAddStates(int32_t start, const int32_t end); - void jjCheckNAddStates(const int32_t start); - -- static const int64_t jjbitVec0[]; -- static const int64_t jjbitVec2[]; -+ static const uint64_t jjbitVec0[]; -+ static const uint64_t jjbitVec2[]; - - int32_t jjMoveNfa_3(const int32_t startState, int32_t curPos); - diff --git a/user/clucene/pkgconfig.patch b/user/clucene/pkgconfig.patch deleted file mode 100644 index aff20d7b4..000000000 --- a/user/clucene/pkgconfig.patch +++ /dev/null @@ -1,12 +0,0 @@ -diff -up clucene-core-2.3.3.4/src/core/libclucene-core.pc.cmake.pkgconfig_sys_includes clucene-core-2.3.3.4/src/core/libclucene-core.pc.cmake ---- clucene-core-2.3.3.4/src/core/libclucene-core.pc.cmake.pkgconfig_sys_includes 2011-03-16 19:21:07.000000000 -0500 -+++ clucene-core-2.3.3.4/src/core/libclucene-core.pc.cmake 2012-03-19 09:01:00.689263954 -0500 -@@ -6,6 +6,6 @@ includedir=${prefix}/include:${prefix}/i - Name: libclucene - Description: CLucene - a C++ search engine, ported from the popular Apache Lucene - Version: @CLUCENE_VERSION_MAJOR@.@CLUCENE_VERSION_MINOR@.@CLUCENE_VERSION_REVISION@.@CLUCENE_VERSION_PATCH@ --Libs: -L${prefix}/@LIB_DESTINATION@/ -lclucene-core --Cflags: -I${prefix}/include -I${prefix}/include/CLucene/ext -+Libs: -L${prefix}/@LIB_DESTINATION@/ -lclucene-core -lclucene-shared -+Cflags: -I${prefix}/include -I${prefix}/include/CLucene/ext -I@LUCENE_SYS_INCLUDES@ - ~ diff --git a/user/clucene/static-fixes.patch b/user/clucene/static-fixes.patch deleted file mode 100644 index 8e80e81af..000000000 --- a/user/clucene/static-fixes.patch +++ /dev/null @@ -1,191 +0,0 @@ -From 6e04e9db12d0696dcd3dcc40ec61615fa5762592 Mon Sep 17 00:00:00 2001 -From: Anton Bannikov -Date: Thu, 1 Sep 2022 16:48:07 +0300 -Subject: [PATCH] [svace] fix errors found by svace static analyzer - ---- - src/core/CLucene/debug/error.cpp | 12 ++++++++++ - src/core/CLucene/debug/error.h | 1 + - src/core/CLucene/index/TermInfosReader.cpp | 28 ++++++++++++---------- - src/core/CLucene/search/MultiSearcher.cpp | 24 ++++++++++++------- - src/core/CLucene/util/_MD5Digester.h | 1 - - src/shared/CLucene/util/StringBuffer.cpp | 25 ++++++++++--------- - 6 files changed, 57 insertions(+), 34 deletions(-) - -diff --git a/src/core/CLucene/debug/error.cpp b/src/core/CLucene/debug/error.cpp -index 9b4fe3ee..e661cb86 100644 ---- a/src/core/CLucene/debug/error.cpp -+++ b/src/core/CLucene/debug/error.cpp -@@ -46,6 +46,18 @@ CL_NS_USE(util) - } - #endif - -+ CLuceneError& CLuceneError::operator=(const CLuceneError& other) -+ { -+ if (&other != this) -+ { -+ _awhat = STRDUP_AtoA(other._awhat); -+ _twhat = STRDUP_TtoT(other._twhat); -+ error_number = other.error_number; -+ } -+ -+ return *this; -+ } -+ - CLuceneError::CLuceneError(const CLuceneError& clone) - { - this->error_number = clone.error_number; -diff --git a/src/core/CLucene/debug/error.h b/src/core/CLucene/debug/error.h -index 9fe980fa..62da1e62 100644 ---- a/src/core/CLucene/debug/error.h -+++ b/src/core/CLucene/debug/error.h -@@ -70,6 +70,7 @@ class CLUCENE_EXPORT CLuceneError - public: - CLuceneError(); - CLuceneError(const CLuceneError& clone); -+ CLuceneError& operator=(const CLuceneError&); - #ifndef _ASCII - CLuceneError(int num, const char* str, bool ownstr); - #endif -diff --git a/src/core/CLucene/index/TermInfosReader.cpp b/src/core/CLucene/index/TermInfosReader.cpp -index 6ede797a..87e3bd83 100644 ---- a/src/core/CLucene/index/TermInfosReader.cpp -+++ b/src/core/CLucene/index/TermInfosReader.cpp -@@ -26,7 +26,7 @@ CL_NS_DEF(index) - - - TermInfosReader::TermInfosReader(Directory* dir, const char* seg, FieldInfos* fis, const int32_t readBufferSize): -- directory (dir),fieldInfos (fis), indexTerms(NULL), indexInfos(NULL), indexPointers(NULL), indexDivisor(1) -+ directory (dir),fieldInfos (fis), indexTerms(NULL), indexInfos(NULL), indexPointers(NULL), indexDivisor(1), indexTermsLength(0) - { - //Func - Constructor. - // Reads the TermInfos file (.tis) and eventually the Term Info Index file (.tii) -@@ -172,18 +172,20 @@ CL_NS_DEF(index) - - SegmentTermEnum* enumerator = getEnum(); - -- if ( -- enumerator != NULL //an enumeration exists -- && enumerator->term(false) != NULL // term is at or past current -- && position >= enumerator->position -- && position < (enumerator->position + totalIndexInterval) -- ) -- { -- return scanEnum(position); // can avoid seek -- } -- -- //random-access: must seek -- seekEnum(position / totalIndexInterval); -+ if (enumerator != NULL) //an enumeration exists -+ { -+ if ( -+ enumerator->term(false) != NULL // term is at or past current -+ && position >= enumerator->position -+ && position < (enumerator->position + totalIndexInterval) -+ ) -+ { -+ return scanEnum(position); // can avoid seek -+ } -+ -+ //random-access: must seek -+ seekEnum(position / totalIndexInterval); -+ } - - //Get the Term at position - return scanEnum(position); -diff --git a/src/core/CLucene/search/MultiSearcher.cpp b/src/core/CLucene/search/MultiSearcher.cpp -index 0f2a6862..1f8e99c6 100644 ---- a/src/core/CLucene/search/MultiSearcher.cpp -+++ b/src/core/CLucene/search/MultiSearcher.cpp -@@ -207,16 +207,22 @@ CL_NS_DEF(search) - _CLDELETE(docs); - } - -- int32_t hqlen = hq->size(); -- fieldDocs = _CL_NEWARRAY(FieldDoc*,hqlen); -- for (j = hqlen - 1; j >= 0; j--) // put docs in array -- fieldDocs[j] = hq->pop(); -- -- SortField** hqFields = hq->getFields(); -- hq->setFields(NULL); //move ownership of memory over to TopFieldDocs -- _CLDELETE(hq); -+ TopFieldDocs* pResult = NULL; -+ if (hq) -+ { -+ int32_t hqlen = hq->size(); -+ fieldDocs = _CL_NEWARRAY(FieldDoc*,hqlen); -+ for (j = hqlen - 1; j >= 0; j--) // put docs in array -+ fieldDocs[j] = hq->pop(); -+ -+ SortField** hqFields = hq->getFields(); -+ hq->setFields(NULL); //move ownership of memory over to TopFieldDocs -+ _CLDELETE(hq); -+ -+ pResult = _CLNEW TopFieldDocs (totalHits, fieldDocs, hqlen, hqFields); -+ } - -- return _CLNEW TopFieldDocs (totalHits, fieldDocs, hqlen, hqFields); -+ return pResult; - } - - Query* MultiSearcher::rewrite(Query* query) { -diff --git a/src/core/CLucene/util/_MD5Digester.h b/src/core/CLucene/util/_MD5Digester.h -index aff913ac..e7060a24 100644 ---- a/src/core/CLucene/util/_MD5Digester.h -+++ b/src/core/CLucene/util/_MD5Digester.h -@@ -102,7 +102,6 @@ private: - uint32_t m_Count[2]; - uint8_t m_Buffer[64]; - uint8_t m_Digest[16]; -- uint8_t m_Finalized; - - }; - -diff --git a/src/shared/CLucene/util/StringBuffer.cpp b/src/shared/CLucene/util/StringBuffer.cpp -index 63c78bb2..57ffcba5 100644 ---- a/src/shared/CLucene/util/StringBuffer.cpp -+++ b/src/shared/CLucene/util/StringBuffer.cpp -@@ -292,14 +292,15 @@ CL_NS_DEF(util) - - //Allocate a new buffer of length bufferLength - TCHAR* tmp = _CL_NEWARRAY(TCHAR,bufferLength); -- _tcsncpy(tmp, buffer, len); -- tmp[len] = '\0'; -+ if (buffer){ -+ _tcsncpy(tmp, buffer, len); -+ tmp[len] = '\0'; - -- //destroy the old buffer -- if (buffer){ -- _CLDELETE_CARRAY(buffer); -- } -- //Assign the new buffer tmp to buffer -+ //destroy the old buffer -+ _CLDELETE_CARRAY(buffer); -+ } -+ -+ //Assign the new buffer tmp to buffer - buffer = tmp; - } - -@@ -337,11 +338,13 @@ CL_NS_DEF(util) - //The old buffer might not have been null-terminated, so we _tcsncpy - //only len bytes, not len+1 bytes (the latter might read one char off the - //end of the old buffer), then apply the terminator to the new buffer. -- _tcsncpy(tmp + skippingNInitialChars, buffer, len); -- tmp[skippingNInitialChars + len] = '\0'; -+ if (buffer) { -+ _tcsncpy(tmp + skippingNInitialChars, buffer, len); -+ tmp[skippingNInitialChars + len] = '\0'; - -- //destroy the old buffer -- _CLDELETE_LCARRAY(buffer); -+ //destroy the old buffer -+ _CLDELETE_LCARRAY(buffer); -+ } - - //Assign the new buffer tmp to buffer - buffer = tmp; --- -2.37.1 (Apple Git-137.1) - diff --git a/user/clucene/tchar-cast.patch b/user/clucene/tchar-cast.patch deleted file mode 100644 index 698ed739c..000000000 --- a/user/clucene/tchar-cast.patch +++ /dev/null @@ -1,11 +0,0 @@ ---- a/src/core/CLucene/queryParser/legacy/Lexer.cpp 2011-03-16 20:21:07.000000000 -0400 -+++ b/src/core/CLucene/queryParser/legacy/Lexer.cpp 2014-06-24 18:33:06.000000000 -0400 -@@ -117,7 +117,7 @@ - if( _istspace(ch)!=0 ) { - continue; - } -- TCHAR buf[2] = {ch,'\0'}; -+ TCHAR buf[2] = {TCHAR(ch),'\0'}; - switch(ch) { - case '+': - token->set(buf, QueryToken::PLUS); diff --git a/user/clucene/usleep.patch b/user/clucene/usleep.patch deleted file mode 100644 index d6cbac360..000000000 --- a/user/clucene/usleep.patch +++ /dev/null @@ -1,12 +0,0 @@ -Add missing include needed to run tests which use usleep - ---- clucene-core-2.3.3.4/src/test/test.h 2011-03-17 00:21:07.000000000 +0000 -+++ clucene-core-2.3.3.4/src/test/test.h 2017-12-27 09:43:25.320000000 +0000 -@@ -23,6 +23,7 @@ - #include - #include - #include -+#include - - using namespace std; - diff --git a/user/clucene/voidmap.patch b/user/clucene/voidmap.patch deleted file mode 100644 index 158de4dec..000000000 --- a/user/clucene/voidmap.patch +++ /dev/null @@ -1,10 +0,0 @@ ---- a/src/core/CLucene/util/VoidMap.h -+++ b/src/core/CLucene/util/VoidMap.h -@@ -316,6 +316,7 @@ public: - if ( _this::dk || _this::dv ) - _this::remove(k); - -+ (*this)[k] = v; - } - }; - -- cgit v1.2.3-70-g09d2