diff --git a/pypkg/redatamlib/readers/FuzzyVariableParser.cpp b/pypkg/redatamlib/readers/FuzzyVariableParser.cpp index 1ecf902..812a152 100644 --- a/pypkg/redatamlib/readers/FuzzyVariableParser.cpp +++ b/pypkg/redatamlib/readers/FuzzyVariableParser.cpp @@ -17,8 +17,14 @@ FuzzyVariableParser::FuzzyVariableParser(ByteArrayReader reader, void FuzzyVariableParser::ParseAllVariables(vector &entities) { vector> searchBounds = GetSearchBounds(entities); - size_t numThreads = std::thread::hardware_concurrency(); - numThreads = std::min(entities.size(), numThreads); + // R-devel suggestion: Default to using all available hardware concurrency + size_t maxThreads = std::thread::hardware_concurrency(); + + size_t numThreads = std::min(entities.size(), maxThreads); + + if (numThreads == 0) { + numThreads = 1; + } size_t chunkSize = entities.size() / numThreads; @@ -41,6 +47,10 @@ vector> FuzzyVariableParser::GetSearchBounds(vector entities) { vector> ret; + if (entities.empty()) { + return ret; + } + for (size_t i = 0; i < entities.size() - 1; ++i) { ret.push_back( {entities[i].GetBounds().second, entities[i + 1].GetBounds().first}); diff --git a/src/readers/FuzzyVariableParser.cpp b/src/readers/FuzzyVariableParser.cpp index 09efdf3..b693b8f 100644 --- a/src/readers/FuzzyVariableParser.cpp +++ b/src/readers/FuzzyVariableParser.cpp @@ -17,8 +17,14 @@ FuzzyVariableParser::FuzzyVariableParser(ByteArrayReader reader, void FuzzyVariableParser::ParseAllVariables(vector &entities) { vector> searchBounds = GetSearchBounds(entities); - size_t numThreads = std::thread::hardware_concurrency(); - numThreads = std::min(entities.size(), numThreads); + // R-devel suggestion: Default to using all available hardware concurrency + size_t maxThreads = std::thread::hardware_concurrency(); + + size_t numThreads = std::min(entities.size(), maxThreads); + + if (numThreads == 0) { + numThreads = 1; + } size_t chunkSize = entities.size() / numThreads; @@ -41,6 +47,10 @@ vector> FuzzyVariableParser::GetSearchBounds(vector entities) { vector> ret; + if (entities.empty()) { + return ret; + } + for (size_t i = 0; i < entities.size() - 1; ++i) { ret.push_back( {entities[i].GetBounds().second, entities[i + 1].GetBounds().first});