# enum.hpp [![travis][badge.travis]][travis] [![appveyor][badge.appveyor]][appveyor] [![codecov][badge.codecov]][codecov] [![language][badge.language]][language] [![license][badge.license]][license] [![paypal][badge.paypal]][paypal] [badge.travis]: https://img.shields.io/travis/BlackMATov/enum.hpp/master.svg?logo=travis [badge.appveyor]: https://img.shields.io/appveyor/ci/BlackMATov/enum-hpp/master.svg?logo=appveyor [badge.codecov]: https://img.shields.io/codecov/c/github/BlackMATov/enum.hpp/master.svg?logo=codecov [badge.language]: https://img.shields.io/badge/language-C%2B%2B17-yellow.svg [badge.license]: https://img.shields.io/badge/license-MIT-blue.svg [badge.paypal]: https://img.shields.io/badge/donate-PayPal-orange.svg?logo=paypal&colorA=00457C [travis]: https://travis-ci.org/BlackMATov/enum.hpp [appveyor]: https://ci.appveyor.com/project/BlackMATov/enum-hpp [codecov]: https://codecov.io/gh/BlackMATov/enum.hpp [language]: https://en.wikipedia.org/wiki/C%2B%2B17 [license]: https://en.wikipedia.org/wiki/MIT_License [paypal]: https://www.paypal.me/matov [enum]: https://github.com/BlackMATov/enum.hpp ## Installation [enum.hpp][enum] is a header-only library. All you need to do is copy the headers files from `headers` directory into your project and include them: ```cpp #include "enum.hpp/enum.hpp" ``` Also, you can add the root repository directory to your [cmake](https://cmake.org) project: ```cmake add_subdirectory(external/enum.hpp) target_link_libraries(your_project_target enum.hpp) ``` ## Examples ### Declarations ```cpp ENUM_HPP_DECL(debug_level, int, (level_info) (level_warning) (level_error)) // equivalent to: enum debug_level : int { level_info, level_warning, level_error, }; struct debug_level_traits { static constexpr std::size_t size = 3; static constexpr const debug_level values[] = { level_info, level_warning, level_warning }; static constexpr const std::string_view names[] = { "level_info", "level_warning", "level_warning" }; static constexpr std::string_view to_string( debug_level e) noexcept; static debug_level from_string( std::string_view name); static constexpr bool from_string_nothrow( std::string_view name, debug_level& result) noexcept; }; ``` ```cpp ENUM_HPP_CLASS_DECL(color, unsigned, (red = 1 << 0) (green = 1 << 1) (blue = 1 << 2) (white = red | green | blue)) // equivalent to: enum class color : unsigned { red = 1 << 0, green = 1 << 1, blue = 1 << 2, white = red | green | blue, }; struct color_traits { static constexpr std::size_t size = 4; static constexpr const color values[] = { color::red, color::green, color::blue, color::white }; static constexpr const std::string_view names[] = { "red", "green", "blue", "white" }; static constexpr std::string_view to_string( color e) noexcept; static color from_string( std::string_view name); static constexpr bool from_string_nothrow( std::string_view name, color& result) noexcept; }; ``` ### Traits using ```cpp ENUM_HPP_CLASS_DECL(color, unsigned, red, green, blue) // size color_traits::size; // 3 // to_string color_traits::to_string(color::red); // returns "red"; color_traits::to_string(color(42)); // returns ""; // from_string color_traits::from_string("green"); // returns color::green; color_traits::from_string("error"); // throws enum_hpp::exception // from_string_nothrow color result; bool success = color_traits::from_string_nothrow("blue", result); // success == true, result == color::blue // names for ( auto n : color_traits::names ) { std::cout << n << ","; } // prints red,green,blue ``` ## Alternatives [Better Enums](https://github.com/aantron/better-enums) - Low variadic macros limit (64) - Replaces C++ enum semantics to custom class [wise_enum](https://github.com/quicknir/wise_enum) - Limited by variadic macros ([msvs: 127](https://docs.microsoft.com/en-us/cpp/cpp/compiler-limits?view=vs-2019)) [Magic Enum](https://github.com/Neargye/magic_enum) - Amazing but requires at least GCC 9.0 ## [License (MIT)](./LICENSE.md)