Skip to content

Commit

Permalink
Make usage of SSE extension optional
Browse files Browse the repository at this point in the history
  • Loading branch information
Yaraslaut committed Dec 20, 2023
1 parent 24c712b commit b123426
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 0 deletions.
1 change: 1 addition & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ option(LIBUNICODE_EXAMPLES "libunicode: Enables building of example programs. [d
option(LIBUNICODE_TESTING "libunicode: Enables building of unittests for libunicode [default: ${MASTER_PROJECT}" ${MASTER_PROJECT})
option(LIBUNICODE_TOOLS "libunicode: Builds CLI tools [default: ${MASTER_PROJECT}]" ${MASTER_PROJECT})
option(LIBUNICODE_BUILD_STATIC "libunicode: provide static library instead of dynamic [default: ${LIBUNICODE_BUILD_STATIC_DEFAULT}]" ${LIBUNICODE_BUILD_STATIC_DEFAULT})
option(LIBUNICODE_USE_INTRINSICS "libunicode: use SSE2 extenstion during text read [default: ON]" ON)

if(LIBUNICODE_TESTING)
enable_testing()
Expand Down
3 changes: 3 additions & 0 deletions scripts/install-deps.sh
Original file line number Diff line number Diff line change
Expand Up @@ -239,6 +239,9 @@ main()
install_deps_FreeBSD
;;
*)
fetch_and_unpack_Catch2
fetch_and_unpack_fmtlib
fetch_and_unpack_yaml_cpp
echo "OS not supported."
;;
esac
Expand Down
4 changes: 4 additions & 0 deletions src/libunicode/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,10 @@ add_library(unicode ${LIBUNICODE_LIB_MODE}
codepoint_properties_names.cpp
)

if(LIBUNICODE_USE_INTRINSICS)
target_compile_definitions(unicode PRIVATE USE_INTRINSICS)
endif()

set(public_headers
capi.h
codepoint_properties.h
Expand Down
2 changes: 2 additions & 0 deletions src/libunicode/scan.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ size_t detail::scan_for_text_ascii(string_view text, size_t maxColumnCount) noex
auto input = text.data();
auto const end = text.data() + min(text.size(), maxColumnCount);

#if defined(USE_INTRINSICS)
intrinsics::m128i const ControlCodeMax = intrinsics::set1_epi8(0x20); // 0..0x1F
intrinsics::m128i const Complex = intrinsics::set1_epi8(-128); // equals to 0x80 (0b1000'0000)

Expand All @@ -95,6 +96,7 @@ size_t detail::scan_for_text_ascii(string_view text, size_t maxColumnCount) noex
}
input += sizeof(intrinsics::m128i);
}
#endif

while (input != end && is_ascii(*input))
++input;
Expand Down

0 comments on commit b123426

Please sign in to comment.