git: e1d94b436d6a - main - editors/imhex: Update to 1.24.3
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sat, 15 Oct 2022 20:53:45 UTC
The branch main has been updated by nobutaka: URL: https://cgit.FreeBSD.org/ports/commit/?id=e1d94b436d6a192d50d3dd44c5f1a71b0a55aebc commit e1d94b436d6a192d50d3dd44c5f1a71b0a55aebc Author: MANTANI Nobutaka <nobutaka@FreeBSD.org> AuthorDate: 2022-10-15 20:51:37 +0000 Commit: MANTANI Nobutaka <nobutaka@FreeBSD.org> CommitDate: 2022-10-15 20:53:22 +0000 editors/imhex: Update to 1.24.3 --- editors/imhex/Makefile | 20 ++-- editors/imhex/distinfo | 32 +++--- editors/imhex/files/patch-CMakeLists.txt | 4 +- .../imhex/files/patch-cmake_build__helpers.cmake | 4 +- ...lib_include_pl_core_ast_ast__node__bitfield.hpp | 11 -- ...pattern__language_lib_include_pl_core_token.hpp | 4 +- .../imhex/files/patch-lib_libimhex_CMakeLists.txt | 4 +- .../patch-lib_libimhex_include_hex_api_task.hpp | 18 +++ ...b_libimhex_include_hex_data__processor_node.hpp | 4 +- .../patch-lib_libimhex_source_api_imhex__api.cpp | 4 +- .../patch-lib_libimhex_source_helpers_file.cpp | 14 +-- .../files/patch-lib_libimhex_source_helpers_fs.cpp | 4 +- ...ltin_source_content_helpers_math__evaluator.cpp | 15 +++ ...tin_source_content_providers_disk__provider.cpp | 14 +-- ...ns_builtin_source_content_settings__entries.cpp | 4 +- ...ins_builtin_source_content_views_view__find.cpp | 125 ++++++++++++++++++++- ...ltin_source_content_views_view__hex__editor.cpp | 4 +- ...ns_windows_include_views_view__tty__console.hpp | 10 ++ editors/imhex/pkg-plist | 9 +- 19 files changed, 232 insertions(+), 72 deletions(-) diff --git a/editors/imhex/Makefile b/editors/imhex/Makefile index 395c44c03bf3..41e96e621458 100644 --- a/editors/imhex/Makefile +++ b/editors/imhex/Makefile @@ -1,5 +1,5 @@ PORTNAME= imhex -PORTVERSION= 1.23.1 +PORTVERSION= 1.24.3 DISTVERSIONPREFIX= v CATEGORIES= editors MASTER_SITES= https://git.sr.ht/~danyspin97/xdgpp/blob/f01f810714443d0f10c333d4d1d9c0383be41375/:xdg @@ -20,6 +20,7 @@ EXTRACT_ONLY= ${DISTNAME}${EXTRACT_SUFX} \ capstone-engine-capstone-${GH_TAG_CAPSTONE}_GH0${EXTRACT_SUFX} \ CLIUtils-CLI11-${GH_TAG_CLI11}_GH0${EXTRACT_SUFX} \ fmtlib-fmt-${GH_TAG_FMT}_GH0${EXTRACT_SUFX} \ + josuttis-jthread-${GH_TAG_JTHREAD}_GH0${EXTRACT_SUFX} \ VirusTotal-yara-${GH_TAG_YARA}_GH0${EXTRACT_SUFX} \ WerWolv-libromfs-${GH_TAG_LIBROMFS}_GH0${EXTRACT_SUFX} \ WerWolv-ImHex-Patterns-${GH_TAG_IMHEX_PATTERNS}_GH0${EXTRACT_SUFX} \ @@ -29,8 +30,8 @@ BUILD_DEPENDS= glm>0:math/glm \ nlohmann-json>0:devel/nlohmann-json \ ${LOCALBASE}/include/range/v3/range.hpp:devel/range-v3 LIB_DEPENDS= libcurl.so:ftp/curl \ - libfreetype.so:print/freetype2 \ libglfw.so:graphics/glfw \ + libfreetype.so:print/freetype2 \ libharfbuzz.so:print/harfbuzz \ libmbedtls.so:security/mbedtls \ libtre.so:textproc/libtre @@ -47,6 +48,7 @@ GH_TUPLE= btzy:nativefiledialog-extended:${GH_TAG_NATIVEFILEDIALOG}:nativefiledi capstone-engine:capstone:${GH_TAG_CAPSTONE}:capstone \ CLIUtils:CLI11:${GH_TAG_CLI11}:cli11 \ fmtlib:fmt:${GH_TAG_FMT}:fmt \ + josuttis:jthread:${GH_TAG_JTHREAD}:jthread \ VirusTotal:yara:${GH_TAG_YARA}:yara \ WerWolv:ImHex-Patterns:${GH_TAG_IMHEX_PATTERNS}:imhex_patterns \ WerWolv:PatternLanguage:${GH_TAG_PATTERN_LANGUAGE}:pattern_language \ @@ -54,12 +56,13 @@ GH_TUPLE= btzy:nativefiledialog-extended:${GH_TAG_NATIVEFILEDIALOG}:nativefiledi GH_TAG_CAPSTONE= d5141c0 GH_TAG_CLI11= faea921 -GH_TAG_FMT= c4ee726 -GH_TAG_IMHEX_PATTERNS= 5481c2f -GH_TAG_LIBROMFS= 8c8556d -GH_TAG_NATIVEFILEDIALOG= 6967d28 -GH_TAG_PATTERN_LANGUAGE= 143628a -GH_TAG_YARA= d5a7565 +GH_TAG_FMT= a337011 +GH_TAG_IMHEX_PATTERNS= 8e70a55 +GH_TAG_JTHREAD= 0fa8d39 +GH_TAG_LIBROMFS= 8efe4c4 +GH_TAG_NATIVEFILEDIALOG= d4df2b6 +GH_TAG_PATTERN_LANGUAGE= ab7d738 +GH_TAG_YARA= ba94b4f CMAKE_ARGS= -DUSE_SYSTEM_CURL=ON -DUSE_SYSTEM_NLOHMANN_JSON=ON \ -DIMHEX_STRIP_RELEASE=OFF -DIMHEX_PLUGINS_IN_SHARE=ON \ @@ -84,6 +87,7 @@ post-extract: ${CP} ${DISTDIR}/${DIST_SUBDIR}/xdg.hpp ${WRKSRC}/lib/external/xdgpp ${CP} -R ${WRKSRC_capstone}/* ${WRKSRC}/lib/external/capstone ${CP} -R ${WRKSRC_fmt}/* ${WRKSRC}/lib/external/fmt + ${CP} -R ${WRKSRC_jthread}/source/*.hpp ${WRKSRC}/lib/libimhex/include ${CP} -R ${WRKSRC_libromfs}/* ${WRKSRC}/lib/external/libromfs ${CP} -R ${WRKSRC_nativefiledialog}/* ${WRKSRC}/lib/external/nativefiledialog ${CP} -R ${WRKSRC_pattern_language}/* ${WRKSRC}/lib/external/pattern_language diff --git a/editors/imhex/distinfo b/editors/imhex/distinfo index 7a9b808d2e73..58cfaee19cbf 100644 --- a/editors/imhex/distinfo +++ b/editors/imhex/distinfo @@ -1,21 +1,23 @@ -TIMESTAMP = 1663402501 +TIMESTAMP = 1665857378 SHA256 (imhex/xdg.hpp) = 2e08ce74adb71ff9b9aa9e1c999733fccd4b00967b9cf0c0e51dbf049392a9ec SIZE (imhex/xdg.hpp) = 7674 -SHA256 (imhex/WerWolv-ImHex-v1.23.1_GH0.tar.gz) = 37bd49d0a8f9b7785106b15f829965affb6235199ea0763397af4fe97b3a1682 -SIZE (imhex/WerWolv-ImHex-v1.23.1_GH0.tar.gz) = 10927633 -SHA256 (imhex/btzy-nativefiledialog-extended-6967d28_GH0.tar.gz) = 67575871aca25f6b448831183851656d95cee5af773ac7b2a1f7f887f6d874d6 -SIZE (imhex/btzy-nativefiledialog-extended-6967d28_GH0.tar.gz) = 412145 +SHA256 (imhex/WerWolv-ImHex-v1.24.3_GH0.tar.gz) = 5d6780b2d4c3b92bbe7619dcae34138072a8ed9c540523d25760da237f01d279 +SIZE (imhex/WerWolv-ImHex-v1.24.3_GH0.tar.gz) = 11126282 +SHA256 (imhex/btzy-nativefiledialog-extended-d4df2b6_GH0.tar.gz) = a0440e52bd25b8f85cb25ef68fe19ca39b4b0fad39358d5a501b317cad9d0f69 +SIZE (imhex/btzy-nativefiledialog-extended-d4df2b6_GH0.tar.gz) = 412249 SHA256 (imhex/capstone-engine-capstone-d5141c0_GH0.tar.gz) = 435d40757928fa73dec19c6d0fbf171bd76341391c8525ce1286927dab44c3e7 SIZE (imhex/capstone-engine-capstone-d5141c0_GH0.tar.gz) = 5761632 SHA256 (imhex/CLIUtils-CLI11-faea921_GH0.tar.gz) = 84773ee9577e6b719e5a84ad62cc381cf3027756690e1db839eaa50bcafc6c78 SIZE (imhex/CLIUtils-CLI11-faea921_GH0.tar.gz) = 299718 -SHA256 (imhex/fmtlib-fmt-c4ee726_GH0.tar.gz) = 05ba66b0a9ed040e5cfb07e845a0aa61fdbbb9a0cbd22a1860a303e8cbf343e4 -SIZE (imhex/fmtlib-fmt-c4ee726_GH0.tar.gz) = 833672 -SHA256 (imhex/VirusTotal-yara-d5a7565_GH0.tar.gz) = 1c908b160f2432a25aefc1e94147949d24bcb79c1412a2be840f767531f3ff7e -SIZE (imhex/VirusTotal-yara-d5a7565_GH0.tar.gz) = 1287317 -SHA256 (imhex/WerWolv-ImHex-Patterns-5481c2f_GH0.tar.gz) = cfa2c76fb0986e406a3541202df4b7e2e5b8cf6bcf5fb14d6605efb1ca32f6bc -SIZE (imhex/WerWolv-ImHex-Patterns-5481c2f_GH0.tar.gz) = 5171762 -SHA256 (imhex/WerWolv-PatternLanguage-143628a_GH0.tar.gz) = 4d284923d1fec8bb942145365cd57e0b33e786c5db2cd7d3d133be417a516070 -SIZE (imhex/WerWolv-PatternLanguage-143628a_GH0.tar.gz) = 288257 -SHA256 (imhex/WerWolv-libromfs-8c8556d_GH0.tar.gz) = 46364edcf21a4cbe7c48094e755751aa03704a9c1efe3be5add5f52a15690474 -SIZE (imhex/WerWolv-libromfs-8c8556d_GH0.tar.gz) = 3868 +SHA256 (imhex/fmtlib-fmt-a337011_GH0.tar.gz) = ba190d69d8b7994ef2ceb533c56bc34feec296fef2f87efab4cfb981a04601cf +SIZE (imhex/fmtlib-fmt-a337011_GH0.tar.gz) = 837936 +SHA256 (imhex/josuttis-jthread-0fa8d39_GH0.tar.gz) = ccd9c871dc2da9611e6d0cba5fc859cec9b233541be7501e5cef9eaa367e1280 +SIZE (imhex/josuttis-jthread-0fa8d39_GH0.tar.gz) = 4450456 +SHA256 (imhex/VirusTotal-yara-ba94b4f_GH0.tar.gz) = 4c81120bff451a55deaa23b48155d3eb35955ce11a1d76fbfcbbe2c2e33770b9 +SIZE (imhex/VirusTotal-yara-ba94b4f_GH0.tar.gz) = 1288534 +SHA256 (imhex/WerWolv-ImHex-Patterns-8e70a55_GH0.tar.gz) = 8d283e8806412d4083f9da9c7b1ff499bc7374394397bd7f270ba11277cd6df2 +SIZE (imhex/WerWolv-ImHex-Patterns-8e70a55_GH0.tar.gz) = 5176390 +SHA256 (imhex/WerWolv-PatternLanguage-ab7d738_GH0.tar.gz) = d7b5844a21622265a1ecd5184650177595cfa40a7bb17cb44f2104f29dc38ac5 +SIZE (imhex/WerWolv-PatternLanguage-ab7d738_GH0.tar.gz) = 415301 +SHA256 (imhex/WerWolv-libromfs-8efe4c4_GH0.tar.gz) = cc538b4add2a451c7c9be4237717b3231171cce56db51a956eaffd85d7f5af5b +SIZE (imhex/WerWolv-libromfs-8efe4c4_GH0.tar.gz) = 4078 diff --git a/editors/imhex/files/patch-CMakeLists.txt b/editors/imhex/files/patch-CMakeLists.txt index 9ad03de1dafd..290002b6d217 100644 --- a/editors/imhex/files/patch-CMakeLists.txt +++ b/editors/imhex/files/patch-CMakeLists.txt @@ -1,6 +1,6 @@ ---- CMakeLists.txt.orig 2022-09-03 22:05:27 UTC +--- CMakeLists.txt.orig 2022-10-08 08:03:47 UTC +++ CMakeLists.txt -@@ -22,8 +22,6 @@ project(imhex VERSION ${IMHEX_VERSION}) +@@ -23,8 +23,6 @@ project(imhex VERSION ${IMHEX_VERSION}) # Make sure project is configured correctly setDefaultBuiltTypeIfUnset() diff --git a/editors/imhex/files/patch-cmake_build__helpers.cmake b/editors/imhex/files/patch-cmake_build__helpers.cmake index 0ebdb118cf2a..818003a32010 100644 --- a/editors/imhex/files/patch-cmake_build__helpers.cmake +++ b/editors/imhex/files/patch-cmake_build__helpers.cmake @@ -1,4 +1,4 @@ ---- cmake/build_helpers.cmake.orig 2022-09-15 12:40:14 UTC +--- cmake/build_helpers.cmake.orig 2022-10-08 08:03:47 UTC +++ cmake/build_helpers.cmake @@ -383,24 +383,15 @@ function(downloadImHexPatternsFiles dest) else () @@ -31,7 +31,7 @@ macro(setupCompilerWarnings target) set(IMHEX_COMMON_FLAGS "-Wall -Wextra -Werror") -- set(IMHEX_C_FLAGS "${IMHEX_COMMON_FLAGS} -Wno-restrict -Wno-stringop-overread") +- set(IMHEX_C_FLAGS "${IMHEX_COMMON_FLAGS} -Wno-restrict -Wno-stringop-overread -Wno-stringop-overflow") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${IMHEX_C_FLAGS}") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${IMHEX_C_FLAGS}") diff --git a/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_ast_ast__node__bitfield.hpp b/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_ast_ast__node__bitfield.hpp deleted file mode 100644 index cc4198d9685b..000000000000 --- a/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_ast_ast__node__bitfield.hpp +++ /dev/null @@ -1,11 +0,0 @@ ---- lib/external/pattern_language/lib/include/pl/core/ast/ast_node_bitfield.hpp.orig 2022-08-18 14:31:33 UTC -+++ lib/external/pattern_language/lib/include/pl/core/ast/ast_node_bitfield.hpp -@@ -86,7 +86,6 @@ namespace pl::core::ast { - - private: - std::vector<std::unique_ptr<ASTNode>> m_entries; -- mutable size_t m_bitOffset = 0x00; - }; - - } -\ No newline at end of file diff --git a/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_token.hpp b/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_token.hpp index 674688dd1b86..6f6e219eae3d 100644 --- a/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_token.hpp +++ b/editors/imhex/files/patch-lib_external_pattern__language_lib_include_pl_core_token.hpp @@ -1,4 +1,4 @@ ---- lib/external/pattern_language/lib/include/pl/core/token.hpp.orig 2022-09-16 15:30:16 UTC +--- lib/external/pattern_language/lib/include/pl/core/token.hpp.orig 2022-10-15 20:26:43 UTC +++ lib/external/pattern_language/lib/include/pl/core/token.hpp @@ -148,9 +148,9 @@ namespace pl::core { @@ -12,7 +12,7 @@ [[nodiscard]] constexpr static inline bool isInteger(const ValueType &type) { return isUnsigned(type) || isSigned(type); } -@@ -194,133 +194,133 @@ namespace pl::core { +@@ -206,133 +206,133 @@ namespace pl::core { namespace tkn { diff --git a/editors/imhex/files/patch-lib_libimhex_CMakeLists.txt b/editors/imhex/files/patch-lib_libimhex_CMakeLists.txt index cc5d449b4c4b..d91be6ec76a6 100644 --- a/editors/imhex/files/patch-lib_libimhex_CMakeLists.txt +++ b/editors/imhex/files/patch-lib_libimhex_CMakeLists.txt @@ -1,6 +1,6 @@ ---- lib/libimhex/CMakeLists.txt.orig 2022-08-14 12:54:20 UTC +--- lib/libimhex/CMakeLists.txt.orig 2022-10-08 08:03:47 UTC +++ lib/libimhex/CMakeLists.txt -@@ -26,7 +26,6 @@ set(FPHSA_NAME_MISMATCHED ON CACHE BOOL "") +@@ -27,7 +27,6 @@ set(FPHSA_NAME_MISMATCHED ON CACHE BOOL "") find_package(PkgConfig REQUIRED) if (NOT USE_SYSTEM_NFD) diff --git a/editors/imhex/files/patch-lib_libimhex_include_hex_api_task.hpp b/editors/imhex/files/patch-lib_libimhex_include_hex_api_task.hpp new file mode 100644 index 000000000000..d5fef1616abe --- /dev/null +++ b/editors/imhex/files/patch-lib_libimhex_include_hex_api_task.hpp @@ -0,0 +1,18 @@ +--- lib/libimhex/include/hex/api/task.hpp.orig 2022-10-08 08:03:47 UTC ++++ lib/libimhex/include/hex/api/task.hpp +@@ -1,6 +1,7 @@ + #pragma once + + #include <hex.hpp> ++#include <jthread.hpp> + + #include <cstdio> + #include <thread> +@@ -11,6 +12,7 @@ + #include <memory> + #include <list> + #include <condition_variable> ++#include <vector> + + namespace hex { + diff --git a/editors/imhex/files/patch-lib_libimhex_include_hex_data__processor_node.hpp b/editors/imhex/files/patch-lib_libimhex_include_hex_data__processor_node.hpp index a42bdab95f2b..b0388d966bd2 100644 --- a/editors/imhex/files/patch-lib_libimhex_include_hex_data__processor_node.hpp +++ b/editors/imhex/files/patch-lib_libimhex_include_hex_data__processor_node.hpp @@ -1,6 +1,6 @@ ---- lib/libimhex/include/hex/data_processor/node.hpp.orig 2022-08-14 15:02:06 UTC +--- lib/libimhex/include/hex/data_processor/node.hpp.orig 2022-10-08 08:03:47 UTC +++ lib/libimhex/include/hex/data_processor/node.hpp -@@ -45,6 +45,7 @@ namespace hex::dp { +@@ -46,6 +46,7 @@ namespace hex::dp { struct NodeError { Node *node; std::string message; diff --git a/editors/imhex/files/patch-lib_libimhex_source_api_imhex__api.cpp b/editors/imhex/files/patch-lib_libimhex_source_api_imhex__api.cpp index a38d2f10790f..24945986719f 100644 --- a/editors/imhex/files/patch-lib_libimhex_source_api_imhex__api.cpp +++ b/editors/imhex/files/patch-lib_libimhex_source_api_imhex__api.cpp @@ -1,4 +1,4 @@ ---- lib/libimhex/source/api/imhex_api.cpp.orig 2022-08-17 21:25:52 UTC +--- lib/libimhex/source/api/imhex_api.cpp.orig 2022-10-08 08:03:47 UTC +++ lib/libimhex/source/api/imhex_api.cpp @@ -4,6 +4,7 @@ #include <hex/api/event.hpp> @@ -8,7 +8,7 @@ #include <utility> #include <unistd.h> -@@ -260,7 +261,7 @@ namespace hex { +@@ -266,7 +267,7 @@ namespace hex { } bool isDirty() { diff --git a/editors/imhex/files/patch-lib_libimhex_source_helpers_file.cpp b/editors/imhex/files/patch-lib_libimhex_source_helpers_file.cpp index f0d74435b58e..c3e38e800446 100644 --- a/editors/imhex/files/patch-lib_libimhex_source_helpers_file.cpp +++ b/editors/imhex/files/patch-lib_libimhex_source_helpers_file.cpp @@ -1,18 +1,18 @@ ---- lib/libimhex/source/helpers/file.cpp.orig 2022-08-17 21:25:52 UTC +--- lib/libimhex/source/helpers/file.cpp.orig 2022-10-08 08:03:47 UTC +++ lib/libimhex/source/helpers/file.cpp @@ -17,12 +17,12 @@ namespace hex::fs { this->m_file = _wfopen(path.c_str(), L"w+b"); #else if (mode == File::Mode::Read) -- this->m_file = fopen64(path.string().c_str(), "rb"); -+ this->m_file = fopen(path.string().c_str(), "rb"); +- this->m_file = fopen64(hex::toUTF8String(path).c_str(), "rb"); ++ this->m_file = fopen(hex::toUTF8String(path).c_str(), "rb"); else if (mode == File::Mode::Write) -- this->m_file = fopen64(path.string().c_str(), "r+b"); -+ this->m_file = fopen(path.string().c_str(), "r+b"); +- this->m_file = fopen64(hex::toUTF8String(path).c_str(), "r+b"); ++ this->m_file = fopen(hex::toUTF8String(path).c_str(), "r+b"); if (mode == File::Mode::Create || (mode == File::Mode::Write && this->m_file == nullptr)) -- this->m_file = fopen64(path.string().c_str(), "w+b"); -+ this->m_file = fopen(path.string().c_str(), "w+b"); +- this->m_file = fopen64(hex::toUTF8String(path).c_str(), "w+b"); ++ this->m_file = fopen(hex::toUTF8String(path).c_str(), "w+b"); #endif } diff --git a/editors/imhex/files/patch-lib_libimhex_source_helpers_fs.cpp b/editors/imhex/files/patch-lib_libimhex_source_helpers_fs.cpp index 9a0b4d5bab60..a36b83e2d2ff 100644 --- a/editors/imhex/files/patch-lib_libimhex_source_helpers_fs.cpp +++ b/editors/imhex/files/patch-lib_libimhex_source_helpers_fs.cpp @@ -1,4 +1,4 @@ ---- lib/libimhex/source/helpers/fs.cpp.orig 2022-08-05 10:52:34 UTC +--- lib/libimhex/source/helpers/fs.cpp.orig 2022-10-08 08:03:47 UTC +++ lib/libimhex/source/helpers/fs.cpp @@ -14,10 +14,15 @@ #include <shlobj.h> @@ -16,7 +16,7 @@ #include <filesystem> namespace hex::fs { -@@ -179,7 +184,7 @@ namespace hex::fs { +@@ -189,7 +194,7 @@ namespace hex::fs { #endif } diff --git a/editors/imhex/files/patch-plugins_builtin_source_content_helpers_math__evaluator.cpp b/editors/imhex/files/patch-plugins_builtin_source_content_helpers_math__evaluator.cpp new file mode 100644 index 000000000000..44d28a094316 --- /dev/null +++ b/editors/imhex/files/patch-plugins_builtin_source_content_helpers_math__evaluator.cpp @@ -0,0 +1,15 @@ +--- plugins/builtin/source/content/helpers/math_evaluator.cpp.orig 2022-10-12 10:48:50 UTC ++++ plugins/builtin/source/content/helpers/math_evaluator.cpp +@@ -434,9 +434,9 @@ namespace hex { + template<typename T> + void MathEvaluator<T>::registerStandardVariables() { + this->setVariable("ans", 0); +- this->setVariable("pi", std::numbers::pi, true); +- this->setVariable("e", std::numbers::e, true); +- this->setVariable("phi", std::numbers::phi, true); ++ this->setVariable("pi", 3.141592653589793238462643383279502884L, true); ++ this->setVariable("e", 2.718281828459045235360287471352662498L, true); ++ this->setVariable("phi", 1.618033988749894848204586834365638117L, true); + } + + template<typename T> diff --git a/editors/imhex/files/patch-plugins_builtin_source_content_providers_disk__provider.cpp b/editors/imhex/files/patch-plugins_builtin_source_content_providers_disk__provider.cpp index 2269f67780d5..6f842aea0d2a 100644 --- a/editors/imhex/files/patch-plugins_builtin_source_content_providers_disk__provider.cpp +++ b/editors/imhex/files/patch-plugins_builtin_source_content_providers_disk__provider.cpp @@ -1,13 +1,11 @@ ---- plugins/builtin/source/content/providers/disk_provider.cpp.orig 2022-08-14 12:54:20 UTC +--- plugins/builtin/source/content/providers/disk_provider.cpp.orig 2022-10-08 08:03:47 UTC +++ plugins/builtin/source/content/providers/disk_provider.cpp -@@ -18,8 +18,9 @@ - #include <sys/stat.h> +@@ -20,7 +20,7 @@ #include <sys/types.h> + #endif -+# if !defined(__FreeBSD__) +-#if defined(OS_LINUX) ++#if !defined(__FreeBSD__) #define lseek lseek64 -- -+# endif - #elif defined(OS_MACOS) + #endif - #include <fcntl.h> diff --git a/editors/imhex/files/patch-plugins_builtin_source_content_settings__entries.cpp b/editors/imhex/files/patch-plugins_builtin_source_content_settings__entries.cpp index 75bacccf8a5e..2df3722bff2f 100644 --- a/editors/imhex/files/patch-plugins_builtin_source_content_settings__entries.cpp +++ b/editors/imhex/files/patch-plugins_builtin_source_content_settings__entries.cpp @@ -1,6 +1,6 @@ ---- plugins/builtin/source/content/settings_entries.cpp.orig 2022-07-16 11:41:37 UTC +--- plugins/builtin/source/content/settings_entries.cpp.orig 2022-10-08 08:03:47 UTC +++ plugins/builtin/source/content/settings_entries.cpp -@@ -19,8 +19,7 @@ namespace { +@@ -21,8 +21,7 @@ namespace { userFolders.clear(); std::vector<std::string> paths = setting; for (const auto &path : paths) { diff --git a/editors/imhex/files/patch-plugins_builtin_source_content_views_view__find.cpp b/editors/imhex/files/patch-plugins_builtin_source_content_views_view__find.cpp index 1bdd6465fdb3..a3f5987cf764 100644 --- a/editors/imhex/files/patch-plugins_builtin_source_content_views_view__find.cpp +++ b/editors/imhex/files/patch-plugins_builtin_source_content_views_view__find.cpp @@ -1,11 +1,128 @@ ---- plugins/builtin/source/content/views/view_find.cpp.orig 2022-09-15 12:40:14 UTC +--- plugins/builtin/source/content/views/view_find.cpp.orig 2022-10-08 08:03:47 UTC +++ plugins/builtin/source/content/views/view_find.cpp -@@ -239,7 +239,7 @@ namespace hex::plugin::builtin { +@@ -153,34 +153,87 @@ namespace hex::plugin::builtin { + } + + template<typename Type, typename StorageType> +- static std::tuple<bool, std::variant<u64, i64, float, double>, size_t> parseNumericValue(const std::string &string) { ++ static std::tuple<bool, u64, size_t> parseNumericValue_u(const std::string &string) { + static_assert(sizeof(StorageType) >= sizeof(Type)); + + StorageType value = 0x00; +- auto result = std::from_chars(string.data(), string.data() + string.size(), value); +- if (result.ec != std::errc() || result.ptr != string.data() + string.size()) ++ try { ++ value = std::stoull(string.data()); ++ } catch (...) { + return { false, { }, 0 }; ++ } + +- if (value < std::numeric_limits<Type>::min() || value > std::numeric_limits<Type>::max()) ++ if (value < std::numeric_limits<Type>::lowest() || value > std::numeric_limits<Type>::max()) + return { false, { }, 0 }; + + return { true, value, sizeof(Type) }; + } + ++ template<typename Type, typename StorageType> ++ static std::tuple<bool, i64, size_t> parseNumericValue_i(const std::string &string) { ++ static_assert(sizeof(StorageType) >= sizeof(Type)); ++ ++ StorageType value = 0x00; ++ try { ++ value = std::stoll(string.data()); ++ } catch (...) { ++ return { false, { }, 0 }; ++ } ++ ++ if (value < std::numeric_limits<Type>::lowest() || value > std::numeric_limits<Type>::max()) ++ return { false, { }, 0 }; ++ ++ return { true, value, sizeof(Type) }; ++ } ++ ++ template<typename Type, typename StorageType> ++ static std::tuple<bool, float, size_t> parseNumericValue_f(const std::string &string) { ++ static_assert(sizeof(StorageType) >= sizeof(Type)); ++ ++ StorageType value = 0x00; ++ try { ++ value = std::stof(string.data()); ++ } catch (...) { ++ return { false, { }, 0 }; ++ } ++ ++ if (value < std::numeric_limits<Type>::lowest() || value > std::numeric_limits<Type>::max()) ++ return { false, { }, 0 }; ++ ++ return { true, value, sizeof(float) }; ++ } ++ ++ template<typename Type, typename StorageType> ++ static std::tuple<bool, double, size_t> parseNumericValue_d(const std::string &string) { ++ static_assert(sizeof(StorageType) >= sizeof(Type)); ++ ++ StorageType value = 0x00; ++ try { ++ value = std::stod(string.data()); ++ } catch (...) { ++ return { false, { }, 0 }; ++ } ++ ++ if (value < std::numeric_limits<Type>::lowest() || value > std::numeric_limits<Type>::max()) ++ return { false, { }, 0 }; ++ ++ return { true, value, sizeof(Type) }; ++ } ++ + std::tuple<bool, std::variant<u64, i64, float, double>, size_t> ViewFind::parseNumericValueInput(const std::string &input, SearchSettings::Value::Type type) { + switch (type) { + using enum SearchSettings::Value::Type; + +- case U8: return parseNumericValue<u8, u64>(input); +- case U16: return parseNumericValue<u16, u64>(input); +- case U32: return parseNumericValue<u32, u64>(input); +- case U64: return parseNumericValue<u64, u64>(input); +- case I8: return parseNumericValue<i8, i64>(input); +- case I16: return parseNumericValue<i16, i64>(input); +- case I32: return parseNumericValue<i32, i64>(input); +- case I64: return parseNumericValue<i64, i64>(input); +- case F32: return parseNumericValue<float, float>(input); +- case F64: return parseNumericValue<double, double>(input); ++ case U8: return parseNumericValue_u<u8, u64>(input); ++ case U16: return parseNumericValue_u<u16, u64>(input); ++ case U32: return parseNumericValue_u<u32, u64>(input); ++ case U64: return parseNumericValue_u<u64, u64>(input); ++ case I8: return parseNumericValue_i<i8, i64>(input); ++ case I16: return parseNumericValue_i<i16, i64>(input); ++ case I32: return parseNumericValue_i<i32, i64>(input); ++ case I64: return parseNumericValue_i<i64, i64>(input); ++ case F32: return parseNumericValue_f<float, float>(input); ++ case F64: return parseNumericValue_d<double, double>(input); + default: return { false, { }, 0 }; + } + } +@@ -293,7 +346,7 @@ namespace hex::plugin::builtin { auto occurrence = reader.begin(); while (true) { -- occurrence = std::search(reader.begin(), reader.end(), std::boyer_moore_horspool_searcher(sequence.begin(), sequence.end())); -+ occurrence = std::search(reader.begin(), reader.end(), sequence.begin(), sequence.end()); +- occurrence = std::search(reader.begin(), reader.end(), std::boyer_moore_horspool_searcher(bytes.begin(), bytes.end())); ++ occurrence = std::search(reader.begin(), reader.end(), bytes.begin(), bytes.end()); if (occurrence == reader.end()) break; +@@ -377,8 +430,12 @@ namespace hex::plugin::builtin { + reader.seek(searchRegion.getStartAddress()); + reader.setEndAddress(searchRegion.getEndAddress()); + +- const auto [validMin, min, sizeMin] = parseNumericValueInput(settings.inputMin, settings.type); +- const auto [validMax, max, sizeMax] = parseNumericValueInput(settings.inputMax, settings.type); ++ const auto validMin = std::get<0>(parseNumericValueInput(settings.inputMin, settings.type)); ++ const auto min = std::get<1>(parseNumericValueInput(settings.inputMin, settings.type)); ++ const auto sizeMin = std::get<2>(parseNumericValueInput(settings.inputMin, settings.type)); ++ const auto validMax = std::get<0>(parseNumericValueInput(settings.inputMax, settings.type)); ++ const auto max = std::get<1>(parseNumericValueInput(settings.inputMax, settings.type)); ++ const auto sizeMax = std::get<2>(parseNumericValueInput(settings.inputMax, settings.type)); + + if (!validMin || !validMax || sizeMin != sizeMax) + return { }; diff --git a/editors/imhex/files/patch-plugins_builtin_source_content_views_view__hex__editor.cpp b/editors/imhex/files/patch-plugins_builtin_source_content_views_view__hex__editor.cpp index 46ef7fe6c59b..bea962f71143 100644 --- a/editors/imhex/files/patch-plugins_builtin_source_content_views_view__hex__editor.cpp +++ b/editors/imhex/files/patch-plugins_builtin_source_content_views_view__hex__editor.cpp @@ -1,6 +1,6 @@ ---- plugins/builtin/source/content/views/view_hex_editor.cpp.orig 2022-09-03 22:05:27 UTC +--- plugins/builtin/source/content/views/view_hex_editor.cpp.orig 2022-10-12 10:48:50 UTC +++ plugins/builtin/source/content/views/view_hex_editor.cpp -@@ -288,7 +288,7 @@ namespace hex::plugin::builtin { +@@ -290,7 +290,7 @@ namespace hex::plugin::builtin { reader.seek(this->m_searchPosition.value_or(0x00)); constexpr static auto searchFunction = [](const auto &haystackBegin, const auto &haystackEnd, const auto &needleBegin, const auto &needleEnd) { diff --git a/editors/imhex/files/patch-plugins_windows_include_views_view__tty__console.hpp b/editors/imhex/files/patch-plugins_windows_include_views_view__tty__console.hpp new file mode 100644 index 000000000000..8044d81e7896 --- /dev/null +++ b/editors/imhex/files/patch-plugins_windows_include_views_view__tty__console.hpp @@ -0,0 +1,10 @@ +--- plugins/windows/include/views/view_tty_console.hpp.orig 2022-10-15 14:50:11 UTC ++++ plugins/windows/include/views/view_tty_console.hpp +@@ -1,6 +1,7 @@ + #pragma once + + #include <hex/ui/view.hpp> ++#include <jthread.hpp> + + #include <windows.h> + diff --git a/editors/imhex/pkg-plist b/editors/imhex/pkg-plist index f5a17e71071f..bcd5457bc959 100644 --- a/editors/imhex/pkg-plist +++ b/editors/imhex/pkg-plist @@ -1,5 +1,5 @@ bin/imhex -lib/libimhex.so.1.23.1 +lib/libimhex.so.1.24.3 share/applications/imhex.desktop %%DATADIR%%/constants/_schema.json %%DATADIR%%/constants/crc16.json @@ -7,17 +7,24 @@ share/applications/imhex.desktop %%DATADIR%%/constants/http_status.json %%DATADIR%%/constants/linux_errors.json %%DATADIR%%/includes/hex/core.pat +%%DATADIR%%/includes/hex/dec.pat %%DATADIR%%/includes/hex/http.pat %%DATADIR%%/includes/hex/impl/imhex_check.pat +%%DATADIR%%/includes/hex/type/mangled.pat +%%DATADIR%%/includes/std/array.pat %%DATADIR%%/includes/type/types/010.pat %%DATADIR%%/includes/type/types/c.pat %%DATADIR%%/includes/type/types/linux.pat %%DATADIR%%/includes/type/types/rust.pat %%DATADIR%%/includes/type/types/win32.pat +%%DATADIR%%/includes/type/base.pat +%%DATADIR%%/includes/type/color.pat %%DATADIR%%/patterns/bson.hexpat %%DATADIR%%/patterns/flac.hexpat +%%DATADIR%%/patterns/id3.hexpat %%DATADIR%%/patterns/minidump.hexpat %%DATADIR%%/patterns/msgpack.hexpat +%%DATADIR%%/patterns/usb.hexpat %%DATADIR%%/patterns/xilinx_bit.hexpat %%DATADIR%%/encodings/arabic_iso.tbl %%DATADIR%%/encodings/arabic_windows.tbl