// Library for pooling common strings. #include "config.h" // IWYU pragma: keep #include #include #include #include #include #include "common.h" #include "fallback.h" // IWYU pragma: keep #include "intern.h" bool string_less_than_string(const wchar_t *a, const wchar_t *b) { return wcscmp(a, b) < 0; } /// The table of intern'd strings. owning_lock> string_table; static const wchar_t *intern_with_dup(const wchar_t *in, bool dup) { if (!in) return NULL; debug(5, L"intern %ls", in); auto &&lock_string_table = string_table.acquire(); std::vector &string_table = lock_string_table.value; const wchar_t *result; auto iter = std::lower_bound(string_table.begin(), string_table.end(), in, string_less_than_string); if (iter != string_table.end() && wcscmp(*iter, in) == 0) { result = *iter; } else { result = dup ? wcsdup(in) : in; string_table.insert(iter, result); } return result; } const wchar_t *intern(const wchar_t *in) { return intern_with_dup(in, true); } const wchar_t *intern_static(const wchar_t *in) { return intern_with_dup(in, false); }