doc_string.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /* doc_string.h - base class for self-documented types
  2. * Copyright (C) 2017 caryoscelus
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation, either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. #ifndef CORE_NODE_DOC_STRING_H_8C65081C_80FB_530C_8E03_3E23E09291D2
  18. #define CORE_NODE_DOC_STRING_H_8C65081C_80FB_530C_8E03_3E23E09291D2
  19. #include <core/std/map.h>
  20. #include <core/std/string.h>
  21. namespace rainynite::core {
  22. class DocString {
  23. public:
  24. virtual string doc_string() const {
  25. return "Undocumented";
  26. }
  27. virtual map<string,string> doc_substrings() const {
  28. return {};
  29. }
  30. string doc_substring(string const& sub) const {
  31. auto mp = doc_substrings();
  32. auto it = mp.find(sub);
  33. if (it != mp.end())
  34. return it->second;
  35. return "Undocumented";
  36. }
  37. };
  38. } // namespace rainynite::core
  39. #define DOC_STRING(s) \
  40. public: \
  41. string doc_string() const override { \
  42. return s; \
  43. }
  44. #endif