/* ======================================== Copyright (C) 2025 Amlal El Mahrouss, Licensed under the Apache 2.0 license ======================================== */ #include /** * @file Frontend.cc * @author Amlal El Mahrouss (amlal@nekernel.org) * @brief Frontend API of NeCTI * @version 0.0.2 * * @copyright Copyright (c) 2025 Amlal El Mahrouss and NeKernel.org Contributors * */ namespace CompilerKit { /// find the perfect matching word in a haystack. /// \param haystack base string /// \param needle the string we search for. /// \return if we found it or not. Bool find_word(STLString haystack, STLString needle) noexcept { auto index = haystack.find(needle); // check for needle validity. if (index == STLString::npos) return false; // declare lambda auto not_part_of_word = [&](int index) { if (std::isspace(haystack[index]) || std::ispunct(haystack[index])) return true; if (index <= 0 || index >= haystack.size()) return true; return false; }; return not_part_of_word(index - 1) && not_part_of_word(index + needle.size()); } /// find a word within strict conditions and returns a range of it. /// \param haystack /// \param needle /// \return position of needle. SizeType find_word_range(STLString haystack, STLString needle) noexcept { auto index = haystack.find(needle); // check for needle validity. if (index == STLString::npos) return false; if (!isalnum((haystack[index + needle.size() + 1])) && !isdigit(haystack[index + needle.size() + 1]) && !isalnum((haystack[index - needle.size() - 1])) && !isdigit(haystack[index - needle.size() - 1])) { return index; } return STLString::npos; } } // namespace CompilerKit