From 02add43e8c04ea6d79ad39828c56062eba3bd207 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaime=20Rodr=C3=ADguez-Guerra?= Date: Mon, 29 Aug 2022 21:06:51 +0200 Subject: [PATCH 1/2] fix regex parsing for lookaheads (?= and (?: --- src/conda.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/conda.c b/src/conda.c index 6f6a65a65..9a0f9ea96 100644 --- a/src/conda.c +++ b/src/conda.c @@ -619,10 +619,10 @@ pool_conda_matchspec(Pool *pool, const char *name) if (p <= version + 1 || (p[-1] != ' ' && p[-1] != '=')) break; /* no build */ /* check char before delimiter */ - if (p[-2] == '=' || p[-2] == '!' || p[-2] == '|' || p[-2] == ',' || p[-2] == '<' || p[-2] == '>' || p[-2] == '~') + if (p[-2] == '=' || p[-2] == '!' || p[-2] == '|' || p[-2] == ',' || p[-2] == '<' || p[-2] == '>' || p[-2] == '~' || p[-2] == '?') { /* illegal combination */ - if (p[-1] == ' ') + if (p[-1] == ' ' || (p[-1] == '=' && p[-2] == '?')) { p--; continue; /* special case space: it may be in the build */ From b8cc436d59f150dc57e9aff20135533fca059dc2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaime=20Rodr=C3=ADguez-Guerra?= Date: Mon, 29 Aug 2022 21:07:26 +0200 Subject: [PATCH 2/2] add optional support for pcre2 --- CMakeLists.txt | 13 ++++++++++++- src/CMakeLists.txt | 1 + src/conda.c | 9 ++++++++- src/repodata.c | 7 +++++++ src/solvversion.h.in | 1 + 5 files changed, 29 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 3541f496c..27864a04d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -33,6 +33,7 @@ OPTION (ENABLE_APPDATA "Build with AppStream appdata support?" OFF) OPTION (MULTI_SEMANTICS "Build with support for multiple distribution types?" OFF) +OPTION (ENABLE_PCRE2 "Build with PCRE2 as the regex engine" OFF) OPTION (ENABLE_LZMA_COMPRESSION "Build with lzma/xz compression support?" OFF) OPTION (ENABLE_BZIP2_COMPRESSION "Build with bzip2 compression support?" OFF) OPTION (ENABLE_ZSTD_COMPRESSION "Build with zstd compression support?" OFF) @@ -203,6 +204,13 @@ IF (MULTI_SEMANTICS) MESSAGE (STATUS "Enabling multi dist support") ENDIF (MULTI_SEMANTICS) +IF (ENABLE_PCRE2) +MESSAGE (STATUS "Enabling PCRE2 regex engine") +FIND_PACKAGE (PkgConfig REQUIRED) +PKG_CHECK_MODULES (PCRE2 REQUIRED libpcre2-posix) +INCLUDE_DIRECTORIES (${PCRE2_INCLUDE_DIRS}) +ENDIF (ENABLE_PCRE2) + IF (ENABLE_RPMDB) SET (ENABLE_RPMPKG ON) ENDIF (ENABLE_RPMDB) @@ -313,7 +321,7 @@ FOREACH (VAR ENABLE_HELIXREPO ENABLE_MDKREPO ENABLE_ARCHREPO ENABLE_DEBIAN ENABLE_HAIKU ENABLE_ZLIB_COMPRESSION ENABLE_LZMA_COMPRESSION ENABLE_BZIP2_COMPRESSION ENABLE_ZSTD_COMPRESSION ENABLE_ZCHUNK_COMPRESSION ENABLE_PGPVRFY ENABLE_APPDATA - WITH_SYSTEM_ZCHUNK) + WITH_SYSTEM_ZCHUNK ENABLE_PCRE2) IF(${VAR}) ADD_DEFINITIONS (-D${VAR}=1) SET (SWIG_FLAGS ${SWIG_FLAGS} -D${VAR}) @@ -411,6 +419,9 @@ SET (SYSTEM_LIBRARIES ${SYSTEM_LIBRARIES} ${EXPAT_LIBRARY}) ENDIF (WITH_LIBXML2 ) ENDIF (ENABLE_RPMMD OR ENABLE_SUSEREPO OR ENABLE_APPDATA OR ENABLE_COMPS OR ENABLE_HELIXREPO OR ENABLE_MDKREPO) +IF (ENABLE_PCRE2) +SET (SYSTEM_LIBRARIES ${SYSTEM_LIBRARIES} ${PCRE2_LIBRARIES}) +ENDIF (ENABLE_PCRE2) IF (ENABLE_ZLIB_COMPRESSION) SET (SYSTEM_LIBRARIES ${SYSTEM_LIBRARIES} ${ZLIB_LIBRARY}) ENDIF (ENABLE_ZLIB_COMPRESSION) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index bbf30bac1..9a781ca86 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -51,6 +51,7 @@ IF (DISABLE_SHARED) ADD_LIBRARY (libsolv STATIC ${libsolv_SRCS}) ELSE (DISABLE_SHARED) ADD_LIBRARY (libsolv SHARED ${libsolv_SRCS}) + TARGET_LINK_LIBRARIES(libsolv ${SYSTEM_LIBRARIES}) ENDIF (DISABLE_SHARED) IF (WIN32) diff --git a/src/conda.c b/src/conda.c index 9a0f9ea96..ff91e13a9 100644 --- a/src/conda.c +++ b/src/conda.c @@ -17,7 +17,14 @@ #include #include #include +#ifdef ENABLE_PCRE2 +#include +#define regcomp pcre2_regcomp +#define regexec pcre2_regexec +#define regfree pcre2_regfree +#else #include +#endif #include "pool.h" #include "repo.h" @@ -574,7 +581,7 @@ pool_conda_matchspec(Pool *pool, const char *name) int haveglob = 0; /* ignore channel and namespace for now */ - if ((p2 = strrchr(name, ':'))) + if ((p2 = strrchr(name, ':')) && (p2 < strchr(name, ' '))) name = p2 + 1; name2 = solv_strdup(name); /* find end of name */ diff --git a/src/repodata.c b/src/repodata.c index 72f03d488..24167170e 100644 --- a/src/repodata.c +++ b/src/repodata.c @@ -22,7 +22,14 @@ #include #include #include +#ifdef ENABLE_PCRE2 +#include +#define regcomp pcre2_regcomp +#define regexec pcre2_regexec +#define regfree pcre2_regfree +#else #include +#endif #include "repo.h" #include "pool.h" diff --git a/src/solvversion.h.in b/src/solvversion.h.in index da0ad743a..35d33b929 100644 --- a/src/solvversion.h.in +++ b/src/solvversion.h.in @@ -30,6 +30,7 @@ extern const char solv_toolversion[]; #cmakedefine LIBSOLV_FEATURE_MULTI_SEMANTICS #cmakedefine LIBSOLV_FEATURE_CONDA +#cmakedefine LIBSOLVEXT_FEATURE_PCRE2 #cmakedefine LIBSOLVEXT_FEATURE_RPMPKG #cmakedefine LIBSOLVEXT_FEATURE_RPMDB #cmakedefine LIBSOLVEXT_FEATURE_RPMDB_BYRPMHEADER