-
-
Notifications
You must be signed in to change notification settings - Fork 6.8k
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
no member named 'thousands_sep' in 'lconv' #631
Comments
Looks like with most things involving the NDK, this symbol ( Starting with NDK 14, a central "sysroot" is available that may solve this issue but that's still not ready for prime time. |
The problem seems that this specific version has no proper locale header, but only a stub. It seems others have had this problem as well. This patch or this patch seem to be solutions. I see what I can do about this. |
Do you plan on implementing a workaround soon? I will not be able to integrate your library into our work code base until this is addressed. Happy to wait and test any solution for you. Just let me know. |
No, I'm sorry this has no priority right now. You may replace function /// return the locale-dependent decimal point
static char get_decimal_point() noexcept
{
const auto loc = localeconv();
assert(loc != nullptr);
return (loc->decimal_point == nullptr) ? '.' : loc->decimal_point[0];
} with /// return the locale-dependent decimal point
static char get_decimal_point() noexcept
{
return '.';
} to avoid using the broken |
How will that one fix the |
Oh, sorry, wrong function. Change serializer(output_adapter_t<char> s, const char ichar)
: o(s), loc(std::localeconv()),
thousands_sep(!loc->thousands_sep ? '\0' : loc->thousands_sep[0]),
decimal_point(!loc->decimal_point ? '\0' : loc->decimal_point[0]),
indent_char(ichar), indent_string(512, indent_char)
{} to serializer(output_adapter_t<char> s, const char ichar)
: o(s), loc(std::localeconv()),
thousands_sep('\0'),
decimal_point('\0'),
indent_char(ichar), indent_string(512, indent_char)
{} |
This is in the |
Please let me know if you can compile the code with this fix. If you execute the test suite, some locale-specific tests should fail, but apart from this, I wonder if the library works. |
I wonder if a better solution here would be for me to implement my own locale, because you're not really doing anything wrong. It's Android's NDK that's busted. |
That's sort of what the patches that @nlohmann referenced in his first comment above do. They add a wrapper that returns the data if it's there, and dummy data otherwise. The most recent solution would be one that you'd have to apply on your end, but I assume those patches could be applied here as a PR if you test them out in your own fork first. I can't speak for @nlohmann, I'm just a user. |
I think it would be best if the users of a broken NDK would provide a proper locale implementation and I could leave my library unchanged. |
That would be nice, but I'm not sure if it's possible to replace the locale implementation without changes to the library as in those patches that you referenced, leaving local patching of the library or not supporting broken NDKs. It wouldn't be the first time there were NDKs that this didn't support. |
I've never replaced system locale before (and it looks like this is done via C API and not normal STL locale). I'd assume I could just provide a different (but interface-same) implementation of that struct. |
The problem is that the interface of that struct is empty. It's a compile-time failure, not a runtime failure, so you'd have to replace the definition of the struct in the NDK. |
That's a shame. Then maybe, one of the linked patches could help. I currently think, the first one could used with a static_if could be the change with the fewest changes (PRs welcome!) In any case, I would be happy to know whether the quick fix above makes the library compile. |
At the moment I'm using the single header from the latest tagged release. If I use develop, do you guys have the single header already updated at the tip? |
|
Looks like your 2 changes are working just fine. Since I cannot simply implement my own locale as mentioned before, it seems that some changes will be required to your json library to support Android NDK prior to API 21. What would be the best way to do this? Maybe a preprocessor switch: I'm happy to contribute a patch, so just let me know design-wise how you'd like to approach this problem. |
Yep,I have stumbled into this one as well.The problem is that Android SDK 19 has very large user segment.Therefore this issue is quite critical.Thanks. |
The above patch doesn't help because there is also this line: const auto loc = localeconv();
assert(loc != nullptr);
const char decimal_point_char = (loc->decimal_point == nullptr) ? '.' : loc->decimal_point[0]; |
Can I safely change it to this: const char decimal_point_char = "." ? |
Yes |
Yeah,that helps,thanks! Any plan to put this patch into official release? |
No, because this patch removes a feature (locale-independence). We need to find a way to properly detect the broken STL of that NDK. |
I have problems reproducing the issue, see #638 (comment). Help is greatly appreciated! |
Does the fix for #638 work here? |
Yes it does |
… lconv not being available on some versions of the Android SDK.
Apply Nlohmann's fix in nlohmann/json#631 to address localeconv() and lconv not being available on some versions of the Android SDK.
Getting this error using NDK r14b with
armeabi-v7a
architecture, API 15, and clang + shared gnu STL. Works fine on MSVC 14 though. How can we get Android working?The text was updated successfully, but these errors were encountered: