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

Improve conversion from scalars to native types #391

Merged
merged 13 commits into from
Sep 7, 2024

Conversation

fktn-k
Copy link
Owner

@fktn-k fktn-k commented Sep 7, 2024

In this PR, conversions from scalars to native data types (int or bool) have been reimplemented, which happens when each scalar token is found in an input buffer during the deserialization process.
The conversions required unnecessary std::string instance creations before, which causes a number of heap allocations even when the instanciations is just the same as duplication of some part of an input buffer.
Most of the unnecessary heap allocations have therefore been replaced with references using iterators with no changes in public APIs and behaviors from the viewpoint of library users.

One exception is that conversions from a scalar to a floating point value still requires unnecessary heap allocations by default.
If std::from_chars() (since C++17) is available, the library now call it and thus no heap allocation happens.
In the other cases, however, the library calls std::stof() or std::stod() depending on the destination type which require a std::string object for a null-terminated string.
Although using some third party libraries like fast_float or implementing a similar feature inside the library can resolve this issue, that either consts a lot or leads to other issues (licensing, dependency management, etc...).
So, I put aside the issue and moved the latest implementations (with some sophistication though).


Pull Request Checklist

Read the CONTRIBUTING.md file for detailed information.

  • Changes are described in the pull request or in a referenced issue.
  • The test suite compiles and runs without any error.
  • The code coverage on your branch is 100%.
  • The documentation is updated if you added/changed a feature.

Please don't

  • The C++11 support varies between different compilers and versions. Please note the list of supported compilers. Some compilers like GCC 4.7 (and earlier), Clang 3.3 (and earlier), or Microsoft Visual Studio 13.0 and earlier are known not to work due to missing or incomplete C++11 support. Please refrain from proposing changes that work around these compiler's limitations with #ifdefs or other means.
  • Please refrain from proposing changes that would break YAML specifications. If you propose a conformant extension of YAML to be supported by the library, please motivate this extension.
  • Please do not open pull requests that address multiple issues.

@fktn-k fktn-k added the improvement refactoring or optimization without public API changes label Sep 7, 2024
@fktn-k fktn-k added this to the Release v0.3.12 milestone Sep 7, 2024
@fktn-k fktn-k self-assigned this Sep 7, 2024
Copy link

github-actions bot commented Sep 7, 2024

:octocat: Upload Coverage Event Notification

Coverage data has been uploaded for the commit 4ee880433e3895d1af26b869524c8efb8b87bf28.
You can download the artifact which contains the same file uploaded to the Coveralls and its HTML version.

Name fkYAML_coverage.pr391.zip
ID 1904914203
URL https://github.com/fktn-k/fkYAML/actions/runs/10754045231/artifacts/1904914203

@fktn-k fktn-k force-pushed the improve_conversion_from_scalar_to_native_types branch 2 times, most recently from c58f4b1 to bc730ac Compare September 7, 2024 13:39
@fktn-k fktn-k force-pushed the improve_conversion_from_scalar_to_native_types branch 6 times, most recently from b6a703d to de93370 Compare September 7, 2024 19:43
@fktn-k fktn-k force-pushed the improve_conversion_from_scalar_to_native_types branch from de93370 to 4ee8804 Compare September 7, 2024 19:59
@fktn-k fktn-k merged commit a929fc3 into develop Sep 7, 2024
165 checks passed
@fktn-k fktn-k deleted the improve_conversion_from_scalar_to_native_types branch September 7, 2024 20:18
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
improvement refactoring or optimization without public API changes
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant