Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

std::format() and std::print() support? #334

Closed
ScottBailey opened this issue Feb 1, 2024 · 2 comments
Closed

std::format() and std::print() support? #334

ScottBailey opened this issue Feb 1, 2024 · 2 comments
Labels
help wanted Extra attention is needed
Milestone

Comments

@ScottBailey
Copy link

I'm not sure if this is misuse by me or a defect.

Using clang-18 and libc++-18:
I cannot get the following to work...

#include <magic_enum.hpp>                                                                                                                        
#include <magic_enum_format.hpp>                                                                                                                 
                                                                                                                                                 
enum class my_enum {a, b, c}; 

int main(int,char**)                                                                                                                             
{                                                                                                                                                
  std::println("Enabled? {}", magic_enum::customize::enum_format_enabled<my_enum>());                                                            
  const std::string a = std::format("a? {}",my_enum::a);                                                                                         
  std::println("ab: {} {}", a, my_enum::b);                                                                                                      
  return 0;                                                                                                                                      
}                                                                                                                                                

...without force defining _cpp_lib_format...

#if !defined(__cpp_lib_format)                                                                                                                   
# define __cpp_lib_format 1                                                                                                                      
#endif 

...and adding a template line to this code to make it:

struct std::formatter<E, std::enable_if_t<std::is_enum_v<std::decay_t<E>> && magic_enum::customize::enum_format_enabled<E>(), char>> : std::formatter<std::string_view, char> {
  template<typename format_context>         // ADDED
  auto format(E e, format_context& ctx) const {

Any insight would be appreciated. Thank you!

@Neargye Neargye added this to the v0.9.6 milestone Feb 1, 2024
@Neargye Neargye modified the milestones: v0.9.6, v0.9.7 Jun 29, 2024
@Neargye
Copy link
Owner

Neargye commented Jun 29, 2024

Quite strange, if compiler support <format> then __cpp_lib_format if defined, see https://en.cppreference.com/w/cpp/utility/feature_test

@Neargye Neargye added the help wanted Extra attention is needed label Jun 29, 2024
@Neargye
Copy link
Owner

Neargye commented Jul 9, 2024

Looks like fixed in #365

@Neargye Neargye closed this as completed Jul 9, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants