From b5420626150ed41e4a445ae399d98bb8ab4d5589 Mon Sep 17 00:00:00 2001 From: themuffinator Date: Sat, 14 Sep 2024 22:06:51 +0100 Subject: [PATCH] Initial commit --- .gitignore | 407 + LICENSE | 674 + README.md | 4 + src/bg_local.h | 265 + src/bots/bot_debug.cpp | 177 + src/bots/bot_debug.h | 6 + src/bots/bot_exports.cpp | 188 + src/bots/bot_exports.h | 11 + src/bots/bot_includes.h | 9 + src/bots/bot_think.cpp | 23 + src/bots/bot_think.h | 7 + src/bots/bot_utils.cpp | 529 + src/bots/bot_utils.h | 10 + src/cg_local.h | 14 + src/cg_main.cpp | 112 + src/cg_screen.cpp | 1710 ++ src/fmt.cc | 110 + src/fmt/args.h | 234 + src/fmt/chrono.h | 2208 ++ src/fmt/color.h | 632 + src/fmt/compile.h | 534 + src/fmt/core.h | 2922 +++ src/fmt/format-inl.h | 1662 ++ src/fmt/format.h | 4510 ++++ src/fmt/os.h | 451 + src/fmt/ostream.h | 209 + src/fmt/printf.h | 667 + src/fmt/ranges.h | 735 + src/fmt/std.h | 465 + src/fmt/xchar.h | 258 + src/format.cc | 43 + src/freeze.c | 829 + src/freeze.h | 39 + src/g_ai.cpp | 1540 ++ src/g_ai_new.cpp | 1422 ++ src/g_chase.cpp | 465 + src/g_cmds.cpp | 3562 +++ src/g_combat.cpp | 1042 + src/g_ctf.cpp | 540 + src/g_func.cpp | 3651 +++ src/g_items.cpp | 6262 +++++ src/g_local.h | 4153 ++++ src/g_main.cpp | 3615 +++ src/g_menu.cpp | 1315 + src/g_misc.cpp | 2607 ++ src/g_monster.cpp | 1691 ++ src/g_monster_spawn.cpp | 363 + src/g_phys.cpp | 1054 + src/g_save.cpp | 2407 ++ src/g_spawn.cpp | 2432 ++ src/g_statusbar.h | 64 + src/g_svcmds.cpp | 279 + src/g_target.cpp | 2716 +++ src/g_trigger.cpp | 1563 ++ src/g_turret.cpp | 603 + src/g_utils.cpp | 1045 + src/g_weapon.cpp | 3238 +++ src/game.h | 2241 ++ src/game.sln | 25 + src/game.vcxproj | 230 + src/game.vcxproj.filters | 286 + src/json/allocator.h | 88 + src/json/assertions.h | 61 + src/json/config.h | 150 + src/json/forwards.h | 43 + src/json/json.h | 15 + src/json/json_features.h | 61 + src/json/reader.h | 405 + src/json/value.h | 935 + src/json/version.h | 28 + src/json/writer.h | 369 + src/monsters/m_actor.cpp | 516 + src/monsters/m_actor.h | 492 + src/monsters/m_arachnid.cpp | 368 + src/monsters/m_arachnid.h | 142 + src/monsters/m_berserk.cpp | 756 + src/monsters/m_berserk.h | 264 + src/monsters/m_boss2.cpp | 653 + src/monsters/m_boss2.h | 192 + src/monsters/m_boss3.cpp | 58 + src/monsters/m_boss31.cpp | 584 + src/monsters/m_boss31.h | 199 + src/monsters/m_boss32.cpp | 761 + src/monsters/m_boss32.h | 502 + src/monsters/m_brain.cpp | 738 + src/monsters/m_brain.h | 233 + src/monsters/m_carrier.cpp | 1048 + src/monsters/m_carrier.h | 88 + src/monsters/m_chick.cpp | 780 + src/monsters/m_chick.h | 299 + src/monsters/m_fixbot.cpp | 1206 + src/monsters/m_fixbot.h | 223 + src/monsters/m_flash.h | 614 + src/monsters/m_flipper.cpp | 368 + src/monsters/m_flipper.h | 171 + src/monsters/m_float.cpp | 660 + src/monsters/m_float.h | 259 + src/monsters/m_flyer.cpp | 670 + src/monsters/m_flyer.h | 161 + src/monsters/m_gekk.cpp | 1490 ++ src/monsters/m_gekk.h | 361 + src/monsters/m_gladiator.cpp | 444 + src/monsters/m_gladiator.h | 101 + src/monsters/m_guardian.cpp | 503 + src/monsters/m_guardian.h | 225 + src/monsters/m_guncmdr.cpp | 1371 ++ src/monsters/m_gunner.cpp | 847 + src/monsters/m_gunner.h | 809 + src/monsters/m_hover.cpp | 587 + src/monsters/m_hover.h | 216 + src/monsters/m_infantry.cpp | 864 + src/monsters/m_infantry.h | 278 + src/monsters/m_insane.cpp | 644 + src/monsters/m_insane.h | 293 + src/monsters/m_medic.cpp | 1472 ++ src/monsters/m_medic.h | 248 + src/monsters/m_move.cpp | 1326 + src/monsters/m_mutant.cpp | 693 + src/monsters/m_mutant.h | 165 + src/monsters/m_parasite.cpp | 860 + src/monsters/m_parasite.h | 137 + src/monsters/m_player.h | 208 + src/monsters/m_rider.h | 71 + src/monsters/m_shambler.cpp | 539 + src/monsters/m_shambler.h | 106 + src/monsters/m_soldier.cpp | 1875 ++ src/monsters/m_soldier.h | 585 + src/monsters/m_stalker.cpp | 957 + src/monsters/m_stalker.h | 104 + src/monsters/m_supertank.cpp | 631 + src/monsters/m_supertank.h | 265 + src/monsters/m_tank.cpp | 1043 + src/monsters/m_tank.h | 305 + src/monsters/m_turret.cpp | 953 + src/monsters/m_turret.h | 27 + src/monsters/m_widow.cpp | 1164 + src/monsters/m_widow.h | 180 + src/monsters/m_widow2.cpp | 1418 ++ src/monsters/m_widow2.h | 137 + src/os.cc | 398 + src/p_client.cpp | 4548 ++++ src/p_hud.cpp | 1935 ++ src/p_menu.cpp | 277 + src/p_menu.h | 39 + src/p_move.cpp | 1551 ++ src/p_trail.cpp | 140 + src/p_view.cpp | 1465 ++ src/p_weapon.cpp | 2797 +++ src/q_std.cpp | 287 + src/q_std.h | 217 + src/q_vec3.h | 549 + src/vcpkg.json | 10 + .../x64-windows-rel/CMakeCache.txt | 474 + .../3.27.2-msvc1/CMakeCCompiler.cmake | 74 + .../3.27.2-msvc1/CMakeCXXCompiler.cmake | 85 + .../3.27.2-msvc1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake | 15 + .../CompilerIdC/CMakeCCompilerId.c | 866 + .../CompilerIdC/CMakeCCompilerId.exe | Bin 0 -> 115200 bytes .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 88 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 2 + .../CMakeFiles/cmake.check_cache | 1 + .../x64-windows-rel/CMakeFiles/rules.ninja | 51 + .../x64-windows-rel/build.ninja | 111 + .../x64-windows-rel/cmake_install.cmake | 44 + .../vcpkg-parallel-configure/.ninja_log | 2 + .../vcpkg-parallel-configure/build.ninja | 6 + .../2b3b374f0b-8ea71ee8ea.clean/.clang-format | 8 + .../.github/workflows/windows.yml | 44 + .../2b3b374f0b-8ea71ee8ea.clean/.gitignore | 36 + .../2b3b374f0b-8ea71ee8ea.clean/.travis.yml | 101 + .../CMakeLists.txt | 361 + .../CONTRIBUTING.md | 20 + .../2b3b374f0b-8ea71ee8ea.clean/ChangeLog.rst | 3665 +++ .../2b3b374f0b-8ea71ee8ea.clean/LICENSE.rst | 27 + .../2b3b374f0b-8ea71ee8ea.clean/README.rst | 506 + .../doc/CMakeLists.txt | 17 + .../doc/_static/bootstrap.min.js | 7 + .../doc/_static/breathe.css | 28 + .../fonts/glyphicons-halflings-regular.eot | Bin 0 -> 20335 bytes .../fonts/glyphicons-halflings-regular.svg | 229 + .../fonts/glyphicons-halflings-regular.ttf | Bin 0 -> 41280 bytes .../fonts/glyphicons-halflings-regular.woff | Bin 0 -> 23320 bytes .../doc/_templates/layout.html | 148 + .../doc/_templates/search.html | 55 + .../2b3b374f0b-8ea71ee8ea.clean/doc/api.rst | 505 + .../doc/basic-bootstrap/README | 2 + .../doc/basic-bootstrap/layout.html | 206 + .../doc/basic-bootstrap/theme.conf | 2 + .../doc/bootstrap/alerts.less | 73 + .../doc/bootstrap/badges.less | 66 + .../doc/bootstrap/bootstrap.less | 50 + .../doc/bootstrap/breadcrumbs.less | 26 + .../doc/bootstrap/button-groups.less | 243 + .../doc/bootstrap/buttons.less | 160 + .../doc/bootstrap/carousel.less | 269 + .../doc/bootstrap/close.less | 34 + .../doc/bootstrap/code.less | 69 + .../doc/bootstrap/component-animations.less | 33 + .../doc/bootstrap/dropdowns.less | 214 + .../doc/bootstrap/forms.less | 574 + .../doc/bootstrap/glyphicons.less | 305 + .../doc/bootstrap/grid.less | 84 + .../doc/bootstrap/input-groups.less | 166 + .../doc/bootstrap/jumbotron.less | 50 + .../doc/bootstrap/labels.less | 64 + .../doc/bootstrap/list-group.less | 124 + .../doc/bootstrap/media.less | 61 + .../doc/bootstrap/mixins.less | 39 + .../doc/bootstrap/mixins/alerts.less | 14 + .../bootstrap/mixins/background-variant.less | 8 + .../doc/bootstrap/mixins/border-radius.less | 18 + .../doc/bootstrap/mixins/buttons.less | 52 + .../doc/bootstrap/mixins/center-block.less | 7 + .../doc/bootstrap/mixins/clearfix.less | 22 + .../doc/bootstrap/mixins/forms.less | 85 + .../doc/bootstrap/mixins/gradients.less | 59 + .../doc/bootstrap/mixins/grid-framework.less | 91 + .../doc/bootstrap/mixins/grid.less | 122 + .../doc/bootstrap/mixins/hide-text.less | 21 + .../doc/bootstrap/mixins/image.less | 33 + .../doc/bootstrap/mixins/labels.less | 12 + .../doc/bootstrap/mixins/list-group.less | 29 + .../doc/bootstrap/mixins/nav-divider.less | 10 + .../bootstrap/mixins/nav-vertical-align.less | 9 + .../doc/bootstrap/mixins/opacity.less | 8 + .../doc/bootstrap/mixins/pagination.less | 23 + .../doc/bootstrap/mixins/panels.less | 24 + .../doc/bootstrap/mixins/progress-bar.less | 10 + .../doc/bootstrap/mixins/reset-filter.less | 8 + .../doc/bootstrap/mixins/resize.less | 6 + .../mixins/responsive-visibility.less | 15 + .../doc/bootstrap/mixins/size.less | 10 + .../doc/bootstrap/mixins/tab-focus.less | 9 + .../doc/bootstrap/mixins/table-row.less | 28 + .../doc/bootstrap/mixins/text-emphasis.less | 8 + .../doc/bootstrap/mixins/text-overflow.less | 8 + .../doc/bootstrap/mixins/vendor-prefixes.less | 227 + .../doc/bootstrap/modals.less | 150 + .../doc/bootstrap/navbar.less | 660 + .../doc/bootstrap/navs.less | 242 + .../doc/bootstrap/normalize.less | 427 + .../doc/bootstrap/pager.less | 54 + .../doc/bootstrap/pagination.less | 88 + .../doc/bootstrap/panels.less | 265 + .../doc/bootstrap/popovers.less | 135 + .../doc/bootstrap/print.less | 107 + .../doc/bootstrap/progress-bars.less | 87 + .../doc/bootstrap/responsive-embed.less | 35 + .../doc/bootstrap/responsive-utilities.less | 194 + .../doc/bootstrap/scaffolding.less | 162 + .../doc/bootstrap/tables.less | 234 + .../doc/bootstrap/theme.less | 273 + .../doc/bootstrap/thumbnails.less | 36 + .../doc/bootstrap/tooltip.less | 102 + .../doc/bootstrap/type.less | 302 + .../doc/bootstrap/utilities.less | 55 + .../doc/bootstrap/variables.less | 861 + .../doc/bootstrap/wells.less | 29 + .../2b3b374f0b-8ea71ee8ea.clean/doc/build.py | 114 + .../2b3b374f0b-8ea71ee8ea.clean/doc/conf.py | 256 + .../doc/contents.rst | 10 + .../2b3b374f0b-8ea71ee8ea.clean/doc/fmt.less | 66 + .../2b3b374f0b-8ea71ee8ea.clean/doc/index.rst | 200 + .../doc/python-license.txt | 290 + .../doc/syntax.rst | 438 + .../2b3b374f0b-8ea71ee8ea.clean/doc/usage.rst | 212 + .../include/fmt/chrono.h | 1118 + .../include/fmt/color.h | 603 + .../include/fmt/compile.h | 701 + .../include/fmt/core.h | 2122 ++ .../include/fmt/format-inl.h | 2801 +++ .../include/fmt/format.h | 3961 +++ .../include/fmt/locale.h | 64 + .../include/fmt/os.h | 480 + .../include/fmt/ostream.h | 177 + .../include/fmt/posix.h | 2 + .../include/fmt/printf.h | 751 + .../include/fmt/ranges.h | 396 + .../pull_request_template.md | 6 + .../2b3b374f0b-8ea71ee8ea.clean/src/format.cc | 99 + .../src/2b3b374f0b-8ea71ee8ea.clean/src/os.cc | 322 + .../support/Android.mk | 15 + .../support/AndroidManifest.xml | 1 + .../support/C++.sublime-syntax | 2061 ++ .../support/README | 4 + .../support/Vagrantfile | 20 + .../support/appveyor-build.py | 43 + .../support/appveyor.yml | 41 + .../support/build.gradle | 107 + .../support/cmake/FindSetEnv.cmake | 7 + .../support/cmake/JoinPaths.cmake | 26 + .../support/cmake/cxx14.cmake | 70 + .../support/cmake/fmt-config.cmake.in | 4 + .../support/cmake/fmt.pc.in | 11 + .../support/compute-powers.py | 53 + .../support/docopt.py | 581 + .../support/manage.py | 290 + .../support/rst2md.py | 159 + .../support/rtd/conf.py | 7 + .../support/rtd/index.rst | 2 + .../support/rtd/theme/layout.html | 17 + .../support/rtd/theme/theme.conf | 2 + .../support/travis-build.py | 119 + .../test/CMakeLists.txt | 244 + .../test/add-subdirectory-test/CMakeLists.txt | 17 + .../test/add-subdirectory-test/main.cc | 6 + .../test/assert-test.cc | 32 + .../test/chrono-test.cc | 398 + .../test/color-test.cc | 99 + .../test/compile-error-test/CMakeLists.txt | 79 + .../test/compile-test.cc | 173 + .../test/core-test.cc | 773 + .../test/cuda-test/CMakeLists.txt | 73 + .../test/cuda-test/cpp14.cc | 11 + .../test/cuda-test/cuda-cpp14.cu | 28 + .../test/find-package-test/CMakeLists.txt | 17 + .../test/find-package-test/main.cc | 6 + .../2b3b374f0b-8ea71ee8ea.clean/test/format | 855 + .../test/format-impl-test.cc | 446 + .../test/format-test.cc | 2495 ++ .../test/fuzzing/.gitignore | 3 + .../test/fuzzing/CMakeLists.txt | 30 + .../test/fuzzing/README.md | 25 + .../test/fuzzing/build.sh | 88 + .../test/fuzzing/chrono-duration.cc | 135 + .../test/fuzzing/float.cc | 34 + .../test/fuzzing/fuzzer-common.h | 75 + .../test/fuzzing/main.cc | 22 + .../test/fuzzing/named-arg.cc | 100 + .../test/fuzzing/one-arg.cc | 91 + .../test/fuzzing/two-args.cc | 105 + .../test/gmock-gtest-all.cc | 11244 +++++++++ .../test/gmock/gmock.h | 14204 +++++++++++ .../test/gtest-extra-test.cc | 439 + .../test/gtest-extra.cc | 87 + .../test/gtest-extra.h | 162 + .../test/gtest/gtest-spi.h | 232 + .../test/gtest/gtest.h | 20065 ++++++++++++++++ .../test/header-only-test.cc | 3 + .../test/header-only-test2.cc | 3 + .../test/locale-test.cc | 160 + .../test/mock-allocator.h | 60 + .../test/os-test.cc | 532 + .../test/ostream-test.cc | 330 + .../test/posix-mock-test.cc | 558 + .../test/posix-mock.h | 77 + .../test/printf-test.cc | 628 + .../test/ranges-test.cc | 203 + .../test/scan-test.cc | 116 + .../2b3b374f0b-8ea71ee8ea.clean/test/scan.h | 238 + .../test/std-format-test.cc | 157 + .../test/test-assert.h | 32 + .../test/test-main.cc | 43 + .../2b3b374f0b-8ea71ee8ea.clean/test/util.cc | 50 + .../2b3b374f0b-8ea71ee8ea.clean/test/util.h | 84 + .../blds/fmt/x64-windows-dbg/.ninja_deps | Bin 0 -> 12692 bytes .../vcpkg/blds/fmt/x64-windows-dbg/.ninja_log | 6 + .../blds/fmt/x64-windows-dbg/CMakeCache.txt | 621 + .../3.27.2-msvc1/CMakeCXXCompiler.cmake | 85 + .../CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 52736 bytes .../3.27.2-msvc1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 263 + .../fmt-targets-debug.cmake | 19 + .../fmt-targets.cmake | 116 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 8 + .../CMakeFiles/cmake.check_cache | 1 + .../CMakeFiles/fmt.dir/embed.manifest | 10 + .../CMakeFiles/fmt.dir/intermediate.manifest | 10 + .../CMakeFiles/fmt.dir/manifest.rc | 2 + .../CMakeFiles/fmt.dir/manifest.res | Bin 0 -> 472 bytes .../x64-windows-dbg/CMakeFiles/rules.ninja | 69 + .../fmt/x64-windows-dbg/CPackConfig.cmake | 70 + .../x64-windows-dbg/CPackSourceConfig.cmake | 76 + .../blds/fmt/x64-windows-dbg/build.ninja | 217 + .../fmt/x64-windows-dbg/cmake_install.cmake | 110 + .../x64-windows-dbg/fmt-config-version.cmake | 43 + .../blds/fmt/x64-windows-dbg/fmt-config.cmake | 28 + .../fmt/x64-windows-dbg/fmt-targets.cmake | 83 + .../vcpkg/blds/fmt/x64-windows-dbg/fmt.pc | 11 + .../fmt/x64-windows-dbg/install_manifest.txt | 19 + .../blds/fmt/x64-windows-rel/.ninja_deps | Bin 0 -> 12692 bytes .../vcpkg/blds/fmt/x64-windows-rel/.ninja_log | 6 + .../blds/fmt/x64-windows-rel/CMakeCache.txt | 621 + .../3.27.2-msvc1/CMakeCXXCompiler.cmake | 85 + .../CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 52736 bytes .../3.27.2-msvc1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 263 + .../fmt-targets-release.cmake | 19 + .../fmt-targets.cmake | 116 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 8 + .../CMakeFiles/cmake.check_cache | 1 + .../x64-windows-rel/CMakeFiles/rules.ninja | 69 + .../fmt/x64-windows-rel/CPackConfig.cmake | 70 + .../x64-windows-rel/CPackSourceConfig.cmake | 76 + .../blds/fmt/x64-windows-rel/build.ninja | 217 + .../fmt/x64-windows-rel/cmake_install.cmake | 110 + .../x64-windows-rel/fmt-config-version.cmake | 43 + .../blds/fmt/x64-windows-rel/fmt-config.cmake | 28 + .../fmt/x64-windows-rel/fmt-targets.cmake | 83 + .../vcpkg/blds/fmt/x64-windows-rel/fmt.pc | 11 + .../fmt/x64-windows-rel/install_manifest.txt | 19 + .../vcpkg-parallel-configure/.ninja_log | 3 + .../vcpkg-parallel-configure/build.ninja | 9 + .../blds/fmt/x64-windows.vcpkg_abi_info.txt | 18 + .../3918c327b1-034a82149a.clean/.clang-format | 4 + .../3918c327b1-034a82149a.clean/.clang-tidy | 11 + .../.gitattributes | 11 + .../.github/ISSUE_TEMPLATE/bug_report.md | 26 + .../.github/ISSUE_TEMPLATE/feature_request.md | 20 + .../3918c327b1-034a82149a.clean/.gitignore | 52 + .../3918c327b1-034a82149a.clean/.travis.yml | 71 + .../.travis_scripts/cmake_builder.sh | 130 + .../.travis_scripts/meson_builder.sh | 83 + .../.travis_scripts/run-clang-format.py | 356 + .../.travis_scripts/run-clang-format.sh | 4 + .../travis.before_install.linux.sh | 8 + .../travis.before_install.osx.sh | 1 + .../.travis_scripts/travis.install.linux.sh | 10 + .../.travis_scripts/travis.install.osx.sh | 1 + .../src/3918c327b1-034a82149a.clean/AUTHORS | 115 + .../CMakeLists.txt | 192 + .../CONTRIBUTING.md | 149 + .../CTestConfig.cmake | 15 + .../src/3918c327b1-034a82149a.clean/LICENSE | 55 + .../src/3918c327b1-034a82149a.clean/README.md | 67 + .../3918c327b1-034a82149a.clean/amalgamate.py | 161 + .../3918c327b1-034a82149a.clean/appveyor.yml | 32 + .../cmake/JoinPaths.cmake | 23 + .../3918c327b1-034a82149a.clean/dev.makefile | 35 + .../devtools/__init__.py | 6 + .../devtools/agent_vmw7.json | 33 + .../devtools/agent_vmxp.json | 26 + .../devtools/antglob.py | 205 + .../devtools/batchbuild.py | 278 + .../devtools/fixeol.py | 70 + .../devtools/licenseupdater.py | 94 + .../devtools/tarball.py | 52 + .../doc/doxyfile.in | 2302 ++ .../doc/footer.html | 21 + .../doc/header.html | 64 + .../doc/jsoncpp.dox | 164 + .../doc/readme.txt | 1 + .../doc/roadmap.dox | 3 + .../doc/web_doxyfile.in | 2290 ++ .../3918c327b1-034a82149a.clean/doxybuild.py | 189 + .../example/CMakeLists.txt | 27 + .../example/README.md | 13 + .../example/readFromStream/errorFormat.json | 3 + .../example/readFromStream/readFromStream.cpp | 30 + .../example/readFromStream/withComment.json | 6 + .../example/readFromString/readFromString.cpp | 37 + .../example/streamWrite/streamWrite.cpp | 22 + .../example/stringWrite/stringWrite.cpp | 33 + .../include/CMakeLists.txt | 5 + .../include/json/allocator.h | 89 + .../include/json/assertions.h | 61 + .../include/json/config.h | 150 + .../include/json/forwards.h | 43 + .../include/json/json.h | 15 + .../include/json/json_features.h | 61 + .../include/json/reader.h | 403 + .../include/json/value.h | 935 + .../include/json/version.h | 28 + .../include/json/writer.h | 367 + .../3918c327b1-034a82149a.clean/meson.build | 119 + .../meson_options.txt | 5 + .../pkg-config/jsoncpp.pc.in | 11 + .../src/CMakeLists.txt | 5 + .../src/jsontestrunner/CMakeLists.txt | 51 + .../src/jsontestrunner/main.cpp | 342 + .../src/lib_json/CMakeLists.txt | 220 + .../src/lib_json/json_reader.cpp | 1993 ++ .../src/lib_json/json_tool.h | 134 + .../src/lib_json/json_value.cpp | 1634 ++ .../src/lib_json/json_valueiterator.inl | 156 + .../src/lib_json/json_writer.cpp | 1258 + .../src/test_lib_json/CMakeLists.txt | 39 + .../src/test_lib_json/fuzz.cpp | 54 + .../src/test_lib_json/fuzz.dict | 54 + .../src/test_lib_json/fuzz.h | 14 + .../src/test_lib_json/jsontest.cpp | 430 + .../src/test_lib_json/jsontest.h | 288 + .../src/test_lib_json/main.cpp | 3921 +++ .../test/cleantests.py | 16 + .../test/data/fail_invalid_quote.json | 1 + .../test/data/fail_test_array_01.json | 1 + .../test/data/fail_test_array_02.json | 1 + .../test/data/fail_test_object_01.json | 1 + .../test/data/fail_test_stack_limit.json | 1 + .../test/data/legacy_test_array_01.expected | 1 + .../test/data/legacy_test_array_01.json | 1 + .../test/data/legacy_test_array_02.expected | 2 + .../test/data/legacy_test_array_02.json | 1 + .../test/data/legacy_test_array_03.expected | 6 + .../test/data/legacy_test_array_03.json | 1 + .../test/data/legacy_test_array_04.expected | 5 + .../test/data/legacy_test_array_04.json | 1 + .../test/data/legacy_test_array_05.expected | 100 + .../test/data/legacy_test_array_05.json | 1 + .../test/data/legacy_test_array_06.expected | 5 + .../test/data/legacy_test_array_06.json | 4 + .../test/data/legacy_test_array_07.expected | 2122 ++ .../test/data/legacy_test_array_07.json | 2 + .../test/data/legacy_test_basic_01.expected | 1 + .../test/data/legacy_test_basic_01.json | 1 + .../test/data/legacy_test_basic_02.expected | 1 + .../test/data/legacy_test_basic_02.json | 1 + .../test/data/legacy_test_basic_03.expected | 3 + .../test/data/legacy_test_basic_03.json | 3 + .../test/data/legacy_test_basic_04.expected | 2 + .../test/data/legacy_test_basic_04.json | 2 + .../test/data/legacy_test_basic_05.expected | 2 + .../test/data/legacy_test_basic_05.json | 2 + .../test/data/legacy_test_basic_06.expected | 2 + .../test/data/legacy_test_basic_06.json | 2 + .../test/data/legacy_test_basic_07.expected | 2 + .../test/data/legacy_test_basic_07.json | 2 + .../test/data/legacy_test_basic_08.expected | 3 + .../test/data/legacy_test_basic_08.json | 3 + .../test/data/legacy_test_basic_09.expected | 4 + .../test/data/legacy_test_basic_09.json | 4 + .../test/data/legacy_test_comment_00.expected | 4 + .../test/data/legacy_test_comment_00.json | 5 + .../test/data/legacy_test_comment_01.expected | 10 + .../test/data/legacy_test_comment_01.json | 10 + .../test/data/legacy_test_comment_02.expected | 23 + .../test/data/legacy_test_comment_02.json | 26 + .../test/data/legacy_test_complex_01.expected | 20 + .../test/data/legacy_test_complex_01.json | 17 + .../test/data/legacy_test_integer_01.expected | 2 + .../test/data/legacy_test_integer_01.json | 2 + .../test/data/legacy_test_integer_02.expected | 2 + .../test/data/legacy_test_integer_02.json | 2 + .../test/data/legacy_test_integer_03.expected | 2 + .../test/data/legacy_test_integer_03.json | 2 + .../test/data/legacy_test_integer_04.expected | 3 + .../test/data/legacy_test_integer_04.json | 3 + .../test/data/legacy_test_integer_05.expected | 2 + .../test/data/legacy_test_integer_05.json | 2 + .../legacy_test_integer_06_64bits.expected | 1 + .../data/legacy_test_integer_06_64bits.json | 2 + .../legacy_test_integer_07_64bits.expected | 1 + .../data/legacy_test_integer_07_64bits.json | 2 + .../legacy_test_integer_08_64bits.expected | 1 + .../data/legacy_test_integer_08_64bits.json | 2 + .../test/data/legacy_test_large_01.expected | 2122 ++ .../test/data/legacy_test_large_01.json | 2 + .../test/data/legacy_test_object_01.expected | 1 + .../test/data/legacy_test_object_01.json | 1 + .../test/data/legacy_test_object_02.expected | 2 + .../test/data/legacy_test_object_02.json | 1 + .../test/data/legacy_test_object_03.expected | 4 + .../test/data/legacy_test_object_03.json | 5 + .../test/data/legacy_test_object_04.expected | 2 + .../test/data/legacy_test_object_04.json | 3 + .../legacy_test_preserve_comment_01.expected | 11 + .../data/legacy_test_preserve_comment_01.json | 14 + .../test/data/legacy_test_real_01.expected | 3 + .../test/data/legacy_test_real_01.json | 3 + .../test/data/legacy_test_real_02.expected | 3 + .../test/data/legacy_test_real_02.json | 3 + .../test/data/legacy_test_real_03.expected | 3 + .../test/data/legacy_test_real_03.json | 3 + .../test/data/legacy_test_real_04.expected | 3 + .../test/data/legacy_test_real_04.json | 3 + .../test/data/legacy_test_real_05.expected | 4 + .../test/data/legacy_test_real_05.json | 3 + .../test/data/legacy_test_real_06.expected | 4 + .../test/data/legacy_test_real_06.json | 3 + .../test/data/legacy_test_real_07.expected | 4 + .../test/data/legacy_test_real_07.json | 3 + .../test/data/legacy_test_real_08.expected | 4 + .../test/data/legacy_test_real_08.json | 4 + .../test/data/legacy_test_real_09.expected | 4 + .../test/data/legacy_test_real_09.json | 4 + .../test/data/legacy_test_real_10.expected | 4 + .../test/data/legacy_test_real_10.json | 4 + .../test/data/legacy_test_real_11.expected | 4 + .../test/data/legacy_test_real_11.json | 4 + .../test/data/legacy_test_real_12.expected | 2 + .../test/data/legacy_test_real_12.json | 2 + .../test/data/legacy_test_string_01.expected | 1 + .../test/data/legacy_test_string_01.json | 1 + .../test/data/legacy_test_string_02.expected | 1 + .../test/data/legacy_test_string_02.json | 1 + .../test/data/legacy_test_string_03.expected | 1 + .../test/data/legacy_test_string_03.json | 1 + .../test/data/legacy_test_string_04.expected | 2 + .../test/data/legacy_test_string_04.json | 2 + .../test/data/legacy_test_string_05.expected | 2 + .../test/data/legacy_test_string_05.json | 2 + .../legacy_test_string_unicode_01.expected | 1 + .../data/legacy_test_string_unicode_01.json | 1 + .../legacy_test_string_unicode_02.expected | 1 + .../data/legacy_test_string_unicode_02.json | 1 + .../legacy_test_string_unicode_03.expected | 1 + .../data/legacy_test_string_unicode_03.json | 1 + .../legacy_test_string_unicode_04.expected | 1 + .../data/legacy_test_string_unicode_04.json | 1 + .../legacy_test_string_unicode_05.expected | 2 + .../data/legacy_test_string_unicode_05.json | 1 + .../test/data/test_array_08.expected | 2 + .../test/data/test_array_08.json | 1 + .../test/data/test_object_05.expected | 2 + .../test/data/test_object_05.json | 1 + .../test/generate_expected.py | 17 + .../test/jsonchecker/fail1.json | 1 + .../test/jsonchecker/fail10.json | 1 + .../test/jsonchecker/fail11.json | 1 + .../test/jsonchecker/fail12.json | 1 + .../test/jsonchecker/fail13.json | 1 + .../test/jsonchecker/fail14.json | 1 + .../test/jsonchecker/fail15.json | 1 + .../test/jsonchecker/fail16.json | 1 + .../test/jsonchecker/fail17.json | 1 + .../test/jsonchecker/fail18.json | 1 + .../test/jsonchecker/fail19.json | 1 + .../test/jsonchecker/fail2.json | 1 + .../test/jsonchecker/fail20.json | 1 + .../test/jsonchecker/fail21.json | 1 + .../test/jsonchecker/fail22.json | 1 + .../test/jsonchecker/fail23.json | 1 + .../test/jsonchecker/fail24.json | 1 + .../test/jsonchecker/fail25.json | 1 + .../test/jsonchecker/fail26.json | 1 + .../test/jsonchecker/fail27.json | 2 + .../test/jsonchecker/fail28.json | 2 + .../test/jsonchecker/fail29.json | 1 + .../test/jsonchecker/fail3.json | 1 + .../test/jsonchecker/fail30.json | 1 + .../test/jsonchecker/fail31.json | 1 + .../test/jsonchecker/fail32.json | 1 + .../test/jsonchecker/fail33.json | 1 + .../test/jsonchecker/fail4.json | 1 + .../test/jsonchecker/fail5.json | 1 + .../test/jsonchecker/fail6.json | 1 + .../test/jsonchecker/fail7.json | 1 + .../test/jsonchecker/fail8.json | 1 + .../test/jsonchecker/fail9.json | 1 + .../test/jsonchecker/pass1.json | 58 + .../test/jsonchecker/pass2.json | 1 + .../test/jsonchecker/pass3.json | 6 + .../test/jsonchecker/readme.txt | 3 + .../test/pyjsontestrunner.py | 71 + .../test/runjsontests.py | 191 + .../test/rununittests.py | 84 + .../3918c327b1-034a82149a.clean/version.in | 1 + .../blds/jsoncpp/x64-windows-dbg/.ninja_deps | Bin 0 -> 5804 bytes .../blds/jsoncpp/x64-windows-dbg/.ninja_log | 10 + .../jsoncpp/x64-windows-dbg/CMakeCache.txt | 599 + .../3.27.2-msvc1/CMakeCXXCompiler.cmake | 85 + .../CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 52736 bytes .../3.27.2-msvc1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 322 + .../CMakeFiles/CheckTypeSize/LCONV_SIZE.bin | Bin 0 -> 52224 bytes .../jsoncppConfig-debug.cmake | 29 + .../jsoncppConfig.cmake | 111 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 22 + .../CMakeFiles/cmake.check_cache | 1 + .../x64-windows-dbg/CMakeFiles/rules.ninja | 78 + .../blds/jsoncpp/x64-windows-dbg/build.ninja | 442 + .../x64-windows-dbg/cmake_install.cmake | 78 + .../include/cmake_install.cmake | 49 + .../x64-windows-dbg/install_manifest.txt | 18 + .../jsoncppConfigVersion.cmake | 65 + .../x64-windows-dbg/src/cmake_install.cmake | 40 + .../CMakeFiles/jsoncpp_lib.dir/embed.manifest | 10 + .../jsoncpp_lib.dir/intermediate.manifest | 10 + .../CMakeFiles/jsoncpp_lib.dir/manifest.rc | 2 + .../CMakeFiles/jsoncpp_lib.dir/manifest.res | Bin 0 -> 472 bytes .../src/lib_json/cmake_install.cmake | 50 + .../blds/jsoncpp/x64-windows-dbg/version | 1 + .../blds/jsoncpp/x64-windows-rel/.ninja_deps | Bin 0 -> 5804 bytes .../blds/jsoncpp/x64-windows-rel/.ninja_log | 10 + .../jsoncpp/x64-windows-rel/CMakeCache.txt | 599 + .../3.27.2-msvc1/CMakeCXXCompiler.cmake | 85 + .../CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 52736 bytes .../3.27.2-msvc1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 322 + .../CMakeFiles/CheckTypeSize/LCONV_SIZE.bin | Bin 0 -> 52224 bytes .../jsoncppConfig-release.cmake | 29 + .../jsoncppConfig.cmake | 111 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 22 + .../CMakeFiles/cmake.check_cache | 1 + .../x64-windows-rel/CMakeFiles/rules.ninja | 78 + .../blds/jsoncpp/x64-windows-rel/build.ninja | 442 + .../x64-windows-rel/cmake_install.cmake | 78 + .../include/cmake_install.cmake | 49 + .../x64-windows-rel/install_manifest.txt | 18 + .../jsoncppConfigVersion.cmake | 65 + .../x64-windows-rel/src/cmake_install.cmake | 40 + .../src/lib_json/cmake_install.cmake | 50 + .../vcpkg-parallel-configure/.ninja_log | 3 + .../vcpkg-parallel-configure/build.ninja | 9 + .../blds/jsoncpp/x64-windows-rel/version | 1 + .../jsoncpp/x64-windows.vcpkg_abi_info.txt | 15 + .../x64-windows.vcpkg_abi_info.txt | 13 + .../x64-windows.vcpkg_abi_info.txt | 21 + .../vcpkg/info/fmt_7.1.3_x64-windows.list | 41 + .../vcpkg/info/jsoncpp_1.9.4_x64-windows.list | 43 + ...g-cmake-config_2021-02-26_x64-windows.list | 8 + .../vcpkg-cmake_2021-02-26_x64-windows.list | 10 + .../vcpkg/pkgs/fmt_x64-windows/BUILD_INFO | 2 + .../vcpkg/pkgs/fmt_x64-windows/CONTROL | 8 + .../pkgs/fmt_x64-windows/include/fmt/chrono.h | 1118 + .../pkgs/fmt_x64-windows/include/fmt/color.h | 603 + .../fmt_x64-windows/include/fmt/compile.h | 701 + .../pkgs/fmt_x64-windows/include/fmt/core.h | 2122 ++ .../fmt_x64-windows/include/fmt/format-inl.h | 2801 +++ .../pkgs/fmt_x64-windows/include/fmt/format.h | 3961 +++ .../pkgs/fmt_x64-windows/include/fmt/locale.h | 64 + .../pkgs/fmt_x64-windows/include/fmt/os.h | 480 + .../fmt_x64-windows/include/fmt/ostream.h | 177 + .../pkgs/fmt_x64-windows/include/fmt/posix.h | 2 + .../pkgs/fmt_x64-windows/include/fmt/printf.h | 751 + .../pkgs/fmt_x64-windows/include/fmt/ranges.h | 396 + .../pkgs/fmt_x64-windows/lib/pkgconfig/fmt.pc | 12 + .../pkgs/fmt_x64-windows/share/fmt/copyright | 27 + .../share/fmt/fmt-config-version.cmake | 43 + .../share/fmt/fmt-config.cmake | 28 + .../share/fmt/fmt-targets-debug.cmake | 19 + .../share/fmt/fmt-targets-release.cmake | 19 + .../share/fmt/fmt-targets.cmake | 116 + .../pkgs/fmt_x64-windows/share/fmt/usage | 7 + .../fmt_x64-windows/share/fmt/vcpkg.spdx.json | 154 + .../share/fmt/vcpkg_abi_info.txt | 18 + .../vcpkg/pkgs/jsoncpp_x64-windows/BUILD_INFO | 2 + .../vcpkg/pkgs/jsoncpp_x64-windows/CONTROL | 6 + .../include/json/allocator.h | 89 + .../include/json/assertions.h | 61 + .../jsoncpp_x64-windows/include/json/config.h | 150 + .../include/json/forwards.h | 43 + .../jsoncpp_x64-windows/include/json/json.h | 15 + .../include/json/json_features.h | 61 + .../jsoncpp_x64-windows/include/json/reader.h | 403 + .../jsoncpp_x64-windows/include/json/value.h | 935 + .../include/json/version.h | 28 + .../jsoncpp_x64-windows/include/json/writer.h | 367 + .../share/jsoncpp/copyright | 55 + .../share/jsoncpp/jsoncppConfig-debug.cmake | 29 + .../share/jsoncpp/jsoncppConfig-release.cmake | 29 + .../share/jsoncpp/jsoncppConfig.cmake | 110 + .../share/jsoncpp/jsoncppConfigVersion.cmake | 65 + .../share/jsoncpp/vcpkg.spdx.json | 110 + .../share/jsoncpp/vcpkg_abi_info.txt | 15 + .../vcpkg-cmake-config_x64-windows/BUILD_INFO | 3 + .../vcpkg-cmake-config_x64-windows/CONTROL | 5 + .../share/vcpkg-cmake-config/copyright | 23 + .../vcpkg-port-config.cmake | 1 + .../share/vcpkg-cmake-config/vcpkg.spdx.json | 182 + .../vcpkg-cmake-config/vcpkg_abi_info.txt | 13 + .../vcpkg_cmake_config_fixup.cmake | 237 + .../pkgs/vcpkg-cmake_x64-windows/BUILD_INFO | 3 + .../pkgs/vcpkg-cmake_x64-windows/CONTROL | 5 + .../share/vcpkg-cmake/copyright | 23 + .../share/vcpkg-cmake/vcpkg-port-config.cmake | 3 + .../share/vcpkg-cmake/vcpkg.spdx.json | 226 + .../share/vcpkg-cmake/vcpkg_abi_info.txt | 21 + .../share/vcpkg-cmake/vcpkg_cmake_build.cmake | 115 + .../vcpkg-cmake/vcpkg_cmake_configure.cmake | 391 + .../vcpkg-cmake/vcpkg_cmake_install.cmake | 46 + src/vcpkg_installed/vcpkg/updates/0000000000 | 6 + src/vcpkg_installed/vcpkg/updates/0000000001 | 6 + src/vcpkg_installed/vcpkg/updates/0000000002 | 6 + src/vcpkg_installed/vcpkg/updates/0000000003 | 6 + src/vcpkg_installed/vcpkg/updates/0000000004 | 9 + src/vcpkg_installed/vcpkg/updates/0000000005 | 9 + src/vcpkg_installed/vcpkg/updates/0000000006 | 7 + src/vcpkg_installed/vcpkg/updates/0000000007 | 7 + src/vcpkg_installed/vcpkg/vcpkg-lock.json | 5 + .../.msbuildstamp-x64-windows-static.stamp | 0 .../x64-windows-rel/CMakeCache.txt | 476 + .../CMakeFiles/3.27.1/CMakeCCompiler.cmake | 74 + .../CMakeFiles/3.27.1/CMakeCXXCompiler.cmake | 85 + .../CMakeFiles/3.27.1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.1/CMakeSystem.cmake | 15 + .../3.27.1/CompilerIdC/CMakeCCompilerId.c | 866 + .../3.27.1/CompilerIdC/CMakeCCompilerId.exe | Bin 0 -> 115200 bytes .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 88 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 2 + .../CMakeFiles/cmake.check_cache | 1 + .../x64-windows-rel/CMakeFiles/rules.ninja | 51 + .../x64-windows-rel/build.ninja | 112 + .../x64-windows-rel/cmake_install.cmake | 44 + .../vcpkg-parallel-configure/.ninja_log | 2 + .../vcpkg-parallel-configure/build.ninja | 6 + .../x64-windows-static-rel/CMakeCache.txt | 476 + .../CMakeFiles/3.27.1/CMakeCCompiler.cmake | 74 + .../CMakeFiles/3.27.1/CMakeCXXCompiler.cmake | 85 + .../CMakeFiles/3.27.1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.1/CMakeSystem.cmake | 15 + .../3.27.1/CompilerIdC/CMakeCCompilerId.c | 866 + .../3.27.1/CompilerIdC/CMakeCCompilerId.exe | Bin 0 -> 115200 bytes .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 88 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 2 + .../CMakeFiles/cmake.check_cache | 1 + .../CMakeFiles/rules.ninja | 51 + .../x64-windows-static-rel/build.ninja | 112 + .../cmake_install.cmake | 44 + .../vcpkg-parallel-configure/.ninja_log | 2 + .../vcpkg-parallel-configure/build.ninja | 6 + .../2b3b374f0b-8ea71ee8ea.clean/.clang-format | 8 + .../.github/workflows/windows.yml | 44 + .../2b3b374f0b-8ea71ee8ea.clean/.gitignore | 36 + .../2b3b374f0b-8ea71ee8ea.clean/.travis.yml | 101 + .../CMakeLists.txt | 361 + .../CONTRIBUTING.md | 20 + .../2b3b374f0b-8ea71ee8ea.clean/ChangeLog.rst | 3665 +++ .../2b3b374f0b-8ea71ee8ea.clean/LICENSE.rst | 27 + .../2b3b374f0b-8ea71ee8ea.clean/README.rst | 506 + .../doc/CMakeLists.txt | 17 + .../doc/_static/bootstrap.min.js | 7 + .../doc/_static/breathe.css | 28 + .../fonts/glyphicons-halflings-regular.eot | Bin 0 -> 20335 bytes .../fonts/glyphicons-halflings-regular.svg | 229 + .../fonts/glyphicons-halflings-regular.ttf | Bin 0 -> 41280 bytes .../fonts/glyphicons-halflings-regular.woff | Bin 0 -> 23320 bytes .../doc/_templates/layout.html | 148 + .../doc/_templates/search.html | 55 + .../2b3b374f0b-8ea71ee8ea.clean/doc/api.rst | 505 + .../doc/basic-bootstrap/README | 2 + .../doc/basic-bootstrap/layout.html | 206 + .../doc/basic-bootstrap/theme.conf | 2 + .../doc/bootstrap/alerts.less | 73 + .../doc/bootstrap/badges.less | 66 + .../doc/bootstrap/bootstrap.less | 50 + .../doc/bootstrap/breadcrumbs.less | 26 + .../doc/bootstrap/button-groups.less | 243 + .../doc/bootstrap/buttons.less | 160 + .../doc/bootstrap/carousel.less | 269 + .../doc/bootstrap/close.less | 34 + .../doc/bootstrap/code.less | 69 + .../doc/bootstrap/component-animations.less | 33 + .../doc/bootstrap/dropdowns.less | 214 + .../doc/bootstrap/forms.less | 574 + .../doc/bootstrap/glyphicons.less | 305 + .../doc/bootstrap/grid.less | 84 + .../doc/bootstrap/input-groups.less | 166 + .../doc/bootstrap/jumbotron.less | 50 + .../doc/bootstrap/labels.less | 64 + .../doc/bootstrap/list-group.less | 124 + .../doc/bootstrap/media.less | 61 + .../doc/bootstrap/mixins.less | 39 + .../doc/bootstrap/mixins/alerts.less | 14 + .../bootstrap/mixins/background-variant.less | 8 + .../doc/bootstrap/mixins/border-radius.less | 18 + .../doc/bootstrap/mixins/buttons.less | 52 + .../doc/bootstrap/mixins/center-block.less | 7 + .../doc/bootstrap/mixins/clearfix.less | 22 + .../doc/bootstrap/mixins/forms.less | 85 + .../doc/bootstrap/mixins/gradients.less | 59 + .../doc/bootstrap/mixins/grid-framework.less | 91 + .../doc/bootstrap/mixins/grid.less | 122 + .../doc/bootstrap/mixins/hide-text.less | 21 + .../doc/bootstrap/mixins/image.less | 33 + .../doc/bootstrap/mixins/labels.less | 12 + .../doc/bootstrap/mixins/list-group.less | 29 + .../doc/bootstrap/mixins/nav-divider.less | 10 + .../bootstrap/mixins/nav-vertical-align.less | 9 + .../doc/bootstrap/mixins/opacity.less | 8 + .../doc/bootstrap/mixins/pagination.less | 23 + .../doc/bootstrap/mixins/panels.less | 24 + .../doc/bootstrap/mixins/progress-bar.less | 10 + .../doc/bootstrap/mixins/reset-filter.less | 8 + .../doc/bootstrap/mixins/resize.less | 6 + .../mixins/responsive-visibility.less | 15 + .../doc/bootstrap/mixins/size.less | 10 + .../doc/bootstrap/mixins/tab-focus.less | 9 + .../doc/bootstrap/mixins/table-row.less | 28 + .../doc/bootstrap/mixins/text-emphasis.less | 8 + .../doc/bootstrap/mixins/text-overflow.less | 8 + .../doc/bootstrap/mixins/vendor-prefixes.less | 227 + .../doc/bootstrap/modals.less | 150 + .../doc/bootstrap/navbar.less | 660 + .../doc/bootstrap/navs.less | 242 + .../doc/bootstrap/normalize.less | 427 + .../doc/bootstrap/pager.less | 54 + .../doc/bootstrap/pagination.less | 88 + .../doc/bootstrap/panels.less | 265 + .../doc/bootstrap/popovers.less | 135 + .../doc/bootstrap/print.less | 107 + .../doc/bootstrap/progress-bars.less | 87 + .../doc/bootstrap/responsive-embed.less | 35 + .../doc/bootstrap/responsive-utilities.less | 194 + .../doc/bootstrap/scaffolding.less | 162 + .../doc/bootstrap/tables.less | 234 + .../doc/bootstrap/theme.less | 273 + .../doc/bootstrap/thumbnails.less | 36 + .../doc/bootstrap/tooltip.less | 102 + .../doc/bootstrap/type.less | 302 + .../doc/bootstrap/utilities.less | 55 + .../doc/bootstrap/variables.less | 861 + .../doc/bootstrap/wells.less | 29 + .../2b3b374f0b-8ea71ee8ea.clean/doc/build.py | 114 + .../2b3b374f0b-8ea71ee8ea.clean/doc/conf.py | 256 + .../doc/contents.rst | 10 + .../2b3b374f0b-8ea71ee8ea.clean/doc/fmt.less | 66 + .../2b3b374f0b-8ea71ee8ea.clean/doc/index.rst | 200 + .../doc/python-license.txt | 290 + .../doc/syntax.rst | 438 + .../2b3b374f0b-8ea71ee8ea.clean/doc/usage.rst | 212 + .../include/fmt/chrono.h | 1118 + .../include/fmt/color.h | 603 + .../include/fmt/compile.h | 701 + .../include/fmt/core.h | 2122 ++ .../include/fmt/format-inl.h | 2801 +++ .../include/fmt/format.h | 3961 +++ .../include/fmt/locale.h | 64 + .../include/fmt/os.h | 480 + .../include/fmt/ostream.h | 177 + .../include/fmt/posix.h | 2 + .../include/fmt/printf.h | 751 + .../include/fmt/ranges.h | 396 + .../pull_request_template.md | 6 + .../2b3b374f0b-8ea71ee8ea.clean/src/format.cc | 99 + .../src/2b3b374f0b-8ea71ee8ea.clean/src/os.cc | 322 + .../support/Android.mk | 15 + .../support/AndroidManifest.xml | 1 + .../support/C++.sublime-syntax | 2061 ++ .../support/README | 4 + .../support/Vagrantfile | 20 + .../support/appveyor-build.py | 43 + .../support/appveyor.yml | 41 + .../support/build.gradle | 107 + .../support/cmake/FindSetEnv.cmake | 7 + .../support/cmake/JoinPaths.cmake | 26 + .../support/cmake/cxx14.cmake | 70 + .../support/cmake/fmt-config.cmake.in | 4 + .../support/cmake/fmt.pc.in | 11 + .../support/compute-powers.py | 53 + .../support/docopt.py | 581 + .../support/manage.py | 290 + .../support/rst2md.py | 159 + .../support/rtd/conf.py | 7 + .../support/rtd/index.rst | 2 + .../support/rtd/theme/layout.html | 17 + .../support/rtd/theme/theme.conf | 2 + .../support/travis-build.py | 119 + .../test/CMakeLists.txt | 244 + .../test/add-subdirectory-test/CMakeLists.txt | 17 + .../test/add-subdirectory-test/main.cc | 6 + .../test/assert-test.cc | 32 + .../test/chrono-test.cc | 398 + .../test/color-test.cc | 99 + .../test/compile-error-test/CMakeLists.txt | 79 + .../test/compile-test.cc | 173 + .../test/core-test.cc | 773 + .../test/cuda-test/CMakeLists.txt | 73 + .../test/cuda-test/cpp14.cc | 11 + .../test/cuda-test/cuda-cpp14.cu | 28 + .../test/find-package-test/CMakeLists.txt | 17 + .../test/find-package-test/main.cc | 6 + .../2b3b374f0b-8ea71ee8ea.clean/test/format | 855 + .../test/format-impl-test.cc | 446 + .../test/format-test.cc | 2495 ++ .../test/fuzzing/.gitignore | 3 + .../test/fuzzing/CMakeLists.txt | 30 + .../test/fuzzing/README.md | 25 + .../test/fuzzing/build.sh | 88 + .../test/fuzzing/chrono-duration.cc | 135 + .../test/fuzzing/float.cc | 34 + .../test/fuzzing/fuzzer-common.h | 75 + .../test/fuzzing/main.cc | 22 + .../test/fuzzing/named-arg.cc | 100 + .../test/fuzzing/one-arg.cc | 91 + .../test/fuzzing/two-args.cc | 105 + .../test/gmock-gtest-all.cc | 11244 +++++++++ .../test/gmock/gmock.h | 14204 +++++++++++ .../test/gtest-extra-test.cc | 439 + .../test/gtest-extra.cc | 87 + .../test/gtest-extra.h | 162 + .../test/gtest/gtest-spi.h | 232 + .../test/gtest/gtest.h | 20065 ++++++++++++++++ .../test/header-only-test.cc | 3 + .../test/header-only-test2.cc | 3 + .../test/locale-test.cc | 160 + .../test/mock-allocator.h | 60 + .../test/os-test.cc | 532 + .../test/ostream-test.cc | 330 + .../test/posix-mock-test.cc | 558 + .../test/posix-mock.h | 77 + .../test/printf-test.cc | 628 + .../test/ranges-test.cc | 203 + .../test/scan-test.cc | 116 + .../2b3b374f0b-8ea71ee8ea.clean/test/scan.h | 238 + .../test/std-format-test.cc | 157 + .../test/test-assert.h | 32 + .../test/test-main.cc | 43 + .../2b3b374f0b-8ea71ee8ea.clean/test/util.cc | 50 + .../2b3b374f0b-8ea71ee8ea.clean/test/util.h | 84 + .../fmt/x64-windows-static-dbg/.ninja_deps | Bin 0 -> 13024 bytes .../fmt/x64-windows-static-dbg/.ninja_log | 5 + .../fmt/x64-windows-static-dbg/CMakeCache.txt | 623 + .../CMakeFiles/3.27.1/CMakeCXXCompiler.cmake | 85 + .../3.27.1/CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 1214976 bytes .../CMakeFiles/3.27.1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 263 + .../fmt-targets-debug.cmake | 19 + .../fmt-targets.cmake | 116 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 8 + .../CMakeFiles/cmake.check_cache | 1 + .../CMakeFiles/rules.ninja | 69 + .../x64-windows-static-dbg/CPackConfig.cmake | 70 + .../CPackSourceConfig.cmake | 76 + .../fmt/x64-windows-static-dbg/build.ninja | 213 + .../cmake_install.cmake | 106 + .../fmt-config-version.cmake | 43 + .../x64-windows-static-dbg/fmt-config.cmake | 28 + .../x64-windows-static-dbg/fmt-targets.cmake | 83 + .../blds/fmt/x64-windows-static-dbg/fmt.pc | 11 + .../install_manifest.txt | 18 + .../fmt/x64-windows-static-rel/.ninja_deps | Bin 0 -> 13024 bytes .../fmt/x64-windows-static-rel/.ninja_log | 5 + .../fmt/x64-windows-static-rel/CMakeCache.txt | 623 + .../CMakeFiles/3.27.1/CMakeCXXCompiler.cmake | 85 + .../3.27.1/CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 1214976 bytes .../CMakeFiles/3.27.1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 263 + .../fmt-targets-release.cmake | 19 + .../fmt-targets.cmake | 116 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 8 + .../CMakeFiles/cmake.check_cache | 1 + .../CMakeFiles/rules.ninja | 69 + .../x64-windows-static-rel/CPackConfig.cmake | 70 + .../CPackSourceConfig.cmake | 76 + .../fmt/x64-windows-static-rel/build.ninja | 213 + .../cmake_install.cmake | 106 + .../fmt-config-version.cmake | 43 + .../x64-windows-static-rel/fmt-config.cmake | 28 + .../x64-windows-static-rel/fmt-targets.cmake | 83 + .../blds/fmt/x64-windows-static-rel/fmt.pc | 11 + .../install_manifest.txt | 18 + .../vcpkg-parallel-configure/.ninja_log | 3 + .../vcpkg-parallel-configure/build.ninja | 9 + .../fmt/x64-windows-static.vcpkg_abi_info.txt | 18 + .../3918c327b1-034a82149a.clean/.clang-format | 4 + .../3918c327b1-034a82149a.clean/.clang-tidy | 11 + .../.gitattributes | 11 + .../.github/ISSUE_TEMPLATE/bug_report.md | 26 + .../.github/ISSUE_TEMPLATE/feature_request.md | 20 + .../3918c327b1-034a82149a.clean/.gitignore | 52 + .../3918c327b1-034a82149a.clean/.travis.yml | 71 + .../.travis_scripts/cmake_builder.sh | 130 + .../.travis_scripts/meson_builder.sh | 83 + .../.travis_scripts/run-clang-format.py | 356 + .../.travis_scripts/run-clang-format.sh | 4 + .../travis.before_install.linux.sh | 8 + .../travis.before_install.osx.sh | 1 + .../.travis_scripts/travis.install.linux.sh | 10 + .../.travis_scripts/travis.install.osx.sh | 1 + .../src/3918c327b1-034a82149a.clean/AUTHORS | 115 + .../CMakeLists.txt | 192 + .../CONTRIBUTING.md | 149 + .../CTestConfig.cmake | 15 + .../src/3918c327b1-034a82149a.clean/LICENSE | 55 + .../src/3918c327b1-034a82149a.clean/README.md | 67 + .../3918c327b1-034a82149a.clean/amalgamate.py | 161 + .../3918c327b1-034a82149a.clean/appveyor.yml | 32 + .../cmake/JoinPaths.cmake | 23 + .../3918c327b1-034a82149a.clean/dev.makefile | 35 + .../devtools/__init__.py | 6 + .../devtools/agent_vmw7.json | 33 + .../devtools/agent_vmxp.json | 26 + .../devtools/antglob.py | 205 + .../devtools/batchbuild.py | 278 + .../devtools/fixeol.py | 70 + .../devtools/licenseupdater.py | 94 + .../devtools/tarball.py | 52 + .../doc/doxyfile.in | 2302 ++ .../doc/footer.html | 21 + .../doc/header.html | 64 + .../doc/jsoncpp.dox | 164 + .../doc/readme.txt | 1 + .../doc/roadmap.dox | 3 + .../doc/web_doxyfile.in | 2290 ++ .../3918c327b1-034a82149a.clean/doxybuild.py | 189 + .../example/CMakeLists.txt | 27 + .../example/README.md | 13 + .../example/readFromStream/errorFormat.json | 3 + .../example/readFromStream/readFromStream.cpp | 30 + .../example/readFromStream/withComment.json | 6 + .../example/readFromString/readFromString.cpp | 37 + .../example/streamWrite/streamWrite.cpp | 22 + .../example/stringWrite/stringWrite.cpp | 33 + .../include/CMakeLists.txt | 5 + .../include/json/allocator.h | 89 + .../include/json/assertions.h | 61 + .../include/json/config.h | 150 + .../include/json/forwards.h | 43 + .../include/json/json.h | 15 + .../include/json/json_features.h | 61 + .../include/json/reader.h | 403 + .../include/json/value.h | 935 + .../include/json/version.h | 28 + .../include/json/writer.h | 367 + .../3918c327b1-034a82149a.clean/meson.build | 119 + .../meson_options.txt | 5 + .../pkg-config/jsoncpp.pc.in | 11 + .../src/CMakeLists.txt | 5 + .../src/jsontestrunner/CMakeLists.txt | 51 + .../src/jsontestrunner/main.cpp | 342 + .../src/lib_json/CMakeLists.txt | 220 + .../src/lib_json/json_reader.cpp | 1993 ++ .../src/lib_json/json_tool.h | 134 + .../src/lib_json/json_value.cpp | 1634 ++ .../src/lib_json/json_valueiterator.inl | 156 + .../src/lib_json/json_writer.cpp | 1258 + .../src/test_lib_json/CMakeLists.txt | 39 + .../src/test_lib_json/fuzz.cpp | 54 + .../src/test_lib_json/fuzz.dict | 54 + .../src/test_lib_json/fuzz.h | 14 + .../src/test_lib_json/jsontest.cpp | 430 + .../src/test_lib_json/jsontest.h | 288 + .../src/test_lib_json/main.cpp | 3921 +++ .../test/cleantests.py | 16 + .../test/data/fail_invalid_quote.json | 1 + .../test/data/fail_test_array_01.json | 1 + .../test/data/fail_test_array_02.json | 1 + .../test/data/fail_test_object_01.json | 1 + .../test/data/fail_test_stack_limit.json | 1 + .../test/data/legacy_test_array_01.expected | 1 + .../test/data/legacy_test_array_01.json | 1 + .../test/data/legacy_test_array_02.expected | 2 + .../test/data/legacy_test_array_02.json | 1 + .../test/data/legacy_test_array_03.expected | 6 + .../test/data/legacy_test_array_03.json | 1 + .../test/data/legacy_test_array_04.expected | 5 + .../test/data/legacy_test_array_04.json | 1 + .../test/data/legacy_test_array_05.expected | 100 + .../test/data/legacy_test_array_05.json | 1 + .../test/data/legacy_test_array_06.expected | 5 + .../test/data/legacy_test_array_06.json | 4 + .../test/data/legacy_test_array_07.expected | 2122 ++ .../test/data/legacy_test_array_07.json | 2 + .../test/data/legacy_test_basic_01.expected | 1 + .../test/data/legacy_test_basic_01.json | 1 + .../test/data/legacy_test_basic_02.expected | 1 + .../test/data/legacy_test_basic_02.json | 1 + .../test/data/legacy_test_basic_03.expected | 3 + .../test/data/legacy_test_basic_03.json | 3 + .../test/data/legacy_test_basic_04.expected | 2 + .../test/data/legacy_test_basic_04.json | 2 + .../test/data/legacy_test_basic_05.expected | 2 + .../test/data/legacy_test_basic_05.json | 2 + .../test/data/legacy_test_basic_06.expected | 2 + .../test/data/legacy_test_basic_06.json | 2 + .../test/data/legacy_test_basic_07.expected | 2 + .../test/data/legacy_test_basic_07.json | 2 + .../test/data/legacy_test_basic_08.expected | 3 + .../test/data/legacy_test_basic_08.json | 3 + .../test/data/legacy_test_basic_09.expected | 4 + .../test/data/legacy_test_basic_09.json | 4 + .../test/data/legacy_test_comment_00.expected | 4 + .../test/data/legacy_test_comment_00.json | 5 + .../test/data/legacy_test_comment_01.expected | 10 + .../test/data/legacy_test_comment_01.json | 10 + .../test/data/legacy_test_comment_02.expected | 23 + .../test/data/legacy_test_comment_02.json | 26 + .../test/data/legacy_test_complex_01.expected | 20 + .../test/data/legacy_test_complex_01.json | 17 + .../test/data/legacy_test_integer_01.expected | 2 + .../test/data/legacy_test_integer_01.json | 2 + .../test/data/legacy_test_integer_02.expected | 2 + .../test/data/legacy_test_integer_02.json | 2 + .../test/data/legacy_test_integer_03.expected | 2 + .../test/data/legacy_test_integer_03.json | 2 + .../test/data/legacy_test_integer_04.expected | 3 + .../test/data/legacy_test_integer_04.json | 3 + .../test/data/legacy_test_integer_05.expected | 2 + .../test/data/legacy_test_integer_05.json | 2 + .../legacy_test_integer_06_64bits.expected | 1 + .../data/legacy_test_integer_06_64bits.json | 2 + .../legacy_test_integer_07_64bits.expected | 1 + .../data/legacy_test_integer_07_64bits.json | 2 + .../legacy_test_integer_08_64bits.expected | 1 + .../data/legacy_test_integer_08_64bits.json | 2 + .../test/data/legacy_test_large_01.expected | 2122 ++ .../test/data/legacy_test_large_01.json | 2 + .../test/data/legacy_test_object_01.expected | 1 + .../test/data/legacy_test_object_01.json | 1 + .../test/data/legacy_test_object_02.expected | 2 + .../test/data/legacy_test_object_02.json | 1 + .../test/data/legacy_test_object_03.expected | 4 + .../test/data/legacy_test_object_03.json | 5 + .../test/data/legacy_test_object_04.expected | 2 + .../test/data/legacy_test_object_04.json | 3 + .../legacy_test_preserve_comment_01.expected | 11 + .../data/legacy_test_preserve_comment_01.json | 14 + .../test/data/legacy_test_real_01.expected | 3 + .../test/data/legacy_test_real_01.json | 3 + .../test/data/legacy_test_real_02.expected | 3 + .../test/data/legacy_test_real_02.json | 3 + .../test/data/legacy_test_real_03.expected | 3 + .../test/data/legacy_test_real_03.json | 3 + .../test/data/legacy_test_real_04.expected | 3 + .../test/data/legacy_test_real_04.json | 3 + .../test/data/legacy_test_real_05.expected | 4 + .../test/data/legacy_test_real_05.json | 3 + .../test/data/legacy_test_real_06.expected | 4 + .../test/data/legacy_test_real_06.json | 3 + .../test/data/legacy_test_real_07.expected | 4 + .../test/data/legacy_test_real_07.json | 3 + .../test/data/legacy_test_real_08.expected | 4 + .../test/data/legacy_test_real_08.json | 4 + .../test/data/legacy_test_real_09.expected | 4 + .../test/data/legacy_test_real_09.json | 4 + .../test/data/legacy_test_real_10.expected | 4 + .../test/data/legacy_test_real_10.json | 4 + .../test/data/legacy_test_real_11.expected | 4 + .../test/data/legacy_test_real_11.json | 4 + .../test/data/legacy_test_real_12.expected | 2 + .../test/data/legacy_test_real_12.json | 2 + .../test/data/legacy_test_string_01.expected | 1 + .../test/data/legacy_test_string_01.json | 1 + .../test/data/legacy_test_string_02.expected | 1 + .../test/data/legacy_test_string_02.json | 1 + .../test/data/legacy_test_string_03.expected | 1 + .../test/data/legacy_test_string_03.json | 1 + .../test/data/legacy_test_string_04.expected | 2 + .../test/data/legacy_test_string_04.json | 2 + .../test/data/legacy_test_string_05.expected | 2 + .../test/data/legacy_test_string_05.json | 2 + .../legacy_test_string_unicode_01.expected | 1 + .../data/legacy_test_string_unicode_01.json | 1 + .../legacy_test_string_unicode_02.expected | 1 + .../data/legacy_test_string_unicode_02.json | 1 + .../legacy_test_string_unicode_03.expected | 1 + .../data/legacy_test_string_unicode_03.json | 1 + .../legacy_test_string_unicode_04.expected | 1 + .../data/legacy_test_string_unicode_04.json | 1 + .../legacy_test_string_unicode_05.expected | 2 + .../data/legacy_test_string_unicode_05.json | 1 + .../test/data/test_array_08.expected | 2 + .../test/data/test_array_08.json | 1 + .../test/data/test_object_05.expected | 2 + .../test/data/test_object_05.json | 1 + .../test/generate_expected.py | 17 + .../test/jsonchecker/fail1.json | 1 + .../test/jsonchecker/fail10.json | 1 + .../test/jsonchecker/fail11.json | 1 + .../test/jsonchecker/fail12.json | 1 + .../test/jsonchecker/fail13.json | 1 + .../test/jsonchecker/fail14.json | 1 + .../test/jsonchecker/fail15.json | 1 + .../test/jsonchecker/fail16.json | 1 + .../test/jsonchecker/fail17.json | 1 + .../test/jsonchecker/fail18.json | 1 + .../test/jsonchecker/fail19.json | 1 + .../test/jsonchecker/fail2.json | 1 + .../test/jsonchecker/fail20.json | 1 + .../test/jsonchecker/fail21.json | 1 + .../test/jsonchecker/fail22.json | 1 + .../test/jsonchecker/fail23.json | 1 + .../test/jsonchecker/fail24.json | 1 + .../test/jsonchecker/fail25.json | 1 + .../test/jsonchecker/fail26.json | 1 + .../test/jsonchecker/fail27.json | 2 + .../test/jsonchecker/fail28.json | 2 + .../test/jsonchecker/fail29.json | 1 + .../test/jsonchecker/fail3.json | 1 + .../test/jsonchecker/fail30.json | 1 + .../test/jsonchecker/fail31.json | 1 + .../test/jsonchecker/fail32.json | 1 + .../test/jsonchecker/fail33.json | 1 + .../test/jsonchecker/fail4.json | 1 + .../test/jsonchecker/fail5.json | 1 + .../test/jsonchecker/fail6.json | 1 + .../test/jsonchecker/fail7.json | 1 + .../test/jsonchecker/fail8.json | 1 + .../test/jsonchecker/fail9.json | 1 + .../test/jsonchecker/pass1.json | 58 + .../test/jsonchecker/pass2.json | 1 + .../test/jsonchecker/pass3.json | 6 + .../test/jsonchecker/readme.txt | 3 + .../test/pyjsontestrunner.py | 71 + .../test/runjsontests.py | 191 + .../test/rununittests.py | 84 + .../3918c327b1-034a82149a.clean/version.in | 1 + .../x64-windows-static-dbg/.ninja_deps | Bin 0 -> 5916 bytes .../jsoncpp/x64-windows-static-dbg/.ninja_log | 9 + .../x64-windows-static-dbg/CMakeCache.txt | 601 + .../CMakeFiles/3.27.1/CMakeCXXCompiler.cmake | 85 + .../3.27.1/CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 1214976 bytes .../CMakeFiles/3.27.1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 322 + .../CMakeFiles/CheckTypeSize/LCONV_SIZE.bin | Bin 0 -> 1214976 bytes .../jsoncppConfig-debug.cmake | 29 + .../jsoncppConfig.cmake | 111 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 22 + .../CMakeFiles/cmake.check_cache | 1 + .../CMakeFiles/rules.ninja | 78 + .../x64-windows-static-dbg/build.ninja | 437 + .../cmake_install.cmake | 78 + .../include/cmake_install.cmake | 49 + .../install_manifest.txt | 17 + .../jsoncppConfigVersion.cmake | 65 + .../src/cmake_install.cmake | 40 + .../src/lib_json/cmake_install.cmake | 46 + .../jsoncpp/x64-windows-static-dbg/version | 1 + .../x64-windows-static-rel/.ninja_deps | Bin 0 -> 5916 bytes .../jsoncpp/x64-windows-static-rel/.ninja_log | 9 + .../x64-windows-static-rel/CMakeCache.txt | 601 + .../CMakeFiles/3.27.1/CMakeCXXCompiler.cmake | 85 + .../3.27.1/CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 1214976 bytes .../CMakeFiles/3.27.1/CMakeRCCompiler.cmake | 6 + .../CMakeFiles/3.27.1/CMakeSystem.cmake | 15 + .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 855 + .../CompilerIdCXX/CMakeCXXCompilerId.exe | Bin 0 -> 115200 bytes .../CMakeFiles/CMakeConfigureLog.yaml | 322 + .../CMakeFiles/CheckTypeSize/LCONV_SIZE.bin | Bin 0 -> 1214976 bytes .../jsoncppConfig-release.cmake | 29 + .../jsoncppConfig.cmake | 111 + .../CMakeFiles/ShowIncludes/foo.h | 1 + .../CMakeFiles/ShowIncludes/main.c | 2 + .../CMakeFiles/TargetDirectories.txt | 22 + .../CMakeFiles/cmake.check_cache | 1 + .../CMakeFiles/rules.ninja | 78 + .../x64-windows-static-rel/build.ninja | 437 + .../cmake_install.cmake | 78 + .../include/cmake_install.cmake | 49 + .../install_manifest.txt | 17 + .../jsoncppConfigVersion.cmake | 65 + .../src/cmake_install.cmake | 40 + .../src/lib_json/cmake_install.cmake | 46 + .../vcpkg-parallel-configure/.ninja_log | 3 + .../vcpkg-parallel-configure/build.ninja | 9 + .../jsoncpp/x64-windows-static-rel/version | 1 + .../x64-windows-static.vcpkg_abi_info.txt | 15 + .../x64-windows.vcpkg_abi_info.txt | 13 + .../x64-windows.vcpkg_abi_info.txt | 21 + .../info/fmt_7.1.3_x64-windows-static.list | 35 + .../jsoncpp_1.9.4_x64-windows-static.list | 37 + ...g-cmake-config_2021-02-26_x64-windows.list | 8 + .../vcpkg-cmake_2021-02-26_x64-windows.list | 10 + .../pkgs/fmt_x64-windows-static/BUILD_INFO | 2 + .../vcpkg/pkgs/fmt_x64-windows-static/CONTROL | 8 + .../include/fmt/chrono.h | 1118 + .../include/fmt/color.h | 603 + .../include/fmt/compile.h | 701 + .../fmt_x64-windows-static/include/fmt/core.h | 2122 ++ .../include/fmt/format-inl.h | 2801 +++ .../include/fmt/format.h | 3961 +++ .../include/fmt/locale.h | 64 + .../fmt_x64-windows-static/include/fmt/os.h | 480 + .../include/fmt/ostream.h | 177 + .../include/fmt/posix.h | 2 + .../include/fmt/printf.h | 751 + .../include/fmt/ranges.h | 396 + .../lib/pkgconfig/fmt.pc | 12 + .../share/fmt/copyright | 27 + .../share/fmt/fmt-config-version.cmake | 43 + .../share/fmt/fmt-config.cmake | 28 + .../share/fmt/fmt-targets-debug.cmake | 19 + .../share/fmt/fmt-targets-release.cmake | 19 + .../share/fmt/fmt-targets.cmake | 116 + .../fmt_x64-windows-static/share/fmt/usage | 7 + .../share/fmt/vcpkg.spdx.json | 154 + .../share/fmt/vcpkg_abi_info.txt | 18 + .../jsoncpp_x64-windows-static/BUILD_INFO | 2 + .../pkgs/jsoncpp_x64-windows-static/CONTROL | 6 + .../include/json/allocator.h | 89 + .../include/json/assertions.h | 61 + .../include/json/config.h | 150 + .../include/json/forwards.h | 43 + .../include/json/json.h | 15 + .../include/json/json_features.h | 61 + .../include/json/reader.h | 403 + .../include/json/value.h | 935 + .../include/json/version.h | 28 + .../include/json/writer.h | 367 + .../share/jsoncpp/copyright | 55 + .../share/jsoncpp/jsoncppConfig-debug.cmake | 29 + .../share/jsoncpp/jsoncppConfig-release.cmake | 29 + .../share/jsoncpp/jsoncppConfig.cmake | 110 + .../share/jsoncpp/jsoncppConfigVersion.cmake | 65 + .../share/jsoncpp/vcpkg.spdx.json | 110 + .../share/jsoncpp/vcpkg_abi_info.txt | 15 + .../vcpkg-cmake-config_x64-windows/BUILD_INFO | 3 + .../vcpkg-cmake-config_x64-windows/CONTROL | 5 + .../share/vcpkg-cmake-config/copyright | 23 + .../vcpkg-port-config.cmake | 1 + .../share/vcpkg-cmake-config/vcpkg.spdx.json | 182 + .../vcpkg-cmake-config/vcpkg_abi_info.txt | 13 + .../vcpkg_cmake_config_fixup.cmake | 237 + .../pkgs/vcpkg-cmake_x64-windows/BUILD_INFO | 3 + .../pkgs/vcpkg-cmake_x64-windows/CONTROL | 5 + .../share/vcpkg-cmake/copyright | 23 + .../share/vcpkg-cmake/vcpkg-port-config.cmake | 3 + .../share/vcpkg-cmake/vcpkg.spdx.json | 226 + .../share/vcpkg-cmake/vcpkg_abi_info.txt | 21 + .../share/vcpkg-cmake/vcpkg_cmake_build.cmake | 115 + .../vcpkg-cmake/vcpkg_cmake_configure.cmake | 391 + .../vcpkg-cmake/vcpkg_cmake_install.cmake | 46 + .../vcpkg/updates/0000000000 | 6 + .../vcpkg/updates/0000000001 | 6 + .../vcpkg/updates/0000000002 | 6 + .../vcpkg/updates/0000000003 | 6 + .../vcpkg/updates/0000000004 | 9 + .../vcpkg/updates/0000000005 | 9 + .../vcpkg/updates/0000000006 | 7 + .../vcpkg/updates/0000000007 | 7 + .../x64-windows-static/vcpkg/vcpkg-lock.json | 5 + .../x64-windows-static/include/fmt/chrono.h | 1118 + .../x64-windows-static/include/fmt/color.h | 603 + .../x64-windows-static/include/fmt/compile.h | 701 + .../x64-windows-static/include/fmt/core.h | 2122 ++ .../include/fmt/format-inl.h | 2801 +++ .../x64-windows-static/include/fmt/format.h | 3961 +++ .../x64-windows-static/include/fmt/locale.h | 64 + .../x64-windows-static/include/fmt/os.h | 480 + .../x64-windows-static/include/fmt/ostream.h | 177 + .../x64-windows-static/include/fmt/posix.h | 2 + .../x64-windows-static/include/fmt/printf.h | 751 + .../x64-windows-static/include/fmt/ranges.h | 396 + .../include/json/allocator.h | 89 + .../include/json/assertions.h | 61 + .../x64-windows-static/include/json/config.h | 150 + .../include/json/forwards.h | 43 + .../x64-windows-static/include/json/json.h | 15 + .../include/json/json_features.h | 61 + .../x64-windows-static/include/json/reader.h | 403 + .../x64-windows-static/include/json/value.h | 935 + .../x64-windows-static/include/json/version.h | 28 + .../x64-windows-static/include/json/writer.h | 367 + .../x64-windows-static/lib/pkgconfig/fmt.pc | 12 + .../x64-windows-static/share/fmt/copyright | 27 + .../share/fmt/fmt-config-version.cmake | 43 + .../share/fmt/fmt-config.cmake | 28 + .../share/fmt/fmt-targets-debug.cmake | 19 + .../share/fmt/fmt-targets-release.cmake | 19 + .../share/fmt/fmt-targets.cmake | 116 + .../x64-windows-static/share/fmt/usage | 7 + .../share/fmt/vcpkg.spdx.json | 154 + .../share/fmt/vcpkg_abi_info.txt | 18 + .../share/jsoncpp/copyright | 55 + .../share/jsoncpp/jsoncppConfig-debug.cmake | 29 + .../share/jsoncpp/jsoncppConfig-release.cmake | 29 + .../share/jsoncpp/jsoncppConfig.cmake | 110 + .../share/jsoncpp/jsoncppConfigVersion.cmake | 65 + .../share/jsoncpp/vcpkg.spdx.json | 110 + .../share/jsoncpp/vcpkg_abi_info.txt | 15 + .../share/vcpkg-cmake-config/copyright | 23 + .../vcpkg-port-config.cmake | 1 + .../share/vcpkg-cmake-config/vcpkg.spdx.json | 182 + .../vcpkg-cmake-config/vcpkg_abi_info.txt | 13 + .../vcpkg_cmake_config_fixup.cmake | 237 + .../x64-windows/share/vcpkg-cmake/copyright | 23 + .../share/vcpkg-cmake/vcpkg-port-config.cmake | 3 + .../share/vcpkg-cmake/vcpkg.spdx.json | 226 + .../share/vcpkg-cmake/vcpkg_abi_info.txt | 21 + .../share/vcpkg-cmake/vcpkg_cmake_build.cmake | 115 + .../vcpkg-cmake/vcpkg_cmake_configure.cmake | 391 + .../vcpkg-cmake/vcpkg_cmake_install.cmake | 46 + .../x64-windows/include/fmt/chrono.h | 1118 + .../x64-windows/include/fmt/color.h | 603 + .../x64-windows/include/fmt/compile.h | 701 + .../x64-windows/include/fmt/core.h | 2122 ++ .../x64-windows/include/fmt/format-inl.h | 2801 +++ .../x64-windows/include/fmt/format.h | 3961 +++ .../x64-windows/include/fmt/locale.h | 64 + .../x64-windows/include/fmt/os.h | 480 + .../x64-windows/include/fmt/ostream.h | 177 + .../x64-windows/include/fmt/posix.h | 2 + .../x64-windows/include/fmt/printf.h | 751 + .../x64-windows/include/fmt/ranges.h | 396 + .../x64-windows/include/json/allocator.h | 89 + .../x64-windows/include/json/assertions.h | 61 + .../x64-windows/include/json/config.h | 150 + .../x64-windows/include/json/forwards.h | 43 + .../x64-windows/include/json/json.h | 15 + .../x64-windows/include/json/json_features.h | 61 + .../x64-windows/include/json/reader.h | 403 + .../x64-windows/include/json/value.h | 935 + .../x64-windows/include/json/version.h | 28 + .../x64-windows/include/json/writer.h | 367 + .../x64-windows/lib/pkgconfig/fmt.pc | 12 + .../x64-windows/share/fmt/copyright | 27 + .../share/fmt/fmt-config-version.cmake | 43 + .../x64-windows/share/fmt/fmt-config.cmake | 28 + .../share/fmt/fmt-targets-debug.cmake | 19 + .../share/fmt/fmt-targets-release.cmake | 19 + .../x64-windows/share/fmt/fmt-targets.cmake | 116 + .../x64-windows/share/fmt/usage | 7 + .../x64-windows/share/fmt/vcpkg.spdx.json | 154 + .../x64-windows/share/fmt/vcpkg_abi_info.txt | 18 + .../x64-windows/share/jsoncpp/copyright | 55 + .../share/jsoncpp/jsoncppConfig-debug.cmake | 29 + .../share/jsoncpp/jsoncppConfig-release.cmake | 29 + .../share/jsoncpp/jsoncppConfig.cmake | 110 + .../share/jsoncpp/jsoncppConfigVersion.cmake | 65 + .../x64-windows/share/jsoncpp/vcpkg.spdx.json | 110 + .../share/jsoncpp/vcpkg_abi_info.txt | 15 + .../share/vcpkg-cmake-config/copyright | 23 + .../vcpkg-port-config.cmake | 1 + .../share/vcpkg-cmake-config/vcpkg.spdx.json | 182 + .../vcpkg-cmake-config/vcpkg_abi_info.txt | 13 + .../vcpkg_cmake_config_fixup.cmake | 237 + .../x64-windows/share/vcpkg-cmake/copyright | 23 + .../share/vcpkg-cmake/vcpkg-port-config.cmake | 3 + .../share/vcpkg-cmake/vcpkg.spdx.json | 226 + .../share/vcpkg-cmake/vcpkg_abi_info.txt | 21 + .../share/vcpkg-cmake/vcpkg_cmake_build.cmake | 115 + .../vcpkg-cmake/vcpkg_cmake_configure.cmake | 391 + .../vcpkg-cmake/vcpkg_cmake_install.cmake | 46 + 1552 files changed, 455507 insertions(+) create mode 100644 .gitignore create mode 100644 LICENSE create mode 100644 README.md create mode 100644 src/bg_local.h create mode 100644 src/bots/bot_debug.cpp create mode 100644 src/bots/bot_debug.h create mode 100644 src/bots/bot_exports.cpp create mode 100644 src/bots/bot_exports.h create mode 100644 src/bots/bot_includes.h create mode 100644 src/bots/bot_think.cpp create mode 100644 src/bots/bot_think.h create mode 100644 src/bots/bot_utils.cpp create mode 100644 src/bots/bot_utils.h create mode 100644 src/cg_local.h create mode 100644 src/cg_main.cpp create mode 100644 src/cg_screen.cpp create mode 100644 src/fmt.cc create mode 100644 src/fmt/args.h create mode 100644 src/fmt/chrono.h create mode 100644 src/fmt/color.h create mode 100644 src/fmt/compile.h create mode 100644 src/fmt/core.h create mode 100644 src/fmt/format-inl.h create mode 100644 src/fmt/format.h create mode 100644 src/fmt/os.h create mode 100644 src/fmt/ostream.h create mode 100644 src/fmt/printf.h create mode 100644 src/fmt/ranges.h create mode 100644 src/fmt/std.h create mode 100644 src/fmt/xchar.h create mode 100644 src/format.cc create mode 100644 src/freeze.c create mode 100644 src/freeze.h create mode 100644 src/g_ai.cpp create mode 100644 src/g_ai_new.cpp create mode 100644 src/g_chase.cpp create mode 100644 src/g_cmds.cpp create mode 100644 src/g_combat.cpp create mode 100644 src/g_ctf.cpp create mode 100644 src/g_func.cpp create mode 100644 src/g_items.cpp create mode 100644 src/g_local.h create mode 100644 src/g_main.cpp create mode 100644 src/g_menu.cpp create mode 100644 src/g_misc.cpp create mode 100644 src/g_monster.cpp create mode 100644 src/g_monster_spawn.cpp create mode 100644 src/g_phys.cpp create mode 100644 src/g_save.cpp create mode 100644 src/g_spawn.cpp create mode 100644 src/g_statusbar.h create mode 100644 src/g_svcmds.cpp create mode 100644 src/g_target.cpp create mode 100644 src/g_trigger.cpp create mode 100644 src/g_turret.cpp create mode 100644 src/g_utils.cpp create mode 100644 src/g_weapon.cpp create mode 100644 src/game.h create mode 100644 src/game.sln create mode 100644 src/game.vcxproj create mode 100644 src/game.vcxproj.filters create mode 100644 src/json/allocator.h create mode 100644 src/json/assertions.h create mode 100644 src/json/config.h create mode 100644 src/json/forwards.h create mode 100644 src/json/json.h create mode 100644 src/json/json_features.h create mode 100644 src/json/reader.h create mode 100644 src/json/value.h create mode 100644 src/json/version.h create mode 100644 src/json/writer.h create mode 100644 src/monsters/m_actor.cpp create mode 100644 src/monsters/m_actor.h create mode 100644 src/monsters/m_arachnid.cpp create mode 100644 src/monsters/m_arachnid.h create mode 100644 src/monsters/m_berserk.cpp create mode 100644 src/monsters/m_berserk.h create mode 100644 src/monsters/m_boss2.cpp create mode 100644 src/monsters/m_boss2.h create mode 100644 src/monsters/m_boss3.cpp create mode 100644 src/monsters/m_boss31.cpp create mode 100644 src/monsters/m_boss31.h create mode 100644 src/monsters/m_boss32.cpp create mode 100644 src/monsters/m_boss32.h create mode 100644 src/monsters/m_brain.cpp create mode 100644 src/monsters/m_brain.h create mode 100644 src/monsters/m_carrier.cpp create mode 100644 src/monsters/m_carrier.h create mode 100644 src/monsters/m_chick.cpp create mode 100644 src/monsters/m_chick.h create mode 100644 src/monsters/m_fixbot.cpp create mode 100644 src/monsters/m_fixbot.h create mode 100644 src/monsters/m_flash.h create mode 100644 src/monsters/m_flipper.cpp create mode 100644 src/monsters/m_flipper.h create mode 100644 src/monsters/m_float.cpp create mode 100644 src/monsters/m_float.h create mode 100644 src/monsters/m_flyer.cpp create mode 100644 src/monsters/m_flyer.h create mode 100644 src/monsters/m_gekk.cpp create mode 100644 src/monsters/m_gekk.h create mode 100644 src/monsters/m_gladiator.cpp create mode 100644 src/monsters/m_gladiator.h create mode 100644 src/monsters/m_guardian.cpp create mode 100644 src/monsters/m_guardian.h create mode 100644 src/monsters/m_guncmdr.cpp create mode 100644 src/monsters/m_gunner.cpp create mode 100644 src/monsters/m_gunner.h create mode 100644 src/monsters/m_hover.cpp create mode 100644 src/monsters/m_hover.h create mode 100644 src/monsters/m_infantry.cpp create mode 100644 src/monsters/m_infantry.h create mode 100644 src/monsters/m_insane.cpp create mode 100644 src/monsters/m_insane.h create mode 100644 src/monsters/m_medic.cpp create mode 100644 src/monsters/m_medic.h create mode 100644 src/monsters/m_move.cpp create mode 100644 src/monsters/m_mutant.cpp create mode 100644 src/monsters/m_mutant.h create mode 100644 src/monsters/m_parasite.cpp create mode 100644 src/monsters/m_parasite.h create mode 100644 src/monsters/m_player.h create mode 100644 src/monsters/m_rider.h create mode 100644 src/monsters/m_shambler.cpp create mode 100644 src/monsters/m_shambler.h create mode 100644 src/monsters/m_soldier.cpp create mode 100644 src/monsters/m_soldier.h create mode 100644 src/monsters/m_stalker.cpp create mode 100644 src/monsters/m_stalker.h create mode 100644 src/monsters/m_supertank.cpp create mode 100644 src/monsters/m_supertank.h create mode 100644 src/monsters/m_tank.cpp create mode 100644 src/monsters/m_tank.h create mode 100644 src/monsters/m_turret.cpp create mode 100644 src/monsters/m_turret.h create mode 100644 src/monsters/m_widow.cpp create mode 100644 src/monsters/m_widow.h create mode 100644 src/monsters/m_widow2.cpp create mode 100644 src/monsters/m_widow2.h create mode 100644 src/os.cc create mode 100644 src/p_client.cpp create mode 100644 src/p_hud.cpp create mode 100644 src/p_menu.cpp create mode 100644 src/p_menu.h create mode 100644 src/p_move.cpp create mode 100644 src/p_trail.cpp create mode 100644 src/p_view.cpp create mode 100644 src/p_weapon.cpp create mode 100644 src/q_std.cpp create mode 100644 src/q_std.h create mode 100644 src/q_vec3.h create mode 100644 src/vcpkg.json create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeCCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdC/CMakeCCompilerId.c create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdC/CMakeCCompilerId.exe create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/detect_compiler/x64-windows-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.clang-format create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.github/workflows/windows.yml create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.gitignore create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.travis.yml create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/CONTRIBUTING.md create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/ChangeLog.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/LICENSE.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/README.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/bootstrap.min.js create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/breathe.css create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.eot create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.svg create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.ttf create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.woff create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_templates/layout.html create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_templates/search.html create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/api.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/basic-bootstrap/README create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/basic-bootstrap/layout.html create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/basic-bootstrap/theme.conf create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/alerts.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/badges.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/bootstrap.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/breadcrumbs.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/button-groups.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/buttons.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/carousel.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/close.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/code.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/component-animations.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/dropdowns.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/forms.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/glyphicons.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/grid.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/input-groups.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/jumbotron.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/labels.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/list-group.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/media.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/alerts.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/background-variant.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/border-radius.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/buttons.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/center-block.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/clearfix.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/forms.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/gradients.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/grid-framework.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/grid.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/hide-text.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/image.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/labels.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/list-group.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/nav-divider.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/nav-vertical-align.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/opacity.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/pagination.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/panels.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/progress-bar.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/reset-filter.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/resize.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/responsive-visibility.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/size.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/tab-focus.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/table-row.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/text-emphasis.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/text-overflow.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/vendor-prefixes.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/modals.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/navbar.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/navs.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/normalize.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/pager.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/pagination.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/panels.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/popovers.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/print.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/progress-bars.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/responsive-embed.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/responsive-utilities.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/scaffolding.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/tables.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/theme.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/thumbnails.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/tooltip.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/type.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/utilities.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/variables.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/wells.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/build.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/conf.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/contents.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/fmt.less create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/index.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/python-license.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/syntax.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/usage.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/chrono.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/color.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/compile.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/core.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/format-inl.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/format.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/locale.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/os.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/ostream.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/posix.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/printf.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/ranges.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/pull_request_template.md create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/src/format.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/src/os.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/Android.mk create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/AndroidManifest.xml create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/C++.sublime-syntax create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/README create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/Vagrantfile create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/appveyor-build.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/appveyor.yml create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/build.gradle create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/FindSetEnv.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/JoinPaths.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/cxx14.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/fmt-config.cmake.in create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/fmt.pc.in create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/compute-powers.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/docopt.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/manage.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rst2md.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/conf.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/index.rst create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/theme/layout.html create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/theme/theme.conf create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/travis-build.py create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/add-subdirectory-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/add-subdirectory-test/main.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/assert-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/chrono-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/color-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/compile-error-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/compile-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/core-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/cuda-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/cuda-test/cpp14.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/cuda-test/cuda-cpp14.cu create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/find-package-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/find-package-test/main.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/format create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/format-impl-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/format-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/.gitignore create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/README.md create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/build.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/chrono-duration.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/float.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/fuzzer-common.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/main.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/named-arg.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/one-arg.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/two-args.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gmock-gtest-all.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gmock/gmock.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest-extra-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest-extra.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest-extra.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest/gtest-spi.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest/gtest.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/header-only-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/header-only-test2.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/locale-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/mock-allocator.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/os-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/ostream-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/posix-mock-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/posix-mock.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/printf-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/ranges-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/scan-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/scan.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/std-format-test.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/test-assert.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/test-main.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/util.cc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/util.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/.ninja_deps create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeCache.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets-debug.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/fmt.dir/embed.manifest create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/fmt.dir/intermediate.manifest create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/fmt.dir/manifest.rc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/fmt.dir/manifest.res create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CPackConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/CPackSourceConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/fmt-config.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/fmt-targets.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/fmt.pc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-dbg/install_manifest.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/.ninja_deps create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets-release.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CPackConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/CPackSourceConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/fmt-config.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/fmt-targets.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/fmt.pc create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/install_manifest.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/fmt/x64-windows.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.clang-format create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.clang-tidy create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.gitattributes create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.github/ISSUE_TEMPLATE/bug_report.md create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.github/ISSUE_TEMPLATE/feature_request.md create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.gitignore create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis.yml create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/cmake_builder.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/meson_builder.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/run-clang-format.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/run-clang-format.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.before_install.linux.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.before_install.osx.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.install.linux.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.install.osx.sh create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/AUTHORS create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/CONTRIBUTING.md create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/CTestConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/LICENSE create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/README.md create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/amalgamate.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/appveyor.yml create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/cmake/JoinPaths.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/dev.makefile create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/__init__.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/agent_vmw7.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/agent_vmxp.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/antglob.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/batchbuild.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/fixeol.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/licenseupdater.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/tarball.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/doxyfile.in create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/footer.html create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/header.html create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/jsoncpp.dox create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/readme.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/roadmap.dox create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/web_doxyfile.in create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doxybuild.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/README.md create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromStream/errorFormat.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromStream/readFromStream.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromStream/withComment.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromString/readFromString.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/streamWrite/streamWrite.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/stringWrite/stringWrite.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/allocator.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/assertions.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/config.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/forwards.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/json.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/json_features.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/reader.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/value.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/version.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/writer.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/meson.build create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/meson_options.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/pkg-config/jsoncpp.pc.in create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/jsontestrunner/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/jsontestrunner/main.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_reader.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_tool.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_value.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_valueiterator.inl create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_writer.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/CMakeLists.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/fuzz.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/fuzz.dict create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/fuzz.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/jsontest.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/jsontest.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/main.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/cleantests.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_invalid_quote.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_array_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_array_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_object_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_stack_limit.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_06.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_06.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_07.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_07.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_06.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_06.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_07.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_07.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_08.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_08.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_09.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_09.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_00.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_00.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_complex_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_complex_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_06_64bits.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_06_64bits.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_07_64bits.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_07_64bits.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_08_64bits.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_08_64bits.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_large_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_large_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_preserve_comment_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_preserve_comment_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_06.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_06.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_07.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_07.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_08.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_08.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_09.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_09.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_10.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_10.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_11.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_11.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_12.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_12.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_01.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_01.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_02.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_02.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_03.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_03.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_04.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_04.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_array_08.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_array_08.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_object_05.expected create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_object_05.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/generate_expected.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail1.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail10.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail11.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail12.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail13.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail14.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail15.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail16.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail17.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail18.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail19.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail2.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail20.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail21.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail22.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail23.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail24.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail25.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail26.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail27.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail28.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail29.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail3.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail30.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail31.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail32.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail33.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail4.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail5.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail6.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail7.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail8.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail9.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/pass1.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/pass2.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/pass3.json create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/readme.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/pyjsontestrunner.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/runjsontests.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/rununittests.py create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/version.in create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/.ninja_deps create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeCache.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/CheckTypeSize/LCONV_SIZE.bin create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig-debug.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/include/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/install_manifest.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/src/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/src/lib_json/CMakeFiles/jsoncpp_lib.dir/embed.manifest create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/src/lib_json/CMakeFiles/jsoncpp_lib.dir/intermediate.manifest create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/src/lib_json/CMakeFiles/jsoncpp_lib.dir/manifest.rc create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/src/lib_json/CMakeFiles/jsoncpp_lib.dir/manifest.res create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/src/lib_json/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-dbg/version create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/.ninja_deps create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/3.27.2-msvc1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/CheckTypeSize/LCONV_SIZE.bin create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig-release.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/include/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/install_manifest.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/src/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/src/lib_json/cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows-rel/version create mode 100644 src/vcpkg_installed/vcpkg/blds/jsoncpp/x64-windows.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/vcpkg-cmake-config/x64-windows.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/blds/vcpkg-cmake/x64-windows.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/info/fmt_7.1.3_x64-windows.list create mode 100644 src/vcpkg_installed/vcpkg/info/jsoncpp_1.9.4_x64-windows.list create mode 100644 src/vcpkg_installed/vcpkg/info/vcpkg-cmake-config_2021-02-26_x64-windows.list create mode 100644 src/vcpkg_installed/vcpkg/info/vcpkg-cmake_2021-02-26_x64-windows.list create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/BUILD_INFO create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/CONTROL create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/chrono.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/color.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/compile.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/core.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/format-inl.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/format.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/locale.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/os.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/ostream.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/posix.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/printf.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/include/fmt/ranges.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/lib/pkgconfig/fmt.pc create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/copyright create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/fmt-config.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/fmt-targets-debug.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/fmt-targets-release.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/fmt-targets.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/usage create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/vcpkg/pkgs/fmt_x64-windows/share/fmt/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/BUILD_INFO create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/CONTROL create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/allocator.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/assertions.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/config.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/forwards.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/json.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/json_features.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/reader.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/value.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/version.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/include/json/writer.h create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/copyright create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/jsoncppConfig-debug.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/jsoncppConfig-release.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/vcpkg/pkgs/jsoncpp_x64-windows/share/jsoncpp/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/BUILD_INFO create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/CONTROL create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/copyright create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg_cmake_config_fixup.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/BUILD_INFO create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/CONTROL create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/copyright create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_cmake_build.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_cmake_configure.cmake create mode 100644 src/vcpkg_installed/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_cmake_install.cmake create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000000 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000001 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000002 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000003 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000004 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000005 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000006 create mode 100644 src/vcpkg_installed/vcpkg/updates/0000000007 create mode 100644 src/vcpkg_installed/vcpkg/vcpkg-lock.json create mode 100644 src/vcpkg_installed/x64-windows-static/.msbuildstamp-x64-windows-static.stamp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CMakeCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CompilerIdC/CMakeCCompilerId.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CompilerIdC/CMakeCCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdC/CMakeCCompilerId.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdC/CMakeCCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/detect_compiler/x64-windows-static-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.clang-format create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.github/workflows/windows.yml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.gitignore create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/.travis.yml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/CONTRIBUTING.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/ChangeLog.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/LICENSE.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/README.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/bootstrap.min.js create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/breathe.css create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.eot create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.svg create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.ttf create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_static/fonts/glyphicons-halflings-regular.woff create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_templates/layout.html create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/_templates/search.html create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/api.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/basic-bootstrap/README create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/basic-bootstrap/layout.html create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/basic-bootstrap/theme.conf create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/alerts.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/badges.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/bootstrap.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/breadcrumbs.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/button-groups.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/buttons.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/carousel.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/close.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/code.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/component-animations.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/dropdowns.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/forms.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/glyphicons.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/grid.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/input-groups.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/jumbotron.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/labels.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/list-group.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/media.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/alerts.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/background-variant.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/border-radius.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/buttons.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/center-block.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/clearfix.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/forms.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/gradients.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/grid-framework.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/grid.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/hide-text.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/image.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/labels.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/list-group.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/nav-divider.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/nav-vertical-align.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/opacity.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/pagination.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/panels.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/progress-bar.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/reset-filter.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/resize.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/responsive-visibility.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/size.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/tab-focus.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/table-row.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/text-emphasis.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/text-overflow.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/mixins/vendor-prefixes.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/modals.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/navbar.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/navs.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/normalize.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/pager.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/pagination.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/panels.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/popovers.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/print.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/progress-bars.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/responsive-embed.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/responsive-utilities.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/scaffolding.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/tables.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/theme.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/thumbnails.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/tooltip.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/type.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/utilities.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/variables.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/bootstrap/wells.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/build.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/conf.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/contents.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/fmt.less create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/index.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/python-license.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/syntax.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/doc/usage.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/chrono.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/color.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/compile.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/core.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/format-inl.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/format.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/locale.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/os.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/ostream.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/posix.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/printf.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/include/fmt/ranges.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/pull_request_template.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/src/format.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/src/os.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/Android.mk create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/AndroidManifest.xml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/C++.sublime-syntax create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/README create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/Vagrantfile create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/appveyor-build.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/appveyor.yml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/build.gradle create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/FindSetEnv.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/JoinPaths.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/cxx14.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/fmt-config.cmake.in create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/cmake/fmt.pc.in create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/compute-powers.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/docopt.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/manage.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rst2md.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/conf.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/index.rst create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/theme/layout.html create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/rtd/theme/theme.conf create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/support/travis-build.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/add-subdirectory-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/add-subdirectory-test/main.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/assert-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/chrono-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/color-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/compile-error-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/compile-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/core-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/cuda-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/cuda-test/cpp14.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/cuda-test/cuda-cpp14.cu create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/find-package-test/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/find-package-test/main.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/format create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/format-impl-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/format-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/.gitignore create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/README.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/build.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/chrono-duration.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/float.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/fuzzer-common.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/main.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/named-arg.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/one-arg.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/fuzzing/two-args.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gmock-gtest-all.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gmock/gmock.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest-extra-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest-extra.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest-extra.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest/gtest-spi.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/gtest/gtest.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/header-only-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/header-only-test2.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/locale-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/mock-allocator.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/os-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/ostream-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/posix-mock-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/posix-mock.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/printf-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/ranges-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/scan-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/scan.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/std-format-test.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/test-assert.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/test-main.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/util.cc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/src/2b3b374f0b-8ea71ee8ea.clean/test/util.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/.ninja_deps create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeCache.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CPackConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/CPackSourceConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/fmt-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/fmt.pc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-dbg/install_manifest.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/.ninja_deps create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets-release.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/Export/2a5b8b7bf6498a831bcdfe56de7404e6/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CPackConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/CPackSourceConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/fmt-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/fmt.pc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/install_manifest.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/fmt/x64-windows-static.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.clang-format create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.clang-tidy create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.gitattributes create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.github/ISSUE_TEMPLATE/bug_report.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.github/ISSUE_TEMPLATE/feature_request.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.gitignore create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis.yml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/cmake_builder.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/meson_builder.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/run-clang-format.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/run-clang-format.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.before_install.linux.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.before_install.osx.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.install.linux.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/.travis_scripts/travis.install.osx.sh create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/AUTHORS create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/CONTRIBUTING.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/CTestConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/LICENSE create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/README.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/amalgamate.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/appveyor.yml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/cmake/JoinPaths.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/dev.makefile create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/__init__.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/agent_vmw7.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/agent_vmxp.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/antglob.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/batchbuild.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/fixeol.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/licenseupdater.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/devtools/tarball.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/doxyfile.in create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/footer.html create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/header.html create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/jsoncpp.dox create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/readme.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/roadmap.dox create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doc/web_doxyfile.in create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/doxybuild.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/README.md create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromStream/errorFormat.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromStream/readFromStream.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromStream/withComment.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/readFromString/readFromString.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/streamWrite/streamWrite.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/example/stringWrite/stringWrite.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/allocator.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/assertions.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/config.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/forwards.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/json.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/json_features.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/reader.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/value.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/version.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/include/json/writer.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/meson.build create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/meson_options.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/pkg-config/jsoncpp.pc.in create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/jsontestrunner/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/jsontestrunner/main.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_reader.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_tool.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_value.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_valueiterator.inl create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/lib_json/json_writer.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/CMakeLists.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/fuzz.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/fuzz.dict create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/fuzz.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/jsontest.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/jsontest.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/src/test_lib_json/main.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/cleantests.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_invalid_quote.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_array_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_array_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_object_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/fail_test_stack_limit.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_06.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_06.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_07.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_array_07.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_06.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_06.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_07.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_07.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_08.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_08.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_09.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_basic_09.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_00.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_00.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_comment_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_complex_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_complex_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_06_64bits.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_06_64bits.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_07_64bits.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_07_64bits.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_08_64bits.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_integer_08_64bits.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_large_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_large_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_object_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_preserve_comment_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_preserve_comment_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_06.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_06.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_07.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_07.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_08.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_08.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_09.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_09.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_10.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_10.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_11.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_11.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_12.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_real_12.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_01.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_01.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_02.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_02.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_03.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_03.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_04.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_04.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/legacy_test_string_unicode_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_array_08.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_array_08.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_object_05.expected create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/data/test_object_05.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/generate_expected.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail1.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail10.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail11.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail12.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail13.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail14.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail15.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail16.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail17.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail18.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail19.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail2.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail20.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail21.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail22.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail23.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail24.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail25.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail26.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail27.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail28.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail29.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail3.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail30.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail31.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail32.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail33.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail4.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail5.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail6.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail7.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail8.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/fail9.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/pass1.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/pass2.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/pass3.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/jsonchecker/readme.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/pyjsontestrunner.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/runjsontests.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/test/rununittests.py create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/src/3918c327b1-034a82149a.clean/version.in create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/.ninja_deps create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeCache.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/3.27.1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/CheckTypeSize/LCONV_SIZE.bin create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/include/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/install_manifest.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/src/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/src/lib_json/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-dbg/version create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/.ninja_deps create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeCache.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeCXXCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeDetermineCompilerABI_CXX.bin create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeRCCompiler.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/3.27.1/CMakeSystem.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/3.27.1/CompilerIdCXX/CMakeCXXCompilerId.exe create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/CMakeConfigureLog.yaml create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/CheckTypeSize/LCONV_SIZE.bin create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig-release.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/Export/8728d72a6b86aa6ce8d1b9aa67305bd2/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/ShowIncludes/foo.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/ShowIncludes/main.c create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/TargetDirectories.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/cmake.check_cache create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/CMakeFiles/rules.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/include/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/install_manifest.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/src/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/src/lib_json/cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/vcpkg-parallel-configure/.ninja_log create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/vcpkg-parallel-configure/build.ninja create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static-rel/version create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/jsoncpp/x64-windows-static.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/vcpkg-cmake-config/x64-windows.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/blds/vcpkg-cmake/x64-windows.vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/info/fmt_7.1.3_x64-windows-static.list create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/info/jsoncpp_1.9.4_x64-windows-static.list create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/info/vcpkg-cmake-config_2021-02-26_x64-windows.list create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/info/vcpkg-cmake_2021-02-26_x64-windows.list create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/BUILD_INFO create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/CONTROL create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/chrono.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/color.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/compile.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/core.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/format-inl.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/format.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/locale.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/os.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/ostream.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/posix.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/printf.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/include/fmt/ranges.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/lib/pkgconfig/fmt.pc create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/fmt-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/fmt-targets-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/fmt-targets-release.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/usage create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/fmt_x64-windows-static/share/fmt/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/BUILD_INFO create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/CONTROL create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/allocator.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/assertions.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/config.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/forwards.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/json.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/json_features.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/reader.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/value.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/version.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/include/json/writer.h create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/jsoncppConfig-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/jsoncppConfig-release.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/jsoncpp_x64-windows-static/share/jsoncpp/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/BUILD_INFO create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/CONTROL create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake-config_x64-windows/share/vcpkg-cmake-config/vcpkg_cmake_config_fixup.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/BUILD_INFO create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/CONTROL create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_cmake_build.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_cmake_configure.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/pkgs/vcpkg-cmake_x64-windows/share/vcpkg-cmake/vcpkg_cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000000 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000001 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000002 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000003 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000004 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000005 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000006 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/updates/0000000007 create mode 100644 src/vcpkg_installed/x64-windows-static/vcpkg/vcpkg-lock.json create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/chrono.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/color.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/compile.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/core.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/format-inl.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/format.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/locale.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/os.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/ostream.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/posix.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/printf.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/fmt/ranges.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/allocator.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/assertions.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/config.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/forwards.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/json.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/json_features.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/reader.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/value.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/version.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/include/json/writer.h create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/lib/pkgconfig/fmt.pc create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/fmt-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/fmt-targets-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/fmt-targets-release.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/usage create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/fmt/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/jsoncppConfig-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/jsoncppConfig-release.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows-static/share/jsoncpp/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake-config/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake-config/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake-config/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake-config/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake-config/vcpkg_cmake_config_fixup.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/copyright create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/vcpkg_cmake_build.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/vcpkg_cmake_configure.cmake create mode 100644 src/vcpkg_installed/x64-windows-static/x64-windows/share/vcpkg-cmake/vcpkg_cmake_install.cmake create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/chrono.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/color.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/compile.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/core.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/format-inl.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/format.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/locale.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/os.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/ostream.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/posix.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/printf.h create mode 100644 src/vcpkg_installed/x64-windows/include/fmt/ranges.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/allocator.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/assertions.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/config.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/forwards.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/json.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/json_features.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/reader.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/value.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/version.h create mode 100644 src/vcpkg_installed/x64-windows/include/json/writer.h create mode 100644 src/vcpkg_installed/x64-windows/lib/pkgconfig/fmt.pc create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/copyright create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/fmt-config-version.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/fmt-config.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/fmt-targets-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/fmt-targets-release.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/fmt-targets.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/usage create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows/share/fmt/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/copyright create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/jsoncppConfig-debug.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/jsoncppConfig-release.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/jsoncppConfig.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/jsoncppConfigVersion.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows/share/jsoncpp/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake-config/copyright create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake-config/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake-config/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake-config/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake-config/vcpkg_cmake_config_fixup.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/copyright create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/vcpkg-port-config.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/vcpkg.spdx.json create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/vcpkg_abi_info.txt create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/vcpkg_cmake_build.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/vcpkg_cmake_configure.cmake create mode 100644 src/vcpkg_installed/x64-windows/share/vcpkg-cmake/vcpkg_cmake_install.cmake diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..89e9ae2 --- /dev/null +++ b/.gitignore @@ -0,0 +1,407 @@ +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. +## +## Get latest from https://github.com/github/gitignore/blob/main/VisualStudio.gitignore + +*.dll +*.exp +*.lib +*.ldb + +# User-specific files +*.rsuser +*.suo +*.user +*.userosscache +*.sln.docstates + +# User-specific files (MonoDevelop/Xamarin Studio) +*.userprefs + +# Mono auto generated files +mono_crash.* + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +x64/ +x86/ +[Ww][Ii][Nn]32/ +[Aa][Rr][Mm]/ +[Aa][Rr][Mm]64/ +bld/ +[Bb]in/ +[Oo]bj/ +[Ll]og/ +[Ll]ogs/ + +# Visual Studio 2015/2017 cache/options directory +.vs/ +# Uncomment if you have tasks that create the project's static files in wwwroot +#wwwroot/ + +# Visual Studio 2017 auto generated files +Generated\ Files/ + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +# NUnit +*.VisualState.xml +TestResult.xml +nunit-*.xml + +# Build Results of an ATL Project +[Dd]ebugPS/ +[Rr]eleasePS/ +dlldata.c + +# Benchmark Results +BenchmarkDotNet.Artifacts/ + +# .NET Core +project.lock.json +project.fragment.lock.json +artifacts/ + +# ASP.NET Scaffolding +ScaffoldingReadMe.txt + +# StyleCop +StyleCopReport.xml + +# Files built by Visual Studio +*_i.c +*_p.c +*_h.h +*.ilk +*.meta +*.obj +*.iobj +*.pch +*.pdb +*.ipdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*_wpftmp.csproj +*.log +*.tlog +*.vspscc +*.vssscc +.builds +*.pidb +*.svclog +*.scc + +# Chutzpah Test files +_Chutzpah* + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opendb +*.opensdf +*.sdf +*.cachefile +*.VC.db +*.VC.VC.opendb + +# Visual Studio profiler +*.psess +*.vsp +*.vspx +*.sap + +# Visual Studio Trace Files +*.e2e + +# TFS 2012 Local Workspace +$tf/ + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper +*.DotSettings.user + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# AxoCover is a Code Coverage Tool +.axoCover/* +!.axoCover/settings.json + +# Coverlet is a free, cross platform Code Coverage Tool +coverage*.json +coverage*.xml +coverage*.info + +# Visual Studio code coverage results +*.coverage +*.coveragexml + +# NCrunch +_NCrunch_* +.*crunch*.local.xml +nCrunchTemp_* + +# MightyMoose +*.mm.* +AutoTest.Net/ + +# Web workbench (sass) +.sass-cache/ + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.[Pp]ublish.xml +*.azurePubxml +# Note: Comment the next line if you want to checkin your web deploy settings, +# but database connection strings (with potential passwords) will be unencrypted +*.pubxml +*.publishproj + +# Microsoft Azure Web App publish settings. Comment the next line if you want to +# checkin your Azure Web App publish settings, but sensitive information contained +# in these scripts will be unencrypted +PublishScripts/ + +# NuGet Packages +*.nupkg +# NuGet Symbol Packages +*.snupkg +# The packages folder can be ignored because of Package Restore +**/[Pp]ackages/* +# except build/, which is used as an MSBuild target. +!**/[Pp]ackages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/[Pp]ackages/repositories.config +# NuGet v3's project.json files produces more ignorable files +*.nuget.props +*.nuget.targets + +# Microsoft Azure Build Output +csx/ +*.build.csdef + +# Microsoft Azure Emulator +ecf/ +rcf/ + +# Windows Store app package directories and files +AppPackages/ +BundleArtifacts/ +Package.StoreAssociation.xml +_pkginfo.txt +*.appx +*.appxbundle +*.appxupload + +# Visual Studio cache files +# files ending in .cache can be ignored +*.[Cc]ache +# but keep track of directories ending in .cache +!?*.[Cc]ache/ + +# Others +ClientBin/ +~$* +*~ +*.dbmdl +*.dbproj.schemaview +*.jfm +*.pfx +*.publishsettings +orleans.codegen.cs + +# Including strong name files can present a security risk +# (https://github.com/github/gitignore/pull/2483#issue-259490424) +#*.snk + +# Since there are multiple workflows, uncomment next line to ignore bower_components +# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) +#bower_components/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file +# to a newer Visual Studio version. Backup files are not needed, +# because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm +ServiceFabricBackup/ +*.rptproj.bak + +# SQL Server files +*.mdf +*.ldf +*.ndf + +# Business Intelligence projects +*.rdl.data +*.bim.layout +*.bim_*.settings +*.rptproj.rsuser +*- [Bb]ackup.rdl +*- [Bb]ackup ([0-9]).rdl +*- [Bb]ackup ([0-9][0-9]).rdl + +# Microsoft Fakes +FakesAssemblies/ + +# GhostDoc plugin setting file +*.GhostDoc.xml + +# Node.js Tools for Visual Studio +.ntvs_analysis.dat +node_modules/ + +# Visual Studio 6 build log +*.plg + +# Visual Studio 6 workspace options file +*.opt + +# Visual Studio 6 auto-generated workspace file (contains which files were open etc.) +*.vbw + +# Visual Studio 6 auto-generated project file (contains which files were open etc.) +*.vbp + +# Visual Studio 6 workspace and project file (working project files containing files to include in project) +*.dsw +*.dsp + +# Visual Studio 6 technical files +*.ncb +*.aps + +# Visual Studio LightSwitch build output +**/*.HTMLClient/GeneratedArtifacts +**/*.DesktopClient/GeneratedArtifacts +**/*.DesktopClient/ModelManifest.xml +**/*.Server/GeneratedArtifacts +**/*.Server/ModelManifest.xml +_Pvt_Extensions + +# Paket dependency manager +.paket/paket.exe +paket-files/ + +# FAKE - F# Make +.fake/ + +# CodeRush personal settings +.cr/personal + +# Python Tools for Visual Studio (PTVS) +__pycache__/ +*.pyc + +# Cake - Uncomment if you are using it +# tools/** +# !tools/packages.config + +# Tabs Studio +*.tss + +# Telerik's JustMock configuration file +*.jmconfig + +# BizTalk build output +*.btp.cs +*.btm.cs +*.odx.cs +*.xsd.cs + +# OpenCover UI analysis results +OpenCover/ + +# Azure Stream Analytics local run output +ASALocalRun/ + +# MSBuild Binary and Structured Log +*.binlog + +# NVidia Nsight GPU debugger configuration file +*.nvuser + +# MFractors (Xamarin productivity tool) working folder +.mfractor/ + +# Local History for Visual Studio +.localhistory/ + +# Visual Studio History (VSHistory) files +.vshistory/ + +# BeatPulse healthcheck temp database +healthchecksdb + +# Backup folder for Package Reference Convert tool in Visual Studio 2017 +MigrationBackup/ + +# Ionide (cross platform F# VS Code tools) working folder +.ionide/ + +# Fody - auto-generated XML schema +FodyWeavers.xsd + +# VS Code files for those working on multiple tools +.vscode/* +!.vscode/settings.json +!.vscode/tasks.json +!.vscode/launch.json +!.vscode/extensions.json +*.code-workspace + +# Local History for Visual Studio Code +.history/ + +# Windows Installer files from build outputs +*.cab +*.msi +*.msix +*.msm +*.msp + +# JetBrains Rider +*.sln.iml +*.dll +game_x64.exp +game_x64.exp +/pack diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..e62ec04 --- /dev/null +++ b/LICENSE @@ -0,0 +1,674 @@ +GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. diff --git a/README.md b/README.md new file mode 100644 index 0000000..6ae2fe5 --- /dev/null +++ b/README.md @@ -0,0 +1,4 @@ +# Welcome to Choppuh! + +## What is Choppuh? +It is what you need to get to! diff --git a/src/bg_local.h b/src/bg_local.h new file mode 100644 index 0000000..bfc8361 --- /dev/null +++ b/src/bg_local.h @@ -0,0 +1,265 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +// g_local.h -- local definitions for game module +#pragma once + +#include "q_std.h" + +// define GAME_INCLUDE so that game.h does not define the +// short, server-visible gclient_t and gentity_t structures, +// because we define the full size ones in this file +#define GAME_INCLUDE +#include "game.h" + +// +// p_move.c +// +struct pm_config_t { + int32_t airaccel = 0; + bool n64_physics = false; +}; + +extern pm_config_t pm_config; + +void Pmove(pmove_t *pmove); +using pm_trace_func_t = trace_t(const vec3_t &start, const vec3_t &mins, const vec3_t &maxs, const vec3_t &end); +using pm_trace_t = std::function; +void PM_StepSlideMove_Generic(vec3_t &origin, vec3_t &velocity, float frametime, const vec3_t &mins, const vec3_t &maxs, touch_list_t &touch, bool has_time, pm_trace_t trace); + +enum class stuck_result_t { + GOOD_POSITION, + FIXED, + NO_GOOD_POSITION +}; + +using stuck_object_trace_fn_t = trace_t(const vec3_t &, const vec3_t &, const vec3_t &, const vec3_t &); + +stuck_result_t G_FixStuckObject_Generic(vec3_t &origin, const vec3_t &own_mins, const vec3_t &own_maxs, std::function trace); + +// state for coop respawning; used to select which +// message to print for the player this is set on. +enum coop_respawn_t { + COOP_RESPAWN_NONE, // no messagee + COOP_RESPAWN_IN_COMBAT, // player is in combat + COOP_RESPAWN_BAD_AREA, // player not in a good spot + COOP_RESPAWN_BLOCKED, // spawning was blocked by something + COOP_RESPAWN_WAITING, // for players that are waiting to respawn + COOP_RESPAWN_NO_LIVES, // out of lives, so need to wait until level switch + COOP_RESPAWN_TOTAL +}; + +// reserved general CS ranges +enum { + CONFIG_MATCH_STATE = CS_GENERAL, + CONFIG_TEAMINFO, + CONFIG_CHASE_PLAYER_NAME, + CONFIG_CHASE_PLAYER_NAME_END = CONFIG_CHASE_PLAYER_NAME + MAX_CLIENTS, + + // nb: offset by 1 since NONE is zero + CONFIG_COOP_RESPAWN_STRING, + CONFIG_COOP_RESPAWN_STRING_END = CONFIG_COOP_RESPAWN_STRING + (COOP_RESPAWN_TOTAL - 1), + + // [Paril-KEX] if 1, n64 player physics apply + CONFIG_N64_PHYSICS, + CONFIG_HEALTH_BAR_NAME, // active health bar name + + CONFIG_STORY_SCORELIMIT, // this is also used for scorelimit display in dm + + CONFIG_LAST +}; + +static_assert(CONFIG_LAST <= CS_GENERAL + MAX_GENERAL); + +// ammo IDs +enum ammo_t : uint8_t { + AMMO_BULLETS, + AMMO_SHELLS, + AMMO_ROCKETS, + AMMO_GRENADES, + AMMO_CELLS, + AMMO_SLUGS, + AMMO_MAGSLUG, + AMMO_TRAP, + AMMO_FLECHETTES, + AMMO_TESLA, + AMMO_DISRUPTOR, + AMMO_PROX, + AMMO_MAX +}; + +// powerup IDs +enum powerup_t : uint8_t { + POWERUP_SCREEN, + POWERUP_SHIELD, + + POWERUP_AM_BOMB, + + POWERUP_QUAD, + POWERUP_DUELFIRE, + POWERUP_PROTECTION, + POWERUP_INVISIBILITY, + POWERUP_SILENCER, + POWERUP_REBREATHER, + POWERUP_ENVIROSUIT, + POWERUP_ADRENALINE, + POWERUP_IR_GOGGLES, + POWERUP_DOUBLE, + POWERUP_SPHERE_VENGEANCE, + POWERUP_SPHERE_HUNTER, + POWERUP_SPHERE_DEFENDER, + POWERUP_DOPPELGANGER, + + POWERUP_BALL, + + POWERUP_FLASHLIGHT, + POWERUP_COMPASS, + + POWERUP_TECH_DISRUPTOR_SHIELD, + POWERUP_TECH_POWER_AMP, + POWERUP_TECH_TIME_ACCEL, + POWERUP_TECH_AUTODOC, + + POWERUP_REGEN, + + POWERUP_MAX +}; + +// ammo stats compressed in 9 bits per entry +// since the range is 0-300 +constexpr size_t BITS_PER_AMMO = 9; + +template +constexpr size_t num_of_type_for_bits(size_t num_bits) { + return (num_bits + (sizeof(TI) * 8) - 1) / ((sizeof(TI) * 8) + 1); +} + +template +constexpr void set_compressed_integer(uint16_t *start, uint8_t id, uint16_t count) { + uint16_t bit_offset = bits_per_value * id; + uint16_t byte = bit_offset / 8; + uint16_t bit_shift = bit_offset % 8; + uint16_t mask = (bit_v -1) << bit_shift; + uint16_t *base = (uint16_t *)((uint8_t *)start + byte); + *base = (*base & ~mask) | ((count << bit_shift) & mask); +} + +template +constexpr uint16_t get_compressed_integer(uint16_t *start, uint8_t id) { + uint16_t bit_offset = bits_per_value * id; + uint16_t byte = bit_offset / 8; + uint16_t bit_shift = bit_offset % 8; + uint16_t mask = (bit_v -1) << bit_shift; + uint16_t *base = (uint16_t *)((uint8_t *)start + byte); + return (*base & mask) >> bit_shift; +} + +constexpr size_t NUM_BITS_FOR_AMMO = 9; +constexpr size_t NUM_AMMO_STATS = num_of_type_for_bits(NUM_BITS_FOR_AMMO * AMMO_MAX); +// if this value is set on an STAT_AMMO_INFO_xxx, don't render ammo +constexpr uint16_t AMMO_VALUE_INFINITE = bit_v -1; + +constexpr void G_SetAmmoStat(uint16_t *start, uint8_t ammo_id, uint16_t count) { + set_compressed_integer(start, ammo_id, count); +} + +constexpr uint16_t G_GetAmmoStat(uint16_t *start, uint8_t ammo_id) { + return get_compressed_integer(start, ammo_id); +} + +// powerup stats compressed in 2 bits per entry; +// 3 is the max you'll ever hold, and for some +// (flashlight) it's to indicate on/off state +constexpr size_t NUM_BITS_PER_POWERUP = 2; +constexpr size_t NUM_POWERUP_STATS = num_of_type_for_bits(NUM_BITS_PER_POWERUP * POWERUP_MAX); + +constexpr void G_SetPowerupStat(uint16_t *start, uint8_t powerup_id, uint16_t count) { + set_compressed_integer(start, powerup_id, count); +} + +constexpr uint16_t G_GetPowerupStat(uint16_t *start, uint8_t powerup_id) { + return get_compressed_integer(start, powerup_id); +} + +// player_state->stats[] indexes +enum player_stat_t { + STAT_HEALTH_ICON = 0, + STAT_HEALTH = 1, + STAT_AMMO_ICON = 2, + STAT_AMMO = 3, + STAT_ARMOR_ICON = 4, + STAT_ARMOR = 5, + STAT_SELECTED_ICON = 6, + STAT_PICKUP_ICON = 7, + STAT_PICKUP_STRING = 8, + STAT_POWERUP_ICON = 9, + STAT_POWERUP_TIME = 10, + STAT_HELPICON = 11, + STAT_SELECTED_ITEM = 12, + STAT_LAYOUTS = 13, + STAT_SCORE = 14, + STAT_FLASHES = 15, // cleared each frame, 1 = health, 2 = armor + STAT_CHASE = 16, + STAT_SPECTATOR = 17, + + STAT_MINISCORE_FIRST_PIC = 18, + STAT_MINISCORE_FIRST_SCORE = 19, + STAT_MINISCORE_SECOND_PIC = 20, + STAT_MINISCORE_SECOND_SCORE = 21, + STAT_CTF_FLAG_PIC = 22, + STAT_MINISCORE_FIRST_POS = 23, + STAT_MINISCORE_SECOND_POS = 24, + STAT_TEAM_RED_HEADER = 25, + STAT_TEAM_BLUE_HEADER = 26, + STAT_TECH = 27, + STAT_CROSSHAIR_ID_VIEW = 28, + STAT_MATCH_STATE = 29, + STAT_CROSSHAIR_ID_VIEW_COLOR = 30, + STAT_TEAMPLAY_INFO = 31, + + // [Kex] More stats for weapon wheel + STAT_WEAPONS_OWNED_1 = 32, + STAT_WEAPONS_OWNED_2 = 33, + STAT_AMMO_INFO_START = 34, + STAT_AMMO_INFO_END = STAT_AMMO_INFO_START + NUM_AMMO_STATS - 1, + STAT_POWERUP_INFO_START, + STAT_POWERUP_INFO_END = STAT_POWERUP_INFO_START + NUM_POWERUP_STATS - 1, + + // [Paril-KEX] Key display + STAT_KEY_A, + STAT_KEY_B, + STAT_KEY_C, + + // [Paril-KEX] currently active wheel weapon (or one we're switching to) + STAT_ACTIVE_WHEEL_WEAPON, + // [Paril-KEX] top of screen coop respawn state + STAT_COOP_RESPAWN, + // [Paril-KEX] respawns remaining + STAT_LIVES, + // [Paril-KEX] hit marker; # of damage we successfully landed + STAT_HIT_MARKER, + // [Paril-KEX] + STAT_SELECTED_ITEM_NAME, + // [Paril-KEX] + STAT_HEALTH_BARS, // two health bar values; 7 bits for value, 1 bit for active + // [Paril-KEX] + STAT_ACTIVE_WEAPON, + + STAT_SCORELIMIT, + STAT_DUEL_HEADER, + + STAT_SHOW_STATUSBAR, + + STAT_COUNTDOWN, + + STAT_MINISCORE_FIRST_VAL, + STAT_MINISCORE_SECOND_VAL, + + STAT_MONSTER_COUNT, + STAT_ROUND_NUMBER, + + // don't use; just for verification + STAT_LAST +}; + +static_assert(STAT_LAST <= MAX_STATS + 1, "stats list overflow"); \ No newline at end of file diff --git a/src/bots/bot_debug.cpp b/src/bots/bot_debug.cpp new file mode 100644 index 0000000..eef3f19 --- /dev/null +++ b/src/bots/bot_debug.cpp @@ -0,0 +1,177 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#include "../g_local.h" +#include "bot_utils.h" +#include "bot_debug.h" + +static const gentity_t *escortBot = nullptr; +static const gentity_t *escortActor = nullptr; + +static const gentity_t *moveToPointBot = nullptr; +static vec3_t moveToPointPos = vec3_origin; + +// how close the bot will try to get to the move to point goal +constexpr float moveToPointTolerance = 16.0f; + +/* +================ +ShowMonsterPathToPlayer +================ +*/ +static void ShowMonsterPathToPlayer(const gentity_t *player) { + const gentity_t *monster = FindFirstMonster(); + if (monster == nullptr) { + return; + } + + const float moveDist = 8.0f; + + std::array pathPoints; + + PathRequest request; + request.start = monster->s.origin; + request.goal = player->s.origin; + request.moveDist = moveDist; + request.pathFlags = PathFlags::All; + request.debugging.drawTime = 0.10f; + request.nodeSearch.minHeight = 64.0f; + request.nodeSearch.maxHeight = 64.0f; + request.nodeSearch.radius = 512.0f; + request.pathPoints.array = &pathPoints.front(); + request.pathPoints.count = pathPoints.size(); + + PathInfo info; + if (gi.GetPathToGoal(request, info)) { + // Do movement stuff.... + for (int i = 0; i < info.numPathPoints; ++i) { + const gvec3_t &point = pathPoints[i]; + gi.Draw_Point(point, 8.0f, rgba_yellow, 0.10f, false); + } + } +} + +/* +================ +UpdateFollowActorDebug + +Set cvar "bot_debug_follow_actor" to 1 +and then run your cursor over any player/monster to pick +that "actor" for the bot to follow. + +When successful, you will see the player/monster highlighted +with a yellow box, and the bot will follow them around the map until +the actor they're following dies, or the bot is told to do something +else by you. + +Check the console for debugging feedback... +================ +*/ +static void UpdateFollowActorDebug(const gentity_t *localPlayer) { + if (bot_debug_follow_actor->integer) { + if (bot_debug_follow_actor->integer == 1) { + escortBot = FindFirstBot(); + escortActor = FindActorUnderCrosshair(localPlayer); + + if (gi.Bot_FollowActor(escortBot, escortActor) != GoalReturnCode::Error) { + gi.cvar_set("bot_debug_follow_actor", "2"); + gi.Com_Print("Follow_Actor: Bot Found Actor To Follow!\n"); + } else { + gi.Com_Print("Follow_Actor: Hover Over Monster/Player To Follow...\n"); + } + } else { + if (gi.Bot_FollowActor(escortBot, escortActor) != GoalReturnCode::Error) { + gi.Draw_Bounds(escortActor->absmin, escortActor->absmax, rgba_yellow, gi.frame_time_s, false); + gi.Draw_Bounds(escortBot->absmin, escortBot->absmax, rgba_cyan, gi.frame_time_s, false); + } else { + gi.Com_Print("Follow_Actor: Bot Or Actor Removed...\n"); + gi.cvar_set("bot_debug_follow_actor", "0"); + } + } + } else { + escortBot = nullptr; + escortActor = nullptr; + } +} + +/* +================ +UpdateMoveToPointDebug + +Set cvar "bot_debug_move_to_point" to 1, +look anywhere in world you'd like the bot to move to, +and then fire your weapon. The point at the end of your crosshair +will be the point in the world the bot will move toward. + +When successful, a point marker will be drawn where the bot will move +toward, and the bot itself will have a box drawn around it. + +Once bot reaches the point, it will clear the goal and go about it's +business until you give it something else to do. + +Check the console for debugging feedback... +================ +*/ +static void UpdateMoveToPointDebug(const gentity_t *localPlayer) { + if (bot_debug_move_to_point->integer) { + if (bot_debug_move_to_point->integer == 1) { + if (localPlayer->client->buttons & BUTTON_ATTACK) { + vec3_t localPlayerForward, right, up; + AngleVectors(localPlayer->client->v_angle, localPlayerForward, right, up); + + const vec3_t localPlayerViewPos = (localPlayer->s.origin + vec3_t{ 0.0f, 0.0f, (float)localPlayer->viewheight }); + const vec3_t end = (localPlayerViewPos + (localPlayerForward * 8192.0f)); + const contents_t mask = (MASK_PROJECTILE & ~CONTENTS_DEADMONSTER); + + trace_t tr = gi.traceline(localPlayerViewPos, end, localPlayer, mask); + moveToPointPos = tr.endpos; + + moveToPointBot = FindFirstBot(); + if (gi.Bot_MoveToPoint(moveToPointBot, moveToPointPos, moveToPointTolerance) != GoalReturnCode::Error) { + gi.cvar_set("bot_debug_move_to_point", "2"); + gi.Com_Print("Move_To_Point: Bot Has Position To Move Toward!\n"); + } + } else { + gi.Com_Print("Move_To_Point: Fire Weapon To Select Move Point...\n"); + } + } else { + const GoalReturnCode result = gi.Bot_MoveToPoint(moveToPointBot, moveToPointPos, moveToPointTolerance); + if (result == GoalReturnCode::Error) { + gi.cvar_set("bot_debug_move_to_point", "0"); + gi.Com_Print("Move_To_Point: Bot Can't Reach Goal Position!\n"); + } else if (result == GoalReturnCode::Finished) { + gi.cvar_set("bot_debug_move_to_point", "0"); + gi.Com_Print("Move_To_Point: Bot Reached Goal Position!\n"); + } else { + gi.Draw_Point(moveToPointPos, 8.0f, rgba_yellow, gi.frame_time_s, false); + gi.Draw_Bounds(moveToPointBot->absmin, moveToPointBot->absmax, rgba_cyan, gi.frame_time_s, false); + } + } + } else { + moveToPointBot = nullptr; + moveToPointPos = vec3_origin; + } +} + +/* +================ +Bot_UpdateDebug +================ +*/ +void Bot_UpdateDebug() { + if (!g_cheats->integer) + return; + + const gentity_t *localPlayer = FindLocalPlayer(); + if (localPlayer == nullptr) { + return; + } + + if (g_debug_monster_paths->integer == 2) { + ShowMonsterPathToPlayer(localPlayer); + } + + UpdateFollowActorDebug(localPlayer); + + UpdateMoveToPointDebug(localPlayer); +} diff --git a/src/bots/bot_debug.h b/src/bots/bot_debug.h new file mode 100644 index 0000000..06e10c6 --- /dev/null +++ b/src/bots/bot_debug.h @@ -0,0 +1,6 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#pragma once + +void Bot_UpdateDebug(); diff --git a/src/bots/bot_exports.cpp b/src/bots/bot_exports.cpp new file mode 100644 index 0000000..50923db --- /dev/null +++ b/src/bots/bot_exports.cpp @@ -0,0 +1,188 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#include "../g_local.h" +#include "bot_exports.h" + +/* +================ +Bot_SetWeapon +================ +*/ +void Bot_SetWeapon(gentity_t *bot, const int weaponIndex, const bool instantSwitch) { + if (weaponIndex <= IT_NULL || weaponIndex > IT_TOTAL) { + return; + } + + if ((bot->svflags & SVF_BOT) == 0) { + return; + } + + gclient_t *client = bot->client; + if (client == nullptr || !client->pers.inventory[weaponIndex]) { + return; + } + + const item_id_t weaponItemID = static_cast(weaponIndex); + + const gitem_t *currentGun = client->pers.weapon; + if (currentGun != nullptr) { + if (currentGun->id == weaponItemID) { + return; + } // already have the gun in hand. + } + + const gitem_t *pendingGun = client->newweapon; + if (pendingGun != nullptr) { + if (pendingGun->id == weaponItemID) { + return; + } // already in the process of switching to that gun, just be patient! + } + + gitem_t *item = &itemlist[weaponIndex]; + if ((item->flags & IF_WEAPON) == 0) { + return; + } + + if (item->use == nullptr) { + return; + } + + bot->client->no_weapon_chains = true; + item->use(bot, item); + + if (instantSwitch) { + // FIXME: ugly, maybe store in client later + const int temp_instant_weapon = g_instant_weapon_switch->integer || !!g_frenzy->integer; + g_instant_weapon_switch->integer = 1; + Change_Weapon(bot); + g_instant_weapon_switch->integer = temp_instant_weapon; + } +} + +/* +================ +Bot_TriggerEntity +================ +*/ +void Bot_TriggerEntity(gentity_t *bot, gentity_t *entity) { + if (!bot->inuse || !entity->inuse) { + return; + } + + if ((bot->svflags & SVF_BOT) == 0) { + return; + } + + if (entity->use) { + entity->use(entity, bot, bot); + } + + trace_t unUsed; + if (entity->touch) { + entity->touch(entity, bot, unUsed, true); + } +} + +/* +================ +Bot_UseItem +================ +*/ +void Bot_UseItem(gentity_t *bot, const int32_t itemID) { + if (!bot->inuse) { + return; + } + + if ((bot->svflags & SVF_BOT) == 0) { + return; + } + + const item_id_t desiredItemID = item_id_t(itemID); + bot->client->pers.selected_item = desiredItemID; + + ValidateSelectedItem(bot); + + if (bot->client->pers.selected_item == IT_NULL) { + return; + } + + if (bot->client->pers.selected_item != desiredItemID) { + return; + } // the itemID changed on us - don't use it! + + gitem_t *item = &itemlist[bot->client->pers.selected_item]; + bot->client->pers.selected_item = IT_NULL; + + if (item->use == nullptr) { + return; + } + + bot->client->no_weapon_chains = true; + item->use(bot, item); +} + +/* +================ +Bot_GetItemID +================ +*/ +int32_t Bot_GetItemID(const char *classname) { + if (classname == nullptr || classname[0] == '\0') { + return Item_Invalid; + } + + if (Q_strcasecmp(classname, "none") == 0) { + return Item_Null; + } + + for (int i = 0; i < IT_TOTAL; ++i) { + const gitem_t *item = itemlist + i; + if (item->classname == nullptr || item->classname[0] == '\0') { + continue; + } + + if (Q_strcasecmp(item->classname, classname) == 0) { + return item->id; + } + } + + return Item_Invalid; +} + +/* +================ +Entity_ForceLookAtPoint +================ +*/ +void Entity_ForceLookAtPoint(gentity_t *entity, gvec3_cref_t point) { + vec3_t viewOrigin = entity->s.origin; + if (entity->client != nullptr) { + viewOrigin += entity->client->ps.viewoffset; + } + + const vec3_t ideal = (point - viewOrigin).normalized(); + + vec3_t viewAngles = vectoangles(ideal); + if (viewAngles.x < -180.0f) { + viewAngles.x = anglemod(viewAngles.x + 360.0f); + } + + if (entity->client != nullptr) { + entity->client->ps.pmove.delta_angles = (viewAngles - entity->client->resp.cmd_angles); + entity->client->ps.viewangles = {}; + entity->client->v_angle = {}; + entity->s.angles = {}; + } +} + +/* +================ +Bot_PickedUpItem + +Check if the given bot has picked up the given item or not. +================ +*/ +bool Bot_PickedUpItem(gentity_t *bot, gentity_t *item) { + return item->item_picked_up_by[(bot->s.number - 1)]; +} diff --git a/src/bots/bot_exports.h b/src/bots/bot_exports.h new file mode 100644 index 0000000..f5337ce --- /dev/null +++ b/src/bots/bot_exports.h @@ -0,0 +1,11 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#pragma once + +void Bot_SetWeapon( gentity_t * bot, const int weaponIndex, const bool instantSwitch ); +void Bot_TriggerEntity( gentity_t * bot, gentity_t * entity ); +int32_t Bot_GetItemID( const char * classname ); +void Bot_UseItem( gentity_t * bot, const int32_t itemID ); +void Entity_ForceLookAtPoint( gentity_t * entity, gvec3_cref_t point ); +bool Bot_PickedUpItem( gentity_t * bot, gentity_t * item ); diff --git a/src/bots/bot_includes.h b/src/bots/bot_includes.h new file mode 100644 index 0000000..b8455ad --- /dev/null +++ b/src/bots/bot_includes.h @@ -0,0 +1,9 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#pragma once + +#include "bot_utils.h" +#include "bot_think.h" +#include "bot_debug.h" +#include "bot_exports.h" diff --git a/src/bots/bot_think.cpp b/src/bots/bot_think.cpp new file mode 100644 index 0000000..bbee860 --- /dev/null +++ b/src/bots/bot_think.cpp @@ -0,0 +1,23 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#include "../g_local.h" +#include "bot_think.h" + +/* +================ +Bot_BeginFrame +================ +*/ +void Bot_BeginFrame( gentity_t * bot ) { + +} + +/* +================ +Bot_EndFrame +================ +*/ +void Bot_EndFrame( gentity_t * bot ) { + +} diff --git a/src/bots/bot_think.h b/src/bots/bot_think.h new file mode 100644 index 0000000..cd179b6 --- /dev/null +++ b/src/bots/bot_think.h @@ -0,0 +1,7 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#pragma once + +void Bot_BeginFrame( gentity_t * bot ); +void Bot_EndFrame( gentity_t * bot ); diff --git a/src/bots/bot_utils.cpp b/src/bots/bot_utils.cpp new file mode 100644 index 0000000..297cbcd --- /dev/null +++ b/src/bots/bot_utils.cpp @@ -0,0 +1,529 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#include "../g_local.h" +#include "../monsters/m_player.h" +#include "bot_utils.h" + +constexpr int Team_Coop_Monster = 0; + +/* +================ +Player_UpdateState +================ +*/ +static void Player_UpdateState(gentity_t *player) { + const client_persistant_t &persistant = player->client->pers; + + player->sv.ent_flags = SVFL_NONE; + if (player->groundentity != nullptr || (player->flags & FL_PARTIALGROUND) != 0) { + player->sv.ent_flags |= SVFL_ONGROUND; + } else { + if (player->client->ps.pmove.pm_flags & PMF_JUMP_HELD) { + player->sv.ent_flags |= SVFL_IS_JUMPING; + } + } + + if (player->client->ps.pmove.pm_flags & PMF_ON_LADDER) { + player->sv.ent_flags |= SVFL_ON_LADDER; + } + + if ((player->client->ps.pmove.pm_flags & PMF_DUCKED) != 0) { + player->sv.ent_flags |= SVFL_IS_CROUCHING; + } + + if (player->client->pu_time_quad > level.time) { + player->sv.ent_flags |= SVFL_HAS_DMG_BOOST; + } else if (player->client->pu_time_duelfire > level.time) { + player->sv.ent_flags |= SVFL_HAS_DMG_BOOST; + } else if (player->client->pu_time_double > level.time) { + player->sv.ent_flags |= SVFL_HAS_DMG_BOOST; + } + + if (player->client->pu_time_protection > level.time) { + player->sv.ent_flags |= SVFL_HAS_PROTECTION; + } + + if (player->client->pu_time_invisibility > level.time) { + player->sv.ent_flags |= SVFL_HAS_INVISIBILITY; + } + + if ((player->client->ps.pmove.pm_flags & PMF_TIME_TELEPORT) != 0) { + player->sv.ent_flags |= SVFL_HAS_TELEPORTED; + } + + if (player->takedamage) { + player->sv.ent_flags |= SVFL_TAKES_DAMAGE; + } + + if (player->solid == SOLID_NOT) { + player->sv.ent_flags |= SVFL_IS_HIDDEN; + } + + if ((player->flags & FL_INWATER) != 0) { + if (player->waterlevel >= WATER_WAIST) { + player->sv.ent_flags |= SVFL_IN_WATER; + } + } + + if ((player->flags & FL_NOTARGET) != 0) { + player->sv.ent_flags |= SVFL_NO_TARGET; + } + + if ((player->flags & FL_GODMODE) != 0) { + player->sv.ent_flags |= SVFL_GOD_MODE; + } + + if (player->movetype == MOVETYPE_NOCLIP) { + player->sv.ent_flags |= SVFL_IS_NOCLIP; + } + + if (player->client->anim_end == FRAME_flip12) { + player->sv.ent_flags |= SVFL_IS_FLIPPING_OFF; + } + + if (player->client->anim_end == FRAME_salute11) { + player->sv.ent_flags |= SVFL_IS_SALUTING; + } + + if (player->client->anim_end == FRAME_taunt17) { + player->sv.ent_flags |= SVFL_IS_TAUNTING; + } + + if (player->client->anim_end == FRAME_wave11) { + player->sv.ent_flags |= SVFL_IS_WAVING; + } + + if (player->client->anim_end == FRAME_point12) { + player->sv.ent_flags |= SVFL_IS_POINTING; + } + + if ((player->client->ps.pmove.pm_flags & PMF_DUCKED) == 0 && player->client->anim_priority <= ANIM_WAVE) { + player->sv.ent_flags |= SVFL_CAN_GESTURE; + } + + if (player->lastMOD.id == MOD_TELEFRAG || player->lastMOD.id == MOD_TELEFRAG_SPAWN) { + player->sv.ent_flags |= SVFL_WAS_TELEFRAGGED; + } + + if (!ClientIsPlaying(player->client) || player->client->eliminated) { + player->sv.ent_flags |= SVFL_IS_SPECTATOR; + } + + player_skinnum_t pl_skinnum; + pl_skinnum.skinnum = player->s.skinnum; + player->sv.team = pl_skinnum.team_index; + + player->sv.buttons = player->client->buttons; + + const item_id_t armorType = ArmorIndex(player); + player->sv.armor_type = armorType; + player->sv.armor_value = persistant.inventory[armorType]; + + player->sv.health = (player->deadflag != true) ? player->health : -1; + player->sv.weapon = (persistant.weapon != nullptr) ? persistant.weapon->id : IT_NULL; + + player->sv.last_attackertime = static_cast(player->client->last_attacker_time.milliseconds()); + player->sv.respawntime = static_cast(player->client->respawn_time.milliseconds()); + player->sv.waterlevel = player->waterlevel; + player->sv.viewheight = player->viewheight; + + player->sv.viewangles = player->client->v_angle; + player->sv.viewforward = player->client->v_forward; + player->sv.velocity = player->velocity; + + player->sv.ground_entity = player->groundentity; + player->sv.enemy = player->enemy; + + static_assert(sizeof(persistant.inventory) <= sizeof(player->sv.inventory)); + memcpy(&player->sv.inventory, &persistant.inventory, sizeof(persistant.inventory)); + + if (!player->sv.init) { + player->sv.init = true; + player->sv.classname = player->classname; + player->sv.targetname = player->targetname; + player->sv.lobby_usernum = P_GetLobbyUserNum(player); + player->sv.starting_health = player->health; + player->sv.max_health = player->max_health; + + // NOTE: entries are assumed to be ranked with the first armor assumed + // NOTE: to be the "best", and last the "worst". You don't need to add + // NOTE: entries for things like armor shards, only actual armors. + // NOTE: Check "Max_Armor_Types" to raise/lower the armor count. + armorInfo_t *armorInfo = player->sv.armor_info; + armorInfo[0].item_id = IT_ARMOR_BODY; + armorInfo[0].max_count = bodyarmor_info.max_count; + armorInfo[1].item_id = IT_ARMOR_COMBAT; + armorInfo[1].max_count = combatarmor_info.max_count; + armorInfo[2].item_id = IT_ARMOR_JACKET; + armorInfo[2].max_count = jacketarmor_info.max_count; + + gi.Info_ValueForKey(player->client->pers.userinfo, "name", player->sv.netname, sizeof(player->sv.netname)); + + gi.Bot_RegisterEntity(player); + } +} + +/* +================ +Monster_UpdateState +================ +*/ +static void Monster_UpdateState(gentity_t *monster) { + monster->sv.ent_flags = SVFL_NONE; + if (monster->groundentity != nullptr) { + monster->sv.ent_flags |= SVFL_ONGROUND; + } + + if (monster->takedamage) { + monster->sv.ent_flags |= SVFL_TAKES_DAMAGE; + } + + if (monster->solid == SOLID_NOT || monster->movetype == MOVETYPE_NONE) { + monster->sv.ent_flags |= SVFL_IS_HIDDEN; + } + + if ((monster->flags & FL_INWATER) != 0) { + monster->sv.ent_flags |= SVFL_IN_WATER; + } + + if (InCoopStyle()) { + monster->sv.team = Team_Coop_Monster; + } else { + monster->sv.team = Team_None; // TODO: CTF/TDM/etc... + } + + monster->sv.health = (monster->deadflag != true) ? monster->health : -1; + monster->sv.waterlevel = monster->waterlevel; + monster->sv.enemy = monster->enemy; + monster->sv.ground_entity = monster->groundentity; + + int32_t viewHeight = monster->viewheight; + if ((monster->monsterinfo.aiflags & AI_DUCKED) != 0) { + viewHeight = int32_t(monster->maxs[2] - 4.0f); + } + monster->sv.viewheight = viewHeight; + + monster->sv.viewangles = monster->s.angles; + + AngleVectors(monster->s.angles, monster->sv.viewforward, nullptr, nullptr); + + monster->sv.velocity = monster->velocity; + + if (!monster->sv.init) { + monster->sv.init = true; + monster->sv.classname = monster->classname; + monster->sv.targetname = monster->targetname; + monster->sv.starting_health = monster->health; + monster->sv.max_health = monster->max_health; + + gi.Bot_RegisterEntity(monster); + } +} + +/* +================ +Item_UpdateState +================ +*/ +static void Item_UpdateState(gentity_t *item) { + item->sv.ent_flags = SVFL_IS_ITEM; + item->sv.respawntime = 0; + + if (item->team != nullptr) { + item->sv.ent_flags |= SVFL_IN_TEAM; + } // some DM maps have items chained together in teams... + + if (item->solid == SOLID_NOT) { + item->sv.ent_flags |= SVFL_IS_HIDDEN; + + if (item->nextthink.milliseconds() > 0) { + if ((item->svflags & SVF_RESPAWNING) != 0) { + const gtime_t pendingRespawnTime = (item->nextthink - level.time); + item->sv.respawntime = static_cast(pendingRespawnTime.milliseconds()); + } else { + // item will respawn at some unknown time in the future... + item->sv.respawntime = Item_UnknownRespawnTime; + } + } + } + + const item_id_t itemID = item->item->id; + if (itemID == IT_FLAG_RED || itemID == IT_FLAG_BLUE) { + item->sv.ent_flags |= SVFL_IS_OBJECTIVE; + // TODO: figure out if the objective is dropped/carried/home... + } + + // always need to update these for items, since random item spawning + // could change them at any time... + item->sv.classname = item->classname; + item->sv.item_id = item->item->id; + + if (!item->sv.init) { + item->sv.init = true; + item->sv.targetname = item->targetname; + + gi.Bot_RegisterEntity(item); + } +} + +/* +================ +Trap_UpdateState +================ +*/ +static void Trap_UpdateState(gentity_t *danger) { + danger->sv.ent_flags = SVFL_TRAP_DANGER; + danger->sv.velocity = danger->velocity; + + if (danger->owner != nullptr && danger->owner->client != nullptr) { + player_skinnum_t pl_skinnum; + pl_skinnum.skinnum = danger->owner->s.skinnum; + danger->sv.team = pl_skinnum.team_index; + } + + if (danger->groundentity != nullptr) { + danger->sv.ent_flags |= SVFL_ONGROUND; + } + + if ((danger->flags & FL_TRAP_LASER_FIELD) == 0) { + danger->sv.ent_flags |= SVFL_ACTIVE; // non-lasers are always active + } else { + danger->sv.start_origin = danger->s.origin; + danger->sv.end_origin = danger->s.old_origin; + if ((danger->svflags & SVF_NOCLIENT) == 0) { + if ((danger->s.renderfx & RF_BEAM)) { + danger->sv.ent_flags |= SVFL_ACTIVE; // lasers are active!! + } + } + } + + if (!danger->sv.init) { + danger->sv.init = true; + danger->sv.classname = danger->classname; + + gi.Bot_RegisterEntity(danger); + } +} + +/* +================ +Mover_UpdateState +================ +*/ +static void Mover_UpdateState(gentity_t *entity) { + entity->sv.ent_flags = SVFL_NONE; + entity->sv.health = entity->health; + + if (entity->takedamage) { + entity->sv.ent_flags |= SVFL_TAKES_DAMAGE; + } + + // plats, movers, and doors use this to determine move state. + const bool isDoor = ((entity->svflags & SVF_DOOR) != 0); + const bool isReversedDoor = (isDoor && entity->spawnflags.has(SPAWNFLAG_DOOR_REVERSE)); + + // doors have their top/bottom states reversed from plats + // ( unless "reverse" spawnflag is set! ) + if (isDoor && !isReversedDoor) { + if (entity->moveinfo.state == STATE_TOP) { + entity->sv.ent_flags |= SVFL_MOVESTATE_BOTTOM; + } else if (entity->moveinfo.state == STATE_BOTTOM) { + entity->sv.ent_flags |= SVFL_MOVESTATE_TOP; + } + } else { + if (entity->moveinfo.state == STATE_TOP) { + entity->sv.ent_flags |= SVFL_MOVESTATE_TOP; + } else if (entity->moveinfo.state == STATE_BOTTOM) { + entity->sv.ent_flags |= SVFL_MOVESTATE_BOTTOM; + } + } + + if (entity->moveinfo.state == STATE_UP || entity->moveinfo.state == STATE_DOWN) { + entity->sv.ent_flags |= SVFL_MOVESTATE_MOVING; + } + + entity->sv.start_origin = entity->moveinfo.start_origin; + entity->sv.end_origin = entity->moveinfo.end_origin; + + if (entity->svflags & SVF_DOOR) { + if (entity->flags & FL_LOCKED) { + entity->sv.ent_flags |= SVFL_IS_LOCKED_DOOR; + } + } + + if (!entity->sv.init) { + entity->sv.init = true; + entity->sv.classname = entity->classname; + entity->sv.targetname = entity->targetname; + entity->sv.spawnflags = entity->spawnflags.value; + } +} + +/* +================ +Entity_UpdateState +================ +*/ +void Entity_UpdateState(gentity_t *ent) { + if (ent->svflags & SVF_MONSTER) { + Monster_UpdateState(ent); + } else if (ent->flags & FL_TRAP || ent->flags & FL_TRAP_LASER_FIELD) { + Trap_UpdateState(ent); + } else if (ent->item != nullptr) { + Item_UpdateState(ent); + } else if (ent->client != nullptr) { + Player_UpdateState(ent); + } else { + Mover_UpdateState(ent); + } +} + +static USE(info_nav_lock_use) (gentity_t *self, gentity_t *other, gentity_t *activator) -> void { + gentity_t *n = nullptr; + + while ((n = G_FindByString<&gentity_t::targetname>(n, self->target))) { + if (!(n->svflags & SVF_DOOR)) { + gi.Com_PrintFmt("{} tried targeting {}, a non-SVF_DOOR\n", *self, *n); + continue; + } + + n->flags ^= FL_LOCKED; + } +} + +/*QUAKED info_nav_lock (1.0 1.0 0.0) (-16 -16 0) (16 16 32) x x x x x x x x NOT_EASY NOT_MEDIUM NOT_HARD NOT_DM NOT_COOP +Toggles locked state on linked entity. +*/ +void SP_info_nav_lock(gentity_t *self) { + if (!self->targetname) { + gi.Com_PrintFmt("{} missing targetname\n", *self); + G_FreeEntity(self); + return; + } + + if (!self->target) { + gi.Com_PrintFmt("{} missing target\n", *self); + G_FreeEntity(self); + return; + } + + self->svflags |= SVF_NOCLIENT; + self->use = info_nav_lock_use; +} + +/* +================ +FindLocalPlayer +================ +*/ +const gentity_t *FindLocalPlayer() { + const gentity_t *localPlayer = nullptr; + + const gentity_t *ent = &g_entities[0]; + for (size_t i = 0; i < globals.num_entities; i++, ent++) { + if (!ent->inuse || !(ent->svflags & SVF_PLAYER)) { + continue; + } + + if (ent->health <= 0) { + continue; + } + + localPlayer = ent; + break; + } + + return localPlayer; +} + +/* +================ +FindFirstBot +================ +*/ +const gentity_t *FindFirstBot() { + const gentity_t *firstBot = nullptr; + + const gentity_t *ent = &g_entities[0]; + for (size_t i = 0; i < globals.num_entities; i++, ent++) { + if (!ent->inuse || !(ent->svflags & SVF_PLAYER)) { + continue; + } + + if (ent->health <= 0) { + continue; + } + + if (!(ent->svflags & SVF_BOT)) { + continue; + } + + firstBot = ent; + break; + } + + return firstBot; +} + +/* +================ +FindFirstMonster +================ +*/ +const gentity_t *FindFirstMonster() { + const gentity_t *firstMonster = nullptr; + + const gentity_t *ent = &g_entities[0]; + for (size_t i = 0; i < globals.num_entities; i++, ent++) { + if (!ent->inuse || !(ent->svflags & SVF_MONSTER)) { + continue; + } + + if (ent->health <= 0) { + continue; + } + + firstMonster = ent; + break; + } + + return firstMonster; +} + +/* +================ +FindFirstMonster + +"Actors" are either players or monsters - i.e. something alive and thinking. +================ +*/ +const gentity_t *FindActorUnderCrosshair(const gentity_t *player) { + if (player == nullptr || !player->inuse) { + return nullptr; + } + + vec3_t forward, right, up; + AngleVectors(player->client->v_angle, forward, right, up); + + const vec3_t eye_position = (player->s.origin + vec3_t{ 0.0f, 0.0f, (float)player->viewheight }); + const vec3_t end = (eye_position + (forward * 8192.0f)); + const contents_t mask = (MASK_PROJECTILE & ~CONTENTS_DEADMONSTER); + + trace_t tr = gi.traceline(eye_position, end, player, mask); + + const gentity_t *traceEnt = tr.ent; + if (traceEnt == nullptr || !tr.ent->inuse) { + return nullptr; + } + + if (!(traceEnt->svflags & SVF_PLAYER) && !(traceEnt->svflags & SVF_MONSTER)) { + return nullptr; + } + + if (traceEnt->health <= 0) { + return nullptr; + } + + return traceEnt; +} diff --git a/src/bots/bot_utils.h b/src/bots/bot_utils.h new file mode 100644 index 0000000..6884b9e --- /dev/null +++ b/src/bots/bot_utils.h @@ -0,0 +1,10 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#pragma once + +void Entity_UpdateState( gentity_t * entity ); +const gentity_t * FindLocalPlayer(); +const gentity_t * FindFirstBot(); +const gentity_t * FindFirstMonster(); +const gentity_t * FindActorUnderCrosshair( const gentity_t * player ); diff --git a/src/cg_local.h b/src/cg_local.h new file mode 100644 index 0000000..de6b552 --- /dev/null +++ b/src/cg_local.h @@ -0,0 +1,14 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +// cg_local.h -- local definitions for game module +#pragma once + +#include "bg_local.h" + +extern cgame_import_t cgi; +extern cgame_export_t cglobals; + +#define SERVER_TICK_RATE cgi.tick_rate // in hz +#define FRAME_TIME_S cgi.frame_time_s +#define FRAME_TIME_MS cgi.frame_time_ms diff --git a/src/cg_main.cpp b/src/cg_main.cpp new file mode 100644 index 0000000..d318f8a --- /dev/null +++ b/src/cg_main.cpp @@ -0,0 +1,112 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. + +#include "cg_local.h" +#include "monsters/m_flash.h" + +cgame_import_t cgi; +cgame_export_t cglobals; + +static void *CG_GetExtension(const char *name) { + return nullptr; +} + +void CG_InitScreen(); + +uint64_t cgame_init_time = 0; + +static void InitCGame() { + CG_InitScreen(); + + cgame_init_time = cgi.CL_ClientRealTime(); + + pm_config.n64_physics = !!strtoul(cgi.get_configstring(CONFIG_N64_PHYSICS), nullptr, 10); + pm_config.airaccel = strtoul(cgi.get_configstring(CS_AIRACCEL), nullptr, 10); +} + +static void ShutdownCGame() {} + +void CG_DrawHUD(int32_t isplit, const cg_server_data_t *data, vrect_t hud_vrect, vrect_t hud_safe, int32_t scale, int32_t playernum, const player_state_t *ps); +void CG_TouchPics(); +layout_flags_t CG_LayoutFlags(const player_state_t *ps); + +static int32_t CG_GetActiveWeaponWheelWeapon(const player_state_t *ps) { + return ps->stats[STAT_ACTIVE_WHEEL_WEAPON]; +} + +static uint32_t CG_GetOwnedWeaponWheelWeapons(const player_state_t *ps) { + return ((uint32_t)(uint16_t)ps->stats[STAT_WEAPONS_OWNED_1]) | ((uint32_t)(uint16_t)(ps->stats[STAT_WEAPONS_OWNED_2]) << 16); +} + +static int16_t CG_GetWeaponWheelAmmoCount(const player_state_t *ps, int32_t ammo_id) { + uint16_t ammo = G_GetAmmoStat((uint16_t *)&ps->stats[STAT_AMMO_INFO_START], ammo_id); + + if (ammo == AMMO_VALUE_INFINITE) + return -1; + + return ammo; +} + +static int16_t CG_GetPowerupWheelCount(const player_state_t *ps, int32_t powerup_id) { + return G_GetPowerupStat((uint16_t *)&ps->stats[STAT_POWERUP_INFO_START], powerup_id); +} + +static int16_t CG_GetHitMarkerDamage(const player_state_t *ps) { + return ps->stats[STAT_HIT_MARKER]; +} + +static void CG_ParseConfigString(int32_t i, const char *s) { + if (i == CONFIG_N64_PHYSICS) + pm_config.n64_physics = !!strtoul(s, nullptr, 10); + else if (i == CS_AIRACCEL) + pm_config.airaccel = strtoul(s, nullptr, 10); +} + +void CG_ParseCenterPrint(const char *str, int isplit, bool instant); +void CG_ClearNotify(int32_t isplit); +void CG_ClearCenterprint(int32_t isplit); +void CG_NotifyMessage(int32_t isplit, const char *msg, bool is_chat); + +static void CG_GetMonsterFlashOffset(monster_muzzleflash_id_t id, gvec3_ref_t offset) { + if (id >= q_countof(monster_flash_offset)) + cgi.Com_Error("Bad muzzle flash offset"); + + offset = monster_flash_offset[id]; +} + +/* +================= +GetCGameAPI + +Returns a pointer to the structure with all entry points +and global variables +================= +*/ +Q2GAME_API cgame_export_t * GetCGameAPI(cgame_import_t * import) { + cgi = *import; + + cglobals.apiversion = CGAME_API_VERSION; + cglobals.Init = InitCGame; + cglobals.Shutdown = ShutdownCGame; + + cglobals.Pmove = Pmove; + cglobals.DrawHUD = CG_DrawHUD; + cglobals.LayoutFlags = CG_LayoutFlags; + cglobals.TouchPics = CG_TouchPics; + + cglobals.GetActiveWeaponWheelWeapon = CG_GetActiveWeaponWheelWeapon; + cglobals.GetOwnedWeaponWheelWeapons = CG_GetOwnedWeaponWheelWeapons; + cglobals.GetWeaponWheelAmmoCount = CG_GetWeaponWheelAmmoCount; + cglobals.GetPowerupWheelCount = CG_GetPowerupWheelCount; + cglobals.GetHitMarkerDamage = CG_GetHitMarkerDamage; + cglobals.ParseConfigString = CG_ParseConfigString; + cglobals.ParseCenterPrint = CG_ParseCenterPrint; + cglobals.ClearNotify = CG_ClearNotify; + cglobals.ClearCenterprint = CG_ClearCenterprint; + cglobals.NotifyMessage = CG_NotifyMessage; + cglobals.GetMonsterFlashOffset = CG_GetMonsterFlashOffset; + + cglobals.GetExtension = CG_GetExtension; + + return &cglobals; +} diff --git a/src/cg_screen.cpp b/src/cg_screen.cpp new file mode 100644 index 0000000..2a534ba --- /dev/null +++ b/src/cg_screen.cpp @@ -0,0 +1,1710 @@ +// Copyright (c) ZeniMax Media Inc. +// Licensed under the GNU General Public License 2.0. +#include "cg_local.h" + +constexpr int32_t STAT_MINUS = 10; // num frame for '-' stats digit +constexpr const char *sb_nums[2][11] = +{ + { "num_0", "num_1", "num_2", "num_3", "num_4", "num_5", + "num_6", "num_7", "num_8", "num_9", "num_minus" + }, + { "anum_0", "anum_1", "anum_2", "anum_3", "anum_4", "anum_5", + "anum_6", "anum_7", "anum_8", "anum_9", "anum_minus" + } +}; + +constexpr int32_t CHAR_WIDTH = 16; +constexpr int32_t CONCHAR_WIDTH = 8; + +static int32_t font_y_offset; + +constexpr rgba_t alt_color{ 112, 255, 52, 255 }; + +static cvar_t *scr_usekfont; + +static cvar_t *scr_centertime; +static cvar_t *scr_printspeed; +static cvar_t *cl_notifytime; +static cvar_t *scr_maxlines; +static cvar_t *ui_acc_contrast; +static cvar_t *ui_acc_alttypeface; + +// static temp data used for hud +static struct { + struct { + struct { + char text[24]; + } table_cells[6]; + } table_rows[11]; // just enough to store 8 levels + header + total (+ one slack) + + size_t column_widths[6]; + int32_t num_rows = 0; + int32_t num_columns = 0; +} hud_temp; + +#include + +// max number of centerprints in the rotating buffer +constexpr size_t MAX_CENTER_PRINTS = 4; + +struct cl_bind_t { + std::string bind; + std::string purpose; +}; + +struct cl_centerprint_t { + std::vector binds; // binds + + std::vector lines; + bool instant; // don't type out + + size_t current_line; // current line we're typing out + size_t line_count; // byte count to draw on current line + bool finished; // done typing it out + uint64_t time_tick, time_off; // time to remove at +}; + +static inline bool CG_ViewingLayout(const player_state_t *ps) { + return ps->stats[STAT_LAYOUTS] & (LAYOUTS_LAYOUT | LAYOUTS_INVENTORY); +} + +static inline bool CG_InIntermission(const player_state_t *ps) { + return ps->stats[STAT_LAYOUTS] & LAYOUTS_INTERMISSION; +} + +static inline bool CG_HudHidden(const player_state_t *ps) { + return ps->stats[STAT_LAYOUTS] & LAYOUTS_HIDE_HUD; +} + +layout_flags_t CG_LayoutFlags(const player_state_t *ps) { + return (layout_flags_t)ps->stats[STAT_LAYOUTS]; +} + +#include +#include + +constexpr size_t MAX_NOTIFY = 8; + +struct cl_notify_t { + std::string message; // utf8 message + bool is_active; // filled or not + bool is_chat; // green or not + uint64_t time; // rotate us when < CL_Time() +}; + +// per-splitscreen client hud storage +struct hud_data_t { + std::array centers; // list of centers + std::optional center_index; // current index we're drawing, or unset if none left + std::array notify; // list of notifies +}; + +static std::array hud_data; + +void CG_ClearCenterprint(int32_t isplit) { + hud_data[isplit].center_index = {}; +} + +void CG_ClearNotify(int32_t isplit) { + for (auto &msg : hud_data[isplit].notify) + msg.is_active = false; +} + +// if the top one is expired, cycle the ones ahead backwards (since +// the times are always increasing) +static void CG_Notify_CheckExpire(hud_data_t &data) { + while (data.notify[0].is_active && data.notify[0].time < cgi.CL_ClientTime()) { + data.notify[0].is_active = false; + + for (size_t i = 1; i < MAX_NOTIFY; i++) + if (data.notify[i].is_active) + std::swap(data.notify[i], data.notify[i - 1]); + } +} + +// add notify to list +static void CG_AddNotify(hud_data_t &data, const char *msg, bool is_chat) { + size_t i = 0; + + if (scr_maxlines->integer <= 0) + return; + + const int max = min(MAX_NOTIFY, (size_t)scr_maxlines->integer); + + for (; i < max; i++) + if (!data.notify[i].is_active) + break; + + // none left, so expire the topmost one + if (i == max) { + data.notify[0].time = 0; + CG_Notify_CheckExpire(data); + i = max - 1; + } + + data.notify[i].message.assign(msg); + data.notify[i].is_active = true; + data.notify[i].is_chat = is_chat; + data.notify[i].time = cgi.CL_ClientTime() + (cl_notifytime->value * 1000); +} + +// draw notifies +static void CG_DrawNotify(int32_t isplit, vrect_t hud_vrect, vrect_t hud_safe, int32_t scale) { + auto &data = hud_data[isplit]; + + CG_Notify_CheckExpire(data); + + int y; + + y = (hud_vrect.y * scale) + hud_safe.y; + + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + + if (ui_acc_contrast->integer) { + for (auto &msg : data.notify) { + if (!msg.is_active || !msg.message.length()) + break; + + vec2_t sz = cgi.SCR_MeasureFontString(msg.message.c_str(), scale); + sz.x += 10; // extra padding for black bars + cgi.SCR_DrawColorPic((hud_vrect.x * scale) + hud_safe.x - 5, y, sz.x, 15 * scale, "_white", rgba_black); + y += 10 * scale; + } + } + + y = (hud_vrect.y * scale) + hud_safe.y; + for (auto &msg : data.notify) { + if (!msg.is_active) + break; + + cgi.SCR_DrawFontString(msg.message.c_str(), (hud_vrect.x * scale) + hud_safe.x, y, scale, msg.is_chat ? alt_color : rgba_white, true, text_align_t::LEFT); + y += 10 * scale; + } + + cgi.SCR_SetAltTypeface(false); + + // draw text input (only the main player can really chat anyways...) + if (isplit == 0) { + const char *input_msg; + bool input_team; + + if (cgi.CL_GetTextInput(&input_msg, &input_team)) + cgi.SCR_DrawFontString(G_Fmt("{}: {}", input_team ? "say_team" : "say", input_msg).data(), (hud_vrect.x * scale) + hud_safe.x, y, scale, rgba_white, true, text_align_t::LEFT); + } +} + +/* +============== +CG_DrawHUDString +============== +*/ +static int CG_DrawHUDString(const char *string, int x, int y, int centerwidth, int _xor, int scale, bool shadow = true) { + int margin; + char line[1024]; + int width; + int i; + + margin = x; + + while (*string) { + // scan out one line of text from the string + width = 0; + while (*string && *string != '\n') + line[width++] = *string++; + line[width] = 0; + + vec2_t size; + + if (scr_usekfont->integer) + size = cgi.SCR_MeasureFontString(line, scale); + + if (centerwidth) { + if (!scr_usekfont->integer) + x = margin + ((centerwidth - width * CONCHAR_WIDTH * scale)) / 2; + else + x = margin + ((centerwidth - size.x)) / 2; + } else + x = margin; + + if (!scr_usekfont->integer) { + for (i = 0; i < width; i++) { + cgi.SCR_DrawChar(x, y, scale, line[i] ^ _xor, shadow); + x += CONCHAR_WIDTH * scale; + } + } else { + cgi.SCR_DrawFontString(line, x, y - (font_y_offset * scale), scale, _xor ? alt_color : rgba_white, true, text_align_t::LEFT); + x += size.x; + } + + if (*string) { + string++; // skip the \n + x = margin; + if (!scr_usekfont->integer) + y += CONCHAR_WIDTH * scale; + else + // TODO + y += 10 * scale;//size.y; + } + } + + return x; +} + +// Shamefully stolen from Kex +static size_t FindStartOfUTF8Codepoint(const std::string &str, size_t pos) { + if (pos >= str.size()) { + return std::string::npos; + } + + for (ptrdiff_t i = pos; i >= 0; i--) { + const char &ch = str[i]; + + if ((ch & 0x80) == 0) { + // character is one byte + return i; + } else if ((ch & 0xC0) == 0x80) { + // character is part of a multi-byte sequence, keep going + continue; + } else { + // character is the start of a multi-byte sequence, so stop now + return i; + } + } + + return std::string::npos; +} + +static size_t FindEndOfUTF8Codepoint(const std::string &str, size_t pos) { + if (pos >= str.size()) { + return std::string::npos; + } + + for (size_t i = pos; i < str.size(); i++) { + const char &ch = str[i]; + + if ((ch & 0x80) == 0) { + // character is one byte + return i; + } else if ((ch & 0xC0) == 0x80) { + // character is part of a multi-byte sequence, keep going + continue; + } else { + // character is the start of a multi-byte sequence, so stop now + return i; + } + } + + return std::string::npos; +} + +void CG_NotifyMessage(int32_t isplit, const char *msg, bool is_chat) { + CG_AddNotify(hud_data[isplit], msg, is_chat); +} + +// centerprint stuff +static cl_centerprint_t &CG_QueueCenterPrint(int isplit, bool instant) { + auto &icl = hud_data[isplit]; + + // just use first index + if (!icl.center_index.has_value() || instant) { + icl.center_index = 0; + + for (size_t i = 1; i < MAX_CENTER_PRINTS; i++) + icl.centers[i].lines.clear(); + + return icl.centers[0]; + } + + // pick the next free index if we can find one + for (size_t i = 1; i < MAX_CENTER_PRINTS; i++) { + auto ¢er = icl.centers[(icl.center_index.value() + i) % MAX_CENTER_PRINTS]; + + if (center.lines.empty()) + return center; + } + + // none, so update the current one (the new end of buffer) + // and skip ahead + auto ¢er = icl.centers[icl.center_index.value()]; + icl.center_index = (icl.center_index.value() + 1) % MAX_CENTER_PRINTS; + return center; +} + +/* +============== +CG_ParseCenterPrint + +Called for important messages that should stay in the center of the screen +for a few moments +============== +*/ +void CG_ParseCenterPrint(const char *str, int isplit, bool instant) { + const char *s; + char line[64]; + int i, j, l; + + // handle center queueing + cl_centerprint_t ¢er = CG_QueueCenterPrint(isplit, instant); + + center.lines.clear(); + + // split the string into lines + size_t line_start = 0; + + std::string string(str); + + center.binds.clear(); + + // [Paril-KEX] pull out bindings. they'll always be at the start + while (string.compare(0, 6, "%bind:") == 0) { + size_t end_of_bind = string.find_first_of('%', 1); + + if (end_of_bind == std::string::npos) + break; + + std::string bind = string.substr(6, end_of_bind - 6); + + if (auto purpose_index = bind.find_first_of(':'); purpose_index != std::string::npos) + center.binds.emplace_back(cl_bind_t{ bind.substr(0, purpose_index), bind.substr(purpose_index + 1) }); + else + center.binds.emplace_back(cl_bind_t{ bind }); + + string = string.substr(end_of_bind + 1); + } + + // echo it to the console + cgi.Com_Print("\n\n\35\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\37\n\n"); + + s = string.c_str(); + do { + // scan the width of the line + for (l = 0; l < 40; l++) + if (s[l] == '\n' || !s[l]) + break; + for (i = 0; i < (40 - l) / 2; i++) + line[i] = ' '; + + for (j = 0; j < l; j++) { + line[i++] = s[j]; + } + + line[i] = '\n'; + line[i + 1] = 0; + + cgi.Com_Print(line); + + while (*s && *s != '\n') + s++; + + if (!*s) + break; + s++; // skip the \n + } while (1); + cgi.Com_Print("\n\n\35\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\37\n\n"); + CG_ClearNotify(isplit); + + for (size_t line_end = 0; ; ) { + line_end = FindEndOfUTF8Codepoint(string, line_end); + + if (line_end == std::string::npos) { + // final line + if (line_start < string.size()) + center.lines.emplace_back(string.c_str() + line_start); + break; + } + + // char part of current line; + // if newline, end line and cut off + const char &ch = string[line_end]; + + if (ch == '\n') { + if (line_end > line_start) + center.lines.emplace_back(string.c_str() + line_start, line_end - line_start); + else + center.lines.emplace_back(); + line_start = line_end + 1; + line_end++; + continue; + } + + line_end++; + } + + if (center.lines.empty()) { + center.finished = true; + return; + } + + center.time_tick = cgi.CL_ClientRealTime() + (scr_printspeed->value * 1000); + center.instant = instant; + center.finished = false; + center.current_line = 0; + center.line_count = 0; +} + +static void CG_DrawCenterString(const player_state_t *ps, const vrect_t &hud_vrect, const vrect_t &hud_safe, int isplit, int scale, cl_centerprint_t ¢er) { + int32_t y = hud_vrect.y * scale; + + if (CG_ViewingLayout(ps)) + y += hud_safe.y; + else if (center.lines.size() <= 4) + y += (hud_vrect.height * 0.2f) * scale; + else + y += 48 * scale; + + int lineHeight = (scr_usekfont->integer ? 10 : 8) * scale; + if (ui_acc_alttypeface->integer) lineHeight *= 1.5f; + + // easy! + if (center.instant) { + for (size_t i = 0; i < center.lines.size(); i++) { + auto &line = center.lines[i]; + + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + + if (ui_acc_contrast->integer && line.length()) { + vec2_t sz = cgi.SCR_MeasureFontString(line.c_str(), scale); + sz.x += 10; // extra padding for black bars + int barY = ui_acc_alttypeface->integer ? y - 8 : y; + cgi.SCR_DrawColorPic((hud_vrect.x + hud_vrect.width / 2) * scale - (sz.x / 2), barY, sz.x, lineHeight, "_white", rgba_black); + } + CG_DrawHUDString(line.c_str(), (hud_vrect.x + hud_vrect.width / 2 + -160) * scale, y, (320 / 2) * 2 * scale, 0, scale); + + cgi.SCR_SetAltTypeface(false); + + y += lineHeight; + } + + for (auto &bind : center.binds) { + y += lineHeight * 2; + cgi.SCR_DrawBind(isplit, bind.bind.c_str(), bind.purpose.c_str(), (hud_vrect.x + (hud_vrect.width / 2)) * scale, y, scale); + } + + if (!center.finished) { + center.finished = true; + center.time_off = cgi.CL_ClientRealTime() + (scr_centertime->value * 1000); + } + + return; + } + + // hard and annoying! + // check if it's time to fetch a new char + const uint64_t t = cgi.CL_ClientRealTime(); + + if (!center.finished) { + if (center.time_tick < t) { + center.time_tick = t + (scr_printspeed->value * 1000); + center.line_count = FindEndOfUTF8Codepoint(center.lines[center.current_line], center.line_count + 1); + + if (center.line_count == std::string::npos) { + center.current_line++; + center.line_count = 0; + + if (center.current_line == center.lines.size()) { + center.current_line--; + center.finished = true; + center.time_off = t + (scr_centertime->value * 1000); + } + } + } + } + + // smallish byte buffer for single line of data... + char buffer[256]; + + for (size_t i = 0; i < center.lines.size(); i++) { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + + auto &line = center.lines[i]; + + buffer[0] = 0; + + if (center.finished || i != center.current_line) + Q_strlcpy(buffer, line.c_str(), sizeof(buffer)); + else + Q_strlcpy(buffer, line.c_str(), min(center.line_count + 1, sizeof(buffer))); + + int blinky_x; + + if (ui_acc_contrast->integer && line.length()) { + vec2_t sz = cgi.SCR_MeasureFontString(line.c_str(), scale); + sz.x += 10; // extra padding for black bars + int barY = ui_acc_alttypeface->integer ? y - 8 : y; + cgi.SCR_DrawColorPic((hud_vrect.x + hud_vrect.width / 2) * scale - (sz.x / 2), barY, sz.x, lineHeight, "_white", rgba_black); + } + + if (buffer[0]) + blinky_x = CG_DrawHUDString(buffer, (hud_vrect.x + hud_vrect.width / 2 + -160) * scale, y, (320 / 2) * 2 * scale, 0, scale); + else + blinky_x = (hud_vrect.width / 2) * scale; + + cgi.SCR_SetAltTypeface(false); + + if (i == center.current_line && !ui_acc_alttypeface->integer) + cgi.SCR_DrawChar(blinky_x, y, scale, 10 + ((cgi.CL_ClientRealTime() >> 8) & 1), true); + + y += lineHeight; + + if (i == center.current_line) + break; + } +} + +static void CG_CheckDrawCenterString(const player_state_t *ps, const vrect_t &hud_vrect, const vrect_t &hud_safe, int isplit, int scale) { + if (CG_InIntermission(ps)) + return; + if (!hud_data[isplit].center_index.has_value()) + return; + + auto &data = hud_data[isplit]; + auto ¢er = data.centers[data.center_index.value()]; + + // ran out of center time + if (center.finished && center.time_off < cgi.CL_ClientRealTime()) { + center.lines.clear(); + + size_t next_index = (data.center_index.value() + 1) % MAX_CENTER_PRINTS; + auto &next_center = data.centers[next_index]; + + // no more + if (next_center.lines.empty()) { + data.center_index.reset(); + return; + } + + // buffer rotated; start timer now + data.center_index = next_index; + next_center.current_line = next_center.line_count = 0; + } + + if (!data.center_index.has_value()) + return; + + CG_DrawCenterString(ps, hud_vrect, hud_safe, isplit, scale, data.centers[data.center_index.value()]); +} + +/* +============== +CG_DrawString +============== +*/ +static void CG_DrawString(int x, int y, int scale, const char *s, bool alt = false, bool shadow = true) { + while (*s) { + cgi.SCR_DrawChar(x, y, scale, *s ^ (alt ? 0x80 : 0), shadow); + x += 8 * scale; + s++; + } +} + +#include + +/* +============== +CG_DrawField +============== +*/ +static void CG_DrawField(int x, int y, int color, int width, int value, int scale) { + char num[16], *ptr; + int l; + int frame; + + if (width < 1) + return; + + // draw number string + if (width > 5) + width = 5; + + auto result = std::to_chars(num, num + sizeof(num) - 1, value); + *(result.ptr) = '\0'; + + l = (result.ptr - num); + + if (l > width) + l = width; + + x += (2 + CHAR_WIDTH * (width - l)) * scale; + + ptr = num; + while (*ptr && l) { + if (*ptr == '-') + frame = STAT_MINUS; + else + frame = *ptr - '0'; + int w, h; + cgi.Draw_GetPicSize(&w, &h, sb_nums[color][frame]); + cgi.SCR_DrawPic(x, y, w * scale, h * scale, sb_nums[color][frame]); + x += CHAR_WIDTH * scale; + ptr++; + l--; + } +} + +// [Paril-KEX] +static void CG_DrawTable(int x, int y, uint32_t width, uint32_t height, int32_t scale) { + // half left + int32_t width_pixels = width; + x -= width_pixels / 2; + y += CONCHAR_WIDTH * scale; + // use Y as top though + + int32_t height_pixels = height; + + // draw border + // KEX_FIXME method that requires less chars + cgi.SCR_DrawChar(x - (CONCHAR_WIDTH * scale), y - (CONCHAR_WIDTH * scale), scale, 18, false); + cgi.SCR_DrawChar((x + width_pixels), y - (CONCHAR_WIDTH * scale), scale, 20, false); + cgi.SCR_DrawChar(x - (CONCHAR_WIDTH * scale), y + height_pixels, scale, 24, false); + cgi.SCR_DrawChar((x + width_pixels), y + height_pixels, scale, 26, false); + + for (int cx = x; cx < x + width_pixels; cx += CONCHAR_WIDTH * scale) { + cgi.SCR_DrawChar(cx, y - (CONCHAR_WIDTH * scale), scale, 19, false); + cgi.SCR_DrawChar(cx, y + height_pixels, scale, 25, false); + } + + for (int cy = y; cy < y + height_pixels; cy += CONCHAR_WIDTH * scale) { + cgi.SCR_DrawChar(x - (CONCHAR_WIDTH * scale), cy, scale, 21, false); + cgi.SCR_DrawChar((x + width_pixels), cy, scale, 23, false); + } + + cgi.SCR_DrawColorPic(x, y, width_pixels, height_pixels, "_white", { 0, 0, 0, 255 }); + + // draw in columns + for (int i = 0; i < hud_temp.num_columns; i++) { + for (int r = 0, ry = y; r < hud_temp.num_rows; r++, ry += (CONCHAR_WIDTH + font_y_offset) * scale) { + int x_offset = 0; + + // center + if (r == 0) { + x_offset = ((hud_temp.column_widths[i]) / 2) - + ((cgi.SCR_MeasureFontString(hud_temp.table_rows[r].table_cells[i].text, scale).x) / 2); + } + // right align + else if (i != 0) { + x_offset = (hud_temp.column_widths[i] - cgi.SCR_MeasureFontString(hud_temp.table_rows[r].table_cells[i].text, scale).x); + } + + //CG_DrawString(x + x_offset, ry, scale, hud_temp.table_rows[r].table_cells[i].text, r == 0, true); + cgi.SCR_DrawFontString(hud_temp.table_rows[r].table_cells[i].text, x + x_offset, ry - (font_y_offset * scale), scale, r == 0 ? alt_color : rgba_white, true, text_align_t::LEFT); + } + + x += (hud_temp.column_widths[i] + cgi.SCR_MeasureFontString(" ", 1).x); + } +} + +/* +================ +CG_ExecuteLayoutString + +================ +*/ +static void CG_ExecuteLayoutString(const char *s, vrect_t hud_vrect, vrect_t hud_safe, int32_t scale, int32_t playernum, const player_state_t *ps) { + int x, y; + int w, h; + int hx, hy; + int value; + const char *token; + int width; + int index; + + if (!s[0]) + return; + + x = hud_vrect.x; + y = hud_vrect.y; + width = 3; + + hx = 320 / 2; + hy = 240 / 2; + + bool flash_frame = (cgi.CL_ClientTime() % 1000) < 500; + + // if non-zero, parse but don't affect state + int32_t if_depth = 0; // current if statement depth + int32_t endif_depth = 0; // at this depth, toggle skip_depth + bool skip_depth = false; // whether we're in a dead stmt or not + + while (s) { + token = COM_Parse(&s); + if (!strcmp(token, "xl")) { + token = COM_Parse(&s); + if (!skip_depth) + x = ((hud_vrect.x + atoi(token)) * scale) + hud_safe.x; + continue; + } + if (!strcmp(token, "xr")) { + token = COM_Parse(&s); + if (!skip_depth) + x = ((hud_vrect.x + hud_vrect.width + atoi(token)) * scale) - hud_safe.x; + continue; + } + if (!strcmp(token, "xv")) { + token = COM_Parse(&s); + if (!skip_depth) + x = (hud_vrect.x + hud_vrect.width / 2 + (atoi(token) - hx)) * scale; + continue; + } + + if (!strcmp(token, "yt")) { + token = COM_Parse(&s); + if (!skip_depth) + y = ((hud_vrect.y + atoi(token)) * scale) + hud_safe.y; + continue; + } + if (!strcmp(token, "yb")) { + token = COM_Parse(&s); + if (!skip_depth) + y = ((hud_vrect.y + hud_vrect.height + atoi(token)) * scale) - hud_safe.y; + continue; + } + if (!strcmp(token, "yv")) { + token = COM_Parse(&s); + if (!skip_depth) + y = (hud_vrect.y + hud_vrect.height / 2 + (atoi(token) - hy)) * scale; + continue; + } + + if (!strcmp(token, "pic")) { // draw a pic from a stat number + token = COM_Parse(&s); + if (!skip_depth) { + int16_t stat = atoi(token); + bool skip = false; + + value = ps->stats[stat]; + if (value >= MAX_IMAGES) + cgi.Com_Error("Pic >= MAX_IMAGES"); + + //muff: client-side hacky hacks - don't show vitals if spectating + if ((ps->stats[STAT_SPECTATOR] && !ps->stats[STAT_CHASE]) && (stat == STAT_HEALTH_ICON || stat == STAT_AMMO_ICON || stat == STAT_ARMOR_ICON)) + skip = true; + + const char *const pic = cgi.get_configstring(CS_IMAGES + value); + + if (pic && *pic && !skip) { + //muff: little hacky hack! resize the player pics on miniscores for clients rockin' muffmode + if (stat == STAT_MINISCORE_FIRST_PIC || stat == STAT_MINISCORE_SECOND_PIC) { + w = 24; + h = 24; + } else { + cgi.Draw_GetPicSize(&w, &h, pic); + } + cgi.SCR_DrawPic(x, y, w * scale, h * scale, pic); + } + } + + continue; + } + + if (!strcmp(token, "client")) { // draw a deathmatch client block + token = COM_Parse(&s); + if (!skip_depth) { + x = (hud_vrect.x + hud_vrect.width / 2 + (atoi(token) - hx)) * scale; + x += 8 * scale; + } + token = COM_Parse(&s); + if (!skip_depth) { + y = (hud_vrect.y + hud_vrect.height / 2 + (atoi(token) - hy)) * scale; + y += 7 * scale; + } + + token = COM_Parse(&s); + + if (!skip_depth) { + value = atoi(token); + if (value >= MAX_CLIENTS || value < 0) + cgi.Com_Error("client >= MAX_CLIENTS"); + } + + int score, ping; + + token = COM_Parse(&s); + if (!skip_depth) + score = atoi(token); + + token = COM_Parse(&s); + if (!skip_depth) { + ping = atoi(token); + + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + if (!scr_usekfont->integer) + CG_DrawString(x + 32 * scale, y, scale, cgi.CL_GetClientName(value)); + else + cgi.SCR_DrawFontString(cgi.CL_GetClientName(value), x + 32 * scale, y - (font_y_offset * scale), scale, rgba_white, true, text_align_t::LEFT); + + if (!scr_usekfont->integer) + CG_DrawString(x + 32 * scale, y + 10 * scale, scale, G_Fmt("{}", score).data(), true); + else + cgi.SCR_DrawFontString(G_Fmt("{}", score).data(), x + 32 * scale, y + (10 - font_y_offset) * scale, scale, rgba_white, true, text_align_t::LEFT); + + cgi.SCR_DrawPic(x + 96 * scale, y + 10 * scale, 9 * scale, 9 * scale, "ping"); + + if (!scr_usekfont->integer) + CG_DrawString(x + 73 * scale + 32 * scale, y + 10 * scale, scale, G_Fmt("{}", ping).data()); + else + cgi.SCR_DrawFontString(G_Fmt("{}", ping).data(), x + 107 * scale, y + (10 - font_y_offset) * scale, scale, rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + if (!strcmp(token, "ctf")) { // draw a ctf client block + int score, ping; + + token = COM_Parse(&s); + if (!skip_depth) + x = (hud_vrect.x + hud_vrect.width / 2 - hx + atoi(token)) * scale; + token = COM_Parse(&s); + if (!skip_depth) + y = (hud_vrect.y + hud_vrect.height / 2 - hy + atoi(token)) * scale; + + token = COM_Parse(&s); + if (!skip_depth) { + value = atoi(token); + if (value >= MAX_CLIENTS || value < 0) + cgi.Com_Error("client >= MAX_CLIENTS"); + } + + token = COM_Parse(&s); + if (!skip_depth) + score = atoi(token); + + token = COM_Parse(&s); + if (!skip_depth) { + ping = atoi(token); + if (ping > 999) + ping = 999; + } + + token = COM_Parse(&s); + + if (!skip_depth) { + + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(G_Fmt("{}", score).data(), x, y - (font_y_offset * scale), scale, value == playernum ? alt_color : rgba_white, true, text_align_t::LEFT); + x += 3 * 9 * scale; + cgi.SCR_DrawFontString(G_Fmt("{}", ping).data(), x, y - (font_y_offset * scale), scale, value == playernum ? alt_color : rgba_white, true, text_align_t::LEFT); + x += 3 * 9 * scale; + cgi.SCR_DrawFontString(cgi.CL_GetClientName(value), x, y - (font_y_offset * scale), scale, value == playernum ? alt_color : rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + + if (*token) { + cgi.Draw_GetPicSize(&w, &h, token); + cgi.SCR_DrawPic(x - ((w + 2) * scale), y, w * scale, h * scale, token); + } + } + continue; + } + + if (!strcmp(token, "picn")) { // draw a pic from a name + token = COM_Parse(&s); + if (!skip_depth) { + //muff: hoo boy, another little hacky hack + if (strstr(token, "/players/")) { + w = h = 32; + + } else if (!strcmp(token, "wheel/p_compass_selected")) { + w = h = 12; + + } else { + cgi.Draw_GetPicSize(&w, &h, token); + } + cgi.SCR_DrawPic(x, y, w * scale, h * scale, token); + } + continue; + } + + if (!strcmp(token, "num")) { // draw a number + token = COM_Parse(&s); + if (!skip_depth) + width = atoi(token); + token = COM_Parse(&s); + if (!skip_depth) { + value = ps->stats[atoi(token)]; + //muff: little hacky hack to conditionally hide text for muffmode connoisseurs + if (value != -999) + CG_DrawField(x, y, 0, width, value, scale); + } + continue; + } + // [Paril-KEX] special handling for the lives number + else if (!strcmp(token, "lives_num")) { + token = COM_Parse(&s); + if (!skip_depth) { + value = ps->stats[atoi(token)]; + CG_DrawField(x, y, value <= 2 ? flash_frame : 0, 1, max(0, value - 2), scale); + } + } + + //muff: client-side hacky hacks - don't show vitals if spectating + if (!ps->stats[STAT_SPECTATOR] || ps->stats[STAT_CHASE]) { + if (!strcmp(token, "hnum")) { + // health number + if (!skip_depth) { + int color; + + width = 3; + value = ps->stats[STAT_HEALTH]; + if (value > 25) + color = 0; // green + else if (value > 0) + color = flash_frame; // flash + else + color = 1; + if (ps->stats[STAT_FLASHES] & 1) { + cgi.Draw_GetPicSize(&w, &h, "field_3"); + cgi.SCR_DrawPic(x, y, w * scale, h * scale, "field_3"); + } + + CG_DrawField(x, y, color, width, value, scale); + } + continue; + } + + if (!strcmp(token, "anum")) { + // ammo number + if (!skip_depth) { + int color; + + width = 3; + value = ps->stats[STAT_AMMO]; + + int32_t min_ammo = cgi.CL_GetWarnAmmoCount(ps->stats[STAT_ACTIVE_WEAPON]); + + if (!min_ammo) + min_ammo = 5; // back compat + + if (value > min_ammo) + color = 0; // green + else if (value >= 0) + color = flash_frame; // flash + else + continue; // negative number = don't show + if (ps->stats[STAT_FLASHES] & 4) { + cgi.Draw_GetPicSize(&w, &h, "field_3"); + cgi.SCR_DrawPic(x, y, w * scale, h * scale, "field_3"); + } + + CG_DrawField(x, y, color, width, value, scale); + } + continue; + } + + if (!strcmp(token, "rnum")) { + // armor number + if (!skip_depth) { + int color; + + width = 3; + value = ps->stats[STAT_ARMOR]; + if (value < 0) + continue; + + color = 0; // green + if (ps->stats[STAT_FLASHES] & 2) { + cgi.Draw_GetPicSize(&w, &h, "field_3"); + cgi.SCR_DrawPic(x, y, w * scale, h * scale, "field_3"); + } + + CG_DrawField(x, y, color, width, value, scale); + } + continue; + } + } + if (!strcmp(token, "stat_string")) { + token = COM_Parse(&s); + + if (!skip_depth) { + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + index = ps->stats[index]; + + if (cgi.CL_ServerProtocol() <= PROTOCOL_VERSION_3XX) + index = CS_REMAP(index).start / CS_MAX_STRING_LENGTH; + + if (index < 0 || index >= MAX_CONFIGSTRINGS) + cgi.Com_Error("Bad stat_string index"); + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, cgi.get_configstring(index)); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(cgi.get_configstring(index), x, y - (font_y_offset * scale), scale, rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + // Q2Eaks alt color stat string + if (!strcmp(token, "stat_string2")) { + token = COM_Parse(&s); + + if (!skip_depth) { + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + index = ps->stats[index]; + + if (cgi.CL_ServerProtocol() <= PROTOCOL_VERSION_3XX) + index = CS_REMAP(index).start / CS_MAX_STRING_LENGTH; + + if (index < 0 || index >= MAX_CONFIGSTRINGS) + cgi.Com_Error("Bad stat_string index"); + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, cgi.get_configstring(index)); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(cgi.get_configstring(index), x, y - (font_y_offset * scale), scale, alt_color, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "cstring")) { + token = COM_Parse(&s); + if (!skip_depth) { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(token, x, y, hx * 2 * scale, 0, scale); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + if (!strcmp(token, "string")) { + token = COM_Parse(&s); + if (!skip_depth) { + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, token); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(token, x, y - (font_y_offset * scale), scale, rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "cstring2")) { + token = COM_Parse(&s); + if (!skip_depth) { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(token, x, y, hx * 2 * scale, 0x80, scale); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + if (!strcmp(token, "string2")) { + token = COM_Parse(&s); + if (!skip_depth) { + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, token, true); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(token, x, y - (font_y_offset * scale), scale, alt_color, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "if")) { + // if stmt + token = COM_Parse(&s); + + if_depth++; + + // skip to endif + if (!skip_depth && !ps->stats[atoi(token)]) { + skip_depth = true; + endif_depth = if_depth; + } + + continue; + } + + if (!strcmp(token, "ifgef")) { + // if stmt + token = COM_Parse(&s); + + if_depth++; + + // skip to endif + if (!skip_depth && cgi.CL_ServerFrame() < atoi(token)) { + skip_depth = true; + endif_depth = if_depth; + } + + continue; + } + + if (!strcmp(token, "endif")) { + if (skip_depth && (if_depth == endif_depth)) + skip_depth = false; + + if_depth--; + + if (if_depth < 0) + cgi.Com_Error("endif without matching if"); + + continue; + } + + // localization stuff + if (!strcmp(token, "loc_stat_string")) { + token = COM_Parse(&s); + + if (!skip_depth) { + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + index = ps->stats[index]; + + if (cgi.CL_ServerProtocol() <= PROTOCOL_VERSION_3XX) + index = CS_REMAP(index).start / CS_MAX_STRING_LENGTH; + + if (index < 0 || index >= MAX_CONFIGSTRINGS) + cgi.Com_Error("Bad stat_string index"); + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, cgi.Localize(cgi.get_configstring(index), nullptr, 0)); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(cgi.Localize(cgi.get_configstring(index), nullptr, 0), x, y - (font_y_offset * scale), scale, rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "loc_stat_rstring")) { + token = COM_Parse(&s); + + if (!skip_depth) { + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + index = ps->stats[index]; + + if (cgi.CL_ServerProtocol() <= PROTOCOL_VERSION_3XX) + index = CS_REMAP(index).start / CS_MAX_STRING_LENGTH; + + if (index < 0 || index >= MAX_CONFIGSTRINGS) + cgi.Com_Error("Bad stat_string index"); + const char *s = cgi.Localize(cgi.get_configstring(index), nullptr, 0); + if (!scr_usekfont->integer) + CG_DrawString(x - (strlen(s) * CONCHAR_WIDTH * scale), y, scale, s); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + vec2_t size = cgi.SCR_MeasureFontString(s, scale); + cgi.SCR_DrawFontString(s, x - size.x, y - (font_y_offset * scale), scale, rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "loc_stat_cstring")) { + token = COM_Parse(&s); + + if (!skip_depth) { + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + index = ps->stats[index]; + + if (cgi.CL_ServerProtocol() <= PROTOCOL_VERSION_3XX) + index = CS_REMAP(index).start / CS_MAX_STRING_LENGTH; + + if (index < 0 || index >= MAX_CONFIGSTRINGS) + cgi.Com_Error("Bad stat_string index"); + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(cgi.Localize(cgi.get_configstring(index), nullptr, 0), x, y, hx * 2 * scale, 0, scale); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + if (!strcmp(token, "loc_stat_cstring2")) { + token = COM_Parse(&s); + + if (!skip_depth) { + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + index = ps->stats[index]; + + if (cgi.CL_ServerProtocol() <= PROTOCOL_VERSION_3XX) + index = CS_REMAP(index).start / CS_MAX_STRING_LENGTH; + + if (index < 0 || index >= MAX_CONFIGSTRINGS) + cgi.Com_Error("Bad stat_string index"); + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(cgi.Localize(cgi.get_configstring(index), nullptr, 0), x, y, hx * 2 * scale, 0x80, scale); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + static char arg_tokens[MAX_LOCALIZATION_ARGS + 1][MAX_TOKEN_CHARS]; + static const char *arg_buffers[MAX_LOCALIZATION_ARGS]; + + if (!strcmp(token, "loc_cstring")) { + int32_t num_args = atoi(COM_Parse(&s)); + + if (num_args < 0 || num_args >= MAX_LOCALIZATION_ARGS) + cgi.Com_Error("Bad loc string"); + + // parse base + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[0], token, sizeof(arg_tokens[0])); + + // parse args + for (size_t i = 0; i < num_args; i++) { + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[1 + i], token, sizeof(arg_tokens[0])); + arg_buffers[i] = arg_tokens[1 + i]; + } + + if (!skip_depth) { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(cgi.Localize(arg_tokens[0], arg_buffers, num_args), x, y, hx * 2 * scale, 0, scale); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + if (!strcmp(token, "loc_string")) { + int32_t num_args = atoi(COM_Parse(&s)); + + if (num_args < 0 || num_args >= MAX_LOCALIZATION_ARGS) + cgi.Com_Error("Bad loc string"); + + // parse base + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[0], token, sizeof(arg_tokens[0])); + + // parse args + for (size_t i = 0; i < num_args; i++) { + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[1 + i], token, sizeof(arg_tokens[0])); + arg_buffers[i] = arg_tokens[1 + i]; + } + + if (!skip_depth) { + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, cgi.Localize(arg_tokens[0], arg_buffers, num_args)); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(cgi.Localize(arg_tokens[0], arg_buffers, num_args), x, y - (font_y_offset * scale), scale, rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "loc_cstring2")) { + int32_t num_args = atoi(COM_Parse(&s)); + + if (num_args < 0 || num_args >= MAX_LOCALIZATION_ARGS) + cgi.Com_Error("Bad loc string"); + + // parse base + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[0], token, sizeof(arg_tokens[0])); + + // parse args + for (size_t i = 0; i < num_args; i++) { + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[1 + i], token, sizeof(arg_tokens[0])); + arg_buffers[i] = arg_tokens[1 + i]; + } + + if (!skip_depth) { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(cgi.Localize(arg_tokens[0], arg_buffers, num_args), x, y, hx * 2 * scale, 0x80, scale); + cgi.SCR_SetAltTypeface(false); + } + continue; + } + + if (!strcmp(token, "loc_string2") || !strcmp(token, "loc_rstring2") || + !strcmp(token, "loc_string") || !strcmp(token, "loc_rstring")) { + bool green = token[strlen(token) - 1] == '2'; + bool rightAlign = !Q_strncasecmp(token, "loc_rstring", strlen("loc_rstring")); + int32_t num_args = atoi(COM_Parse(&s)); + + if (num_args < 0 || num_args >= MAX_LOCALIZATION_ARGS) + cgi.Com_Error("Bad loc string"); + + // parse base + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[0], token, sizeof(arg_tokens[0])); + + // parse args + for (size_t i = 0; i < num_args; i++) { + token = COM_Parse(&s); + Q_strlcpy(arg_tokens[1 + i], token, sizeof(arg_tokens[0])); + arg_buffers[i] = arg_tokens[1 + i]; + } + + if (!skip_depth) { + const char *locStr = cgi.Localize(arg_tokens[0], arg_buffers, num_args); + int xOffs = 0; + if (rightAlign) { + xOffs = scr_usekfont->integer ? cgi.SCR_MeasureFontString(locStr, scale).x : (strlen(locStr) * CONCHAR_WIDTH * scale); + } + + if (!scr_usekfont->integer) + CG_DrawString(x - xOffs, y, scale, locStr, green); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(locStr, x - xOffs, y - (font_y_offset * scale), scale, green ? alt_color : rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + // draw time remaining + if (!strcmp(token, "time_limit")) { + // end frame + token = COM_Parse(&s); + + if (!skip_depth) { + int32_t end_frame = atoi(token); + + if (end_frame < cgi.CL_ServerFrame()) + continue; + + uint64_t remaining_ms = (end_frame - cgi.CL_ServerFrame()) * cgi.frame_time_ms; + + const bool green = true; + arg_buffers[0] = G_Fmt("{:02}:{:02}", (remaining_ms / 1000) / 60, (remaining_ms / 1000) % 60).data(); + + const char *locStr = cgi.Localize("$g_score_time", arg_buffers, 1); + int xOffs = scr_usekfont->integer ? cgi.SCR_MeasureFontString(locStr, scale).x : (strlen(locStr) * CONCHAR_WIDTH * scale); + if (!scr_usekfont->integer) + CG_DrawString(x - xOffs, y, scale, locStr, green); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(locStr, x - xOffs, y - (font_y_offset * scale), scale, green ? alt_color : rgba_white, true, text_align_t::LEFT); + cgi.SCR_SetAltTypeface(false); + } + } + } + + // draw client dogtag + if (!strcmp(token, "dogtag")) { + token = COM_Parse(&s); + + if (!skip_depth) { + value = atoi(token); + if (value >= MAX_CLIENTS || value < 0) + cgi.Com_Error("client >= MAX_CLIENTS"); + + const std::string_view path = G_Fmt("/tags/{}", cgi.CL_GetClientDogtag(value)); + cgi.SCR_DrawPic(x, y, 198 * scale, 32 * scale, path.data()); + } + } + + if (!strcmp(token, "start_table")) { + token = COM_Parse(&s); + value = atoi(token); + + if (!skip_depth) { + if (value >= q_countof(hud_temp.table_rows[0].table_cells)) + cgi.Com_Error("table too big"); + + hud_temp.num_columns = value; + hud_temp.num_rows = 1; + + for (int i = 0; i < value; i++) + hud_temp.column_widths[i] = 0; + } + + for (int i = 0; i < value; i++) { + token = COM_Parse(&s); + if (!skip_depth) { + token = cgi.Localize(token, nullptr, 0); + Q_strlcpy(hud_temp.table_rows[0].table_cells[i].text, token, sizeof(hud_temp.table_rows[0].table_cells[i].text)); + hud_temp.column_widths[i] = max(hud_temp.column_widths[i], (size_t)cgi.SCR_MeasureFontString(hud_temp.table_rows[0].table_cells[i].text, scale).x); + } + } + } + + if (!strcmp(token, "table_row")) { + token = COM_Parse(&s); + value = atoi(token); + + if (!skip_depth) { + if (hud_temp.num_rows >= q_countof(hud_temp.table_rows)) { + cgi.Com_Error("table too big"); + return; + } + } + + auto &row = hud_temp.table_rows[hud_temp.num_rows]; + + for (int i = 0; i < value; i++) { + token = COM_Parse(&s); + if (!skip_depth) { + Q_strlcpy(row.table_cells[i].text, token, sizeof(row.table_cells[i].text)); + hud_temp.column_widths[i] = max(hud_temp.column_widths[i], (size_t)cgi.SCR_MeasureFontString(row.table_cells[i].text, scale).x); + } + } + + if (!skip_depth) { + for (int i = value; i < hud_temp.num_columns; i++) + row.table_cells[i].text[0] = '\0'; + + hud_temp.num_rows++; + } + } + + if (!strcmp(token, "draw_table")) { + if (!skip_depth) { + // in scaled pixels, incl padding between elements + uint32_t total_inner_table_width = 0; + + for (int i = 0; i < hud_temp.num_columns; i++) { + if (i != 0) + total_inner_table_width += cgi.SCR_MeasureFontString(" ", scale).x; + + total_inner_table_width += hud_temp.column_widths[i]; + } + + // in scaled pixels + uint32_t total_table_height = hud_temp.num_rows * (CONCHAR_WIDTH + font_y_offset) * scale; + + CG_DrawTable(x, y, total_inner_table_width, total_table_height, scale); + } + } + + if (!strcmp(token, "stat_pname")) { + token = COM_Parse(&s); + + if (!skip_depth) { + text_align_t align = text_align_t::LEFT; + + index = atoi(token); + if (index < 0 || index >= MAX_STATS) + cgi.Com_Error("Bad stat_string index"); + + //muff: hacky hacks - move crosshair id text to 160, align centrally + if (index == STAT_CROSSHAIR_ID_VIEW) { + x = (hud_vrect.x + hud_vrect.width / 2 + 160 - hx) * scale; + align = text_align_t::CENTER; + } + + index = ps->stats[index] - 1; + + if (!scr_usekfont->integer) + CG_DrawString(x, y, scale, cgi.CL_GetClientName(index)); + else { + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(cgi.CL_GetClientName(index), x, y - (font_y_offset * scale), scale, rgba_white, true, align); + cgi.SCR_SetAltTypeface(false); + } + } + continue; + } + + if (!strcmp(token, "health_bars")) { + if (skip_depth) + continue; + + const byte *stat = reinterpret_cast(&ps->stats[STAT_HEALTH_BARS]); + const char *name = cgi.Localize(cgi.get_configstring(CONFIG_HEALTH_BAR_NAME), nullptr, 0); + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + CG_DrawHUDString(name, (hud_vrect.x + hud_vrect.width / 2 + -160) * scale, y, (320 / 2) * 2 * scale, 0, scale); + cgi.SCR_SetAltTypeface(false); + float bar_width = ((hud_vrect.width * scale) - (hud_safe.x * 2)) * 0.50f; + float bar_height = 4 * scale; + + y += cgi.SCR_FontLineHeight(scale); + + float x = ((hud_vrect.x + (hud_vrect.width * 0.5f)) * scale) - (bar_width * 0.5f); + + // 2 health bars, hardcoded + for (size_t i = 0; i < 2; i++, stat++) { + if (!(*stat & 0b10000000)) + continue; + + float percent = (*stat & 0b01111111) / 127.f; + + cgi.SCR_DrawColorPic(x, y, bar_width + scale, bar_height + scale, "_white", rgba_black); + + if (percent > 0) + cgi.SCR_DrawColorPic(x, y, bar_width * percent, bar_height, "_white", rgba_red); + if (percent < 1) + cgi.SCR_DrawColorPic(x + (bar_width * percent), y, bar_width * (1.f - percent), bar_height, "_white", { 80, 80, 80, 255 }); + + y += bar_height * 3; + } + } + + if (!strcmp(token, "story")) { + const char *story_str = cgi.get_configstring(CONFIG_STORY_SCORELIMIT); + + if (!*story_str) + continue; + + const char *localized = cgi.Localize(story_str, nullptr, 0); + vec2_t size = cgi.SCR_MeasureFontString(localized, scale); + float centerx = ((hud_vrect.x + (hud_vrect.width * 0.5f)) * scale); + float centery = ((hud_vrect.y + (hud_vrect.height * 0.5f)) * scale) - (size.y * 0.5f); + + cgi.SCR_SetAltTypeface(ui_acc_alttypeface->integer && true); + cgi.SCR_DrawFontString(localized, centerx, centery, scale, rgba_white, true, text_align_t::CENTER); + cgi.SCR_SetAltTypeface(false); + } + } + + if (skip_depth) + cgi.Com_Error("if with no matching endif"); +} + +static cvar_t *cl_skipHud; +static cvar_t *cl_paused; + +/* +================ +CL_DrawInventory +================ +*/ +constexpr size_t DISPLAY_ITEMS = 19; + +static void CG_DrawInventory(const player_state_t *ps, const std::array &inventory, vrect_t hud_vrect, int32_t scale) { + int i; + int num, selected_num, item; + int index[MAX_ITEMS]; + int x, y; + int width, height; + int selected; + int top; + + selected = ps->stats[STAT_SELECTED_ITEM]; + + num = 0; + selected_num = 0; + for (i = 0; i < MAX_ITEMS; i++) { + if (i == selected) { + selected_num = num; + } + if (inventory[i]) { + index[num] = i; + num++; + } + } + + // determine scroll point + top = selected_num - DISPLAY_ITEMS / 2; + if (num - top < DISPLAY_ITEMS) + top = num - DISPLAY_ITEMS; + if (top < 0) + top = 0; + + x = hud_vrect.x * scale; + y = hud_vrect.y * scale; + width = hud_vrect.width; + height = hud_vrect.height; + + x += ((width / 2) - (256 / 2)) * scale; + y += ((height / 2) - (216 / 2)) * scale; + + int pich, picw; + cgi.Draw_GetPicSize(&picw, &pich, "inventory"); + cgi.SCR_DrawPic(x, y + 8 * scale, picw * scale, pich * scale, "inventory"); + + y += 27 * scale; + x += 22 * scale; + + for (i = top; i < num && i < top + DISPLAY_ITEMS; i++) { + item = index[i]; + if (item == selected) // draw a blinky cursor by the selected item + { + if ((cgi.CL_ClientRealTime() * 10) & 1) + cgi.SCR_DrawChar(x - 8, y, scale, 15, false); + } + + if (!scr_usekfont->integer) { + CG_DrawString(x, y, scale, + G_Fmt("{:3} {}", inventory[item], + cgi.Localize(cgi.get_configstring(CS_ITEMS + item), nullptr, 0)).data(), + item == selected, false); + } else { + const char *string = G_Fmt("{}", inventory[item]).data(); + cgi.SCR_DrawFontString(string, x + (216 * scale) - (16 * scale), y - (font_y_offset * scale), scale, (item == selected) ? alt_color : rgba_white, true, text_align_t::RIGHT); + + string = cgi.Localize(cgi.get_configstring(CS_ITEMS + item), nullptr, 0); + cgi.SCR_DrawFontString(string, x + (16 * scale), y - (font_y_offset * scale), scale, (item == selected) ? alt_color : rgba_white, true, text_align_t::LEFT); + } + + y += 8 * scale; + } +} + +extern uint64_t cgame_init_time; + +void CG_DrawHUD(int32_t isplit, const cg_server_data_t *data, vrect_t hud_vrect, vrect_t hud_safe, int32_t scale, int32_t playernum, const player_state_t *ps) { + if (cgi.CL_InAutoDemoLoop()) { + if (cl_paused->integer) return; // demo is paused, menu is open + + uint64_t time = cgi.CL_ClientRealTime() - cgame_init_time; + if (time < 20000 && + (time % 4000) < 2000) + cgi.SCR_DrawFontString(cgi.Localize("$m_eou_press_button", nullptr, 0), hud_vrect.width * 0.5f * scale, (hud_vrect.height - 64.f) * scale, scale, rgba_green, true, text_align_t::CENTER); + return; + } + + // draw HUD + if (!cl_skipHud->integer && !(ps->stats[STAT_LAYOUTS] & LAYOUTS_HIDE_HUD)) + CG_ExecuteLayoutString(cgi.get_configstring(CS_STATUSBAR), hud_vrect, hud_safe, scale, playernum, ps); + + // draw centerprint string + CG_CheckDrawCenterString(ps, hud_vrect, hud_safe, isplit, scale); + + // draw notify + CG_DrawNotify(isplit, hud_vrect, hud_safe, scale); + + // svc_layout still drawn with hud off + if (ps->stats[STAT_LAYOUTS] & LAYOUTS_LAYOUT) + CG_ExecuteLayoutString(data->layout, hud_vrect, hud_safe, scale, playernum, ps); + + // inventory too + if (ps->stats[STAT_LAYOUTS] & LAYOUTS_INVENTORY) + CG_DrawInventory(ps, data->inventory, hud_vrect, scale); +} + +/* +================ +CG_TouchPics + +================ +*/ +void CG_TouchPics() { + for (auto &nums : sb_nums) + for (auto &str : nums) + cgi.Draw_RegisterPic(str); + + cgi.Draw_RegisterPic("inventory"); + + font_y_offset = (cgi.SCR_FontLineHeight(1) - CONCHAR_WIDTH) / 2; +} + +void CG_InitScreen() { + cl_paused = cgi.cvar("paused", "0", CVAR_NOFLAGS); + cl_skipHud = cgi.cvar("cl_skipHud", "0", CVAR_ARCHIVE); + scr_usekfont = cgi.cvar("scr_usekfont", "1", CVAR_NOFLAGS); + + scr_centertime = cgi.cvar("scr_centertime", "5.0", CVAR_ARCHIVE); // [Sam-KEX] Changed from 2.5 + scr_printspeed = cgi.cvar("scr_printspeed", "0.04", CVAR_NOFLAGS); // [Sam-KEX] Changed from 8 + cl_notifytime = cgi.cvar("cl_notifytime", "5.0", CVAR_ARCHIVE); + scr_maxlines = cgi.cvar("scr_maxlines", "4", CVAR_ARCHIVE); + ui_acc_contrast = cgi.cvar("ui_acc_contrast", "0", CVAR_NOFLAGS); + ui_acc_alttypeface = cgi.cvar("ui_acc_alttypeface", "0", CVAR_NOFLAGS); + + hud_data = {}; +} \ No newline at end of file diff --git a/src/fmt.cc b/src/fmt.cc new file mode 100644 index 0000000..a02167c --- /dev/null +++ b/src/fmt.cc @@ -0,0 +1,110 @@ +module; + +// Put all implementation-provided headers into the global module fragment +// to prevent attachment to this module. +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#if __has_include() +# include +#endif +#if defined(_MSC_VER) || defined(__MINGW32__) +# include +#endif +#if defined __APPLE__ || defined(__FreeBSD__) +# include +#endif +#if __has_include() +# include +#endif +#if (__has_include() || defined(__APPLE__) || \ + defined(__linux__)) && \ + (!defined(WINAPI_FAMILY) || (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP)) +# include +# include +# include +# ifndef _WIN32 +# include +# else +# include +# endif +#endif +#ifdef _WIN32 +# if defined(__GLIBCXX__) +# include +# include +# elif defined(_LIBCPP_VERSION) +# include <__std_stream> +# endif +# define WIN32_LEAN_AND_MEAN +# include +#endif + +export module fmt; + +#define FMT_EXPORT export +#define FMT_BEGIN_EXPORT export { +#define FMT_END_EXPORT } + +// If you define FMT_ATTACH_TO_GLOBAL_MODULE +// - all declarations are detached from module 'fmt' +// - the module behaves like a traditional static library, too +// - all library symbols are mangled traditionally +// - you can mix TUs with either importing or #including the {fmt} API +#ifdef FMT_ATTACH_TO_GLOBAL_MODULE +extern "C++" { +#endif + +// All library-provided declarations and definitions must be in the module +// purview to be exported. +#include "fmt/args.h" +#include "fmt/chrono.h" +#include "fmt/color.h" +#include "fmt/compile.h" +#include "fmt/format.h" +#include "fmt/os.h" +#include "fmt/printf.h" +#include "fmt/std.h" +#include "fmt/xchar.h" + +#ifdef FMT_ATTACH_TO_GLOBAL_MODULE +} +#endif + +// gcc doesn't yet implement private module fragments +#if !FMT_GCC_VERSION +module : private; +#endif + +#include "format.cc" +#include "os.cc" diff --git a/src/fmt/args.h b/src/fmt/args.h new file mode 100644 index 0000000..2d684e7 --- /dev/null +++ b/src/fmt/args.h @@ -0,0 +1,234 @@ +// Formatting library for C++ - dynamic argument lists +// +// Copyright (c) 2012 - present, Victor Zverovich +// All rights reserved. +// +// For the license information refer to format.h. + +#ifndef FMT_ARGS_H_ +#define FMT_ARGS_H_ + +#include // std::reference_wrapper +#include // std::unique_ptr +#include + +#include "core.h" + +FMT_BEGIN_NAMESPACE + +namespace detail { + +template struct is_reference_wrapper : std::false_type {}; +template +struct is_reference_wrapper> : std::true_type {}; + +template const T& unwrap(const T& v) { return v; } +template const T& unwrap(const std::reference_wrapper& v) { + return static_cast(v); +} + +class dynamic_arg_list { + // Workaround for clang's -Wweak-vtables. Unlike for regular classes, for + // templates it doesn't complain about inability to deduce single translation + // unit for placing vtable. So storage_node_base is made a fake template. + template struct node { + virtual ~node() = default; + std::unique_ptr> next; + }; + + template struct typed_node : node<> { + T value; + + template + FMT_CONSTEXPR typed_node(const Arg& arg) : value(arg) {} + + template + FMT_CONSTEXPR typed_node(const basic_string_view& arg) + : value(arg.data(), arg.size()) {} + }; + + std::unique_ptr> head_; + + public: + template const T& push(const Arg& arg) { + auto new_node = std::unique_ptr>(new typed_node(arg)); + auto& value = new_node->value; + new_node->next = std::move(head_); + head_ = std::move(new_node); + return value; + } +}; +} // namespace detail + +/** + \rst + A dynamic version of `fmt::format_arg_store`. + It's equipped with a storage to potentially temporary objects which lifetimes + could be shorter than the format arguments object. + + It can be implicitly converted into `~fmt::basic_format_args` for passing + into type-erased formatting functions such as `~fmt::vformat`. + \endrst + */ +template +class dynamic_format_arg_store +#if FMT_GCC_VERSION && FMT_GCC_VERSION < 409 + // Workaround a GCC template argument substitution bug. + : public basic_format_args +#endif +{ + private: + using char_type = typename Context::char_type; + + template struct need_copy { + static constexpr detail::type mapped_type = + detail::mapped_type_constant::value; + + enum { + value = !(detail::is_reference_wrapper::value || + std::is_same>::value || + std::is_same>::value || + (mapped_type != detail::type::cstring_type && + mapped_type != detail::type::string_type && + mapped_type != detail::type::custom_type)) + }; + }; + + template + using stored_type = conditional_t< + std::is_convertible>::value && + !detail::is_reference_wrapper::value, + std::basic_string, T>; + + // Storage of basic_format_arg must be contiguous. + std::vector> data_; + std::vector> named_info_; + + // Storage of arguments not fitting into basic_format_arg must grow + // without relocation because items in data_ refer to it. + detail::dynamic_arg_list dynamic_args_; + + friend class basic_format_args; + + unsigned long long get_types() const { + return detail::is_unpacked_bit | data_.size() | + (named_info_.empty() + ? 0ULL + : static_cast(detail::has_named_args_bit)); + } + + const basic_format_arg* data() const { + return named_info_.empty() ? data_.data() : data_.data() + 1; + } + + template void emplace_arg(const T& arg) { + data_.emplace_back(detail::make_arg(arg)); + } + + template + void emplace_arg(const detail::named_arg& arg) { + if (named_info_.empty()) { + constexpr const detail::named_arg_info* zero_ptr{nullptr}; + data_.insert(data_.begin(), {zero_ptr, 0}); + } + data_.emplace_back(detail::make_arg(detail::unwrap(arg.value))); + auto pop_one = [](std::vector>* data) { + data->pop_back(); + }; + std::unique_ptr>, decltype(pop_one)> + guard{&data_, pop_one}; + named_info_.push_back({arg.name, static_cast(data_.size() - 2u)}); + data_[0].value_.named_args = {named_info_.data(), named_info_.size()}; + guard.release(); + } + + public: + constexpr dynamic_format_arg_store() = default; + + /** + \rst + Adds an argument into the dynamic store for later passing to a formatting + function. + + Note that custom types and string types (but not string views) are copied + into the store dynamically allocating memory if necessary. + + **Example**:: + + fmt::dynamic_format_arg_store store; + store.push_back(42); + store.push_back("abc"); + store.push_back(1.5f); + std::string result = fmt::vformat("{} and {} and {}", store); + \endrst + */ + template void push_back(const T& arg) { + if (detail::const_check(need_copy::value)) + emplace_arg(dynamic_args_.push>(arg)); + else + emplace_arg(detail::unwrap(arg)); + } + + /** + \rst + Adds a reference to the argument into the dynamic store for later passing to + a formatting function. + + **Example**:: + + fmt::dynamic_format_arg_store store; + char band[] = "Rolling Stones"; + store.push_back(std::cref(band)); + band[9] = 'c'; // Changing str affects the output. + std::string result = fmt::vformat("{}", store); + // result == "Rolling Scones" + \endrst + */ + template void push_back(std::reference_wrapper arg) { + static_assert( + need_copy::value, + "objects of built-in types and string views are always copied"); + emplace_arg(arg.get()); + } + + /** + Adds named argument into the dynamic store for later passing to a formatting + function. ``std::reference_wrapper`` is supported to avoid copying of the + argument. The name is always copied into the store. + */ + template + void push_back(const detail::named_arg& arg) { + const char_type* arg_name = + dynamic_args_.push>(arg.name).c_str(); + if (detail::const_check(need_copy::value)) { + emplace_arg( + fmt::arg(arg_name, dynamic_args_.push>(arg.value))); + } else { + emplace_arg(fmt::arg(arg_name, arg.value)); + } + } + + /** Erase all elements from the store */ + void clear() { + data_.clear(); + named_info_.clear(); + dynamic_args_ = detail::dynamic_arg_list(); + } + + /** + \rst + Reserves space to store at least *new_cap* arguments including + *new_cap_named* named arguments. + \endrst + */ + void reserve(size_t new_cap, size_t new_cap_named) { + FMT_ASSERT(new_cap >= new_cap_named, + "Set of arguments includes set of named arguments"); + data_.reserve(new_cap); + named_info_.reserve(new_cap_named); + } +}; + +FMT_END_NAMESPACE + +#endif // FMT_ARGS_H_ diff --git a/src/fmt/chrono.h b/src/fmt/chrono.h new file mode 100644 index 0000000..ff3e144 --- /dev/null +++ b/src/fmt/chrono.h @@ -0,0 +1,2208 @@ +// Formatting library for C++ - chrono support +// +// Copyright (c) 2012 - present, Victor Zverovich +// All rights reserved. +// +// For the license information refer to format.h. + +#ifndef FMT_CHRONO_H_ +#define FMT_CHRONO_H_ + +#include +#include +#include // std::isfinite +#include // std::memcpy +#include +#include +#include +#include +#include + +#include "format.h" + +FMT_BEGIN_NAMESPACE + +// Check if std::chrono::local_t is available. +#ifndef FMT_USE_LOCAL_TIME +# ifdef __cpp_lib_chrono +# define FMT_USE_LOCAL_TIME (__cpp_lib_chrono >= 201907L) +# else +# define FMT_USE_LOCAL_TIME 0 +# endif +#endif + +// Check if std::chrono::utc_timestamp is available. +#ifndef FMT_USE_UTC_TIME +# ifdef __cpp_lib_chrono +# define FMT_USE_UTC_TIME (__cpp_lib_chrono >= 201907L) +# else +# define FMT_USE_UTC_TIME 0 +# endif +#endif + +// Enable tzset. +#ifndef FMT_USE_TZSET +// UWP doesn't provide _tzset. +# if FMT_HAS_INCLUDE("winapifamily.h") +# include +# endif +# if defined(_WIN32) && (!defined(WINAPI_FAMILY) || \ + (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP)) +# define FMT_USE_TZSET 1 +# else +# define FMT_USE_TZSET 0 +# endif +#endif + +// Enable safe chrono durations, unless explicitly disabled. +#ifndef FMT_SAFE_DURATION_CAST +# define FMT_SAFE_DURATION_CAST 1 +#endif +#if FMT_SAFE_DURATION_CAST + +// For conversion between std::chrono::durations without undefined +// behaviour or erroneous results. +// This is a stripped down version of duration_cast, for inclusion in fmt. +// See https://github.com/pauldreik/safe_duration_cast +// +// Copyright Paul Dreik 2019 +namespace safe_duration_cast { + +template ::value && + std::numeric_limits::is_signed == + std::numeric_limits::is_signed)> +FMT_CONSTEXPR To lossless_integral_conversion(const From from, int& ec) { + ec = 0; + using F = std::numeric_limits; + using T = std::numeric_limits; + static_assert(F::is_integer, "From must be integral"); + static_assert(T::is_integer, "To must be integral"); + + // A and B are both signed, or both unsigned. + if (detail::const_check(F::digits <= T::digits)) { + // From fits in To without any problem. + } else { + // From does not always fit in To, resort to a dynamic check. + if (from < (T::min)() || from > (T::max)()) { + // outside range. + ec = 1; + return {}; + } + } + return static_cast(from); +} + +/** + * converts From to To, without loss. If the dynamic value of from + * can't be converted to To without loss, ec is set. + */ +template ::value && + std::numeric_limits::is_signed != + std::numeric_limits::is_signed)> +FMT_CONSTEXPR To lossless_integral_conversion(const From from, int& ec) { + ec = 0; + using F = std::numeric_limits; + using T = std::numeric_limits; + static_assert(F::is_integer, "From must be integral"); + static_assert(T::is_integer, "To must be integral"); + + if (detail::const_check(F::is_signed && !T::is_signed)) { + // From may be negative, not allowed! + if (fmt::detail::is_negative(from)) { + ec = 1; + return {}; + } + // From is positive. Can it always fit in To? + if (detail::const_check(F::digits > T::digits) && + from > static_cast(detail::max_value())) { + ec = 1; + return {}; + } + } + + if (detail::const_check(!F::is_signed && T::is_signed && + F::digits >= T::digits) && + from > static_cast(detail::max_value())) { + ec = 1; + return {}; + } + return static_cast(from); // Lossless conversion. +} + +template ::value)> +FMT_CONSTEXPR To lossless_integral_conversion(const From from, int& ec) { + ec = 0; + return from; +} // function + +// clang-format off +/** + * converts From to To if possible, otherwise ec is set. + * + * input | output + * ---------------------------------|--------------- + * NaN | NaN + * Inf | Inf + * normal, fits in output | converted (possibly lossy) + * normal, does not fit in output | ec is set + * subnormal | best effort + * -Inf | -Inf + */ +// clang-format on +template ::value)> +FMT_CONSTEXPR To safe_float_conversion(const From from, int& ec) { + ec = 0; + using T = std::numeric_limits; + static_assert(std::is_floating_point::value, "From must be floating"); + static_assert(std::is_floating_point::value, "To must be floating"); + + // catch the only happy case + if (std::isfinite(from)) { + if (from >= T::lowest() && from <= (T::max)()) { + return static_cast(from); + } + // not within range. + ec = 1; + return {}; + } + + // nan and inf will be preserved + return static_cast(from); +} // function + +template ::value)> +FMT_CONSTEXPR To safe_float_conversion(const From from, int& ec) { + ec = 0; + static_assert(std::is_floating_point::value, "From must be floating"); + return from; +} + +/** + * safe duration cast between integral durations + */ +template ::value), + FMT_ENABLE_IF(std::is_integral::value)> +To safe_duration_cast(std::chrono::duration from, + int& ec) { + using From = std::chrono::duration; + ec = 0; + // the basic idea is that we need to convert from count() in the from type + // to count() in the To type, by multiplying it with this: + struct Factor + : std::ratio_divide {}; + + static_assert(Factor::num > 0, "num must be positive"); + static_assert(Factor::den > 0, "den must be positive"); + + // the conversion is like this: multiply from.count() with Factor::num + // /Factor::den and convert it to To::rep, all this without + // overflow/underflow. let's start by finding a suitable type that can hold + // both To, From and Factor::num + using IntermediateRep = + typename std::common_type::type; + + // safe conversion to IntermediateRep + IntermediateRep count = + lossless_integral_conversion(from.count(), ec); + if (ec) return {}; + // multiply with Factor::num without overflow or underflow + if (detail::const_check(Factor::num != 1)) { + const auto max1 = detail::max_value() / Factor::num; + if (count > max1) { + ec = 1; + return {}; + } + const auto min1 = + (std::numeric_limits::min)() / Factor::num; + if (detail::const_check(!std::is_unsigned::value) && + count < min1) { + ec = 1; + return {}; + } + count *= Factor::num; + } + + if (detail::const_check(Factor::den != 1)) count /= Factor::den; + auto tocount = lossless_integral_conversion(count, ec); + return ec ? To() : To(tocount); +} + +/** + * safe duration_cast between floating point durations + */ +template ::value), + FMT_ENABLE_IF(std::is_floating_point::value)> +To safe_duration_cast(std::chrono::duration from, + int& ec) { + using From = std::chrono::duration; + ec = 0; + if (std::isnan(from.count())) { + // nan in, gives nan out. easy. + return To{std::numeric_limits::quiet_NaN()}; + } + // maybe we should also check if from is denormal, and decide what to do about + // it. + + // +-inf should be preserved. + if (std::isinf(from.count())) { + return To{from.count()}; + } + + // the basic idea is that we need to convert from count() in the from type + // to count() in the To type, by multiplying it with this: + struct Factor + : std::ratio_divide {}; + + static_assert(Factor::num > 0, "num must be positive"); + static_assert(Factor::den > 0, "den must be positive"); + + // the conversion is like this: multiply from.count() with Factor::num + // /Factor::den and convert it to To::rep, all this without + // overflow/underflow. let's start by finding a suitable type that can hold + // both To, From and Factor::num + using IntermediateRep = + typename std::common_type::type; + + // force conversion of From::rep -> IntermediateRep to be safe, + // even if it will never happen be narrowing in this context. + IntermediateRep count = + safe_float_conversion(from.count(), ec); + if (ec) { + return {}; + } + + // multiply with Factor::num without overflow or underflow + if (detail::const_check(Factor::num != 1)) { + constexpr auto max1 = detail::max_value() / + static_cast(Factor::num); + if (count > max1) { + ec = 1; + return {}; + } + constexpr auto min1 = std::numeric_limits::lowest() / + static_cast(Factor::num); + if (count < min1) { + ec = 1; + return {}; + } + count *= static_cast(Factor::num); + } + + // this can't go wrong, right? den>0 is checked earlier. + if (detail::const_check(Factor::den != 1)) { + using common_t = typename std::common_type::type; + count /= static_cast(Factor::den); + } + + // convert to the to type, safely + using ToRep = typename To::rep; + + const ToRep tocount = safe_float_conversion(count, ec); + if (ec) { + return {}; + } + return To{tocount}; +} +} // namespace safe_duration_cast +#endif + +// Prevents expansion of a preceding token as a function-style macro. +// Usage: f FMT_NOMACRO() +#define FMT_NOMACRO + +namespace detail { +template struct null {}; +inline null<> localtime_r FMT_NOMACRO(...) { return null<>(); } +inline null<> localtime_s(...) { return null<>(); } +inline null<> gmtime_r(...) { return null<>(); } +inline null<> gmtime_s(...) { return null<>(); } + +inline const std::locale& get_classic_locale() { + static const auto& locale = std::locale::classic(); + return locale; +} + +template struct codecvt_result { + static constexpr const size_t max_size = 32; + CodeUnit buf[max_size]; + CodeUnit* end; +}; +template +constexpr const size_t codecvt_result::max_size; + +template +void write_codecvt(codecvt_result& out, string_view in_buf, + const std::locale& loc) { +#if FMT_CLANG_VERSION +# pragma clang diagnostic push +# pragma clang diagnostic ignored "-Wdeprecated" + auto& f = std::use_facet>(loc); +# pragma clang diagnostic pop +#else + auto& f = std::use_facet>(loc); +#endif + auto mb = std::mbstate_t(); + const char* from_next = nullptr; + auto result = f.in(mb, in_buf.begin(), in_buf.end(), from_next, + std::begin(out.buf), std::end(out.buf), out.end); + if (result != std::codecvt_base::ok) + FMT_THROW(format_error("failed to format time")); +} + +template +auto write_encoded_tm_str(OutputIt out, string_view in, const std::locale& loc) + -> OutputIt { + if (detail::is_utf8() && loc != get_classic_locale()) { + // char16_t and char32_t codecvts are broken in MSVC (linkage errors) and + // gcc-4. +#if FMT_MSC_VERSION != 0 || \ + (defined(__GLIBCXX__) && !defined(_GLIBCXX_USE_DUAL_ABI)) + // The _GLIBCXX_USE_DUAL_ABI macro is always defined in libstdc++ from gcc-5 + // and newer. + using code_unit = wchar_t; +#else + using code_unit = char32_t; +#endif + + using unit_t = codecvt_result; + unit_t unit; + write_codecvt(unit, in, loc); + // In UTF-8 is used one to four one-byte code units. + auto u = + to_utf8>(); + if (!u.convert({unit.buf, to_unsigned(unit.end - unit.buf)})) + FMT_THROW(format_error("failed to format time")); + return copy_str(u.c_str(), u.c_str() + u.size(), out); + } + return copy_str(in.data(), in.data() + in.size(), out); +} + +template ::value)> +auto write_tm_str(OutputIt out, string_view sv, const std::locale& loc) + -> OutputIt { + codecvt_result unit; + write_codecvt(unit, sv, loc); + return copy_str(unit.buf, unit.end, out); +} + +template ::value)> +auto write_tm_str(OutputIt out, string_view sv, const std::locale& loc) + -> OutputIt { + return write_encoded_tm_str(out, sv, loc); +} + +template +inline void do_write(buffer& buf, const std::tm& time, + const std::locale& loc, char format, char modifier) { + auto&& format_buf = formatbuf>(buf); + auto&& os = std::basic_ostream(&format_buf); + os.imbue(loc); + using iterator = std::ostreambuf_iterator; + const auto& facet = std::use_facet>(loc); + auto end = facet.put(os, os, Char(' '), &time, format, modifier); + if (end.failed()) FMT_THROW(format_error("failed to format time")); +} + +template ::value)> +auto write(OutputIt out, const std::tm& time, const std::locale& loc, + char format, char modifier = 0) -> OutputIt { + auto&& buf = get_buffer(out); + do_write(buf, time, loc, format, modifier); + return get_iterator(buf, out); +} + +template ::value)> +auto write(OutputIt out, const std::tm& time, const std::locale& loc, + char format, char modifier = 0) -> OutputIt { + auto&& buf = basic_memory_buffer(); + do_write(buf, time, loc, format, modifier); + return write_encoded_tm_str(out, string_view(buf.data(), buf.size()), loc); +} + +} // namespace detail + +FMT_BEGIN_EXPORT + +/** + Converts given time since epoch as ``std::time_t`` value into calendar time, + expressed in local time. Unlike ``std::localtime``, this function is + thread-safe on most platforms. + */ +inline std::tm localtime(std::time_t time) { + struct dispatcher { + std::time_t time_; + std::tm tm_; + + dispatcher(std::time_t t) : time_(t) {} + + bool run() { + using namespace fmt::detail; + return handle(localtime_r(&time_, &tm_)); + } + + bool handle(std::tm* tm) { return tm != nullptr; } + + bool handle(detail::null<>) { + using namespace fmt::detail; + return fallback(localtime_s(&tm_, &time_)); + } + + bool fallback(int res) { return res == 0; } + +#if !FMT_MSC_VERSION + bool fallback(detail::null<>) { + using namespace fmt::detail; + std::tm* tm = std::localtime(&time_); + if (tm) tm_ = *tm; + return tm != nullptr; + } +#endif + }; + dispatcher lt(time); + // Too big time values may be unsupported. + if (!lt.run()) FMT_THROW(format_error("time_t value out of range")); + return lt.tm_; +} + +#if FMT_USE_LOCAL_TIME +template +inline auto localtime(std::chrono::local_time time) -> std::tm { + return localtime(std::chrono::system_clock::to_time_t( + std::chrono::current_zone()->to_sys(time))); +} +#endif + +/** + Converts given time since epoch as ``std::time_t`` value into calendar time, + expressed in Coordinated Universal Time (UTC). Unlike ``std::gmtime``, this + function is thread-safe on most platforms. + */ +inline std::tm gmtime(std::time_t time) { + struct dispatcher { + std::time_t time_; + std::tm tm_; + + dispatcher(std::time_t t) : time_(t) {} + + bool run() { + using namespace fmt::detail; + return handle(gmtime_r(&time_, &tm_)); + } + + bool handle(std::tm* tm) { return tm != nullptr; } + + bool handle(detail::null<>) { + using namespace fmt::detail; + return fallback(gmtime_s(&tm_, &time_)); + } + + bool fallback(int res) { return res == 0; } + +#if !FMT_MSC_VERSION + bool fallback(detail::null<>) { + std::tm* tm = std::gmtime(&time_); + if (tm) tm_ = *tm; + return tm != nullptr; + } +#endif + }; + auto gt = dispatcher(time); + // Too big time values may be unsupported. + if (!gt.run()) FMT_THROW(format_error("time_t value out of range")); + return gt.tm_; +} + +inline std::tm gmtime( + std::chrono::time_point time_point) { + return gmtime(std::chrono::system_clock::to_time_t(time_point)); +} + +namespace detail { + +// Writes two-digit numbers a, b and c separated by sep to buf. +// The method by Pavel Novikov based on +// https://johnnylee-sde.github.io/Fast-unsigned-integer-to-time-string/. +inline void write_digit2_separated(char* buf, unsigned a, unsigned b, + unsigned c, char sep) { + unsigned long long digits = + a | (b << 24) | (static_cast(c) << 48); + // Convert each value to BCD. + // We have x = a * 10 + b and we want to convert it to BCD y = a * 16 + b. + // The difference is + // y - x = a * 6 + // a can be found from x: + // a = floor(x / 10) + // then + // y = x + a * 6 = x + floor(x / 10) * 6 + // floor(x / 10) is (x * 205) >> 11 (needs 16 bits). + digits += (((digits * 205) >> 11) & 0x000f00000f00000f) * 6; + // Put low nibbles to high bytes and high nibbles to low bytes. + digits = ((digits & 0x00f00000f00000f0) >> 4) | + ((digits & 0x000f00000f00000f) << 8); + auto usep = static_cast(sep); + // Add ASCII '0' to each digit byte and insert separators. + digits |= 0x3030003030003030 | (usep << 16) | (usep << 40); + + constexpr const size_t len = 8; + if (const_check(is_big_endian())) { + char tmp[len]; + std::memcpy(tmp, &digits, len); + std::reverse_copy(tmp, tmp + len, buf); + } else { + std::memcpy(buf, &digits, len); + } +} + +template FMT_CONSTEXPR inline const char* get_units() { + if (std::is_same::value) return "as"; + if (std::is_same::value) return "fs"; + if (std::is_same::value) return "ps"; + if (std::is_same::value) return "ns"; + if (std::is_same::value) return "µs"; + if (std::is_same::value) return "ms"; + if (std::is_same::value) return "cs"; + if (std::is_same::value) return "ds"; + if (std::is_same>::value) return "s"; + if (std::is_same::value) return "das"; + if (std::is_same::value) return "hs"; + if (std::is_same::value) return "ks"; + if (std::is_same::value) return "Ms"; + if (std::is_same::value) return "Gs"; + if (std::is_same::value) return "Ts"; + if (std::is_same::value) return "Ps"; + if (std::is_same::value) return "Es"; + if (std::is_same>::value) return "m"; + if (std::is_same>::value) return "h"; + return nullptr; +} + +enum class numeric_system { + standard, + // Alternative numeric system, e.g. 十二 instead of 12 in ja_JP locale. + alternative +}; + +// Glibc extensions for formatting numeric values. +enum class pad_type { + unspecified, + // Do not pad a numeric result string. + none, + // Pad a numeric result string with zeros even if the conversion specifier + // character uses space-padding by default. + zero, + // Pad a numeric result string with spaces. + space, +}; + +template +auto write_padding(OutputIt out, pad_type pad, int width) -> OutputIt { + if (pad == pad_type::none) return out; + return std::fill_n(out, width, pad == pad_type::space ? ' ' : '0'); +} + +template +auto write_padding(OutputIt out, pad_type pad) -> OutputIt { + if (pad != pad_type::none) *out++ = pad == pad_type::space ? ' ' : '0'; + return out; +} + +// Parses a put_time-like format string and invokes handler actions. +template +FMT_CONSTEXPR const Char* parse_chrono_format(const Char* begin, + const Char* end, + Handler&& handler) { + if (begin == end || *begin == '}') return begin; + if (*begin != '%') FMT_THROW(format_error("invalid format")); + auto ptr = begin; + pad_type pad = pad_type::unspecified; + while (ptr != end) { + auto c = *ptr; + if (c == '}') break; + if (c != '%') { + ++ptr; + continue; + } + if (begin != ptr) handler.on_text(begin, ptr); + ++ptr; // consume '%' + if (ptr == end) FMT_THROW(format_error("invalid format")); + c = *ptr; + switch (c) { + case '_': + pad = pad_type::space; + ++ptr; + break; + case '-': + pad = pad_type::none; + ++ptr; + break; + case '0': + pad = pad_type::zero; + ++ptr; + break; + } + if (ptr == end) FMT_THROW(format_error("invalid format")); + c = *ptr++; + switch (c) { + case '%': + handler.on_text(ptr - 1, ptr); + break; + case 'n': { + const Char newline[] = {'\n'}; + handler.on_text(newline, newline + 1); + break; + } + case 't': { + const Char tab[] = {'\t'}; + handler.on_text(tab, tab + 1); + break; + } + // Year: + case 'Y': + handler.on_year(numeric_system::standard); + break; + case 'y': + handler.on_short_year(numeric_system::standard); + break; + case 'C': + handler.on_century(numeric_system::standard); + break; + case 'G': + handler.on_iso_week_based_year(); + break; + case 'g': + handler.on_iso_week_based_short_year(); + break; + // Day of the week: + case 'a': + handler.on_abbr_weekday(); + break; + case 'A': + handler.on_full_weekday(); + break; + case 'w': + handler.on_dec0_weekday(numeric_system::standard); + break; + case 'u': + handler.on_dec1_weekday(numeric_system::standard); + break; + // Month: + case 'b': + case 'h': + handler.on_abbr_month(); + break; + case 'B': + handler.on_full_month(); + break; + case 'm': + handler.on_dec_month(numeric_system::standard); + break; + // Day of the year/month: + case 'U': + handler.on_dec0_week_of_year(numeric_system::standard); + break; + case 'W': + handler.on_dec1_week_of_year(numeric_system::standard); + break; + case 'V': + handler.on_iso_week_of_year(numeric_system::standard); + break; + case 'j': + handler.on_day_of_year(); + break; + case 'd': + handler.on_day_of_month(numeric_system::standard); + break; + case 'e': + handler.on_day_of_month_space(numeric_system::standard); + break; + // Hour, minute, second: + case 'H': + handler.on_24_hour(numeric_system::standard, pad); + break; + case 'I': + handler.on_12_hour(numeric_system::standard, pad); + break; + case 'M': + handler.on_minute(numeric_system::standard, pad); + break; + case 'S': + handler.on_second(numeric_system::standard, pad); + break; + // Other: + case 'c': + handler.on_datetime(numeric_system::standard); + break; + case 'x': + handler.on_loc_date(numeric_system::standard); + break; + case 'X': + handler.on_loc_time(numeric_system::standard); + break; + case 'D': + handler.on_us_date(); + break; + case 'F': + handler.on_iso_date(); + break; + case 'r': + handler.on_12_hour_time(); + break; + case 'R': + handler.on_24_hour_time(); + break; + case 'T': + handler.on_iso_time(); + break; + case 'p': + handler.on_am_pm(); + break; + case 'Q': + handler.on_duration_value(); + break; + case 'q': + handler.on_duration_unit(); + break; + case 'z': + handler.on_utc_offset(numeric_system::standard); + break; + case 'Z': + handler.on_tz_name(); + break; + // Alternative representation: + case 'E': { + if (ptr == end) FMT_THROW(format_error("invalid format")); + c = *ptr++; + switch (c) { + case 'Y': + handler.on_year(numeric_system::alternative); + break; + case 'y': + handler.on_offset_year(); + break; + case 'C': + handler.on_century(numeric_system::alternative); + break; + case 'c': + handler.on_datetime(numeric_system::alternative); + break; + case 'x': + handler.on_loc_date(numeric_system::alternative); + break; + case 'X': + handler.on_loc_time(numeric_system::alternative); + break; + case 'z': + handler.on_utc_offset(numeric_system::alternative); + break; + default: + FMT_THROW(format_error("invalid format")); + } + break; + } + case 'O': + if (ptr == end) FMT_THROW(format_error("invalid format")); + c = *ptr++; + switch (c) { + case 'y': + handler.on_short_year(numeric_system::alternative); + break; + case 'm': + handler.on_dec_month(numeric_system::alternative); + break; + case 'U': + handler.on_dec0_week_of_year(numeric_system::alternative); + break; + case 'W': + handler.on_dec1_week_of_year(numeric_system::alternative); + break; + case 'V': + handler.on_iso_week_of_year(numeric_system::alternative); + break; + case 'd': + handler.on_day_of_month(numeric_system::alternative); + break; + case 'e': + handler.on_day_of_month_space(numeric_system::alternative); + break; + case 'w': + handler.on_dec0_weekday(numeric_system::alternative); + break; + case 'u': + handler.on_dec1_weekday(numeric_system::alternative); + break; + case 'H': + handler.on_24_hour(numeric_system::alternative, pad); + break; + case 'I': + handler.on_12_hour(numeric_system::alternative, pad); + break; + case 'M': + handler.on_minute(numeric_system::alternative, pad); + break; + case 'S': + handler.on_second(numeric_system::alternative, pad); + break; + case 'z': + handler.on_utc_offset(numeric_system::alternative); + break; + default: + FMT_THROW(format_error("invalid format")); + } + break; + default: + FMT_THROW(format_error("invalid format")); + } + begin = ptr; + } + if (begin != ptr) handler.on_text(begin, ptr); + return ptr; +} + +template struct null_chrono_spec_handler { + FMT_CONSTEXPR void unsupported() { + static_cast(this)->unsupported(); + } + FMT_CONSTEXPR void on_year(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_short_year(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_offset_year() { unsupported(); } + FMT_CONSTEXPR void on_century(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_iso_week_based_year() { unsupported(); } + FMT_CONSTEXPR void on_iso_week_based_short_year() { unsupported(); } + FMT_CONSTEXPR void on_abbr_weekday() { unsupported(); } + FMT_CONSTEXPR void on_full_weekday() { unsupported(); } + FMT_CONSTEXPR void on_dec0_weekday(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_dec1_weekday(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_abbr_month() { unsupported(); } + FMT_CONSTEXPR void on_full_month() { unsupported(); } + FMT_CONSTEXPR void on_dec_month(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_dec0_week_of_year(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_dec1_week_of_year(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_iso_week_of_year(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_day_of_year() { unsupported(); } + FMT_CONSTEXPR void on_day_of_month(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_day_of_month_space(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_24_hour(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_12_hour(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_minute(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_second(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_datetime(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_loc_date(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_loc_time(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_us_date() { unsupported(); } + FMT_CONSTEXPR void on_iso_date() { unsupported(); } + FMT_CONSTEXPR void on_12_hour_time() { unsupported(); } + FMT_CONSTEXPR void on_24_hour_time() { unsupported(); } + FMT_CONSTEXPR void on_iso_time() { unsupported(); } + FMT_CONSTEXPR void on_am_pm() { unsupported(); } + FMT_CONSTEXPR void on_duration_value() { unsupported(); } + FMT_CONSTEXPR void on_duration_unit() { unsupported(); } + FMT_CONSTEXPR void on_utc_offset(numeric_system) { unsupported(); } + FMT_CONSTEXPR void on_tz_name() { unsupported(); } +}; + +struct tm_format_checker : null_chrono_spec_handler { + FMT_NORETURN void unsupported() { FMT_THROW(format_error("no format")); } + + template + FMT_CONSTEXPR void on_text(const Char*, const Char*) {} + FMT_CONSTEXPR void on_year(numeric_system) {} + FMT_CONSTEXPR void on_short_year(numeric_system) {} + FMT_CONSTEXPR void on_offset_year() {} + FMT_CONSTEXPR void on_century(numeric_system) {} + FMT_CONSTEXPR void on_iso_week_based_year() {} + FMT_CONSTEXPR void on_iso_week_based_short_year() {} + FMT_CONSTEXPR void on_abbr_weekday() {} + FMT_CONSTEXPR void on_full_weekday() {} + FMT_CONSTEXPR void on_dec0_weekday(numeric_system) {} + FMT_CONSTEXPR void on_dec1_weekday(numeric_system) {} + FMT_CONSTEXPR void on_abbr_month() {} + FMT_CONSTEXPR void on_full_month() {} + FMT_CONSTEXPR void on_dec_month(numeric_system) {} + FMT_CONSTEXPR void on_dec0_week_of_year(numeric_system) {} + FMT_CONSTEXPR void on_dec1_week_of_year(numeric_system) {} + FMT_CONSTEXPR void on_iso_week_of_year(numeric_system) {} + FMT_CONSTEXPR void on_day_of_year() {} + FMT_CONSTEXPR void on_day_of_month(numeric_system) {} + FMT_CONSTEXPR void on_day_of_month_space(numeric_system) {} + FMT_CONSTEXPR void on_24_hour(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_12_hour(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_minute(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_second(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_datetime(numeric_system) {} + FMT_CONSTEXPR void on_loc_date(numeric_system) {} + FMT_CONSTEXPR void on_loc_time(numeric_system) {} + FMT_CONSTEXPR void on_us_date() {} + FMT_CONSTEXPR void on_iso_date() {} + FMT_CONSTEXPR void on_12_hour_time() {} + FMT_CONSTEXPR void on_24_hour_time() {} + FMT_CONSTEXPR void on_iso_time() {} + FMT_CONSTEXPR void on_am_pm() {} + FMT_CONSTEXPR void on_utc_offset(numeric_system) {} + FMT_CONSTEXPR void on_tz_name() {} +}; + +inline const char* tm_wday_full_name(int wday) { + static constexpr const char* full_name_list[] = { + "Sunday", "Monday", "Tuesday", "Wednesday", + "Thursday", "Friday", "Saturday"}; + return wday >= 0 && wday <= 6 ? full_name_list[wday] : "?"; +} +inline const char* tm_wday_short_name(int wday) { + static constexpr const char* short_name_list[] = {"Sun", "Mon", "Tue", "Wed", + "Thu", "Fri", "Sat"}; + return wday >= 0 && wday <= 6 ? short_name_list[wday] : "???"; +} + +inline const char* tm_mon_full_name(int mon) { + static constexpr const char* full_name_list[] = { + "January", "February", "March", "April", "May", "June", + "July", "August", "September", "October", "November", "December"}; + return mon >= 0 && mon <= 11 ? full_name_list[mon] : "?"; +} +inline const char* tm_mon_short_name(int mon) { + static constexpr const char* short_name_list[] = { + "Jan", "Feb", "Mar", "Apr", "May", "Jun", + "Jul", "Aug", "Sep", "Oct", "Nov", "Dec", + }; + return mon >= 0 && mon <= 11 ? short_name_list[mon] : "???"; +} + +template +struct has_member_data_tm_gmtoff : std::false_type {}; +template +struct has_member_data_tm_gmtoff> + : std::true_type {}; + +template +struct has_member_data_tm_zone : std::false_type {}; +template +struct has_member_data_tm_zone> + : std::true_type {}; + +#if FMT_USE_TZSET +inline void tzset_once() { + static bool init = []() -> bool { + _tzset(); + return true; + }(); + ignore_unused(init); +} +#endif + +// Converts value to Int and checks that it's in the range [0, upper). +template ::value)> +inline Int to_nonnegative_int(T value, Int upper) { + FMT_ASSERT(std::is_unsigned::value || + (value >= 0 && to_unsigned(value) <= to_unsigned(upper)), + "invalid value"); + (void)upper; + return static_cast(value); +} +template ::value)> +inline Int to_nonnegative_int(T value, Int upper) { + if (value < 0 || value > static_cast(upper)) + FMT_THROW(format_error("invalid value")); + return static_cast(value); +} + +constexpr long long pow10(std::uint32_t n) { + return n == 0 ? 1 : 10 * pow10(n - 1); +} + +// Counts the number of fractional digits in the range [0, 18] according to the +// C++20 spec. If more than 18 fractional digits are required then returns 6 for +// microseconds precision. +template () / 10)> +struct count_fractional_digits { + static constexpr int value = + Num % Den == 0 ? N : count_fractional_digits::value; +}; + +// Base case that doesn't instantiate any more templates +// in order to avoid overflow. +template +struct count_fractional_digits { + static constexpr int value = (Num % Den == 0) ? N : 6; +}; + +// Format subseconds which are given as an integer type with an appropriate +// number of digits. +template +void write_fractional_seconds(OutputIt& out, Duration d, int precision = -1) { + constexpr auto num_fractional_digits = + count_fractional_digits::value; + + using subsecond_precision = std::chrono::duration< + typename std::common_type::type, + std::ratio<1, detail::pow10(num_fractional_digits)>>; + + const auto fractional = + d - std::chrono::duration_cast(d); + const auto subseconds = + std::chrono::treat_as_floating_point< + typename subsecond_precision::rep>::value + ? fractional.count() + : std::chrono::duration_cast(fractional).count(); + auto n = static_cast>(subseconds); + const int num_digits = detail::count_digits(n); + + int leading_zeroes = (std::max)(0, num_fractional_digits - num_digits); + if (precision < 0) { + FMT_ASSERT(!std::is_floating_point::value, ""); + if (std::ratio_less::value) { + *out++ = '.'; + out = std::fill_n(out, leading_zeroes, '0'); + out = format_decimal(out, n, num_digits).end; + } + } else { + *out++ = '.'; + leading_zeroes = (std::min)(leading_zeroes, precision); + out = std::fill_n(out, leading_zeroes, '0'); + int remaining = precision - leading_zeroes; + if (remaining != 0 && remaining < num_digits) { + n /= to_unsigned(detail::pow10(to_unsigned(num_digits - remaining))); + out = format_decimal(out, n, remaining).end; + return; + } + out = format_decimal(out, n, num_digits).end; + remaining -= num_digits; + out = std::fill_n(out, remaining, '0'); + } +} + +// Format subseconds which are given as a floating point type with an +// appropriate number of digits. We cannot pass the Duration here, as we +// explicitly need to pass the Rep value in the chrono_formatter. +template +void write_floating_seconds(memory_buffer& buf, Duration duration, + int num_fractional_digits = -1) { + using rep = typename Duration::rep; + FMT_ASSERT(std::is_floating_point::value, ""); + + auto val = duration.count(); + + if (num_fractional_digits < 0) { + // For `std::round` with fallback to `round`: + // On some toolchains `std::round` is not available (e.g. GCC 6). + using namespace std; + num_fractional_digits = + count_fractional_digits::value; + if (num_fractional_digits < 6 && static_cast(round(val)) != val) + num_fractional_digits = 6; + } + + format_to(std::back_inserter(buf), FMT_STRING("{:.{}f}"), + std::fmod(val * static_cast(Duration::period::num) / + static_cast(Duration::period::den), + static_cast(60)), + num_fractional_digits); +} + +template +class tm_writer { + private: + static constexpr int days_per_week = 7; + + const std::locale& loc_; + const bool is_classic_; + OutputIt out_; + const Duration* subsecs_; + const std::tm& tm_; + + auto tm_sec() const noexcept -> int { + FMT_ASSERT(tm_.tm_sec >= 0 && tm_.tm_sec <= 61, ""); + return tm_.tm_sec; + } + auto tm_min() const noexcept -> int { + FMT_ASSERT(tm_.tm_min >= 0 && tm_.tm_min <= 59, ""); + return tm_.tm_min; + } + auto tm_hour() const noexcept -> int { + FMT_ASSERT(tm_.tm_hour >= 0 && tm_.tm_hour <= 23, ""); + return tm_.tm_hour; + } + auto tm_mday() const noexcept -> int { + FMT_ASSERT(tm_.tm_mday >= 1 && tm_.tm_mday <= 31, ""); + return tm_.tm_mday; + } + auto tm_mon() const noexcept -> int { + FMT_ASSERT(tm_.tm_mon >= 0 && tm_.tm_mon <= 11, ""); + return tm_.tm_mon; + } + auto tm_year() const noexcept -> long long { return 1900ll + tm_.tm_year; } + auto tm_wday() const noexcept -> int { + FMT_ASSERT(tm_.tm_wday >= 0 && tm_.tm_wday <= 6, ""); + return tm_.tm_wday; + } + auto tm_yday() const noexcept -> int { + FMT_ASSERT(tm_.tm_yday >= 0 && tm_.tm_yday <= 365, ""); + return tm_.tm_yday; + } + + auto tm_hour12() const noexcept -> int { + const auto h = tm_hour(); + const auto z = h < 12 ? h : h - 12; + return z == 0 ? 12 : z; + } + + // POSIX and the C Standard are unclear or inconsistent about what %C and %y + // do if the year is negative or exceeds 9999. Use the convention that %C + // concatenated with %y yields the same output as %Y, and that %Y contains at + // least 4 characters, with more only if necessary. + auto split_year_lower(long long year) const noexcept -> int { + auto l = year % 100; + if (l < 0) l = -l; // l in [0, 99] + return static_cast(l); + } + + // Algorithm: + // https://en.wikipedia.org/wiki/ISO_week_date#Calculating_the_week_number_from_a_month_and_day_of_the_month_or_ordinal_date + auto iso_year_weeks(long long curr_year) const noexcept -> int { + const auto prev_year = curr_year - 1; + const auto curr_p = + (curr_year + curr_year / 4 - curr_year / 100 + curr_year / 400) % + days_per_week; + const auto prev_p = + (prev_year + prev_year / 4 - prev_year / 100 + prev_year / 400) % + days_per_week; + return 52 + ((curr_p == 4 || prev_p == 3) ? 1 : 0); + } + auto iso_week_num(int tm_yday, int tm_wday) const noexcept -> int { + return (tm_yday + 11 - (tm_wday == 0 ? days_per_week : tm_wday)) / + days_per_week; + } + auto tm_iso_week_year() const noexcept -> long long { + const auto year = tm_year(); + const auto w = iso_week_num(tm_yday(), tm_wday()); + if (w < 1) return year - 1; + if (w > iso_year_weeks(year)) return year + 1; + return year; + } + auto tm_iso_week_of_year() const noexcept -> int { + const auto year = tm_year(); + const auto w = iso_week_num(tm_yday(), tm_wday()); + if (w < 1) return iso_year_weeks(year - 1); + if (w > iso_year_weeks(year)) return 1; + return w; + } + + void write1(int value) { + *out_++ = static_cast('0' + to_unsigned(value) % 10); + } + void write2(int value) { + const char* d = digits2(to_unsigned(value) % 100); + *out_++ = *d++; + *out_++ = *d; + } + void write2(int value, pad_type pad) { + unsigned int v = to_unsigned(value) % 100; + if (v >= 10) { + const char* d = digits2(v); + *out_++ = *d++; + *out_++ = *d; + } else { + out_ = detail::write_padding(out_, pad); + *out_++ = static_cast('0' + v); + } + } + + void write_year_extended(long long year) { + // At least 4 characters. + int width = 4; + if (year < 0) { + *out_++ = '-'; + year = 0 - year; + --width; + } + uint32_or_64_or_128_t n = to_unsigned(year); + const int num_digits = count_digits(n); + if (width > num_digits) out_ = std::fill_n(out_, width - num_digits, '0'); + out_ = format_decimal(out_, n, num_digits).end; + } + void write_year(long long year) { + if (year >= 0 && year < 10000) { + write2(static_cast(year / 100)); + write2(static_cast(year % 100)); + } else { + write_year_extended(year); + } + } + + void write_utc_offset(long offset, numeric_system ns) { + if (offset < 0) { + *out_++ = '-'; + offset = -offset; + } else { + *out_++ = '+'; + } + offset /= 60; + write2(static_cast(offset / 60)); + if (ns != numeric_system::standard) *out_++ = ':'; + write2(static_cast(offset % 60)); + } + template ::value)> + void format_utc_offset_impl(const T& tm, numeric_system ns) { + write_utc_offset(tm.tm_gmtoff, ns); + } + template ::value)> + void format_utc_offset_impl(const T& tm, numeric_system ns) { +#if defined(_WIN32) && defined(_UCRT) +# if FMT_USE_TZSET + tzset_once(); +# endif + long offset = 0; + _get_timezone(&offset); + if (tm.tm_isdst) { + long dstbias = 0; + _get_dstbias(&dstbias); + offset += dstbias; + } + write_utc_offset(-offset, ns); +#else + if (ns == numeric_system::standard) return format_localized('z'); + + // Extract timezone offset from timezone conversion functions. + std::tm gtm = tm; + std::time_t gt = std::mktime(>m); + std::tm ltm = gmtime(gt); + std::time_t lt = std::mktime(<m); + long offset = gt - lt; + write_utc_offset(offset, ns); +#endif + } + + template ::value)> + void format_tz_name_impl(const T& tm) { + if (is_classic_) + out_ = write_tm_str(out_, tm.tm_zone, loc_); + else + format_localized('Z'); + } + template ::value)> + void format_tz_name_impl(const T&) { + format_localized('Z'); + } + + void format_localized(char format, char modifier = 0) { + out_ = write(out_, tm_, loc_, format, modifier); + } + + public: + tm_writer(const std::locale& loc, OutputIt out, const std::tm& tm, + const Duration* subsecs = nullptr) + : loc_(loc), + is_classic_(loc_ == get_classic_locale()), + out_(out), + subsecs_(subsecs), + tm_(tm) {} + + OutputIt out() const { return out_; } + + FMT_CONSTEXPR void on_text(const Char* begin, const Char* end) { + out_ = copy_str(begin, end, out_); + } + + void on_abbr_weekday() { + if (is_classic_) + out_ = write(out_, tm_wday_short_name(tm_wday())); + else + format_localized('a'); + } + void on_full_weekday() { + if (is_classic_) + out_ = write(out_, tm_wday_full_name(tm_wday())); + else + format_localized('A'); + } + void on_dec0_weekday(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) return write1(tm_wday()); + format_localized('w', 'O'); + } + void on_dec1_weekday(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) { + auto wday = tm_wday(); + write1(wday == 0 ? days_per_week : wday); + } else { + format_localized('u', 'O'); + } + } + + void on_abbr_month() { + if (is_classic_) + out_ = write(out_, tm_mon_short_name(tm_mon())); + else + format_localized('b'); + } + void on_full_month() { + if (is_classic_) + out_ = write(out_, tm_mon_full_name(tm_mon())); + else + format_localized('B'); + } + + void on_datetime(numeric_system ns) { + if (is_classic_) { + on_abbr_weekday(); + *out_++ = ' '; + on_abbr_month(); + *out_++ = ' '; + on_day_of_month_space(numeric_system::standard); + *out_++ = ' '; + on_iso_time(); + *out_++ = ' '; + on_year(numeric_system::standard); + } else { + format_localized('c', ns == numeric_system::standard ? '\0' : 'E'); + } + } + void on_loc_date(numeric_system ns) { + if (is_classic_) + on_us_date(); + else + format_localized('x', ns == numeric_system::standard ? '\0' : 'E'); + } + void on_loc_time(numeric_system ns) { + if (is_classic_) + on_iso_time(); + else + format_localized('X', ns == numeric_system::standard ? '\0' : 'E'); + } + void on_us_date() { + char buf[8]; + write_digit2_separated(buf, to_unsigned(tm_mon() + 1), + to_unsigned(tm_mday()), + to_unsigned(split_year_lower(tm_year())), '/'); + out_ = copy_str(std::begin(buf), std::end(buf), out_); + } + void on_iso_date() { + auto year = tm_year(); + char buf[10]; + size_t offset = 0; + if (year >= 0 && year < 10000) { + copy2(buf, digits2(static_cast(year / 100))); + } else { + offset = 4; + write_year_extended(year); + year = 0; + } + write_digit2_separated(buf + 2, static_cast(year % 100), + to_unsigned(tm_mon() + 1), to_unsigned(tm_mday()), + '-'); + out_ = copy_str(std::begin(buf) + offset, std::end(buf), out_); + } + + void on_utc_offset(numeric_system ns) { format_utc_offset_impl(tm_, ns); } + void on_tz_name() { format_tz_name_impl(tm_); } + + void on_year(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) + return write_year(tm_year()); + format_localized('Y', 'E'); + } + void on_short_year(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) + return write2(split_year_lower(tm_year())); + format_localized('y', 'O'); + } + void on_offset_year() { + if (is_classic_) return write2(split_year_lower(tm_year())); + format_localized('y', 'E'); + } + + void on_century(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) { + auto year = tm_year(); + auto upper = year / 100; + if (year >= -99 && year < 0) { + // Zero upper on negative year. + *out_++ = '-'; + *out_++ = '0'; + } else if (upper >= 0 && upper < 100) { + write2(static_cast(upper)); + } else { + out_ = write(out_, upper); + } + } else { + format_localized('C', 'E'); + } + } + + void on_dec_month(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) + return write2(tm_mon() + 1); + format_localized('m', 'O'); + } + + void on_dec0_week_of_year(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) + return write2((tm_yday() + days_per_week - tm_wday()) / days_per_week); + format_localized('U', 'O'); + } + void on_dec1_week_of_year(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) { + auto wday = tm_wday(); + write2((tm_yday() + days_per_week - + (wday == 0 ? (days_per_week - 1) : (wday - 1))) / + days_per_week); + } else { + format_localized('W', 'O'); + } + } + void on_iso_week_of_year(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) + return write2(tm_iso_week_of_year()); + format_localized('V', 'O'); + } + + void on_iso_week_based_year() { write_year(tm_iso_week_year()); } + void on_iso_week_based_short_year() { + write2(split_year_lower(tm_iso_week_year())); + } + + void on_day_of_year() { + auto yday = tm_yday() + 1; + write1(yday / 100); + write2(yday % 100); + } + void on_day_of_month(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) return write2(tm_mday()); + format_localized('d', 'O'); + } + void on_day_of_month_space(numeric_system ns) { + if (is_classic_ || ns == numeric_system::standard) { + auto mday = to_unsigned(tm_mday()) % 100; + const char* d2 = digits2(mday); + *out_++ = mday < 10 ? ' ' : d2[0]; + *out_++ = d2[1]; + } else { + format_localized('e', 'O'); + } + } + + void on_24_hour(numeric_system ns, pad_type pad) { + if (is_classic_ || ns == numeric_system::standard) + return write2(tm_hour(), pad); + format_localized('H', 'O'); + } + void on_12_hour(numeric_system ns, pad_type pad) { + if (is_classic_ || ns == numeric_system::standard) + return write2(tm_hour12(), pad); + format_localized('I', 'O'); + } + void on_minute(numeric_system ns, pad_type pad) { + if (is_classic_ || ns == numeric_system::standard) + return write2(tm_min(), pad); + format_localized('M', 'O'); + } + + void on_second(numeric_system ns, pad_type pad) { + if (is_classic_ || ns == numeric_system::standard) { + write2(tm_sec(), pad); + if (subsecs_) { + if (std::is_floating_point::value) { + auto buf = memory_buffer(); + write_floating_seconds(buf, *subsecs_); + if (buf.size() > 1) { + // Remove the leading "0", write something like ".123". + out_ = std::copy(buf.begin() + 1, buf.end(), out_); + } + } else { + write_fractional_seconds(out_, *subsecs_); + } + } + } else { + // Currently no formatting of subseconds when a locale is set. + format_localized('S', 'O'); + } + } + + void on_12_hour_time() { + if (is_classic_) { + char buf[8]; + write_digit2_separated(buf, to_unsigned(tm_hour12()), + to_unsigned(tm_min()), to_unsigned(tm_sec()), ':'); + out_ = copy_str(std::begin(buf), std::end(buf), out_); + *out_++ = ' '; + on_am_pm(); + } else { + format_localized('r'); + } + } + void on_24_hour_time() { + write2(tm_hour()); + *out_++ = ':'; + write2(tm_min()); + } + void on_iso_time() { + on_24_hour_time(); + *out_++ = ':'; + on_second(numeric_system::standard, pad_type::unspecified); + } + + void on_am_pm() { + if (is_classic_) { + *out_++ = tm_hour() < 12 ? 'A' : 'P'; + *out_++ = 'M'; + } else { + format_localized('p'); + } + } + + // These apply to chrono durations but not tm. + void on_duration_value() {} + void on_duration_unit() {} +}; + +struct chrono_format_checker : null_chrono_spec_handler { + bool has_precision_integral = false; + + FMT_NORETURN void unsupported() { FMT_THROW(format_error("no date")); } + + template + FMT_CONSTEXPR void on_text(const Char*, const Char*) {} + FMT_CONSTEXPR void on_24_hour(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_12_hour(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_minute(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_second(numeric_system, pad_type) {} + FMT_CONSTEXPR void on_12_hour_time() {} + FMT_CONSTEXPR void on_24_hour_time() {} + FMT_CONSTEXPR void on_iso_time() {} + FMT_CONSTEXPR void on_am_pm() {} + FMT_CONSTEXPR void on_duration_value() const { + if (has_precision_integral) { + FMT_THROW(format_error("precision not allowed for this argument type")); + } + } + FMT_CONSTEXPR void on_duration_unit() {} +}; + +template ::value&& has_isfinite::value)> +inline bool isfinite(T) { + return true; +} + +template ::value)> +inline T mod(T x, int y) { + return x % static_cast(y); +} +template ::value)> +inline T mod(T x, int y) { + return std::fmod(x, static_cast(y)); +} + +// If T is an integral type, maps T to its unsigned counterpart, otherwise +// leaves it unchanged (unlike std::make_unsigned). +template ::value> +struct make_unsigned_or_unchanged { + using type = T; +}; + +template struct make_unsigned_or_unchanged { + using type = typename std::make_unsigned::type; +}; + +#if FMT_SAFE_DURATION_CAST +// throwing version of safe_duration_cast +template +To fmt_safe_duration_cast(std::chrono::duration from) { + int ec; + To to = safe_duration_cast::safe_duration_cast(from, ec); + if (ec) FMT_THROW(format_error("cannot format duration")); + return to; +} +#endif + +template ::value)> +inline std::chrono::duration get_milliseconds( + std::chrono::duration d) { + // this may overflow and/or the result may not fit in the + // target type. +#if FMT_SAFE_DURATION_CAST + using CommonSecondsType = + typename std::common_type::type; + const auto d_as_common = fmt_safe_duration_cast(d); + const auto d_as_whole_seconds = + fmt_safe_duration_cast(d_as_common); + // this conversion should be nonproblematic + const auto diff = d_as_common - d_as_whole_seconds; + const auto ms = + fmt_safe_duration_cast>(diff); + return ms; +#else + auto s = std::chrono::duration_cast(d); + return std::chrono::duration_cast(d - s); +#endif +} + +template ::value)> +OutputIt format_duration_value(OutputIt out, Rep val, int) { + return write(out, val); +} + +template ::value)> +OutputIt format_duration_value(OutputIt out, Rep val, int precision) { + auto specs = format_specs(); + specs.precision = precision; + specs.type = precision >= 0 ? presentation_type::fixed_lower + : presentation_type::general_lower; + return write(out, val, specs); +} + +template +OutputIt copy_unit(string_view unit, OutputIt out, Char) { + return std::copy(unit.begin(), unit.end(), out); +} + +template +OutputIt copy_unit(string_view unit, OutputIt out, wchar_t) { + // This works when wchar_t is UTF-32 because units only contain characters + // that have the same representation in UTF-16 and UTF-32. + utf8_to_utf16 u(unit); + return std::copy(u.c_str(), u.c_str() + u.size(), out); +} + +template +OutputIt format_duration_unit(OutputIt out) { + if (const char* unit = get_units()) + return copy_unit(string_view(unit), out, Char()); + *out++ = '['; + out = write(out, Period::num); + if (const_check(Period::den != 1)) { + *out++ = '/'; + out = write(out, Period::den); + } + *out++ = ']'; + *out++ = 's'; + return out; +} + +class get_locale { + private: + union { + std::locale locale_; + }; + bool has_locale_ = false; + + public: + get_locale(bool localized, locale_ref loc) : has_locale_(localized) { + if (localized) + ::new (&locale_) std::locale(loc.template get()); + } + ~get_locale() { + if (has_locale_) locale_.~locale(); + } + operator const std::locale&() const { + return has_locale_ ? locale_ : get_classic_locale(); + } +}; + +template +struct chrono_formatter { + FormatContext& context; + OutputIt out; + int precision; + bool localized = false; + // rep is unsigned to avoid overflow. + using rep = + conditional_t::value && sizeof(Rep) < sizeof(int), + unsigned, typename make_unsigned_or_unchanged::type>; + rep val; + using seconds = std::chrono::duration; + seconds s; + using milliseconds = std::chrono::duration; + bool negative; + + using char_type = typename FormatContext::char_type; + using tm_writer_type = tm_writer; + + chrono_formatter(FormatContext& ctx, OutputIt o, + std::chrono::duration d) + : context(ctx), + out(o), + val(static_cast(d.count())), + negative(false) { + if (d.count() < 0) { + val = 0 - val; + negative = true; + } + + // this may overflow and/or the result may not fit in the + // target type. +#if FMT_SAFE_DURATION_CAST + // might need checked conversion (rep!=Rep) + auto tmpval = std::chrono::duration(val); + s = fmt_safe_duration_cast(tmpval); +#else + s = std::chrono::duration_cast( + std::chrono::duration(val)); +#endif + } + + // returns true if nan or inf, writes to out. + bool handle_nan_inf() { + if (isfinite(val)) { + return false; + } + if (isnan(val)) { + write_nan(); + return true; + } + // must be +-inf + if (val > 0) { + write_pinf(); + } else { + write_ninf(); + } + return true; + } + + Rep hour() const { return static_cast(mod((s.count() / 3600), 24)); } + + Rep hour12() const { + Rep hour = static_cast(mod((s.count() / 3600), 12)); + return hour <= 0 ? 12 : hour; + } + + Rep minute() const { return static_cast(mod((s.count() / 60), 60)); } + Rep second() const { return static_cast(mod(s.count(), 60)); } + + std::tm time() const { + auto time = std::tm(); + time.tm_hour = to_nonnegative_int(hour(), 24); + time.tm_min = to_nonnegative_int(minute(), 60); + time.tm_sec = to_nonnegative_int(second(), 60); + return time; + } + + void write_sign() { + if (negative) { + *out++ = '-'; + negative = false; + } + } + + void write(Rep value, int width, pad_type pad = pad_type::unspecified) { + write_sign(); + if (isnan(value)) return write_nan(); + uint32_or_64_or_128_t n = + to_unsigned(to_nonnegative_int(value, max_value())); + int num_digits = detail::count_digits(n); + if (width > num_digits) { + out = detail::write_padding(out, pad, width - num_digits); + } + out = format_decimal(out, n, num_digits).end; + } + + void write_nan() { std::copy_n("nan", 3, out); } + void write_pinf() { std::copy_n("inf", 3, out); } + void write_ninf() { std::copy_n("-inf", 4, out); } + + template + void format_tm(const tm& time, Callback cb, Args... args) { + if (isnan(val)) return write_nan(); + get_locale loc(localized, context.locale()); + auto w = tm_writer_type(loc, out, time); + (w.*cb)(args...); + out = w.out(); + } + + void on_text(const char_type* begin, const char_type* end) { + std::copy(begin, end, out); + } + + // These are not implemented because durations don't have date information. + void on_abbr_weekday() {} + void on_full_weekday() {} + void on_dec0_weekday(numeric_system) {} + void on_dec1_weekday(numeric_system) {} + void on_abbr_month() {} + void on_full_month() {} + void on_datetime(numeric_system) {} + void on_loc_date(numeric_system) {} + void on_loc_time(numeric_system) {} + void on_us_date() {} + void on_iso_date() {} + void on_utc_offset(numeric_system) {} + void on_tz_name() {} + void on_year(numeric_system) {} + void on_short_year(numeric_system) {} + void on_offset_year() {} + void on_century(numeric_system) {} + void on_iso_week_based_year() {} + void on_iso_week_based_short_year() {} + void on_dec_month(numeric_system) {} + void on_dec0_week_of_year(numeric_system) {} + void on_dec1_week_of_year(numeric_system) {} + void on_iso_week_of_year(numeric_system) {} + void on_day_of_year() {} + void on_day_of_month(numeric_system) {} + void on_day_of_month_space(numeric_system) {} + + void on_24_hour(numeric_system ns, pad_type pad) { + if (handle_nan_inf()) return; + + if (ns == numeric_system::standard) return write(hour(), 2, pad); + auto time = tm(); + time.tm_hour = to_nonnegative_int(hour(), 24); + format_tm(time, &tm_writer_type::on_24_hour, ns, pad); + } + + void on_12_hour(numeric_system ns, pad_type pad) { + if (handle_nan_inf()) return; + + if (ns == numeric_system::standard) return write(hour12(), 2, pad); + auto time = tm(); + time.tm_hour = to_nonnegative_int(hour12(), 12); + format_tm(time, &tm_writer_type::on_12_hour, ns, pad); + } + + void on_minute(numeric_system ns, pad_type pad) { + if (handle_nan_inf()) return; + + if (ns == numeric_system::standard) return write(minute(), 2, pad); + auto time = tm(); + time.tm_min = to_nonnegative_int(minute(), 60); + format_tm(time, &tm_writer_type::on_minute, ns, pad); + } + + void on_second(numeric_system ns, pad_type pad) { + if (handle_nan_inf()) return; + + if (ns == numeric_system::standard) { + if (std::is_floating_point::value) { + auto buf = memory_buffer(); + write_floating_seconds(buf, std::chrono::duration(val), + precision); + if (negative) *out++ = '-'; + if (buf.size() < 2 || buf[1] == '.') { + out = detail::write_padding(out, pad); + } + out = std::copy(buf.begin(), buf.end(), out); + } else { + write(second(), 2, pad); + write_fractional_seconds( + out, std::chrono::duration(val), precision); + } + return; + } + auto time = tm(); + time.tm_sec = to_nonnegative_int(second(), 60); + format_tm(time, &tm_writer_type::on_second, ns, pad); + } + + void on_12_hour_time() { + if (handle_nan_inf()) return; + format_tm(time(), &tm_writer_type::on_12_hour_time); + } + + void on_24_hour_time() { + if (handle_nan_inf()) { + *out++ = ':'; + handle_nan_inf(); + return; + } + + write(hour(), 2); + *out++ = ':'; + write(minute(), 2); + } + + void on_iso_time() { + on_24_hour_time(); + *out++ = ':'; + if (handle_nan_inf()) return; + on_second(numeric_system::standard, pad_type::unspecified); + } + + void on_am_pm() { + if (handle_nan_inf()) return; + format_tm(time(), &tm_writer_type::on_am_pm); + } + + void on_duration_value() { + if (handle_nan_inf()) return; + write_sign(); + out = format_duration_value(out, val, precision); + } + + void on_duration_unit() { + out = format_duration_unit(out); + } +}; + +} // namespace detail + +#if defined(__cpp_lib_chrono) && __cpp_lib_chrono >= 201907 +using weekday = std::chrono::weekday; +#else +// A fallback version of weekday. +class weekday { + private: + unsigned char value; + + public: + weekday() = default; + explicit constexpr weekday(unsigned wd) noexcept + : value(static_cast(wd != 7 ? wd : 0)) {} + constexpr unsigned c_encoding() const noexcept { return value; } +}; + +class year_month_day {}; +#endif + +// A rudimentary weekday formatter. +template struct formatter { + private: + bool localized = false; + + public: + FMT_CONSTEXPR auto parse(basic_format_parse_context& ctx) + -> decltype(ctx.begin()) { + auto begin = ctx.begin(), end = ctx.end(); + if (begin != end && *begin == 'L') { + ++begin; + localized = true; + } + return begin; + } + + template + auto format(weekday wd, FormatContext& ctx) const -> decltype(ctx.out()) { + auto time = std::tm(); + time.tm_wday = static_cast(wd.c_encoding()); + detail::get_locale loc(localized, ctx.locale()); + auto w = detail::tm_writer(loc, ctx.out(), time); + w.on_abbr_weekday(); + return w.out(); + } +}; + +template +struct formatter, Char> { + private: + format_specs specs_; + detail::arg_ref width_ref_; + detail::arg_ref precision_ref_; + bool localized_ = false; + basic_string_view format_str_; + + public: + FMT_CONSTEXPR auto parse(basic_format_parse_context& ctx) + -> decltype(ctx.begin()) { + auto it = ctx.begin(), end = ctx.end(); + if (it == end || *it == '}') return it; + + it = detail::parse_align(it, end, specs_); + if (it == end) return it; + + it = detail::parse_dynamic_spec(it, end, specs_.width, width_ref_, ctx); + if (it == end) return it; + + auto checker = detail::chrono_format_checker(); + if (*it == '.') { + checker.has_precision_integral = !std::is_floating_point::value; + it = detail::parse_precision(it, end, specs_.precision, precision_ref_, + ctx); + } + if (it != end && *it == 'L') { + localized_ = true; + ++it; + } + end = detail::parse_chrono_format(it, end, checker); + format_str_ = {it, detail::to_unsigned(end - it)}; + return end; + } + + template + auto format(std::chrono::duration d, FormatContext& ctx) const + -> decltype(ctx.out()) { + auto specs = specs_; + auto precision = specs.precision; + specs.precision = -1; + auto begin = format_str_.begin(), end = format_str_.end(); + // As a possible future optimization, we could avoid extra copying if width + // is not specified. + auto buf = basic_memory_buffer(); + auto out = std::back_inserter(buf); + detail::handle_dynamic_spec(specs.width, width_ref_, + ctx); + detail::handle_dynamic_spec(precision, + precision_ref_, ctx); + if (begin == end || *begin == '}') { + out = detail::format_duration_value(out, d.count(), precision); + detail::format_duration_unit(out); + } else { + using chrono_formatter = + detail::chrono_formatter; + auto f = chrono_formatter(ctx, out, d); + f.precision = precision; + f.localized = localized_; + detail::parse_chrono_format(begin, end, f); + } + return detail::write( + ctx.out(), basic_string_view(buf.data(), buf.size()), specs); + } +}; + +template +struct formatter, + Char> : formatter { + FMT_CONSTEXPR formatter() { + this->format_str_ = detail::string_literal{}; + } + + template + auto format(std::chrono::time_point val, + FormatContext& ctx) const -> decltype(ctx.out()) { + using period = typename Duration::period; + if (detail::const_check( + period::num != 1 || period::den != 1 || + std::is_floating_point::value)) { + const auto epoch = val.time_since_epoch(); + auto subsecs = std::chrono::duration_cast( + epoch - std::chrono::duration_cast(epoch)); + + if (subsecs.count() < 0) { + auto second = + std::chrono::duration_cast(std::chrono::seconds(1)); + if (epoch.count() < ((Duration::min)() + second).count()) + FMT_THROW(format_error("duration is too small")); + subsecs += second; + val -= second; + } + + return formatter::do_format( + gmtime(std::chrono::time_point_cast(val)), ctx, + &subsecs); + } + + return formatter::format( + gmtime(std::chrono::time_point_cast(val)), ctx); + } +}; + +#if FMT_USE_LOCAL_TIME +template +struct formatter, Char> + : formatter { + FMT_CONSTEXPR formatter() { + this->format_str_ = detail::string_literal{}; + } + + template + auto format(std::chrono::local_time val, FormatContext& ctx) const + -> decltype(ctx.out()) { + using period = typename Duration::period; + if (period::num != 1 || period::den != 1 || + std::is_floating_point::value) { + const auto epoch = val.time_since_epoch(); + const auto subsecs = std::chrono::duration_cast( + epoch - std::chrono::duration_cast(epoch)); + + return formatter::do_format( + localtime(std::chrono::time_point_cast(val)), + ctx, &subsecs); + } + + return formatter::format( + localtime(std::chrono::time_point_cast(val)), + ctx); + } +}; +#endif + +#if FMT_USE_UTC_TIME +template +struct formatter, + Char> + : formatter, + Char> { + template + auto format(std::chrono::time_point val, + FormatContext& ctx) const -> decltype(ctx.out()) { + return formatter< + std::chrono::time_point, + Char>::format(std::chrono::utc_clock::to_sys(val), ctx); + } +}; +#endif + +template struct formatter { + private: + format_specs specs_; + detail::arg_ref width_ref_; + + protected: + basic_string_view format_str_; + + template + auto do_format(const std::tm& tm, FormatContext& ctx, + const Duration* subsecs) const -> decltype(ctx.out()) { + auto specs = specs_; + auto buf = basic_memory_buffer(); + auto out = std::back_inserter(buf); + detail::handle_dynamic_spec(specs.width, width_ref_, + ctx); + + auto loc_ref = ctx.locale(); + detail::get_locale loc(static_cast(loc_ref), loc_ref); + auto w = + detail::tm_writer(loc, out, tm, subsecs); + detail::parse_chrono_format(format_str_.begin(), format_str_.end(), w); + return detail::write( + ctx.out(), basic_string_view(buf.data(), buf.size()), specs); + } + + public: + FMT_CONSTEXPR auto parse(basic_format_parse_context& ctx) + -> decltype(ctx.begin()) { + auto it = ctx.begin(), end = ctx.end(); + if (it == end || *it == '}') return it; + + it = detail::parse_align(it, end, specs_); + if (it == end) return it; + + it = detail::parse_dynamic_spec(it, end, specs_.width, width_ref_, ctx); + if (it == end) return it; + + end = detail::parse_chrono_format(it, end, detail::tm_format_checker()); + // Replace the default format_str only if the new spec is not empty. + if (end != it) format_str_ = {it, detail::to_unsigned(end - it)}; + return end; + } + + template + auto format(const std::tm& tm, FormatContext& ctx) const + -> decltype(ctx.out()) { + return do_format(tm, ctx, nullptr); + } +}; + +FMT_END_EXPORT +FMT_END_NAMESPACE + +#endif // FMT_CHRONO_H_ diff --git a/src/fmt/color.h b/src/fmt/color.h new file mode 100644 index 0000000..8697e1c --- /dev/null +++ b/src/fmt/color.h @@ -0,0 +1,632 @@ +// Formatting library for C++ - color support +// +// Copyright (c) 2018 - present, Victor Zverovich and fmt contributors +// All rights reserved. +// +// For the license information refer to format.h. + +#ifndef FMT_COLOR_H_ +#define FMT_COLOR_H_ + +#include "format.h" + +FMT_BEGIN_NAMESPACE +FMT_BEGIN_EXPORT + +enum class color : uint32_t { + alice_blue = 0xF0F8FF, // rgb(240,248,255) + antique_white = 0xFAEBD7, // rgb(250,235,215) + aqua = 0x00FFFF, // rgb(0,255,255) + aquamarine = 0x7FFFD4, // rgb(127,255,212) + azure = 0xF0FFFF, // rgb(240,255,255) + beige = 0xF5F5DC, // rgb(245,245,220) + bisque = 0xFFE4C4, // rgb(255,228,196) + black = 0x000000, // rgb(0,0,0) + blanched_almond = 0xFFEBCD, // rgb(255,235,205) + blue = 0x0000FF, // rgb(0,0,255) + blue_violet = 0x8A2BE2, // rgb(138,43,226) + brown = 0xA52A2A, // rgb(165,42,42) + burly_wood = 0xDEB887, // rgb(222,184,135) + cadet_blue = 0x5F9EA0, // rgb(95,158,160) + chartreuse = 0x7FFF00, // rgb(127,255,0) + chocolate = 0xD2691E, // rgb(210,105,30) + coral = 0xFF7F50, // rgb(255,127,80) + cornflower_blue = 0x6495ED, // rgb(100,149,237) + cornsilk = 0xFFF8DC, // rgb(255,248,220) + crimson = 0xDC143C, // rgb(220,20,60) + cyan = 0x00FFFF, // rgb(0,255,255) + dark_blue = 0x00008B, // rgb(0,0,139) + dark_cyan = 0x008B8B, // rgb(0,139,139) + dark_golden_rod = 0xB8860B, // rgb(184,134,11) + dark_gray = 0xA9A9A9, // rgb(169,169,169) + dark_green = 0x006400, // rgb(0,100,0) + dark_khaki = 0xBDB76B, // rgb(189,183,107) + dark_magenta = 0x8B008B, // rgb(139,0,139) + dark_olive_green = 0x556B2F, // rgb(85,107,47) + dark_orange = 0xFF8C00, // rgb(255,140,0) + dark_orchid = 0x9932CC, // rgb(153,50,204) + dark_red = 0x8B0000, // rgb(139,0,0) + dark_salmon = 0xE9967A, // rgb(233,150,122) + dark_sea_green = 0x8FBC8F, // rgb(143,188,143) + dark_slate_blue = 0x483D8B, // rgb(72,61,139) + dark_slate_gray = 0x2F4F4F, // rgb(47,79,79) + dark_turquoise = 0x00CED1, // rgb(0,206,209) + dark_violet = 0x9400D3, // rgb(148,0,211) + deep_pink = 0xFF1493, // rgb(255,20,147) + deep_sky_blue = 0x00BFFF, // rgb(0,191,255) + dim_gray = 0x696969, // rgb(105,105,105) + dodger_blue = 0x1E90FF, // rgb(30,144,255) + fire_brick = 0xB22222, // rgb(178,34,34) + floral_white = 0xFFFAF0, // rgb(255,250,240) + forest_green = 0x228B22, // rgb(34,139,34) + fuchsia = 0xFF00FF, // rgb(255,0,255) + gainsboro = 0xDCDCDC, // rgb(220,220,220) + ghost_white = 0xF8F8FF, // rgb(248,248,255) + gold = 0xFFD700, // rgb(255,215,0) + golden_rod = 0xDAA520, // rgb(218,165,32) + gray = 0x808080, // rgb(128,128,128) + green = 0x008000, // rgb(0,128,0) + green_yellow = 0xADFF2F, // rgb(173,255,47) + honey_dew = 0xF0FFF0, // rgb(240,255,240) + hot_pink = 0xFF69B4, // rgb(255,105,180) + indian_red = 0xCD5C5C, // rgb(205,92,92) + indigo = 0x4B0082, // rgb(75,0,130) + ivory = 0xFFFFF0, // rgb(255,255,240) + khaki = 0xF0E68C, // rgb(240,230,140) + lavender = 0xE6E6FA, // rgb(230,230,250) + lavender_blush = 0xFFF0F5, // rgb(255,240,245) + lawn_green = 0x7CFC00, // rgb(124,252,0) + lemon_chiffon = 0xFFFACD, // rgb(255,250,205) + light_blue = 0xADD8E6, // rgb(173,216,230) + light_coral = 0xF08080, // rgb(240,128,128) + light_cyan = 0xE0FFFF, // rgb(224,255,255) + light_golden_rod_yellow = 0xFAFAD2, // rgb(250,250,210) + light_gray = 0xD3D3D3, // rgb(211,211,211) + light_green = 0x90EE90, // rgb(144,238,144) + light_pink = 0xFFB6C1, // rgb(255,182,193) + light_salmon = 0xFFA07A, // rgb(255,160,122) + light_sea_green = 0x20B2AA, // rgb(32,178,170) + light_sky_blue = 0x87CEFA, // rgb(135,206,250) + light_slate_gray = 0x778899, // rgb(119,136,153) + light_steel_blue = 0xB0C4DE, // rgb(176,196,222) + light_yellow = 0xFFFFE0, // rgb(255,255,224) + lime = 0x00FF00, // rgb(0,255,0) + lime_green = 0x32CD32, // rgb(50,205,50) + linen = 0xFAF0E6, // rgb(250,240,230) + magenta = 0xFF00FF, // rgb(255,0,255) + maroon = 0x800000, // rgb(128,0,0) + medium_aquamarine = 0x66CDAA, // rgb(102,205,170) + medium_blue = 0x0000CD, // rgb(0,0,205) + medium_orchid = 0xBA55D3, // rgb(186,85,211) + medium_purple = 0x9370DB, // rgb(147,112,219) + medium_sea_green = 0x3CB371, // rgb(60,179,113) + medium_slate_blue = 0x7B68EE, // rgb(123,104,238) + medium_spring_green = 0x00FA9A, // rgb(0,250,154) + medium_turquoise = 0x48D1CC, // rgb(72,209,204) + medium_violet_red = 0xC71585, // rgb(199,21,133) + midnight_blue = 0x191970, // rgb(25,25,112) + mint_cream = 0xF5FFFA, // rgb(245,255,250) + misty_rose = 0xFFE4E1, // rgb(255,228,225) + moccasin = 0xFFE4B5, // rgb(255,228,181) + navajo_white = 0xFFDEAD, // rgb(255,222,173) + navy = 0x000080, // rgb(0,0,128) + old_lace = 0xFDF5E6, // rgb(253,245,230) + olive = 0x808000, // rgb(128,128,0) + olive_drab = 0x6B8E23, // rgb(107,142,35) + orange = 0xFFA500, // rgb(255,165,0) + orange_red = 0xFF4500, // rgb(255,69,0) + orchid = 0xDA70D6, // rgb(218,112,214) + pale_golden_rod = 0xEEE8AA, // rgb(238,232,170) + pale_green = 0x98FB98, // rgb(152,251,152) + pale_turquoise = 0xAFEEEE, // rgb(175,238,238) + pale_violet_red = 0xDB7093, // rgb(219,112,147) + papaya_whip = 0xFFEFD5, // rgb(255,239,213) + peach_puff = 0xFFDAB9, // rgb(255,218,185) + peru = 0xCD853F, // rgb(205,133,63) + pink = 0xFFC0CB, // rgb(255,192,203) + plum = 0xDDA0DD, // rgb(221,160,221) + powder_blue = 0xB0E0E6, // rgb(176,224,230) + purple = 0x800080, // rgb(128,0,128) + rebecca_purple = 0x663399, // rgb(102,51,153) + red = 0xFF0000, // rgb(255,0,0) + rosy_brown = 0xBC8F8F, // rgb(188,143,143) + royal_blue = 0x4169E1, // rgb(65,105,225) + saddle_brown = 0x8B4513, // rgb(139,69,19) + salmon = 0xFA8072, // rgb(250,128,114) + sandy_brown = 0xF4A460, // rgb(244,164,96) + sea_green = 0x2E8B57, // rgb(46,139,87) + sea_shell = 0xFFF5EE, // rgb(255,245,238) + sienna = 0xA0522D, // rgb(160,82,45) + silver = 0xC0C0C0, // rgb(192,192,192) + sky_blue = 0x87CEEB, // rgb(135,206,235) + slate_blue = 0x6A5ACD, // rgb(106,90,205) + slate_gray = 0x708090, // rgb(112,128,144) + snow = 0xFFFAFA, // rgb(255,250,250) + spring_green = 0x00FF7F, // rgb(0,255,127) + steel_blue = 0x4682B4, // rgb(70,130,180) + tan = 0xD2B48C, // rgb(210,180,140) + teal = 0x008080, // rgb(0,128,128) + thistle = 0xD8BFD8, // rgb(216,191,216) + tomato = 0xFF6347, // rgb(255,99,71) + turquoise = 0x40E0D0, // rgb(64,224,208) + violet = 0xEE82EE, // rgb(238,130,238) + wheat = 0xF5DEB3, // rgb(245,222,179) + white = 0xFFFFFF, // rgb(255,255,255) + white_smoke = 0xF5F5F5, // rgb(245,245,245) + yellow = 0xFFFF00, // rgb(255,255,0) + yellow_green = 0x9ACD32 // rgb(154,205,50) +}; // enum class color + +enum class terminal_color : uint8_t { + black = 30, + red, + green, + yellow, + blue, + magenta, + cyan, + white, + bright_black = 90, + bright_red, + bright_green, + bright_yellow, + bright_blue, + bright_magenta, + bright_cyan, + bright_white +}; + +enum class emphasis : uint8_t { + bold = 1, + faint = 1 << 1, + italic = 1 << 2, + underline = 1 << 3, + blink = 1 << 4, + reverse = 1 << 5, + conceal = 1 << 6, + strikethrough = 1 << 7, +}; + +// rgb is a struct for red, green and blue colors. +// Using the name "rgb" makes some editors show the color in a tooltip. +struct rgb { + FMT_CONSTEXPR rgb() : r(0), g(0), b(0) {} + FMT_CONSTEXPR rgb(uint8_t r_, uint8_t g_, uint8_t b_) : r(r_), g(g_), b(b_) {} + FMT_CONSTEXPR rgb(uint32_t hex) + : r((hex >> 16) & 0xFF), g((hex >> 8) & 0xFF), b(hex & 0xFF) {} + FMT_CONSTEXPR rgb(color hex) + : r((uint32_t(hex) >> 16) & 0xFF), + g((uint32_t(hex) >> 8) & 0xFF), + b(uint32_t(hex) & 0xFF) {} + uint8_t r; + uint8_t g; + uint8_t b; +}; + +namespace detail { + +// color is a struct of either a rgb color or a terminal color. +struct color_type { + FMT_CONSTEXPR color_type() noexcept : is_rgb(), value{} {} + FMT_CONSTEXPR color_type(color rgb_color) noexcept : is_rgb(true), value{} { + value.rgb_color = static_cast(rgb_color); + } + FMT_CONSTEXPR color_type(rgb rgb_color) noexcept : is_rgb(true), value{} { + value.rgb_color = (static_cast(rgb_color.r) << 16) | + (static_cast(rgb_color.g) << 8) | rgb_color.b; + } + FMT_CONSTEXPR color_type(terminal_color term_color) noexcept + : is_rgb(), value{} { + value.term_color = static_cast(term_color); + } + bool is_rgb; + union color_union { + uint8_t term_color; + uint32_t rgb_color; + } value; +}; +} // namespace detail + +/** A text style consisting of foreground and background colors and emphasis. */ +class text_style { + public: + FMT_CONSTEXPR text_style(emphasis em = emphasis()) noexcept + : set_foreground_color(), set_background_color(), ems(em) {} + + FMT_CONSTEXPR text_style& operator|=(const text_style& rhs) { + if (!set_foreground_color) { + set_foreground_color = rhs.set_foreground_color; + foreground_color = rhs.foreground_color; + } else if (rhs.set_foreground_color) { + if (!foreground_color.is_rgb || !rhs.foreground_color.is_rgb) + FMT_THROW(format_error("can't OR a terminal color")); + foreground_color.value.rgb_color |= rhs.foreground_color.value.rgb_color; + } + + if (!set_background_color) { + set_background_color = rhs.set_background_color; + background_color = rhs.background_color; + } else if (rhs.set_background_color) { + if (!background_color.is_rgb || !rhs.background_color.is_rgb) + FMT_THROW(format_error("can't OR a terminal color")); + background_color.value.rgb_color |= rhs.background_color.value.rgb_color; + } + + ems = static_cast(static_cast(ems) | + static_cast(rhs.ems)); + return *this; + } + + friend FMT_CONSTEXPR text_style operator|(text_style lhs, + const text_style& rhs) { + return lhs |= rhs; + } + + FMT_CONSTEXPR bool has_foreground() const noexcept { + return set_foreground_color; + } + FMT_CONSTEXPR bool has_background() const noexcept { + return set_background_color; + } + FMT_CONSTEXPR bool has_emphasis() const noexcept { + return static_cast(ems) != 0; + } + FMT_CONSTEXPR detail::color_type get_foreground() const noexcept { + FMT_ASSERT(has_foreground(), "no foreground specified for this style"); + return foreground_color; + } + FMT_CONSTEXPR detail::color_type get_background() const noexcept { + FMT_ASSERT(has_background(), "no background specified for this style"); + return background_color; + } + FMT_CONSTEXPR emphasis get_emphasis() const noexcept { + FMT_ASSERT(has_emphasis(), "no emphasis specified for this style"); + return ems; + } + + private: + FMT_CONSTEXPR text_style(bool is_foreground, + detail::color_type text_color) noexcept + : set_foreground_color(), set_background_color(), ems() { + if (is_foreground) { + foreground_color = text_color; + set_foreground_color = true; + } else { + background_color = text_color; + set_background_color = true; + } + } + + friend FMT_CONSTEXPR text_style fg(detail::color_type foreground) noexcept; + + friend FMT_CONSTEXPR text_style bg(detail::color_type background) noexcept; + + detail::color_type foreground_color; + detail::color_type background_color; + bool set_foreground_color; + bool set_background_color; + emphasis ems; +}; + +/** Creates a text style from the foreground (text) color. */ +FMT_CONSTEXPR inline text_style fg(detail::color_type foreground) noexcept { + return text_style(true, foreground); +} + +/** Creates a text style from the background color. */ +FMT_CONSTEXPR inline text_style bg(detail::color_type background) noexcept { + return text_style(false, background); +} + +FMT_CONSTEXPR inline text_style operator|(emphasis lhs, emphasis rhs) noexcept { + return text_style(lhs) | rhs; +} + +namespace detail { + +template struct ansi_color_escape { + FMT_CONSTEXPR ansi_color_escape(detail::color_type text_color, + const char* esc) noexcept { + // If we have a terminal color, we need to output another escape code + // sequence. + if (!text_color.is_rgb) { + bool is_background = esc == string_view("\x1b[48;2;"); + uint32_t value = text_color.value.term_color; + // Background ASCII codes are the same as the foreground ones but with + // 10 more. + if (is_background) value += 10u; + + size_t index = 0; + buffer[index++] = static_cast('\x1b'); + buffer[index++] = static_cast('['); + + if (value >= 100u) { + buffer[index++] = static_cast('1'); + value %= 100u; + } + buffer[index++] = static_cast('0' + value / 10u); + buffer[index++] = static_cast('0' + value % 10u); + + buffer[index++] = static_cast('m'); + buffer[index++] = static_cast('\0'); + return; + } + + for (int i = 0; i < 7; i++) { + buffer[i] = static_cast(esc[i]); + } + rgb color(text_color.value.rgb_color); + to_esc(color.r, buffer + 7, ';'); + to_esc(color.g, buffer + 11, ';'); + to_esc(color.b, buffer + 15, 'm'); + buffer[19] = static_cast(0); + } + FMT_CONSTEXPR ansi_color_escape(emphasis em) noexcept { + uint8_t em_codes[num_emphases] = {}; + if (has_emphasis(em, emphasis::bold)) em_codes[0] = 1; + if (has_emphasis(em, emphasis::faint)) em_codes[1] = 2; + if (has_emphasis(em, emphasis::italic)) em_codes[2] = 3; + if (has_emphasis(em, emphasis::underline)) em_codes[3] = 4; + if (has_emphasis(em, emphasis::blink)) em_codes[4] = 5; + if (has_emphasis(em, emphasis::reverse)) em_codes[5] = 7; + if (has_emphasis(em, emphasis::conceal)) em_codes[6] = 8; + if (has_emphasis(em, emphasis::strikethrough)) em_codes[7] = 9; + + size_t index = 0; + for (size_t i = 0; i < num_emphases; ++i) { + if (!em_codes[i]) continue; + buffer[index++] = static_cast('\x1b'); + buffer[index++] = static_cast('['); + buffer[index++] = static_cast('0' + em_codes[i]); + buffer[index++] = static_cast('m'); + } + buffer[index++] = static_cast(0); + } + FMT_CONSTEXPR operator const Char*() const noexcept { return buffer; } + + FMT_CONSTEXPR const Char* begin() const noexcept { return buffer; } + FMT_CONSTEXPR_CHAR_TRAITS const Char* end() const noexcept { + return buffer + std::char_traits::length(buffer); + } + + private: + static constexpr size_t num_emphases = 8; + Char buffer[7u + 3u * num_emphases + 1u]; + + static FMT_CONSTEXPR void to_esc(uint8_t c, Char* out, + char delimiter) noexcept { + out[0] = static_cast('0' + c / 100); + out[1] = static_cast('0' + c / 10 % 10); + out[2] = static_cast('0' + c % 10); + out[3] = static_cast(delimiter); + } + static FMT_CONSTEXPR bool has_emphasis(emphasis em, emphasis mask) noexcept { + return static_cast(em) & static_cast(mask); + } +}; + +template +FMT_CONSTEXPR ansi_color_escape make_foreground_color( + detail::color_type foreground) noexcept { + return ansi_color_escape(foreground, "\x1b[38;2;"); +} + +template +FMT_CONSTEXPR ansi_color_escape make_background_color( + detail::color_type background) noexcept { + return ansi_color_escape(background, "\x1b[48;2;"); +} + +template +FMT_CONSTEXPR ansi_color_escape make_emphasis(emphasis em) noexcept { + return ansi_color_escape(em); +} + +template inline void reset_color(buffer& buffer) { + auto reset_color = string_view("\x1b[0m"); + buffer.append(reset_color.begin(), reset_color.end()); +} + +template struct styled_arg { + const T& value; + text_style style; +}; + +template +void vformat_to(buffer& buf, const text_style& ts, + basic_string_view format_str, + basic_format_args>> args) { + bool has_style = false; + if (ts.has_emphasis()) { + has_style = true; + auto emphasis = detail::make_emphasis(ts.get_emphasis()); + buf.append(emphasis.begin(), emphasis.end()); + } + if (ts.has_foreground()) { + has_style = true; + auto foreground = detail::make_foreground_color(ts.get_foreground()); + buf.append(foreground.begin(), foreground.end()); + } + if (ts.has_background()) { + has_style = true; + auto background = detail::make_background_color(ts.get_background()); + buf.append(background.begin(), background.end()); + } + detail::vformat_to(buf, format_str, args, {}); + if (has_style) detail::reset_color(buf); +} + +} // namespace detail + +inline void vprint(std::FILE* f, const text_style& ts, string_view fmt, + format_args args) { + // Legacy wide streams are not supported. + auto buf = memory_buffer(); + detail::vformat_to(buf, ts, fmt, args); + if (detail::is_utf8()) { + detail::print(f, string_view(buf.begin(), buf.size())); + return; + } + buf.push_back('\0'); + int result = std::fputs(buf.data(), f); + if (result < 0) + FMT_THROW(system_error(errno, FMT_STRING("cannot write to file"))); +} + +/** + \rst + Formats a string and prints it to the specified file stream using ANSI + escape sequences to specify text formatting. + + **Example**:: + + fmt::print(fmt::emphasis::bold | fg(fmt::color::red), + "Elapsed time: {0:.2f} seconds", 1.23); + \endrst + */ +template ::value)> +void print(std::FILE* f, const text_style& ts, const S& format_str, + const Args&... args) { + vprint(f, ts, format_str, + fmt::make_format_args>>(args...)); +} + +/** + \rst + Formats a string and prints it to stdout using ANSI escape sequences to + specify text formatting. + + **Example**:: + + fmt::print(fmt::emphasis::bold | fg(fmt::color::red), + "Elapsed time: {0:.2f} seconds", 1.23); + \endrst + */ +template ::value)> +void print(const text_style& ts, const S& format_str, const Args&... args) { + return print(stdout, ts, format_str, args...); +} + +template > +inline std::basic_string vformat( + const text_style& ts, const S& format_str, + basic_format_args>> args) { + basic_memory_buffer buf; + detail::vformat_to(buf, ts, detail::to_string_view(format_str), args); + return fmt::to_string(buf); +} + +/** + \rst + Formats arguments and returns the result as a string using ANSI + escape sequences to specify text formatting. + + **Example**:: + + #include + std::string message = fmt::format(fmt::emphasis::bold | fg(fmt::color::red), + "The answer is {}", 42); + \endrst +*/ +template > +inline std::basic_string format(const text_style& ts, const S& format_str, + const Args&... args) { + return fmt::vformat(ts, detail::to_string_view(format_str), + fmt::make_format_args>(args...)); +} + +/** + Formats a string with the given text_style and writes the output to ``out``. + */ +template ::value)> +OutputIt vformat_to( + OutputIt out, const text_style& ts, basic_string_view format_str, + basic_format_args>> args) { + auto&& buf = detail::get_buffer(out); + detail::vformat_to(buf, ts, format_str, args); + return detail::get_iterator(buf, out); +} + +/** + \rst + Formats arguments with the given text_style, writes the result to the output + iterator ``out`` and returns the iterator past the end of the output range. + + **Example**:: + + std::vector out; + fmt::format_to(std::back_inserter(out), + fmt::emphasis::bold | fg(fmt::color::red), "{}", 42); + \endrst +*/ +template >::value&& + detail::is_string::value> +inline auto format_to(OutputIt out, const text_style& ts, const S& format_str, + Args&&... args) -> + typename std::enable_if::type { + return vformat_to(out, ts, detail::to_string_view(format_str), + fmt::make_format_args>>(args...)); +} + +template +struct formatter, Char> : formatter { + template + auto format(const detail::styled_arg& arg, FormatContext& ctx) const + -> decltype(ctx.out()) { + const auto& ts = arg.style; + const auto& value = arg.value; + auto out = ctx.out(); + + bool has_style = false; + if (ts.has_emphasis()) { + has_style = true; + auto emphasis = detail::make_emphasis(ts.get_emphasis()); + out = std::copy(emphasis.begin(), emphasis.end(), out); + } + if (ts.has_foreground()) { + has_style = true; + auto foreground = + detail::make_foreground_color(ts.get_foreground()); + out = std::copy(foreground.begin(), foreground.end(), out); + } + if (ts.has_background()) { + has_style = true; + auto background = + detail::make_background_color(ts.get_background()); + out = std::copy(background.begin(), background.end(), out); + } + out = formatter::format(value, ctx); + if (has_style) { + auto reset_color = string_view("\x1b[0m"); + out = std::copy(reset_color.begin(), reset_color.end(), out); + } + return out; + } +}; + +/** + \rst + Returns an argument that will be formatted using ANSI escape sequences, + to be used in a formatting function. + + **Example**:: + + fmt::print("Elapsed time: {0:.2f} seconds", + fmt::styled(1.23, fmt::fg(fmt::color::green) | + fmt::bg(fmt::color::blue))); + \endrst + */ +template +FMT_CONSTEXPR auto styled(const T& value, text_style ts) + -> detail::styled_arg> { + return detail::styled_arg>{value, ts}; +} + +FMT_END_EXPORT +FMT_END_NAMESPACE + +#endif // FMT_COLOR_H_ diff --git a/src/fmt/compile.h b/src/fmt/compile.h new file mode 100644 index 0000000..a4c7e49 --- /dev/null +++ b/src/fmt/compile.h @@ -0,0 +1,534 @@ +// Formatting library for C++ - experimental format string compilation +// +// Copyright (c) 2012 - present, Victor Zverovich and fmt contributors +// All rights reserved. +// +// For the license information refer to format.h. + +#ifndef FMT_COMPILE_H_ +#define FMT_COMPILE_H_ + +#include "format.h" + +FMT_BEGIN_NAMESPACE +namespace detail { + +template +FMT_CONSTEXPR inline counting_iterator copy_str(InputIt begin, InputIt end, + counting_iterator it) { + return it + (end - begin); +} + +// A compile-time string which is compiled into fast formatting code. +class compiled_string {}; + +template +struct is_compiled_string : std::is_base_of {}; + +/** + \rst + Converts a string literal *s* into a format string that will be parsed at + compile time and converted into efficient formatting code. Requires C++17 + ``constexpr if`` compiler support. + + **Example**:: + + // Converts 42 into std::string using the most efficient method and no + // runtime format string processing. + std::string s = fmt::format(FMT_COMPILE("{}"), 42); + \endrst + */ +#if defined(__cpp_if_constexpr) && defined(__cpp_return_type_deduction) +# define FMT_COMPILE(s) \ + FMT_STRING_IMPL(s, fmt::detail::compiled_string, explicit) +#else +# define FMT_COMPILE(s) FMT_STRING(s) +#endif + +#if FMT_USE_NONTYPE_TEMPLATE_ARGS +template Str> +struct udl_compiled_string : compiled_string { + using char_type = Char; + explicit constexpr operator basic_string_view() const { + return {Str.data, N - 1}; + } +}; +#endif + +template +const T& first(const T& value, const Tail&...) { + return value; +} + +#if defined(__cpp_if_constexpr) && defined(__cpp_return_type_deduction) +template struct type_list {}; + +// Returns a reference to the argument at index N from [first, rest...]. +template +constexpr const auto& get([[maybe_unused]] const T& first, + [[maybe_unused]] const Args&... rest) { + static_assert(N < 1 + sizeof...(Args), "index is out of bounds"); + if constexpr (N == 0) + return first; + else + return detail::get(rest...); +} + +template +constexpr int get_arg_index_by_name(basic_string_view name, + type_list) { + return get_arg_index_by_name(name); +} + +template struct get_type_impl; + +template struct get_type_impl> { + using type = + remove_cvref_t(std::declval()...))>; +}; + +template +using get_type = typename get_type_impl::type; + +template struct is_compiled_format : std::false_type {}; + +template struct text { + basic_string_view data; + using char_type = Char; + + template + constexpr OutputIt format(OutputIt out, const Args&...) const { + return write(out, data); + } +}; + +template +struct is_compiled_format> : std::true_type {}; + +template +constexpr text make_text(basic_string_view s, size_t pos, + size_t size) { + return {{&s[pos], size}}; +} + +template struct code_unit { + Char value; + using char_type = Char; + + template + constexpr OutputIt format(OutputIt out, const Args&...) const { + *out++ = value; + return out; + } +}; + +// This ensures that the argument type is convertible to `const T&`. +template +constexpr const T& get_arg_checked(const Args&... args) { + const auto& arg = detail::get(args...); + if constexpr (detail::is_named_arg>()) { + return arg.value; + } else { + return arg; + } +} + +template +struct is_compiled_format> : std::true_type {}; + +// A replacement field that refers to argument N. +template struct field { + using char_type = Char; + + template + constexpr OutputIt format(OutputIt out, const Args&... args) const { + const T& arg = get_arg_checked(args...); + if constexpr (std::is_convertible_v>) { + auto s = basic_string_view(arg); + return copy_str(s.begin(), s.end(), out); + } + return write(out, arg); + } +}; + +template +struct is_compiled_format> : std::true_type {}; + +// A replacement field that refers to argument with name. +template struct runtime_named_field { + using char_type = Char; + basic_string_view name; + + template + constexpr static bool try_format_argument( + OutputIt& out, + // [[maybe_unused]] due to unused-but-set-parameter warning in GCC 7,8,9 + [[maybe_unused]] basic_string_view arg_name, const T& arg) { + if constexpr (is_named_arg::type>::value) { + if (arg_name == arg.name) { + out = write(out, arg.value); + return true; + } + } + return false; + } + + template + constexpr OutputIt format(OutputIt out, const Args&... args) const { + bool found = (try_format_argument(out, name, args) || ...); + if (!found) { + FMT_THROW(format_error("argument with specified name is not found")); + } + return out; + } +}; + +template +struct is_compiled_format> : std::true_type {}; + +// A replacement field that refers to argument N and has format specifiers. +template struct spec_field { + using char_type = Char; + formatter fmt; + + template + constexpr FMT_INLINE OutputIt format(OutputIt out, + const Args&... args) const { + const auto& vargs = + fmt::make_format_args>(args...); + basic_format_context ctx(out, vargs); + return fmt.format(get_arg_checked(args...), ctx); + } +}; + +template +struct is_compiled_format> : std::true_type {}; + +template struct concat { + L lhs; + R rhs; + using char_type = typename L::char_type; + + template + constexpr OutputIt format(OutputIt out, const Args&... args) const { + out = lhs.format(out, args...); + return rhs.format(out, args...); + } +}; + +template +struct is_compiled_format> : std::true_type {}; + +template +constexpr concat make_concat(L lhs, R rhs) { + return {lhs, rhs}; +} + +struct unknown_format {}; + +template +constexpr size_t parse_text(basic_string_view str, size_t pos) { + for (size_t size = str.size(); pos != size; ++pos) { + if (str[pos] == '{' || str[pos] == '}') break; + } + return pos; +} + +template +constexpr auto compile_format_string(S format_str); + +template +constexpr auto parse_tail(T head, S format_str) { + if constexpr (POS != + basic_string_view(format_str).size()) { + constexpr auto tail = compile_format_string(format_str); + if constexpr (std::is_same, + unknown_format>()) + return tail; + else + return make_concat(head, tail); + } else { + return head; + } +} + +template struct parse_specs_result { + formatter fmt; + size_t end; + int next_arg_id; +}; + +enum { manual_indexing_id = -1 }; + +template +constexpr parse_specs_result parse_specs(basic_string_view str, + size_t pos, int next_arg_id) { + str.remove_prefix(pos); + auto ctx = + compile_parse_context(str, max_value(), nullptr, next_arg_id); + auto f = formatter(); + auto end = f.parse(ctx); + return {f, pos + fmt::detail::to_unsigned(end - str.data()), + next_arg_id == 0 ? manual_indexing_id : ctx.next_arg_id()}; +} + +template struct arg_id_handler { + arg_ref arg_id; + + constexpr int on_auto() { + FMT_ASSERT(false, "handler cannot be used with automatic indexing"); + return 0; + } + constexpr int on_index(int id) { + arg_id = arg_ref(id); + return 0; + } + constexpr int on_name(basic_string_view id) { + arg_id = arg_ref(id); + return 0; + } +}; + +template struct parse_arg_id_result { + arg_ref arg_id; + const Char* arg_id_end; +}; + +template +constexpr auto parse_arg_id(const Char* begin, const Char* end) { + auto handler = arg_id_handler{arg_ref{}}; + auto arg_id_end = parse_arg_id(begin, end, handler); + return parse_arg_id_result{handler.arg_id, arg_id_end}; +} + +template struct field_type { + using type = remove_cvref_t; +}; + +template +struct field_type::value>> { + using type = remove_cvref_t; +}; + +template +constexpr auto parse_replacement_field_then_tail(S format_str) { + using char_type = typename S::char_type; + constexpr auto str = basic_string_view(format_str); + constexpr char_type c = END_POS != str.size() ? str[END_POS] : char_type(); + if constexpr (c == '}') { + return parse_tail( + field::type, ARG_INDEX>(), + format_str); + } else if constexpr (c != ':') { + FMT_THROW(format_error("expected ':'")); + } else { + constexpr auto result = parse_specs::type>( + str, END_POS + 1, NEXT_ID == manual_indexing_id ? 0 : NEXT_ID); + if constexpr (result.end >= str.size() || str[result.end] != '}') { + FMT_THROW(format_error("expected '}'")); + return 0; + } else { + return parse_tail( + spec_field::type, ARG_INDEX>{ + result.fmt}, + format_str); + } + } +} + +// Compiles a non-empty format string and returns the compiled representation +// or unknown_format() on unrecognized input. +template +constexpr auto compile_format_string(S format_str) { + using char_type = typename S::char_type; + constexpr auto str = basic_string_view(format_str); + if constexpr (str[POS] == '{') { + if constexpr (POS + 1 == str.size()) + FMT_THROW(format_error("unmatched '{' in format string")); + if constexpr (str[POS + 1] == '{') { + return parse_tail(make_text(str, POS, 1), format_str); + } else if constexpr (str[POS + 1] == '}' || str[POS + 1] == ':') { + static_assert(ID != manual_indexing_id, + "cannot switch from manual to automatic argument indexing"); + constexpr auto next_id = + ID != manual_indexing_id ? ID + 1 : manual_indexing_id; + return parse_replacement_field_then_tail, Args, + POS + 1, ID, next_id>( + format_str); + } else { + constexpr auto arg_id_result = + parse_arg_id(str.data() + POS + 1, str.data() + str.size()); + constexpr auto arg_id_end_pos = arg_id_result.arg_id_end - str.data(); + constexpr char_type c = + arg_id_end_pos != str.size() ? str[arg_id_end_pos] : char_type(); + static_assert(c == '}' || c == ':', "missing '}' in format string"); + if constexpr (arg_id_result.arg_id.kind == arg_id_kind::index) { + static_assert( + ID == manual_indexing_id || ID == 0, + "cannot switch from automatic to manual argument indexing"); + constexpr auto arg_index = arg_id_result.arg_id.val.index; + return parse_replacement_field_then_tail, + Args, arg_id_end_pos, + arg_index, manual_indexing_id>( + format_str); + } else if constexpr (arg_id_result.arg_id.kind == arg_id_kind::name) { + constexpr auto arg_index = + get_arg_index_by_name(arg_id_result.arg_id.val.name, Args{}); + if constexpr (arg_index >= 0) { + constexpr auto next_id = + ID != manual_indexing_id ? ID + 1 : manual_indexing_id; + return parse_replacement_field_then_tail< + decltype(get_type::value), Args, arg_id_end_pos, + arg_index, next_id>(format_str); + } else if constexpr (c == '}') { + return parse_tail( + runtime_named_field{arg_id_result.arg_id.val.name}, + format_str); + } else if constexpr (c == ':') { + return unknown_format(); // no type info for specs parsing + } + } + } + } else if constexpr (str[POS] == '}') { + if constexpr (POS + 1 == str.size()) + FMT_THROW(format_error("unmatched '}' in format string")); + return parse_tail(make_text(str, POS, 1), format_str); + } else { + constexpr auto end = parse_text(str, POS + 1); + if constexpr (end - POS > 1) { + return parse_tail(make_text(str, POS, end - POS), + format_str); + } else { + return parse_tail(code_unit{str[POS]}, + format_str); + } + } +} + +template ::value)> +constexpr auto compile(S format_str) { + constexpr auto str = basic_string_view(format_str); + if constexpr (str.size() == 0) { + return detail::make_text(str, 0, 0); + } else { + constexpr auto result = + detail::compile_format_string, 0, 0>( + format_str); + return result; + } +} +#endif // defined(__cpp_if_constexpr) && defined(__cpp_return_type_deduction) +} // namespace detail + +FMT_BEGIN_EXPORT + +#if defined(__cpp_if_constexpr) && defined(__cpp_return_type_deduction) + +template ::value)> +FMT_INLINE std::basic_string format(const CompiledFormat& cf, + const Args&... args) { + auto s = std::basic_string(); + cf.format(std::back_inserter(s), args...); + return s; +} + +template ::value)> +constexpr FMT_INLINE OutputIt format_to(OutputIt out, const CompiledFormat& cf, + const Args&... args) { + return cf.format(out, args...); +} + +template ::value)> +FMT_INLINE std::basic_string format(const S&, + Args&&... args) { + if constexpr (std::is_same::value) { + constexpr auto str = basic_string_view(S()); + if constexpr (str.size() == 2 && str[0] == '{' && str[1] == '}') { + const auto& first = detail::first(args...); + if constexpr (detail::is_named_arg< + remove_cvref_t>::value) { + return fmt::to_string(first.value); + } else { + return fmt::to_string(first); + } + } + } + constexpr auto compiled = detail::compile(S()); + if constexpr (std::is_same, + detail::unknown_format>()) { + return fmt::format( + static_cast>(S()), + std::forward(args)...); + } else { + return fmt::format(compiled, std::forward(args)...); + } +} + +template ::value)> +FMT_CONSTEXPR OutputIt format_to(OutputIt out, const S&, Args&&... args) { + constexpr auto compiled = detail::compile(S()); + if constexpr (std::is_same, + detail::unknown_format>()) { + return fmt::format_to( + out, static_cast>(S()), + std::forward(args)...); + } else { + return fmt::format_to(out, compiled, std::forward(args)...); + } +} +#endif + +template ::value)> +format_to_n_result format_to_n(OutputIt out, size_t n, + const S& format_str, Args&&... args) { + using traits = detail::fixed_buffer_traits; + auto buf = detail::iterator_buffer(out, n); + format_to(std::back_inserter(buf), format_str, std::forward(args)...); + return {buf.out(), buf.count()}; +} + +template ::value)> +FMT_CONSTEXPR20 size_t formatted_size(const S& format_str, + const Args&... args) { + return fmt::format_to(detail::counting_iterator(), format_str, args...) + .count(); +} + +template ::value)> +void print(std::FILE* f, const S& format_str, const Args&... args) { + memory_buffer buffer; + fmt::format_to(std::back_inserter(buffer), format_str, args...); + detail::print(f, {buffer.data(), buffer.size()}); +} + +template ::value)> +void print(const S& format_str, const Args&... args) { + print(stdout, format_str, args...); +} + +#if FMT_USE_NONTYPE_TEMPLATE_ARGS +inline namespace literals { +template constexpr auto operator""_cf() { + using char_t = remove_cvref_t; + return detail::udl_compiled_string(); +} +} // namespace literals +#endif + +FMT_END_EXPORT +FMT_END_NAMESPACE + +#endif // FMT_COMPILE_H_ diff --git a/src/fmt/core.h b/src/fmt/core.h new file mode 100644 index 0000000..f9e3b7d --- /dev/null +++ b/src/fmt/core.h @@ -0,0 +1,2922 @@ +// Formatting library for C++ - the core API for char/UTF-8 +// +// Copyright (c) 2012 - present, Victor Zverovich +// All rights reserved. +// +// For the license information refer to format.h. + +#ifndef FMT_CORE_H_ +#define FMT_CORE_H_ + +#include // std::byte +#include // std::FILE +#include // std::strlen +#include +#include +#include // std::addressof +#include +#include + +// The fmt library version in the form major * 10000 + minor * 100 + patch. +#define FMT_VERSION 100101 + +#if defined(__clang__) && !defined(__ibmxl__) +# define FMT_CLANG_VERSION (__clang_major__ * 100 + __clang_minor__) +#else +# define FMT_CLANG_VERSION 0 +#endif + +#if defined(__GNUC__) && !defined(__clang__) && !defined(__INTEL_COMPILER) && \ + !defined(__NVCOMPILER) +# define FMT_GCC_VERSION (__GNUC__ * 100 + __GNUC_MINOR__) +#else +# define FMT_GCC_VERSION 0 +#endif + +#ifndef FMT_GCC_PRAGMA +// Workaround _Pragma bug https://gcc.gnu.org/bugzilla/show_bug.cgi?id=59884. +# if FMT_GCC_VERSION >= 504 +# define FMT_GCC_PRAGMA(arg) _Pragma(arg) +# else +# define FMT_GCC_PRAGMA(arg) +# endif +#endif + +#ifdef __ICL +# define FMT_ICC_VERSION __ICL +#elif defined(__INTEL_COMPILER) +# define FMT_ICC_VERSION __INTEL_COMPILER +#else +# define FMT_ICC_VERSION 0 +#endif + +#ifdef _MSC_VER +# define FMT_MSC_VERSION _MSC_VER +# define FMT_MSC_WARNING(...) __pragma(warning(__VA_ARGS__)) +#else +# define FMT_MSC_VERSION 0 +# define FMT_MSC_WARNING(...) +#endif + +#ifdef _MSVC_LANG +# define FMT_CPLUSPLUS _MSVC_LANG +#else +# define FMT_CPLUSPLUS __cplusplus +#endif + +#ifdef __has_feature +# define FMT_HAS_FEATURE(x) __has_feature(x) +#else +# define FMT_HAS_FEATURE(x) 0 +#endif + +#if defined(__has_include) || FMT_ICC_VERSION >= 1600 || FMT_MSC_VERSION > 1900 +# define FMT_HAS_INCLUDE(x) __has_include(x) +#else +# define FMT_HAS_INCLUDE(x) 0 +#endif + +#ifdef __has_cpp_attribute +# define FMT_HAS_CPP_ATTRIBUTE(x) __has_cpp_attribute(x) +#else +# define FMT_HAS_CPP_ATTRIBUTE(x) 0 +#endif + +#define FMT_HAS_CPP14_ATTRIBUTE(attribute) \ + (FMT_CPLUSPLUS >= 201402L && FMT_HAS_CPP_ATTRIBUTE(attribute)) + +#define FMT_HAS_CPP17_ATTRIBUTE(attribute) \ + (FMT_CPLUSPLUS >= 201703L && FMT_HAS_CPP_ATTRIBUTE(attribute)) + +// Check if relaxed C++14 constexpr is supported. +// GCC doesn't allow throw in constexpr until version 6 (bug 67371). +#ifndef FMT_USE_CONSTEXPR +# if (FMT_HAS_FEATURE(cxx_relaxed_constexpr) || FMT_MSC_VERSION >= 1912 || \ + (FMT_GCC_VERSION >= 600 && FMT_CPLUSPLUS >= 201402L)) && \ + !FMT_ICC_VERSION && (!defined(__NVCC__) || FMT_CPLUSPLUS >= 202002L) +# define FMT_USE_CONSTEXPR 1 +# else +# define FMT_USE_CONSTEXPR 0 +# endif +#endif +#if FMT_USE_CONSTEXPR +# define FMT_CONSTEXPR constexpr +#else +# define FMT_CONSTEXPR +#endif + +#if ((FMT_CPLUSPLUS >= 202002L) && \ + (!defined(_GLIBCXX_RELEASE) || _GLIBCXX_RELEASE > 9)) || \ + (FMT_CPLUSPLUS >= 201709L && FMT_GCC_VERSION >= 1002) +# define FMT_CONSTEXPR20 constexpr +#else +# define FMT_CONSTEXPR20 +#endif + +// Check if constexpr std::char_traits<>::{compare,length} are supported. +#if defined(__GLIBCXX__) +# if FMT_CPLUSPLUS >= 201703L && defined(_GLIBCXX_RELEASE) && \ + _GLIBCXX_RELEASE >= 7 // GCC 7+ libstdc++ has _GLIBCXX_RELEASE. +# define FMT_CONSTEXPR_CHAR_TRAITS constexpr +# endif +#elif defined(_LIBCPP_VERSION) && FMT_CPLUSPLUS >= 201703L && \ + _LIBCPP_VERSION >= 4000 +# define FMT_CONSTEXPR_CHAR_TRAITS constexpr +#elif FMT_MSC_VERSION >= 1914 && FMT_CPLUSPLUS >= 201703L +# define FMT_CONSTEXPR_CHAR_TRAITS constexpr +#endif +#ifndef FMT_CONSTEXPR_CHAR_TRAITS +# define FMT_CONSTEXPR_CHAR_TRAITS +#endif + +// Check if exceptions are disabled. +#ifndef FMT_EXCEPTIONS +# if (defined(__GNUC__) && !defined(__EXCEPTIONS)) || \ + (FMT_MSC_VERSION && !_HAS_EXCEPTIONS) +# define FMT_EXCEPTIONS 0 +# else +# define FMT_EXCEPTIONS 1 +# endif +#endif + +// Disable [[noreturn]] on MSVC/NVCC because of bogus unreachable code warnings. +#if FMT_EXCEPTIONS && FMT_HAS_CPP_ATTRIBUTE(noreturn) && !FMT_MSC_VERSION && \ + !defined(__NVCC__) +# define FMT_NORETURN [[noreturn]] +#else +# define FMT_NORETURN +#endif + +#ifndef FMT_NODISCARD +# if FMT_HAS_CPP17_ATTRIBUTE(nodiscard) +# define FMT_NODISCARD [[nodiscard]] +# else +# define FMT_NODISCARD +# endif +#endif + +#ifndef FMT_INLINE +# if FMT_GCC_VERSION || FMT_CLANG_VERSION +# define FMT_INLINE inline __attribute__((always_inline)) +# else +# define FMT_INLINE inline +# endif +#endif + +#ifdef _MSC_VER +# define FMT_UNCHECKED_ITERATOR(It) \ + using _Unchecked_type = It // Mark iterator as checked. +#else +# define FMT_UNCHECKED_ITERATOR(It) using unchecked_type = It +#endif + +#ifndef FMT_BEGIN_NAMESPACE +# define FMT_BEGIN_NAMESPACE \ + namespace fmt { \ + inline namespace v10 { +# define FMT_END_NAMESPACE \ + } \ + } +#endif + +#ifndef FMT_EXPORT +# define FMT_EXPORT +# define FMT_BEGIN_EXPORT +# define FMT_END_EXPORT +#endif + +#if !defined(FMT_HEADER_ONLY) && defined(_WIN32) +# ifdef FMT_LIB_EXPORT +# define FMT_API __declspec(dllexport) +# elif defined(FMT_SHARED) +# define FMT_API __declspec(dllimport) +# endif +#else +# if defined(FMT_LIB_EXPORT) || defined(FMT_SHARED) +# if defined(__GNUC__) || defined(__clang__) +# define FMT_API __attribute__((visibility("default"))) +# endif +# endif +#endif +#ifndef FMT_API +# define FMT_API +#endif + +// libc++ supports string_view in pre-c++17. +#if FMT_HAS_INCLUDE() && \ + (FMT_CPLUSPLUS >= 201703L || defined(_LIBCPP_VERSION)) +# include +# define FMT_USE_STRING_VIEW +#elif FMT_HAS_INCLUDE("experimental/string_view") && FMT_CPLUSPLUS >= 201402L +# include +# define FMT_USE_EXPERIMENTAL_STRING_VIEW +#endif + +#ifndef FMT_UNICODE +# define FMT_UNICODE !FMT_MSC_VERSION +#endif + +#ifndef FMT_CONSTEVAL +# if ((FMT_GCC_VERSION >= 1000 || FMT_CLANG_VERSION >= 1101) && \ + (!defined(__apple_build_version__) || \ + __apple_build_version__ >= 14000029L) && \ + FMT_CPLUSPLUS >= 202002L) || \ + (defined(__cpp_consteval) && \ + (!FMT_MSC_VERSION || _MSC_FULL_VER >= 193030704)) +// consteval is broken in MSVC before VS2022 and Apple clang before 14. +# define FMT_CONSTEVAL consteval +# define FMT_HAS_CONSTEVAL +# else +# define FMT_CONSTEVAL +# endif +#endif + +#ifndef FMT_USE_NONTYPE_TEMPLATE_ARGS +# if defined(__cpp_nontype_template_args) && \ + ((FMT_GCC_VERSION >= 903 && FMT_CPLUSPLUS >= 201709L) || \ + __cpp_nontype_template_args >= 201911L) && \ + !defined(__NVCOMPILER) && !defined(__LCC__) +# define FMT_USE_NONTYPE_TEMPLATE_ARGS 1 +# else +# define FMT_USE_NONTYPE_TEMPLATE_ARGS 0 +# endif +#endif + +// Enable minimal optimizations for more compact code in debug mode. +FMT_GCC_PRAGMA("GCC push_options") +#if !defined(__OPTIMIZE__) && !defined(__NVCOMPILER) && !defined(__LCC__) && \ + !defined(__CUDACC__) +FMT_GCC_PRAGMA("GCC optimize(\"Og\")") +#endif + +FMT_BEGIN_NAMESPACE + +// Implementations of enable_if_t and other metafunctions for older systems. +template +using enable_if_t = typename std::enable_if::type; +template +using conditional_t = typename std::conditional::type; +template using bool_constant = std::integral_constant; +template +using remove_reference_t = typename std::remove_reference::type; +template +using remove_const_t = typename std::remove_const::type; +template +using remove_cvref_t = typename std::remove_cv>::type; +template struct type_identity { using type = T; }; +template using type_identity_t = typename type_identity::type; +template +using underlying_t = typename std::underlying_type::type; + +// Checks whether T is a container with contiguous storage. +template struct is_contiguous : std::false_type {}; +template +struct is_contiguous> : std::true_type {}; + +struct monostate { + constexpr monostate() {} +}; + +// An enable_if helper to be used in template parameters which results in much +// shorter symbols: https://godbolt.org/z/sWw4vP. Extra parentheses are needed +// to workaround a bug in MSVC 2019 (see #1140 and #1186). +#ifdef FMT_DOC +# define FMT_ENABLE_IF(...) +#else +# define FMT_ENABLE_IF(...) fmt::enable_if_t<(__VA_ARGS__), int> = 0 +#endif + +// This is defined in core.h instead of format.h to avoid injecting in std. +// It is a template to avoid undesirable implicit conversions to std::byte. +#ifdef __cpp_lib_byte +template ::value)> +inline auto format_as(T b) -> unsigned char { + return static_cast(b); +} +#endif + +namespace detail { +// Suppresses "unused variable" warnings with the method described in +// https://herbsutter.com/2009/10/18/mailbag-shutting-up-compiler-warnings/. +// (void)var does not work on many Intel compilers. +template FMT_CONSTEXPR void ignore_unused(const T&...) {} + +constexpr FMT_INLINE auto is_constant_evaluated( + bool default_value = false) noexcept -> bool { +// Workaround for incompatibility between libstdc++ consteval-based +// std::is_constant_evaluated() implementation and clang-14. +// https://github.com/fmtlib/fmt/issues/3247 +#if FMT_CPLUSPLUS >= 202002L && defined(_GLIBCXX_RELEASE) && \ + _GLIBCXX_RELEASE >= 12 && \ + (FMT_CLANG_VERSION >= 1400 && FMT_CLANG_VERSION < 1500) + ignore_unused(default_value); + return __builtin_is_constant_evaluated(); +#elif defined(__cpp_lib_is_constant_evaluated) + ignore_unused(default_value); + return std::is_constant_evaluated(); +#else + return default_value; +#endif +} + +// Suppresses "conditional expression is constant" warnings. +template constexpr FMT_INLINE auto const_check(T value) -> T { + return value; +} + +FMT_NORETURN FMT_API void assert_fail(const char* file, int line, + const char* message); + +#ifndef FMT_ASSERT +# ifdef NDEBUG +// FMT_ASSERT is not empty to avoid -Wempty-body. +# define FMT_ASSERT(condition, message) \ + fmt::detail::ignore_unused((condition), (message)) +# else +# define FMT_ASSERT(condition, message) \ + ((condition) /* void() fails with -Winvalid-constexpr on clang 4.0.1 */ \ + ? (void)0 \ + : fmt::detail::assert_fail(__FILE__, __LINE__, (message))) +# endif +#endif + +#if defined(FMT_USE_STRING_VIEW) +template using std_string_view = std::basic_string_view; +#elif defined(FMT_USE_EXPERIMENTAL_STRING_VIEW) +template +using std_string_view = std::experimental::basic_string_view; +#else +template struct std_string_view {}; +#endif + +#ifdef FMT_USE_INT128 +// Do nothing. +#elif defined(__SIZEOF_INT128__) && !defined(__NVCC__) && \ + !(FMT_CLANG_VERSION && FMT_MSC_VERSION) +# define FMT_USE_INT128 1 +using int128_opt = __int128_t; // An optional native 128-bit integer. +using uint128_opt = __uint128_t; +template inline auto convert_for_visit(T value) -> T { + return value; +} +#else +# define FMT_USE_INT128 0 +#endif +#if !FMT_USE_INT128 +enum class int128_opt {}; +enum class uint128_opt {}; +// Reduce template instantiations. +template auto convert_for_visit(T) -> monostate { return {}; } +#endif + +// Casts a nonnegative integer to unsigned. +template +FMT_CONSTEXPR auto to_unsigned(Int value) -> + typename std::make_unsigned::type { + FMT_ASSERT(std::is_unsigned::value || value >= 0, "negative value"); + return static_cast::type>(value); +} + +FMT_CONSTEXPR inline auto is_utf8() -> bool { + FMT_MSC_WARNING(suppress : 4566) constexpr unsigned char section[] = "\u00A7"; + + // Avoid buggy sign extensions in MSVC's constant evaluation mode (#2297). + using uchar = unsigned char; + return FMT_UNICODE || (sizeof(section) == 3 && uchar(section[0]) == 0xC2 && + uchar(section[1]) == 0xA7); +} +} // namespace detail + +/** + An implementation of ``std::basic_string_view`` for pre-C++17. It provides a + subset of the API. ``fmt::basic_string_view`` is used for format strings even + if ``std::string_view`` is available to prevent issues when a library is + compiled with a different ``-std`` option than the client code (which is not + recommended). + */ +FMT_EXPORT +template class basic_string_view { + private: + const Char* data_; + size_t size_; + + public: + using value_type = Char; + using iterator = const Char*; + + constexpr basic_string_view() noexcept : data_(nullptr), size_(0) {} + + /** Constructs a string reference object from a C string and a size. */ + constexpr basic_string_view(const Char* s, size_t count) noexcept + : data_(s), size_(count) {} + + /** + \rst + Constructs a string reference object from a C string computing + the size with ``std::char_traits::length``. + \endrst + */ + FMT_CONSTEXPR_CHAR_TRAITS + FMT_INLINE + basic_string_view(const Char* s) + : data_(s), + size_(detail::const_check(std::is_same::value && + !detail::is_constant_evaluated(true)) + ? std::strlen(reinterpret_cast(s)) + : std::char_traits::length(s)) {} + + /** Constructs a string reference from a ``std::basic_string`` object. */ + template + FMT_CONSTEXPR basic_string_view( + const std::basic_string& s) noexcept + : data_(s.data()), size_(s.size()) {} + + template >::value)> + FMT_CONSTEXPR basic_string_view(S s) noexcept + : data_(s.data()), size_(s.size()) {} + + /** Returns a pointer to the string data. */ + constexpr auto data() const noexcept -> const Char* { return data_; } + + /** Returns the string size. */ + constexpr auto size() const noexcept -> size_t { return size_; } + + constexpr auto begin() const noexcept -> iterator { return data_; } + constexpr auto end() const noexcept -> iterator { return data_ + size_; } + + constexpr auto operator[](size_t pos) const noexcept -> const Char& { + return data_[pos]; + } + + FMT_CONSTEXPR void remove_prefix(size_t n) noexcept { + data_ += n; + size_ -= n; + } + + FMT_CONSTEXPR_CHAR_TRAITS bool starts_with( + basic_string_view sv) const noexcept { + return size_ >= sv.size_ && + std::char_traits::compare(data_, sv.data_, sv.size_) == 0; + } + FMT_CONSTEXPR_CHAR_TRAITS bool starts_with(Char c) const noexcept { + return size_ >= 1 && std::char_traits::eq(*data_, c); + } + FMT_CONSTEXPR_CHAR_TRAITS bool starts_with(const Char* s) const { + return starts_with(basic_string_view(s)); + } + + // Lexicographically compare this string reference to other. + FMT_CONSTEXPR_CHAR_TRAITS auto compare(basic_string_view other) const -> int { + size_t str_size = size_ < other.size_ ? size_ : other.size_; + int result = std::char_traits::compare(data_, other.data_, str_size); + if (result == 0) + result = size_ == other.size_ ? 0 : (size_ < other.size_ ? -1 : 1); + return result; + } + + FMT_CONSTEXPR_CHAR_TRAITS friend auto operator==(basic_string_view lhs, + basic_string_view rhs) + -> bool { + return lhs.compare(rhs) == 0; + } + friend auto operator!=(basic_string_view lhs, basic_string_view rhs) -> bool { + return lhs.compare(rhs) != 0; + } + friend auto operator<(basic_string_view lhs, basic_string_view rhs) -> bool { + return lhs.compare(rhs) < 0; + } + friend auto operator<=(basic_string_view lhs, basic_string_view rhs) -> bool { + return lhs.compare(rhs) <= 0; + } + friend auto operator>(basic_string_view lhs, basic_string_view rhs) -> bool { + return lhs.compare(rhs) > 0; + } + friend auto operator>=(basic_string_view lhs, basic_string_view rhs) -> bool { + return lhs.compare(rhs) >= 0; + } +}; + +FMT_EXPORT +using string_view = basic_string_view; + +/** Specifies if ``T`` is a character type. Can be specialized by users. */ +FMT_EXPORT +template struct is_char : std::false_type {}; +template <> struct is_char : std::true_type {}; + +namespace detail { + +// A base class for compile-time strings. +struct compile_string {}; + +template +struct is_compile_string : std::is_base_of {}; + +template ::value)> +FMT_INLINE auto to_string_view(const Char* s) -> basic_string_view { + return s; +} +template +inline auto to_string_view(const std::basic_string& s) + -> basic_string_view { + return s; +} +template +constexpr auto to_string_view(basic_string_view s) + -> basic_string_view { + return s; +} +template >::value)> +inline auto to_string_view(std_string_view s) -> basic_string_view { + return s; +} +template ::value)> +constexpr auto to_string_view(const S& s) + -> basic_string_view { + return basic_string_view(s); +} +void to_string_view(...); + +// Specifies whether S is a string type convertible to fmt::basic_string_view. +// It should be a constexpr function but MSVC 2017 fails to compile it in +// enable_if and MSVC 2015 fails to compile it as an alias template. +// ADL is intentionally disabled as to_string_view is not an extension point. +template +struct is_string + : std::is_class()))> {}; + +template struct char_t_impl {}; +template struct char_t_impl::value>> { + using result = decltype(to_string_view(std::declval())); + using type = typename result::value_type; +}; + +enum class type { + none_type, + // Integer types should go first, + int_type, + uint_type, + long_long_type, + ulong_long_type, + int128_type, + uint128_type, + bool_type, + char_type, + last_integer_type = char_type, + // followed by floating-point types. + float_type, + double_type, + long_double_type, + last_numeric_type = long_double_type, + cstring_type, + string_type, + pointer_type, + custom_type +}; + +// Maps core type T to the corresponding type enum constant. +template +struct type_constant : std::integral_constant {}; + +#define FMT_TYPE_CONSTANT(Type, constant) \ + template \ + struct type_constant \ + : std::integral_constant {} + +FMT_TYPE_CONSTANT(int, int_type); +FMT_TYPE_CONSTANT(unsigned, uint_type); +FMT_TYPE_CONSTANT(long long, long_long_type); +FMT_TYPE_CONSTANT(unsigned long long, ulong_long_type); +FMT_TYPE_CONSTANT(int128_opt, int128_type); +FMT_TYPE_CONSTANT(uint128_opt, uint128_type); +FMT_TYPE_CONSTANT(bool, bool_type); +FMT_TYPE_CONSTANT(Char, char_type); +FMT_TYPE_CONSTANT(float, float_type); +FMT_TYPE_CONSTANT(double, double_type); +FMT_TYPE_CONSTANT(long double, long_double_type); +FMT_TYPE_CONSTANT(const Char*, cstring_type); +FMT_TYPE_CONSTANT(basic_string_view, string_type); +FMT_TYPE_CONSTANT(const void*, pointer_type); + +constexpr bool is_integral_type(type t) { + return t > type::none_type && t <= type::last_integer_type; +} +constexpr bool is_arithmetic_type(type t) { + return t > type::none_type && t <= type::last_numeric_type; +} + +constexpr auto set(type rhs) -> int { return 1 << static_cast(rhs); } +constexpr auto in(type t, int set) -> bool { + return ((set >> static_cast(t)) & 1) != 0; +} + +// Bitsets of types. +enum { + sint_set = + set(type::int_type) | set(type::long_long_type) | set(type::int128_type), + uint_set = set(type::uint_type) | set(type::ulong_long_type) | + set(type::uint128_type), + bool_set = set(type::bool_type), + char_set = set(type::char_type), + float_set = set(type::float_type) | set(type::double_type) | + set(type::long_double_type), + string_set = set(type::string_type), + cstring_set = set(type::cstring_type), + pointer_set = set(type::pointer_type) +}; + +FMT_NORETURN FMT_API void throw_format_error(const char* message); + +struct error_handler { + constexpr error_handler() = default; + + // This function is intentionally not constexpr to give a compile-time error. + FMT_NORETURN void on_error(const char* message) { + throw_format_error(message); + } +}; +} // namespace detail + +/** Throws ``format_error`` with a given message. */ +using detail::throw_format_error; + +/** String's character type. */ +template using char_t = typename detail::char_t_impl::type; + +/** + \rst + Parsing context consisting of a format string range being parsed and an + argument counter for automatic indexing. + You can use the ``format_parse_context`` type alias for ``char`` instead. + \endrst + */ +FMT_EXPORT +template class basic_format_parse_context { + private: + basic_string_view format_str_; + int next_arg_id_; + + FMT_CONSTEXPR void do_check_arg_id(int id); + + public: + using char_type = Char; + using iterator = const Char*; + + explicit constexpr basic_format_parse_context( + basic_string_view format_str, int next_arg_id = 0) + : format_str_(format_str), next_arg_id_(next_arg_id) {} + + /** + Returns an iterator to the beginning of the format string range being + parsed. + */ + constexpr auto begin() const noexcept -> iterator { + return format_str_.begin(); + } + + /** + Returns an iterator past the end of the format string range being parsed. + */ + constexpr auto end() const noexcept -> iterator { return format_str_.end(); } + + /** Advances the begin iterator to ``it``. */ + FMT_CONSTEXPR void advance_to(iterator it) { + format_str_.remove_prefix(detail::to_unsigned(it - begin())); + } + + /** + Reports an error if using the manual argument indexing; otherwise returns + the next argument index and switches to the automatic indexing. + */ + FMT_CONSTEXPR auto next_arg_id() -> int { + if (next_arg_id_ < 0) { + detail::throw_format_error( + "cannot switch from manual to automatic argument indexing"); + return 0; + } + int id = next_arg_id_++; + do_check_arg_id(id); + return id; + } + + /** + Reports an error if using the automatic argument indexing; otherwise + switches to the manual indexing. + */ + FMT_CONSTEXPR void check_arg_id(int id) { + if (next_arg_id_ > 0) { + detail::throw_format_error( + "cannot switch from automatic to manual argument indexing"); + return; + } + next_arg_id_ = -1; + do_check_arg_id(id); + } + FMT_CONSTEXPR void check_arg_id(basic_string_view) {} + FMT_CONSTEXPR void check_dynamic_spec(int arg_id); +}; + +FMT_EXPORT +using format_parse_context = basic_format_parse_context; + +namespace detail { +// A parse context with extra data used only in compile-time checks. +template +class compile_parse_context : public basic_format_parse_context { + private: + int num_args_; + const type* types_; + using base = basic_format_parse_context; + + public: + explicit FMT_CONSTEXPR compile_parse_context( + basic_string_view format_str, int num_args, const type* types, + int next_arg_id = 0) + : base(format_str, next_arg_id), num_args_(num_args), types_(types) {} + + constexpr auto num_args() const -> int { return num_args_; } + constexpr auto arg_type(int id) const -> type { return types_[id]; } + + FMT_CONSTEXPR auto next_arg_id() -> int { + int id = base::next_arg_id(); + if (id >= num_args_) throw_format_error("argument not found"); + return id; + } + + FMT_CONSTEXPR void check_arg_id(int id) { + base::check_arg_id(id); + if (id >= num_args_) throw_format_error("argument not found"); + } + using base::check_arg_id; + + FMT_CONSTEXPR void check_dynamic_spec(int arg_id) { + detail::ignore_unused(arg_id); +#if !defined(__LCC__) + if (arg_id < num_args_ && types_ && !is_integral_type(types_[arg_id])) + throw_format_error("width/precision is not integer"); +#endif + } +}; + +// Extracts a reference to the container from back_insert_iterator. +template +inline auto get_container(std::back_insert_iterator it) + -> Container& { + using base = std::back_insert_iterator; + struct accessor : base { + accessor(base b) : base(b) {} + using base::container; + }; + return *accessor(it).container; +} + +template +FMT_CONSTEXPR auto copy_str(InputIt begin, InputIt end, OutputIt out) + -> OutputIt { + while (begin != end) *out++ = static_cast(*begin++); + return out; +} + +template , U>::value&& is_char::value)> +FMT_CONSTEXPR auto copy_str(T* begin, T* end, U* out) -> U* { + if (is_constant_evaluated()) return copy_str(begin, end, out); + auto size = to_unsigned(end - begin); + if (size > 0) memcpy(out, begin, size * sizeof(U)); + return out + size; +} + +/** + \rst + A contiguous memory buffer with an optional growing ability. It is an internal + class and shouldn't be used directly, only via `~fmt::basic_memory_buffer`. + \endrst + */ +template class buffer { + private: + T* ptr_; + size_t size_; + size_t capacity_; + + protected: + // Don't initialize ptr_ since it is not accessed to save a few cycles. + FMT_MSC_WARNING(suppress : 26495) + buffer(size_t sz) noexcept : size_(sz), capacity_(sz) {} + + FMT_CONSTEXPR20 buffer(T* p = nullptr, size_t sz = 0, size_t cap = 0) noexcept + : ptr_(p), size_(sz), capacity_(cap) {} + + FMT_CONSTEXPR20 ~buffer() = default; + buffer(buffer&&) = default; + + /** Sets the buffer data and capacity. */ + FMT_CONSTEXPR void set(T* buf_data, size_t buf_capacity) noexcept { + ptr_ = buf_data; + capacity_ = buf_capacity; + } + + /** Increases the buffer capacity to hold at least *capacity* elements. */ + virtual FMT_CONSTEXPR20 void grow(size_t capacity) = 0; + + public: + using value_type = T; + using const_reference = const T&; + + buffer(const buffer&) = delete; + void operator=(const buffer&) = delete; + + FMT_INLINE auto begin() noexcept -> T* { return ptr_; } + FMT_INLINE auto end() noexcept -> T* { return ptr_ + size_; } + + FMT_INLINE auto begin() const noexcept -> const T* { return ptr_; } + FMT_INLINE auto end() const noexcept -> const T* { return ptr_ + size_; } + + /** Returns the size of this buffer. */ + constexpr auto size() const noexcept -> size_t { return size_; } + + /** Returns the capacity of this buffer. */ + constexpr auto capacity() const noexcept -> size_t { return capacity_; } + + /** Returns a pointer to the buffer data (not null-terminated). */ + FMT_CONSTEXPR auto data() noexcept -> T* { return ptr_; } + FMT_CONSTEXPR auto data() const noexcept -> const T* { return ptr_; } + + /** Clears this buffer. */ + void clear() { size_ = 0; } + + // Tries resizing the buffer to contain *count* elements. If T is a POD type + // the new elements may not be initialized. + FMT_CONSTEXPR20 void try_resize(size_t count) { + try_reserve(count); + size_ = count <= capacity_ ? count : capacity_; + } + + // Tries increasing the buffer capacity to *new_capacity*. It can increase the + // capacity by a smaller amount than requested but guarantees there is space + // for at least one additional element either by increasing the capacity or by + // flushing the buffer if it is full. + FMT_CONSTEXPR20 void try_reserve(size_t new_capacity) { + if (new_capacity > capacity_) grow(new_capacity); + } + + FMT_CONSTEXPR20 void push_back(const T& value) { + try_reserve(size_ + 1); + ptr_[size_++] = value; + } + + /** Appends data to the end of the buffer. */ + template void append(const U* begin, const U* end); + + template FMT_CONSTEXPR auto operator[](Idx index) -> T& { + return ptr_[index]; + } + template + FMT_CONSTEXPR auto operator[](Idx index) const -> const T& { + return ptr_[index]; + } +}; + +struct buffer_traits { + explicit buffer_traits(size_t) {} + auto count() const -> size_t { return 0; } + auto limit(size_t size) -> size_t { return size; } +}; + +class fixed_buffer_traits { + private: + size_t count_ = 0; + size_t limit_; + + public: + explicit fixed_buffer_traits(size_t limit) : limit_(limit) {} + auto count() const -> size_t { return count_; } + auto limit(size_t size) -> size_t { + size_t n = limit_ > count_ ? limit_ - count_ : 0; + count_ += size; + return size < n ? size : n; + } +}; + +// A buffer that writes to an output iterator when flushed. +template +class iterator_buffer final : public Traits, public buffer { + private: + OutputIt out_; + enum { buffer_size = 256 }; + T data_[buffer_size]; + + protected: + FMT_CONSTEXPR20 void grow(size_t) override { + if (this->size() == buffer_size) flush(); + } + + void flush() { + auto size = this->size(); + this->clear(); + out_ = copy_str(data_, data_ + this->limit(size), out_); + } + + public: + explicit iterator_buffer(OutputIt out, size_t n = buffer_size) + : Traits(n), buffer(data_, 0, buffer_size), out_(out) {} + iterator_buffer(iterator_buffer&& other) + : Traits(other), buffer(data_, 0, buffer_size), out_(other.out_) {} + ~iterator_buffer() { flush(); } + + auto out() -> OutputIt { + flush(); + return out_; + } + auto count() const -> size_t { return Traits::count() + this->size(); } +}; + +template +class iterator_buffer final + : public fixed_buffer_traits, + public buffer { + private: + T* out_; + enum { buffer_size = 256 }; + T data_[buffer_size]; + + protected: + FMT_CONSTEXPR20 void grow(size_t) override { + if (this->size() == this->capacity()) flush(); + } + + void flush() { + size_t n = this->limit(this->size()); + if (this->data() == out_) { + out_ += n; + this->set(data_, buffer_size); + } + this->clear(); + } + + public: + explicit iterator_buffer(T* out, size_t n = buffer_size) + : fixed_buffer_traits(n), buffer(out, 0, n), out_(out) {} + iterator_buffer(iterator_buffer&& other) + : fixed_buffer_traits(other), + buffer(std::move(other)), + out_(other.out_) { + if (this->data() != out_) { + this->set(data_, buffer_size); + this->clear(); + } + } + ~iterator_buffer() { flush(); } + + auto out() -> T* { + flush(); + return out_; + } + auto count() const -> size_t { + return fixed_buffer_traits::count() + this->size(); + } +}; + +template class iterator_buffer final : public buffer { + protected: + FMT_CONSTEXPR20 void grow(size_t) override {} + + public: + explicit iterator_buffer(T* out, size_t = 0) : buffer(out, 0, ~size_t()) {} + + auto out() -> T* { return &*this->end(); } +}; + +// A buffer that writes to a container with the contiguous storage. +template +class iterator_buffer, + enable_if_t::value, + typename Container::value_type>> + final : public buffer { + private: + Container& container_; + + protected: + FMT_CONSTEXPR20 void grow(size_t capacity) override { + container_.resize(capacity); + this->set(&container_[0], capacity); + } + + public: + explicit iterator_buffer(Container& c) + : buffer(c.size()), container_(c) {} + explicit iterator_buffer(std::back_insert_iterator out, size_t = 0) + : iterator_buffer(get_container(out)) {} + + auto out() -> std::back_insert_iterator { + return std::back_inserter(container_); + } +}; + +// A buffer that counts the number of code units written discarding the output. +template class counting_buffer final : public buffer { + private: + enum { buffer_size = 256 }; + T data_[buffer_size]; + size_t count_ = 0; + + protected: + FMT_CONSTEXPR20 void grow(size_t) override { + if (this->size() != buffer_size) return; + count_ += this->size(); + this->clear(); + } + + public: + counting_buffer() : buffer(data_, 0, buffer_size) {} + + auto count() -> size_t { return count_ + this->size(); } +}; +} // namespace detail + +template +FMT_CONSTEXPR void basic_format_parse_context::do_check_arg_id(int id) { + // Argument id is only checked at compile-time during parsing because + // formatting has its own validation. + if (detail::is_constant_evaluated() && + (!FMT_GCC_VERSION || FMT_GCC_VERSION >= 1200)) { + using context = detail::compile_parse_context; + if (id >= static_cast(this)->num_args()) + detail::throw_format_error("argument not found"); + } +} + +template +FMT_CONSTEXPR void basic_format_parse_context::check_dynamic_spec( + int arg_id) { + if (detail::is_constant_evaluated() && + (!FMT_GCC_VERSION || FMT_GCC_VERSION >= 1200)) { + using context = detail::compile_parse_context; + static_cast(this)->check_dynamic_spec(arg_id); + } +} + +FMT_EXPORT template class basic_format_arg; +FMT_EXPORT template class basic_format_args; +FMT_EXPORT template class dynamic_format_arg_store; + +// A formatter for objects of type T. +FMT_EXPORT +template +struct formatter { + // A deleted default constructor indicates a disabled formatter. + formatter() = delete; +}; + +// Specifies if T has an enabled formatter specialization. A type can be +// formattable even if it doesn't have a formatter e.g. via a conversion. +template +using has_formatter = + std::is_constructible>; + +// An output iterator that appends to a buffer. +// It is used to reduce symbol sizes for the common case. +class appender : public std::back_insert_iterator> { + using base = std::back_insert_iterator>; + + public: + using std::back_insert_iterator>::back_insert_iterator; + appender(base it) noexcept : base(it) {} + FMT_UNCHECKED_ITERATOR(appender); + + auto operator++() noexcept -> appender& { return *this; } + auto operator++(int) noexcept -> appender { return *this; } +}; + +namespace detail { + +template +constexpr auto has_const_formatter_impl(T*) + -> decltype(typename Context::template formatter_type().format( + std::declval(), std::declval()), + true) { + return true; +} +template +constexpr auto has_const_formatter_impl(...) -> bool { + return false; +} +template +constexpr auto has_const_formatter() -> bool { + return has_const_formatter_impl(static_cast(nullptr)); +} + +template +using buffer_appender = conditional_t::value, appender, + std::back_insert_iterator>>; + +// Maps an output iterator to a buffer. +template +auto get_buffer(OutputIt out) -> iterator_buffer { + return iterator_buffer(out); +} +template , Buf>::value)> +auto get_buffer(std::back_insert_iterator out) -> buffer& { + return get_container(out); +} + +template +FMT_INLINE auto get_iterator(Buf& buf, OutputIt) -> decltype(buf.out()) { + return buf.out(); +} +template +auto get_iterator(buffer&, OutputIt out) -> OutputIt { + return out; +} + +struct view {}; + +template struct named_arg : view { + const Char* name; + const T& value; + named_arg(const Char* n, const T& v) : name(n), value(v) {} +}; + +template struct named_arg_info { + const Char* name; + int id; +}; + +template +struct arg_data { + // args_[0].named_args points to named_args_ to avoid bloating format_args. + // +1 to workaround a bug in gcc 7.5 that causes duplicated-branches warning. + T args_[1 + (NUM_ARGS != 0 ? NUM_ARGS : +1)]; + named_arg_info named_args_[NUM_NAMED_ARGS]; + + template + arg_data(const U&... init) : args_{T(named_args_, NUM_NAMED_ARGS), init...} {} + arg_data(const arg_data& other) = delete; + auto args() const -> const T* { return args_ + 1; } + auto named_args() -> named_arg_info* { return named_args_; } +}; + +template +struct arg_data { + // +1 to workaround a bug in gcc 7.5 that causes duplicated-branches warning. + T args_[NUM_ARGS != 0 ? NUM_ARGS : +1]; + + template + FMT_CONSTEXPR FMT_INLINE arg_data(const U&... init) : args_{init...} {} + FMT_CONSTEXPR FMT_INLINE auto args() const -> const T* { return args_; } + FMT_CONSTEXPR FMT_INLINE auto named_args() -> std::nullptr_t { + return nullptr; + } +}; + +template +inline void init_named_args(named_arg_info*, int, int) {} + +template struct is_named_arg : std::false_type {}; +template struct is_statically_named_arg : std::false_type {}; + +template +struct is_named_arg> : std::true_type {}; + +template ::value)> +void init_named_args(named_arg_info* named_args, int arg_count, + int named_arg_count, const T&, const Tail&... args) { + init_named_args(named_args, arg_count + 1, named_arg_count, args...); +} + +template ::value)> +void init_named_args(named_arg_info* named_args, int arg_count, + int named_arg_count, const T& arg, const Tail&... args) { + named_args[named_arg_count++] = {arg.name, arg_count}; + init_named_args(named_args, arg_count + 1, named_arg_count, args...); +} + +template +FMT_CONSTEXPR FMT_INLINE void init_named_args(std::nullptr_t, int, int, + const Args&...) {} + +template constexpr auto count() -> size_t { return B ? 1 : 0; } +template constexpr auto count() -> size_t { + return (B1 ? 1 : 0) + count(); +} + +template constexpr auto count_named_args() -> size_t { + return count::value...>(); +} + +template +constexpr auto count_statically_named_args() -> size_t { + return count::value...>(); +} + +struct unformattable {}; +struct unformattable_char : unformattable {}; +struct unformattable_pointer : unformattable {}; + +template struct string_value { + const Char* data; + size_t size; +}; + +template struct named_arg_value { + const named_arg_info* data; + size_t size; +}; + +template struct custom_value { + using parse_context = typename Context::parse_context_type; + void* value; + void (*format)(void* arg, parse_context& parse_ctx, Context& ctx); +}; + +// A formatting argument value. +template class value { + public: + using char_type = typename Context::char_type; + + union { + monostate no_value; + int int_value; + unsigned uint_value; + long long long_long_value; + unsigned long long ulong_long_value; + int128_opt int128_value; + uint128_opt uint128_value; + bool bool_value; + char_type char_value; + float float_value; + double double_value; + long double long_double_value; + const void* pointer; + string_value string; + custom_value custom; + named_arg_value named_args; + }; + + constexpr FMT_INLINE value() : no_value() {} + constexpr FMT_INLINE value(int val) : int_value(val) {} + constexpr FMT_INLINE value(unsigned val) : uint_value(val) {} + constexpr FMT_INLINE value(long long val) : long_long_value(val) {} + constexpr FMT_INLINE value(unsigned long long val) : ulong_long_value(val) {} + FMT_INLINE value(int128_opt val) : int128_value(val) {} + FMT_INLINE value(uint128_opt val) : uint128_value(val) {} + constexpr FMT_INLINE value(float val) : float_value(val) {} + constexpr FMT_INLINE value(double val) : double_value(val) {} + FMT_INLINE value(long double val) : long_double_value(val) {} + constexpr FMT_INLINE value(bool val) : bool_value(val) {} + constexpr FMT_INLINE value(char_type val) : char_value(val) {} + FMT_CONSTEXPR FMT_INLINE value(const char_type* val) { + string.data = val; + if (is_constant_evaluated()) string.size = {}; + } + FMT_CONSTEXPR FMT_INLINE value(basic_string_view val) { + string.data = val.data(); + string.size = val.size(); + } + FMT_INLINE value(const void* val) : pointer(val) {} + FMT_INLINE value(const named_arg_info* args, size_t size) + : named_args{args, size} {} + + template FMT_CONSTEXPR20 FMT_INLINE value(T& val) { + using value_type = remove_const_t; + custom.value = const_cast(std::addressof(val)); + // Get the formatter type through the context to allow different contexts + // have different extension points, e.g. `formatter` for `format` and + // `printf_formatter` for `printf`. + custom.format = format_custom_arg< + value_type, typename Context::template formatter_type>; + } + value(unformattable); + value(unformattable_char); + value(unformattable_pointer); + + private: + // Formats an argument of a custom type, such as a user-defined class. + template + static void format_custom_arg(void* arg, + typename Context::parse_context_type& parse_ctx, + Context& ctx) { + auto f = Formatter(); + parse_ctx.advance_to(f.parse(parse_ctx)); + using qualified_type = + conditional_t(), const T, T>; + ctx.advance_to(f.format(*static_cast(arg), ctx)); + } +}; + +// To minimize the number of types we need to deal with, long is translated +// either to int or to long long depending on its size. +enum { long_short = sizeof(long) == sizeof(int) }; +using long_type = conditional_t; +using ulong_type = conditional_t; + +template struct format_as_result { + template ::value || std::is_class::value)> + static auto map(U*) -> decltype(format_as(std::declval())); + static auto map(...) -> void; + + using type = decltype(map(static_cast(nullptr))); +}; +template using format_as_t = typename format_as_result::type; + +template +struct has_format_as + : bool_constant, void>::value> {}; + +// Maps formatting arguments to core types. +// arg_mapper reports errors by returning unformattable instead of using +// static_assert because it's used in the is_formattable trait. +template struct arg_mapper { + using char_type = typename Context::char_type; + + FMT_CONSTEXPR FMT_INLINE auto map(signed char val) -> int { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(unsigned char val) -> unsigned { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(short val) -> int { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(unsigned short val) -> unsigned { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(int val) -> int { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(unsigned val) -> unsigned { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(long val) -> long_type { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(unsigned long val) -> ulong_type { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(long long val) -> long long { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(unsigned long long val) + -> unsigned long long { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(int128_opt val) -> int128_opt { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(uint128_opt val) -> uint128_opt { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(bool val) -> bool { return val; } + + template ::value || + std::is_same::value)> + FMT_CONSTEXPR FMT_INLINE auto map(T val) -> char_type { + return val; + } + template ::value || +#ifdef __cpp_char8_t + std::is_same::value || +#endif + std::is_same::value || + std::is_same::value) && + !std::is_same::value, + int> = 0> + FMT_CONSTEXPR FMT_INLINE auto map(T) -> unformattable_char { + return {}; + } + + FMT_CONSTEXPR FMT_INLINE auto map(float val) -> float { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(double val) -> double { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(long double val) -> long double { + return val; + } + + FMT_CONSTEXPR FMT_INLINE auto map(char_type* val) -> const char_type* { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(const char_type* val) -> const char_type* { + return val; + } + template ::value && !std::is_pointer::value && + std::is_same>::value)> + FMT_CONSTEXPR FMT_INLINE auto map(const T& val) + -> basic_string_view { + return to_string_view(val); + } + template ::value && !std::is_pointer::value && + !std::is_same>::value)> + FMT_CONSTEXPR FMT_INLINE auto map(const T&) -> unformattable_char { + return {}; + } + + FMT_CONSTEXPR FMT_INLINE auto map(void* val) -> const void* { return val; } + FMT_CONSTEXPR FMT_INLINE auto map(const void* val) -> const void* { + return val; + } + FMT_CONSTEXPR FMT_INLINE auto map(std::nullptr_t val) -> const void* { + return val; + } + + // Use SFINAE instead of a const T* parameter to avoid a conflict with the + // array overload. + template < + typename T, + FMT_ENABLE_IF( + std::is_pointer::value || std::is_member_pointer::value || + std::is_function::type>::value || + (std::is_array::value && + !std::is_convertible::value))> + FMT_CONSTEXPR auto map(const T&) -> unformattable_pointer { + return {}; + } + + template ::value)> + FMT_CONSTEXPR FMT_INLINE auto map(const T (&values)[N]) -> const T (&)[N] { + return values; + } + + // Only map owning types because mapping views can be unsafe. + template , + FMT_ENABLE_IF(std::is_arithmetic::value)> + FMT_CONSTEXPR FMT_INLINE auto map(const T& val) -> decltype(this->map(U())) { + return map(format_as(val)); + } + + template > + struct formattable : bool_constant() || + (has_formatter::value && + !std::is_const::value)> {}; + + template ::value)> + FMT_CONSTEXPR FMT_INLINE auto do_map(T& val) -> T& { + return val; + } + template ::value)> + FMT_CONSTEXPR FMT_INLINE auto do_map(T&) -> unformattable { + return {}; + } + + template , + FMT_ENABLE_IF((std::is_class::value || std::is_enum::value || + std::is_union::value) && + !is_string::value && !is_char::value && + !is_named_arg::value && + !std::is_arithmetic>::value)> + FMT_CONSTEXPR FMT_INLINE auto map(T& val) -> decltype(this->do_map(val)) { + return do_map(val); + } + + template ::value)> + FMT_CONSTEXPR FMT_INLINE auto map(const T& named_arg) + -> decltype(this->map(named_arg.value)) { + return map(named_arg.value); + } + + auto map(...) -> unformattable { return {}; } +}; + +// A type constant after applying arg_mapper. +template +using mapped_type_constant = + type_constant().map(std::declval())), + typename Context::char_type>; + +enum { packed_arg_bits = 4 }; +// Maximum number of arguments with packed types. +enum { max_packed_args = 62 / packed_arg_bits }; +enum : unsigned long long { is_unpacked_bit = 1ULL << 63 }; +enum : unsigned long long { has_named_args_bit = 1ULL << 62 }; + +template +auto copy_str(InputIt begin, InputIt end, appender out) -> appender { + get_container(out).append(begin, end); + return out; +} +template +auto copy_str(InputIt begin, InputIt end, + std::back_insert_iterator out) + -> std::back_insert_iterator { + get_container(out).append(begin, end); + return out; +} + +template +FMT_CONSTEXPR auto copy_str(R&& rng, OutputIt out) -> OutputIt { + return detail::copy_str(rng.begin(), rng.end(), out); +} + +#if FMT_GCC_VERSION && FMT_GCC_VERSION < 500 +// A workaround for gcc 4.8 to make void_t work in a SFINAE context. +template struct void_t_impl { using type = void; }; +template using void_t = typename void_t_impl::type; +#else +template using void_t = void; +#endif + +template +struct is_output_iterator : std::false_type {}; + +template +struct is_output_iterator< + It, T, + void_t::iterator_category, + decltype(*std::declval() = std::declval())>> + : std::true_type {}; + +template struct is_back_insert_iterator : std::false_type {}; +template +struct is_back_insert_iterator> + : std::true_type {}; + +// A type-erased reference to an std::locale to avoid a heavy include. +class locale_ref { + private: + const void* locale_; // A type-erased pointer to std::locale. + + public: + constexpr FMT_INLINE locale_ref() : locale_(nullptr) {} + template explicit locale_ref(const Locale& loc); + + explicit operator bool() const noexcept { return locale_ != nullptr; } + + template auto get() const -> Locale; +}; + +template constexpr auto encode_types() -> unsigned long long { + return 0; +} + +template +constexpr auto encode_types() -> unsigned long long { + return static_cast(mapped_type_constant::value) | + (encode_types() << packed_arg_bits); +} + +#if defined(__cpp_if_constexpr) +// This type is intentionally undefined, only used for errors +template struct type_is_unformattable_for; +#endif + +template +FMT_CONSTEXPR FMT_INLINE auto make_arg(T& val) -> value { + using arg_type = remove_cvref_t().map(val))>; + + constexpr bool formattable_char = + !std::is_same::value; + static_assert(formattable_char, "Mixing character types is disallowed."); + + // Formatting of arbitrary pointers is disallowed. If you want to format a + // pointer cast it to `void*` or `const void*`. In particular, this forbids + // formatting of `[const] volatile char*` printed as bool by iostreams. + constexpr bool formattable_pointer = + !std::is_same::value; + static_assert(formattable_pointer, + "Formatting of non-void pointers is disallowed."); + + constexpr bool formattable = !std::is_same::value; +#if defined(__cpp_if_constexpr) + if constexpr (!formattable) { + type_is_unformattable_for _; + } +#endif + static_assert( + formattable, + "Cannot format an argument. To make type T formattable provide a " + "formatter specialization: https://fmt.dev/latest/api.html#udt"); + return {arg_mapper().map(val)}; +} + +template +FMT_CONSTEXPR auto make_arg(T& val) -> basic_format_arg { + auto arg = basic_format_arg(); + arg.type_ = mapped_type_constant::value; + arg.value_ = make_arg(val); + return arg; +} + +template +FMT_CONSTEXPR inline auto make_arg(T& val) -> basic_format_arg { + return make_arg(val); +} +} // namespace detail +FMT_BEGIN_EXPORT + +// A formatting argument. It is a trivially copyable/constructible type to +// allow storage in basic_memory_buffer. +template class basic_format_arg { + private: + detail::value value_; + detail::type type_; + + template + friend FMT_CONSTEXPR auto detail::make_arg(T& value) + -> basic_format_arg; + + template + friend FMT_CONSTEXPR auto visit_format_arg(Visitor&& vis, + const basic_format_arg& arg) + -> decltype(vis(0)); + + friend class basic_format_args; + friend class dynamic_format_arg_store; + + using char_type = typename Context::char_type; + + template + friend struct detail::arg_data; + + basic_format_arg(const detail::named_arg_info* args, size_t size) + : value_(args, size) {} + + public: + class handle { + public: + explicit handle(detail::custom_value custom) : custom_(custom) {} + + void format(typename Context::parse_context_type& parse_ctx, + Context& ctx) const { + custom_.format(custom_.value, parse_ctx, ctx); + } + + private: + detail::custom_value custom_; + }; + + constexpr basic_format_arg() : type_(detail::type::none_type) {} + + constexpr explicit operator bool() const noexcept { + return type_ != detail::type::none_type; + } + + auto type() const -> detail::type { return type_; } + + auto is_integral() const -> bool { return detail::is_integral_type(type_); } + auto is_arithmetic() const -> bool { + return detail::is_arithmetic_type(type_); + } +}; + +/** + \rst + Visits an argument dispatching to the appropriate visit method based on + the argument type. For example, if the argument type is ``double`` then + ``vis(value)`` will be called with the value of type ``double``. + \endrst + */ +// DEPRECATED! +template +FMT_CONSTEXPR FMT_INLINE auto visit_format_arg( + Visitor&& vis, const basic_format_arg& arg) -> decltype(vis(0)) { + switch (arg.type_) { + case detail::type::none_type: + break; + case detail::type::int_type: + return vis(arg.value_.int_value); + case detail::type::uint_type: + return vis(arg.value_.uint_value); + case detail::type::long_long_type: + return vis(arg.value_.long_long_value); + case detail::type::ulong_long_type: + return vis(arg.value_.ulong_long_value); + case detail::type::int128_type: + return vis(detail::convert_for_visit(arg.value_.int128_value)); + case detail::type::uint128_type: + return vis(detail::convert_for_visit(arg.value_.uint128_value)); + case detail::type::bool_type: + return vis(arg.value_.bool_value); + case detail::type::char_type: + return vis(arg.value_.char_value); + case detail::type::float_type: + return vis(arg.value_.float_value); + case detail::type::double_type: + return vis(arg.value_.double_value); + case detail::type::long_double_type: + return vis(arg.value_.long_double_value); + case detail::type::cstring_type: + return vis(arg.value_.string.data); + case detail::type::string_type: + using sv = basic_string_view; + return vis(sv(arg.value_.string.data, arg.value_.string.size)); + case detail::type::pointer_type: + return vis(arg.value_.pointer); + case detail::type::custom_type: + return vis(typename basic_format_arg::handle(arg.value_.custom)); + } + return vis(monostate()); +} + +// Formatting context. +template class basic_format_context { + private: + OutputIt out_; + basic_format_args args_; + detail::locale_ref loc_; + + public: + using iterator = OutputIt; + using format_arg = basic_format_arg; + using format_args = basic_format_args; + using parse_context_type = basic_format_parse_context; + template using formatter_type = formatter; + + /** The character type for the output. */ + using char_type = Char; + + basic_format_context(basic_format_context&&) = default; + basic_format_context(const basic_format_context&) = delete; + void operator=(const basic_format_context&) = delete; + /** + Constructs a ``basic_format_context`` object. References to the arguments + are stored in the object so make sure they have appropriate lifetimes. + */ + constexpr basic_format_context(OutputIt out, format_args ctx_args, + detail::locale_ref loc = {}) + : out_(out), args_(ctx_args), loc_(loc) {} + + constexpr auto arg(int id) const -> format_arg { return args_.get(id); } + FMT_CONSTEXPR auto arg(basic_string_view name) -> format_arg { + return args_.get(name); + } + FMT_CONSTEXPR auto arg_id(basic_string_view name) -> int { + return args_.get_id(name); + } + auto args() const -> const format_args& { return args_; } + + FMT_CONSTEXPR auto error_handler() -> detail::error_handler { return {}; } + void on_error(const char* message) { error_handler().on_error(message); } + + // Returns an iterator to the beginning of the output range. + FMT_CONSTEXPR auto out() -> iterator { return out_; } + + // Advances the begin iterator to ``it``. + void advance_to(iterator it) { + if (!detail::is_back_insert_iterator()) out_ = it; + } + + FMT_CONSTEXPR auto locale() -> detail::locale_ref { return loc_; } +}; + +template +using buffer_context = + basic_format_context, Char>; +using format_context = buffer_context; + +template +using is_formattable = bool_constant>() + .map(std::declval()))>::value>; + +/** + \rst + An array of references to arguments. It can be implicitly converted into + `~fmt::basic_format_args` for passing into type-erased formatting functions + such as `~fmt::vformat`. + \endrst + */ +template +class format_arg_store +#if FMT_GCC_VERSION && FMT_GCC_VERSION < 409 + // Workaround a GCC template argument substitution bug. + : public basic_format_args +#endif +{ + private: + static const size_t num_args = sizeof...(Args); + static constexpr size_t num_named_args = detail::count_named_args(); + static const bool is_packed = num_args <= detail::max_packed_args; + + using value_type = conditional_t, + basic_format_arg>; + + detail::arg_data + data_; + + friend class basic_format_args; + + static constexpr unsigned long long desc = + (is_packed ? detail::encode_types() + : detail::is_unpacked_bit | num_args) | + (num_named_args != 0 + ? static_cast(detail::has_named_args_bit) + : 0); + + public: + template + FMT_CONSTEXPR FMT_INLINE format_arg_store(T&... args) + : +#if FMT_GCC_VERSION && FMT_GCC_VERSION < 409 + basic_format_args(*this), +#endif + data_{detail::make_arg(args)...} { + if (detail::const_check(num_named_args != 0)) + detail::init_named_args(data_.named_args(), 0, 0, args...); + } +}; + +/** + \rst + Constructs a `~fmt::format_arg_store` object that contains references to + arguments and can be implicitly converted to `~fmt::format_args`. `Context` + can be omitted in which case it defaults to `~fmt::format_context`. + See `~fmt::arg` for lifetime considerations. + \endrst + */ +// Arguments are taken by lvalue references to avoid some lifetime issues. +template +constexpr auto make_format_args(T&... args) + -> format_arg_store...> { + return {args...}; +} + +/** + \rst + Returns a named argument to be used in a formatting function. + It should only be used in a call to a formatting function or + `dynamic_format_arg_store::push_back`. + + **Example**:: + + fmt::print("Elapsed time: {s:.2f} seconds", fmt::arg("s", 1.23)); + \endrst + */ +template +inline auto arg(const Char* name, const T& arg) -> detail::named_arg { + static_assert(!detail::is_named_arg(), "nested named arguments"); + return {name, arg}; +} +FMT_END_EXPORT + +/** + \rst + A view of a collection of formatting arguments. To avoid lifetime issues it + should only be used as a parameter type in type-erased functions such as + ``vformat``:: + + void vlog(string_view format_str, format_args args); // OK + format_args args = make_format_args(); // Error: dangling reference + \endrst + */ +template class basic_format_args { + public: + using size_type = int; + using format_arg = basic_format_arg; + + private: + // A descriptor that contains information about formatting arguments. + // If the number of arguments is less or equal to max_packed_args then + // argument types are passed in the descriptor. This reduces binary code size + // per formatting function call. + unsigned long long desc_; + union { + // If is_packed() returns true then argument values are stored in values_; + // otherwise they are stored in args_. This is done to improve cache + // locality and reduce compiled code size since storing larger objects + // may require more code (at least on x86-64) even if the same amount of + // data is actually copied to stack. It saves ~10% on the bloat test. + const detail::value* values_; + const format_arg* args_; + }; + + constexpr auto is_packed() const -> bool { + return (desc_ & detail::is_unpacked_bit) == 0; + } + auto has_named_args() const -> bool { + return (desc_ & detail::has_named_args_bit) != 0; + } + + FMT_CONSTEXPR auto type(int index) const -> detail::type { + int shift = index * detail::packed_arg_bits; + unsigned int mask = (1 << detail::packed_arg_bits) - 1; + return static_cast((desc_ >> shift) & mask); + } + + constexpr FMT_INLINE basic_format_args(unsigned long long desc, + const detail::value* values) + : desc_(desc), values_(values) {} + constexpr basic_format_args(unsigned long long desc, const format_arg* args) + : desc_(desc), args_(args) {} + + public: + constexpr basic_format_args() : desc_(0), args_(nullptr) {} + + /** + \rst + Constructs a `basic_format_args` object from `~fmt::format_arg_store`. + \endrst + */ + template + constexpr FMT_INLINE basic_format_args( + const format_arg_store& store) + : basic_format_args(format_arg_store::desc, + store.data_.args()) {} + + /** + \rst + Constructs a `basic_format_args` object from + `~fmt::dynamic_format_arg_store`. + \endrst + */ + constexpr FMT_INLINE basic_format_args( + const dynamic_format_arg_store& store) + : basic_format_args(store.get_types(), store.data()) {} + + /** + \rst + Constructs a `basic_format_args` object from a dynamic set of arguments. + \endrst + */ + constexpr basic_format_args(const format_arg* args, int count) + : basic_format_args(detail::is_unpacked_bit | detail::to_unsigned(count), + args) {} + + /** Returns the argument with the specified id. */ + FMT_CONSTEXPR auto get(int id) const -> format_arg { + format_arg arg; + if (!is_packed()) { + if (id < max_size()) arg = args_[id]; + return arg; + } + if (id >= detail::max_packed_args) return arg; + arg.type_ = type(id); + if (arg.type_ == detail::type::none_type) return arg; + arg.value_ = values_[id]; + return arg; + } + + template + auto get(basic_string_view name) const -> format_arg { + int id = get_id(name); + return id >= 0 ? get(id) : format_arg(); + } + + template + auto get_id(basic_string_view name) const -> int { + if (!has_named_args()) return -1; + const auto& named_args = + (is_packed() ? values_[-1] : args_[-1].value_).named_args; + for (size_t i = 0; i < named_args.size; ++i) { + if (named_args.data[i].name == name) return named_args.data[i].id; + } + return -1; + } + + auto max_size() const -> int { + unsigned long long max_packed = detail::max_packed_args; + return static_cast(is_packed() ? max_packed + : desc_ & ~detail::is_unpacked_bit); + } +}; + +/** An alias to ``basic_format_args``. */ +// A separate type would result in shorter symbols but break ABI compatibility +// between clang and gcc on ARM (#1919). +FMT_EXPORT using format_args = basic_format_args; + +// We cannot use enum classes as bit fields because of a gcc bug, so we put them +// in namespaces instead (https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61414). +// Additionally, if an underlying type is specified, older gcc incorrectly warns +// that the type is too small. Both bugs are fixed in gcc 9.3. +#if FMT_GCC_VERSION && FMT_GCC_VERSION < 903 +# define FMT_ENUM_UNDERLYING_TYPE(type) +#else +# define FMT_ENUM_UNDERLYING_TYPE(type) : type +#endif +namespace align { +enum type FMT_ENUM_UNDERLYING_TYPE(unsigned char){none, left, right, center, + numeric}; +} +using align_t = align::type; +namespace sign { +enum type FMT_ENUM_UNDERLYING_TYPE(unsigned char){none, minus, plus, space}; +} +using sign_t = sign::type; + +namespace detail { + +// Workaround an array initialization issue in gcc 4.8. +template struct fill_t { + private: + enum { max_size = 4 }; + Char data_[max_size] = {Char(' '), Char(0), Char(0), Char(0)}; + unsigned char size_ = 1; + + public: + FMT_CONSTEXPR void operator=(basic_string_view s) { + auto size = s.size(); + FMT_ASSERT(size <= max_size, "invalid fill"); + for (size_t i = 0; i < size; ++i) data_[i] = s[i]; + size_ = static_cast(size); + } + + constexpr auto size() const -> size_t { return size_; } + constexpr auto data() const -> const Char* { return data_; } + + FMT_CONSTEXPR auto operator[](size_t index) -> Char& { return data_[index]; } + FMT_CONSTEXPR auto operator[](size_t index) const -> const Char& { + return data_[index]; + } +}; +} // namespace detail + +enum class presentation_type : unsigned char { + none, + dec, // 'd' + oct, // 'o' + hex_lower, // 'x' + hex_upper, // 'X' + bin_lower, // 'b' + bin_upper, // 'B' + hexfloat_lower, // 'a' + hexfloat_upper, // 'A' + exp_lower, // 'e' + exp_upper, // 'E' + fixed_lower, // 'f' + fixed_upper, // 'F' + general_lower, // 'g' + general_upper, // 'G' + chr, // 'c' + string, // 's' + pointer, // 'p' + debug // '?' +}; + +// Format specifiers for built-in and string types. +template struct format_specs { + int width; + int precision; + presentation_type type; + align_t align : 4; + sign_t sign : 3; + bool alt : 1; // Alternate form ('#'). + bool localized : 1; + detail::fill_t fill; + + constexpr format_specs() + : width(0), + precision(-1), + type(presentation_type::none), + align(align::none), + sign(sign::none), + alt(false), + localized(false) {} +}; + +namespace detail { + +enum class arg_id_kind { none, index, name }; + +// An argument reference. +template struct arg_ref { + FMT_CONSTEXPR arg_ref() : kind(arg_id_kind::none), val() {} + + FMT_CONSTEXPR explicit arg_ref(int index) + : kind(arg_id_kind::index), val(index) {} + FMT_CONSTEXPR explicit arg_ref(basic_string_view name) + : kind(arg_id_kind::name), val(name) {} + + FMT_CONSTEXPR auto operator=(int idx) -> arg_ref& { + kind = arg_id_kind::index; + val.index = idx; + return *this; + } + + arg_id_kind kind; + union value { + FMT_CONSTEXPR value(int idx = 0) : index(idx) {} + FMT_CONSTEXPR value(basic_string_view n) : name(n) {} + + int index; + basic_string_view name; + } val; +}; + +// Format specifiers with width and precision resolved at formatting rather +// than parsing time to allow reusing the same parsed specifiers with +// different sets of arguments (precompilation of format strings). +template +struct dynamic_format_specs : format_specs { + arg_ref width_ref; + arg_ref precision_ref; +}; + +// Converts a character to ASCII. Returns '\0' on conversion failure. +template ::value)> +constexpr auto to_ascii(Char c) -> char { + return c <= 0xff ? static_cast(c) : '\0'; +} +template ::value)> +constexpr auto to_ascii(Char c) -> char { + return c <= 0xff ? static_cast(c) : '\0'; +} + +// Returns the number of code units in a code point or 1 on error. +template +FMT_CONSTEXPR auto code_point_length(const Char* begin) -> int { + if (const_check(sizeof(Char) != 1)) return 1; + auto c = static_cast(*begin); + return static_cast((0x3a55000000000000ull >> (2 * (c >> 3))) & 0x3) + 1; +} + +// Return the result via the out param to workaround gcc bug 77539. +template +FMT_CONSTEXPR auto find(Ptr first, Ptr last, T value, Ptr& out) -> bool { + for (out = first; out != last; ++out) { + if (*out == value) return true; + } + return false; +} + +template <> +inline auto find(const char* first, const char* last, char value, + const char*& out) -> bool { + out = static_cast( + std::memchr(first, value, to_unsigned(last - first))); + return out != nullptr; +} + +// Parses the range [begin, end) as an unsigned integer. This function assumes +// that the range is non-empty and the first character is a digit. +template +FMT_CONSTEXPR auto parse_nonnegative_int(const Char*& begin, const Char* end, + int error_value) noexcept -> int { + FMT_ASSERT(begin != end && '0' <= *begin && *begin <= '9', ""); + unsigned value = 0, prev = 0; + auto p = begin; + do { + prev = value; + value = value * 10 + unsigned(*p - '0'); + ++p; + } while (p != end && '0' <= *p && *p <= '9'); + auto num_digits = p - begin; + begin = p; + if (num_digits <= std::numeric_limits::digits10) + return static_cast(value); + // Check for overflow. + const unsigned max = to_unsigned((std::numeric_limits::max)()); + return num_digits == std::numeric_limits::digits10 + 1 && + prev * 10ull + unsigned(p[-1] - '0') <= max + ? static_cast(value) + : error_value; +} + +FMT_CONSTEXPR inline auto parse_align(char c) -> align_t { + switch (c) { + case '<': + return align::left; + case '>': + return align::right; + case '^': + return align::center; + } + return align::none; +} + +template constexpr auto is_name_start(Char c) -> bool { + return ('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z') || c == '_'; +} + +template +FMT_CONSTEXPR auto do_parse_arg_id(const Char* begin, const Char* end, + Handler&& handler) -> const Char* { + Char c = *begin; + if (c >= '0' && c <= '9') { + int index = 0; + constexpr int max = (std::numeric_limits::max)(); + if (c != '0') + index = parse_nonnegative_int(begin, end, max); + else + ++begin; + if (begin == end || (*begin != '}' && *begin != ':')) + throw_format_error("invalid format string"); + else + handler.on_index(index); + return begin; + } + if (!is_name_start(c)) { + throw_format_error("invalid format string"); + return begin; + } + auto it = begin; + do { + ++it; + } while (it != end && (is_name_start(*it) || ('0' <= *it && *it <= '9'))); + handler.on_name({begin, to_unsigned(it - begin)}); + return it; +} + +template +FMT_CONSTEXPR FMT_INLINE auto parse_arg_id(const Char* begin, const Char* end, + Handler&& handler) -> const Char* { + FMT_ASSERT(begin != end, ""); + Char c = *begin; + if (c != '}' && c != ':') return do_parse_arg_id(begin, end, handler); + handler.on_auto(); + return begin; +} + +template struct dynamic_spec_id_handler { + basic_format_parse_context& ctx; + arg_ref& ref; + + FMT_CONSTEXPR void on_auto() { + int id = ctx.next_arg_id(); + ref = arg_ref(id); + ctx.check_dynamic_spec(id); + } + FMT_CONSTEXPR void on_index(int id) { + ref = arg_ref(id); + ctx.check_arg_id(id); + ctx.check_dynamic_spec(id); + } + FMT_CONSTEXPR void on_name(basic_string_view id) { + ref = arg_ref(id); + ctx.check_arg_id(id); + } +}; + +// Parses [integer | "{" [arg_id] "}"]. +template +FMT_CONSTEXPR auto parse_dynamic_spec(const Char* begin, const Char* end, + int& value, arg_ref& ref, + basic_format_parse_context& ctx) + -> const Char* { + FMT_ASSERT(begin != end, ""); + if ('0' <= *begin && *begin <= '9') { + int val = parse_nonnegative_int(begin, end, -1); + if (val != -1) + value = val; + else + throw_format_error("number is too big"); + } else if (*begin == '{') { + ++begin; + auto handler = dynamic_spec_id_handler{ctx, ref}; + if (begin != end) begin = parse_arg_id(begin, end, handler); + if (begin != end && *begin == '}') return ++begin; + throw_format_error("invalid format string"); + } + return begin; +} + +template +FMT_CONSTEXPR auto parse_precision(const Char* begin, const Char* end, + int& value, arg_ref& ref, + basic_format_parse_context& ctx) + -> const Char* { + ++begin; + if (begin == end || *begin == '}') { + throw_format_error("invalid precision"); + return begin; + } + return parse_dynamic_spec(begin, end, value, ref, ctx); +} + +enum class state { start, align, sign, hash, zero, width, precision, locale }; + +// Parses standard format specifiers. +template +FMT_CONSTEXPR FMT_INLINE auto parse_format_specs( + const Char* begin, const Char* end, dynamic_format_specs& specs, + basic_format_parse_context& ctx, type arg_type) -> const Char* { + auto c = '\0'; + if (end - begin > 1) { + auto next = to_ascii(begin[1]); + c = parse_align(next) == align::none ? to_ascii(*begin) : '\0'; + } else { + if (begin == end) return begin; + c = to_ascii(*begin); + } + + struct { + state current_state = state::start; + FMT_CONSTEXPR void operator()(state s, bool valid = true) { + if (current_state >= s || !valid) + throw_format_error("invalid format specifier"); + current_state = s; + } + } enter_state; + + using pres = presentation_type; + constexpr auto integral_set = sint_set | uint_set | bool_set | char_set; + struct { + const Char*& begin; + dynamic_format_specs& specs; + type arg_type; + + FMT_CONSTEXPR auto operator()(pres type, int set) -> const Char* { + if (!in(arg_type, set)) throw_format_error("invalid format specifier"); + specs.type = type; + return begin + 1; + } + } parse_presentation_type{begin, specs, arg_type}; + + for (;;) { + switch (c) { + case '<': + case '>': + case '^': + enter_state(state::align); + specs.align = parse_align(c); + ++begin; + break; + case '+': + case '-': + case ' ': + enter_state(state::sign, in(arg_type, sint_set | float_set)); + switch (c) { + case '+': + specs.sign = sign::plus; + break; + case '-': + specs.sign = sign::minus; + break; + case ' ': + specs.sign = sign::space; + break; + } + ++begin; + break; + case '#': + enter_state(state::hash, is_arithmetic_type(arg_type)); + specs.alt = true; + ++begin; + break; + case '0': + enter_state(state::zero); + if (!is_arithmetic_type(arg_type)) + throw_format_error("format specifier requires numeric argument"); + if (specs.align == align::none) { + // Ignore 0 if align is specified for compatibility with std::format. + specs.align = align::numeric; + specs.fill[0] = Char('0'); + } + ++begin; + break; + case '1': + case '2': + case '3': + case '4': + case '5': + case '6': + case '7': + case '8': + case '9': + case '{': + enter_state(state::width); + begin = parse_dynamic_spec(begin, end, specs.width, specs.width_ref, ctx); + break; + case '.': + enter_state(state::precision, + in(arg_type, float_set | string_set | cstring_set)); + begin = parse_precision(begin, end, specs.precision, specs.precision_ref, + ctx); + break; + case 'L': + enter_state(state::locale, is_arithmetic_type(arg_type)); + specs.localized = true; + ++begin; + break; + case 'd': + return parse_presentation_type(pres::dec, integral_set); + case 'o': + return parse_presentation_type(pres::oct, integral_set); + case 'x': + return parse_presentation_type(pres::hex_lower, integral_set); + case 'X': + return parse_presentation_type(pres::hex_upper, integral_set); + case 'b': + return parse_presentation_type(pres::bin_lower, integral_set); + case 'B': + return parse_presentation_type(pres::bin_upper, integral_set); + case 'a': + return parse_presentation_type(pres::hexfloat_lower, float_set); + case 'A': + return parse_presentation_type(pres::hexfloat_upper, float_set); + case 'e': + return parse_presentation_type(pres::exp_lower, float_set); + case 'E': + return parse_presentation_type(pres::exp_upper, float_set); + case 'f': + return parse_presentation_type(pres::fixed_lower, float_set); + case 'F': + return parse_presentation_type(pres::fixed_upper, float_set); + case 'g': + return parse_presentation_type(pres::general_lower, float_set); + case 'G': + return parse_presentation_type(pres::general_upper, float_set); + case 'c': + return parse_presentation_type(pres::chr, integral_set); + case 's': + return parse_presentation_type(pres::string, + bool_set | string_set | cstring_set); + case 'p': + return parse_presentation_type(pres::pointer, pointer_set | cstring_set); + case '?': + return parse_presentation_type(pres::debug, + char_set | string_set | cstring_set); + case '}': + return begin; + default: { + if (*begin == '}') return begin; + // Parse fill and alignment. + auto fill_end = begin + code_point_length(begin); + if (end - fill_end <= 0) { + throw_format_error("invalid format specifier"); + return begin; + } + if (*begin == '{') { + throw_format_error("invalid fill character '{'"); + return begin; + } + auto align = parse_align(to_ascii(*fill_end)); + enter_state(state::align, align != align::none); + specs.fill = {begin, to_unsigned(fill_end - begin)}; + specs.align = align; + begin = fill_end + 1; + } + } + if (begin == end) return begin; + c = to_ascii(*begin); + } +} + +template +FMT_CONSTEXPR auto parse_replacement_field(const Char* begin, const Char* end, + Handler&& handler) -> const Char* { + struct id_adapter { + Handler& handler; + int arg_id; + + FMT_CONSTEXPR void on_auto() { arg_id = handler.on_arg_id(); } + FMT_CONSTEXPR void on_index(int id) { arg_id = handler.on_arg_id(id); } + FMT_CONSTEXPR void on_name(basic_string_view id) { + arg_id = handler.on_arg_id(id); + } + }; + + ++begin; + if (begin == end) return handler.on_error("invalid format string"), end; + if (*begin == '}') { + handler.on_replacement_field(handler.on_arg_id(), begin); + } else if (*begin == '{') { + handler.on_text(begin, begin + 1); + } else { + auto adapter = id_adapter{handler, 0}; + begin = parse_arg_id(begin, end, adapter); + Char c = begin != end ? *begin : Char(); + if (c == '}') { + handler.on_replacement_field(adapter.arg_id, begin); + } else if (c == ':') { + begin = handler.on_format_specs(adapter.arg_id, begin + 1, end); + if (begin == end || *begin != '}') + return handler.on_error("unknown format specifier"), end; + } else { + return handler.on_error("missing '}' in format string"), end; + } + } + return begin + 1; +} + +template +FMT_CONSTEXPR FMT_INLINE void parse_format_string( + basic_string_view format_str, Handler&& handler) { + auto begin = format_str.data(); + auto end = begin + format_str.size(); + if (end - begin < 32) { + // Use a simple loop instead of memchr for small strings. + const Char* p = begin; + while (p != end) { + auto c = *p++; + if (c == '{') { + handler.on_text(begin, p - 1); + begin = p = parse_replacement_field(p - 1, end, handler); + } else if (c == '}') { + if (p == end || *p != '}') + return handler.on_error("unmatched '}' in format string"); + handler.on_text(begin, p); + begin = ++p; + } + } + handler.on_text(begin, end); + return; + } + struct writer { + FMT_CONSTEXPR void operator()(const Char* from, const Char* to) { + if (from == to) return; + for (;;) { + const Char* p = nullptr; + if (!find(from, to, Char('}'), p)) + return handler_.on_text(from, to); + ++p; + if (p == to || *p != '}') + return handler_.on_error("unmatched '}' in format string"); + handler_.on_text(from, p); + from = p + 1; + } + } + Handler& handler_; + } write = {handler}; + while (begin != end) { + // Doing two passes with memchr (one for '{' and another for '}') is up to + // 2.5x faster than the naive one-pass implementation on big format strings. + const Char* p = begin; + if (*begin != '{' && !find(begin + 1, end, Char('{'), p)) + return write(begin, end); + write(begin, p); + begin = parse_replacement_field(p, end, handler); + } +} + +template ::value> struct strip_named_arg { + using type = T; +}; +template struct strip_named_arg { + using type = remove_cvref_t; +}; + +template +FMT_CONSTEXPR auto parse_format_specs(ParseContext& ctx) + -> decltype(ctx.begin()) { + using char_type = typename ParseContext::char_type; + using context = buffer_context; + using mapped_type = conditional_t< + mapped_type_constant::value != type::custom_type, + decltype(arg_mapper().map(std::declval())), + typename strip_named_arg::type>; +#if defined(__cpp_if_constexpr) + if constexpr (std::is_default_constructible_v< + formatter>) { + return formatter().parse(ctx); + } else { + type_is_unformattable_for _; + return ctx.begin(); + } +#else + return formatter().parse(ctx); +#endif +} + +// Checks char specs and returns true iff the presentation type is char-like. +template +FMT_CONSTEXPR auto check_char_specs(const format_specs& specs) -> bool { + if (specs.type != presentation_type::none && + specs.type != presentation_type::chr && + specs.type != presentation_type::debug) { + return false; + } + if (specs.align == align::numeric || specs.sign != sign::none || specs.alt) + throw_format_error("invalid format specifier for char"); + return true; +} + +#if FMT_USE_NONTYPE_TEMPLATE_ARGS +template +constexpr auto get_arg_index_by_name(basic_string_view name) -> int { + if constexpr (is_statically_named_arg()) { + if (name == T::name) return N; + } + if constexpr (sizeof...(Args) > 0) + return get_arg_index_by_name(name); + (void)name; // Workaround an MSVC bug about "unused" parameter. + return -1; +} +#endif + +template +FMT_CONSTEXPR auto get_arg_index_by_name(basic_string_view name) -> int { +#if FMT_USE_NONTYPE_TEMPLATE_ARGS + if constexpr (sizeof...(Args) > 0) + return get_arg_index_by_name<0, Args...>(name); +#endif + (void)name; + return -1; +} + +template class format_string_checker { + private: + using parse_context_type = compile_parse_context; + static constexpr int num_args = sizeof...(Args); + + // Format specifier parsing function. + // In the future basic_format_parse_context will replace compile_parse_context + // here and will use is_constant_evaluated and downcasting to access the data + // needed for compile-time checks: https://godbolt.org/z/GvWzcTjh1. + using parse_func = const Char* (*)(parse_context_type&); + + type types_[num_args > 0 ? static_cast(num_args) : 1]; + parse_context_type context_; + parse_func parse_funcs_[num_args > 0 ? static_cast(num_args) : 1]; + + public: + explicit FMT_CONSTEXPR format_string_checker(basic_string_view fmt) + : types_{mapped_type_constant>::value...}, + context_(fmt, num_args, types_), + parse_funcs_{&parse_format_specs...} {} + + FMT_CONSTEXPR void on_text(const Char*, const Char*) {} + + FMT_CONSTEXPR auto on_arg_id() -> int { return context_.next_arg_id(); } + FMT_CONSTEXPR auto on_arg_id(int id) -> int { + return context_.check_arg_id(id), id; + } + FMT_CONSTEXPR auto on_arg_id(basic_string_view id) -> int { +#if FMT_USE_NONTYPE_TEMPLATE_ARGS + auto index = get_arg_index_by_name(id); + if (index < 0) on_error("named argument is not found"); + return index; +#else + (void)id; + on_error("compile-time checks for named arguments require C++20 support"); + return 0; +#endif + } + + FMT_CONSTEXPR void on_replacement_field(int id, const Char* begin) { + on_format_specs(id, begin, begin); // Call parse() on empty specs. + } + + FMT_CONSTEXPR auto on_format_specs(int id, const Char* begin, const Char*) + -> const Char* { + context_.advance_to(begin); + // id >= 0 check is a workaround for gcc 10 bug (#2065). + return id >= 0 && id < num_args ? parse_funcs_[id](context_) : begin; + } + + FMT_CONSTEXPR void on_error(const char* message) { + throw_format_error(message); + } +}; + +// Reports a compile-time error if S is not a valid format string. +template ::value)> +FMT_INLINE void check_format_string(const S&) { +#ifdef FMT_ENFORCE_COMPILE_STRING + static_assert(is_compile_string::value, + "FMT_ENFORCE_COMPILE_STRING requires all format strings to use " + "FMT_STRING."); +#endif +} +template ::value)> +void check_format_string(S format_str) { + using char_t = typename S::char_type; + FMT_CONSTEXPR auto s = basic_string_view(format_str); + using checker = format_string_checker...>; + FMT_CONSTEXPR bool error = (parse_format_string(s, checker(s)), true); + ignore_unused(error); +} + +template struct vformat_args { + using type = basic_format_args< + basic_format_context>, Char>>; +}; +template <> struct vformat_args { using type = format_args; }; + +// Use vformat_args and avoid type_identity to keep symbols short. +template +void vformat_to(buffer& buf, basic_string_view fmt, + typename vformat_args::type args, locale_ref loc = {}); + +FMT_API void vprint_mojibake(std::FILE*, string_view, format_args); +#ifndef _WIN32 +inline void vprint_mojibake(std::FILE*, string_view, format_args) {} +#endif +} // namespace detail + +FMT_BEGIN_EXPORT + +// A formatter specialization for natively supported types. +template +struct formatter::value != + detail::type::custom_type>> { + private: + detail::dynamic_format_specs specs_; + + public: + template + FMT_CONSTEXPR auto parse(ParseContext& ctx) -> const Char* { + auto type = detail::type_constant::value; + auto end = + detail::parse_format_specs(ctx.begin(), ctx.end(), specs_, ctx, type); + if (type == detail::type::char_type) detail::check_char_specs(specs_); + return end; + } + + template ::value, + FMT_ENABLE_IF(U == detail::type::string_type || + U == detail::type::cstring_type || + U == detail::type::char_type)> + FMT_CONSTEXPR void set_debug_format(bool set = true) { + specs_.type = set ? presentation_type::debug : presentation_type::none; + } + + template + FMT_CONSTEXPR auto format(const T& val, FormatContext& ctx) const + -> decltype(ctx.out()); +}; + +template struct runtime_format_string { + basic_string_view str; +}; + +/** A compile-time format string. */ +template class basic_format_string { + private: + basic_string_view str_; + + public: + template >::value)> + FMT_CONSTEVAL FMT_INLINE basic_format_string(const S& s) : str_(s) { + static_assert( + detail::count< + (std::is_base_of>::value && + std::is_reference::value)...>() == 0, + "passing views as lvalues is disallowed"); +#ifdef FMT_HAS_CONSTEVAL + if constexpr (detail::count_named_args() == + detail::count_statically_named_args()) { + using checker = + detail::format_string_checker...>; + detail::parse_format_string(str_, checker(s)); + } +#else + detail::check_format_string(s); +#endif + } + basic_format_string(runtime_format_string fmt) : str_(fmt.str) {} + + FMT_INLINE operator basic_string_view() const { return str_; } + FMT_INLINE auto get() const -> basic_string_view { return str_; } +}; + +#if FMT_GCC_VERSION && FMT_GCC_VERSION < 409 +// Workaround broken conversion on older gcc. +template using format_string = string_view; +inline auto runtime(string_view s) -> string_view { return s; } +#else +template +using format_string = basic_format_string...>; +/** + \rst + Creates a runtime format string. + + **Example**:: + + // Check format string at runtime instead of compile-time. + fmt::print(fmt::runtime("{:d}"), "I am not a number"); + \endrst + */ +inline auto runtime(string_view s) -> runtime_format_string<> { return {{s}}; } +#endif + +FMT_API auto vformat(string_view fmt, format_args args) -> std::string; + +/** + \rst + Formats ``args`` according to specifications in ``fmt`` and returns the result + as a string. + + **Example**:: + + #include + std::string message = fmt::format("The answer is {}.", 42); + \endrst +*/ +template +FMT_NODISCARD FMT_INLINE auto format(format_string fmt, T&&... args) + -> std::string { + return vformat(fmt, fmt::make_format_args(args...)); +} + +/** Formats a string and writes the output to ``out``. */ +template ::value)> +auto vformat_to(OutputIt out, string_view fmt, format_args args) -> OutputIt { + auto&& buf = detail::get_buffer(out); + detail::vformat_to(buf, fmt, args, {}); + return detail::get_iterator(buf, out); +} + +/** + \rst + Formats ``args`` according to specifications in ``fmt``, writes the result to + the output iterator ``out`` and returns the iterator past the end of the output + range. `format_to` does not append a terminating null character. + + **Example**:: + + auto out = std::vector(); + fmt::format_to(std::back_inserter(out), "{}", 42); + \endrst + */ +template ::value)> +FMT_INLINE auto format_to(OutputIt out, format_string fmt, T&&... args) + -> OutputIt { + return vformat_to(out, fmt, fmt::make_format_args(args...)); +} + +template struct format_to_n_result { + /** Iterator past the end of the output range. */ + OutputIt out; + /** Total (not truncated) output size. */ + size_t size; +}; + +template ::value)> +auto vformat_to_n(OutputIt out, size_t n, string_view fmt, format_args args) + -> format_to_n_result { + using traits = detail::fixed_buffer_traits; + auto buf = detail::iterator_buffer(out, n); + detail::vformat_to(buf, fmt, args, {}); + return {buf.out(), buf.count()}; +} + +/** + \rst + Formats ``args`` according to specifications in ``fmt``, writes up to ``n`` + characters of the result to the output iterator ``out`` and returns the total + (not truncated) output size and the iterator past the end of the output range. + `format_to_n` does not append a terminating null character. + \endrst + */ +template ::value)> +FMT_INLINE auto format_to_n(OutputIt out, size_t n, format_string fmt, + T&&... args) -> format_to_n_result { + return vformat_to_n(out, n, fmt, fmt::make_format_args(args...)); +} + +/** Returns the number of chars in the output of ``format(fmt, args...)``. */ +template +FMT_NODISCARD FMT_INLINE auto formatted_size(format_string fmt, + T&&... args) -> size_t { + auto buf = detail::counting_buffer<>(); + detail::vformat_to(buf, fmt, fmt::make_format_args(args...), {}); + return buf.count(); +} + +FMT_API void vprint(string_view fmt, format_args args); +FMT_API void vprint(std::FILE* f, string_view fmt, format_args args); + +/** + \rst + Formats ``args`` according to specifications in ``fmt`` and writes the output + to ``stdout``. + + **Example**:: + + fmt::print("Elapsed time: {0:.2f} seconds", 1.23); + \endrst + */ +template +FMT_INLINE void print(format_string fmt, T&&... args) { + const auto& vargs = fmt::make_format_args(args...); + return detail::is_utf8() ? vprint(fmt, vargs) + : detail::vprint_mojibake(stdout, fmt, vargs); +} + +/** + \rst + Formats ``args`` according to specifications in ``fmt`` and writes the + output to the file ``f``. + + **Example**:: + + fmt::print(stderr, "Don't {}!", "panic"); + \endrst + */ +template +FMT_INLINE void print(std::FILE* f, format_string fmt, T&&... args) { + const auto& vargs = fmt::make_format_args(args...); + return detail::is_utf8() ? vprint(f, fmt, vargs) + : detail::vprint_mojibake(f, fmt, vargs); +} + +/** + Formats ``args`` according to specifications in ``fmt`` and writes the + output to the file ``f`` followed by a newline. + */ +template +FMT_INLINE void println(std::FILE* f, format_string fmt, T&&... args) { + return fmt::print(f, "{}\n", fmt::format(fmt, std::forward(args)...)); +} + +/** + Formats ``args`` according to specifications in ``fmt`` and writes the output + to ``stdout`` followed by a newline. + */ +template +FMT_INLINE void println(format_string fmt, T&&... args) { + return fmt::println(stdout, fmt, std::forward(args)...); +} + +FMT_END_EXPORT +FMT_GCC_PRAGMA("GCC pop_options") +FMT_END_NAMESPACE + +#ifdef FMT_HEADER_ONLY +# include "format.h" +#endif +#endif // FMT_CORE_H_ diff --git a/src/fmt/format-inl.h b/src/fmt/format-inl.h new file mode 100644 index 0000000..dac2d43 --- /dev/null +++ b/src/fmt/format-inl.h @@ -0,0 +1,1662 @@ +// Formatting library for C++ - implementation +// +// Copyright (c) 2012 - 2016, Victor Zverovich +// All rights reserved. +// +// For the license information refer to format.h. + +#ifndef FMT_FORMAT_INL_H_ +#define FMT_FORMAT_INL_H_ + +#include +#include // errno +#include +#include +#include + +#ifndef FMT_STATIC_THOUSANDS_SEPARATOR +# include +#endif + +#ifdef _WIN32 +# include // _isatty +#endif + +#include "format.h" + +FMT_BEGIN_NAMESPACE +namespace detail { + +FMT_FUNC void assert_fail(const char* file, int line, const char* message) { + // Use unchecked std::fprintf to avoid triggering another assertion when + // writing to stderr fails + std::fprintf(stderr, "%s:%d: assertion failed: %s", file, line, message); + // Chosen instead of std::abort to satisfy Clang in CUDA mode during device + // code pass. + std::terminate(); +} + +FMT_FUNC void throw_format_error(const char* message) { + FMT_THROW(format_error(message)); +} + +FMT_FUNC void format_error_code(detail::buffer& out, int error_code, + string_view message) noexcept { + // Report error code making sure that the output fits into + // inline_buffer_size to avoid dynamic memory allocation and potential + // bad_alloc. + out.try_resize(0); + static const char SEP[] = ": "; + static const char ERROR_STR[] = "error "; + // Subtract 2 to account for terminating null characters in SEP and ERROR_STR. + size_t error_code_size = sizeof(SEP) + sizeof(ERROR_STR) - 2; + auto abs_value = static_cast>(error_code); + if (detail::is_negative(error_code)) { + abs_value = 0 - abs_value; + ++error_code_size; + } + error_code_size += detail::to_unsigned(detail::count_digits(abs_value)); + auto it = buffer_appender(out); + if (message.size() <= inline_buffer_size - error_code_size) + format_to(it, FMT_STRING("{}{}"), message, SEP); + format_to(it, FMT_STRING("{}{}"), ERROR_STR, error_code); + FMT_ASSERT(out.size() <= inline_buffer_size, ""); +} + +FMT_FUNC void report_error(format_func func, int error_code, + const char* message) noexcept { + memory_buffer full_message; + func(full_message, error_code, message); + // Don't use fwrite_fully because the latter may throw. + if (std::fwrite(full_message.data(), full_message.size(), 1, stderr) > 0) + std::fputc('\n', stderr); +} + +// A wrapper around fwrite that throws on error. +inline void fwrite_fully(const void* ptr, size_t size, size_t count, + FILE* stream) { + size_t written = std::fwrite(ptr, size, count, stream); + if (written < count) + FMT_THROW(system_error(errno, FMT_STRING("cannot write to file"))); +} + +#ifndef FMT_STATIC_THOUSANDS_SEPARATOR +template +locale_ref::locale_ref(const Locale& loc) : locale_(&loc) { + static_assert(std::is_same::value, ""); +} + +template Locale locale_ref::get() const { + static_assert(std::is_same::value, ""); + return locale_ ? *static_cast(locale_) : std::locale(); +} + +template +FMT_FUNC auto thousands_sep_impl(locale_ref loc) -> thousands_sep_result { + auto& facet = std::use_facet>(loc.get()); + auto grouping = facet.grouping(); + auto thousands_sep = grouping.empty() ? Char() : facet.thousands_sep(); + return {std::move(grouping), thousands_sep}; +} +template FMT_FUNC Char decimal_point_impl(locale_ref loc) { + return std::use_facet>(loc.get()) + .decimal_point(); +} +#else +template +FMT_FUNC auto thousands_sep_impl(locale_ref) -> thousands_sep_result { + return {"\03", FMT_STATIC_THOUSANDS_SEPARATOR}; +} +template FMT_FUNC Char decimal_point_impl(locale_ref) { + return '.'; +} +#endif + +FMT_FUNC auto write_loc(appender out, loc_value value, + const format_specs<>& specs, locale_ref loc) -> bool { +#ifndef FMT_STATIC_THOUSANDS_SEPARATOR + auto locale = loc.get(); + // We cannot use the num_put facet because it may produce output in + // a wrong encoding. + using facet = format_facet; + if (std::has_facet(locale)) + return std::use_facet(locale).put(out, value, specs); + return facet(locale).put(out, value, specs); +#endif + return false; +} +} // namespace detail + +template typename Locale::id format_facet::id; + +#ifndef FMT_STATIC_THOUSANDS_SEPARATOR +template format_facet::format_facet(Locale& loc) { + auto& numpunct = std::use_facet>(loc); + grouping_ = numpunct.grouping(); + if (!grouping_.empty()) separator_ = std::string(1, numpunct.thousands_sep()); +} + +template <> +FMT_API FMT_FUNC auto format_facet::do_put( + appender out, loc_value val, const format_specs<>& specs) const -> bool { + return val.visit( + detail::loc_writer<>{out, specs, separator_, grouping_, decimal_point_}); +} +#endif + +FMT_FUNC std::system_error vsystem_error(int error_code, string_view fmt, + format_args args) { + auto ec = std::error_code(error_code, std::generic_category()); + return std::system_error(ec, vformat(fmt, args)); +} + +namespace detail { + +template inline bool operator==(basic_fp x, basic_fp y) { + return x.f == y.f && x.e == y.e; +} + +// Compilers should be able to optimize this into the ror instruction. +FMT_CONSTEXPR inline uint32_t rotr(uint32_t n, uint32_t r) noexcept { + r &= 31; + return (n >> r) | (n << (32 - r)); +} +FMT_CONSTEXPR inline uint64_t rotr(uint64_t n, uint32_t r) noexcept { + r &= 63; + return (n >> r) | (n << (64 - r)); +} + +// Implementation of Dragonbox algorithm: https://github.com/jk-jeon/dragonbox. +namespace dragonbox { +// Computes upper 64 bits of multiplication of a 32-bit unsigned integer and a +// 64-bit unsigned integer. +inline uint64_t umul96_upper64(uint32_t x, uint64_t y) noexcept { + return umul128_upper64(static_cast(x) << 32, y); +} + +// Computes lower 128 bits of multiplication of a 64-bit unsigned integer and a +// 128-bit unsigned integer. +inline uint128_fallback umul192_lower128(uint64_t x, + uint128_fallback y) noexcept { + uint64_t high = x * y.high(); + uint128_fallback high_low = umul128(x, y.low()); + return {high + high_low.high(), high_low.low()}; +} + +// Computes lower 64 bits of multiplication of a 32-bit unsigned integer and a +// 64-bit unsigned integer. +inline uint64_t umul96_lower64(uint32_t x, uint64_t y) noexcept { + return x * y; +} + +// Various fast log computations. +inline int floor_log10_pow2_minus_log10_4_over_3(int e) noexcept { + FMT_ASSERT(e <= 2936 && e >= -2985, "too large exponent"); + return (e * 631305 - 261663) >> 21; +} + +FMT_INLINE_VARIABLE constexpr struct { + uint32_t divisor; + int shift_amount; +} div_small_pow10_infos[] = {{10, 16}, {100, 16}}; + +// Replaces n by floor(n / pow(10, N)) returning true if and only if n is +// divisible by pow(10, N). +// Precondition: n <= pow(10, N + 1). +template +bool check_divisibility_and_divide_by_pow10(uint32_t& n) noexcept { + // The numbers below are chosen such that: + // 1. floor(n/d) = floor(nm / 2^k) where d=10 or d=100, + // 2. nm mod 2^k < m if and only if n is divisible by d, + // where m is magic_number, k is shift_amount + // and d is divisor. + // + // Item 1 is a common technique of replacing division by a constant with + // multiplication, see e.g. "Division by Invariant Integers Using + // Multiplication" by Granlund and Montgomery (1994). magic_number (m) is set + // to ceil(2^k/d) for large enough k. + // The idea for item 2 originates from Schubfach. + constexpr auto info = div_small_pow10_infos[N - 1]; + FMT_ASSERT(n <= info.divisor * 10, "n is too large"); + constexpr uint32_t magic_number = + (1u << info.shift_amount) / info.divisor + 1; + n *= magic_number; + const uint32_t comparison_mask = (1u << info.shift_amount) - 1; + bool result = (n & comparison_mask) < magic_number; + n >>= info.shift_amount; + return result; +} + +// Computes floor(n / pow(10, N)) for small n and N. +// Precondition: n <= pow(10, N + 1). +template uint32_t small_division_by_pow10(uint32_t n) noexcept { + constexpr auto info = div_small_pow10_infos[N - 1]; + FMT_ASSERT(n <= info.divisor * 10, "n is too large"); + constexpr uint32_t magic_number = + (1u << info.shift_amount) / info.divisor + 1; + return (n * magic_number) >> info.shift_amount; +} + +// Computes floor(n / 10^(kappa + 1)) (float) +inline uint32_t divide_by_10_to_kappa_plus_1(uint32_t n) noexcept { + // 1374389535 = ceil(2^37/100) + return static_cast((static_cast(n) * 1374389535) >> 37); +} +// Computes floor(n / 10^(kappa + 1)) (double) +inline uint64_t divide_by_10_to_kappa_plus_1(uint64_t n) noexcept { + // 2361183241434822607 = ceil(2^(64+7)/1000) + return umul128_upper64(n, 2361183241434822607ull) >> 7; +} + +// Various subroutines using pow10 cache +template struct cache_accessor; + +template <> struct cache_accessor { + using carrier_uint = float_info::carrier_uint; + using cache_entry_type = uint64_t; + + static uint64_t get_cached_power(int k) noexcept { + FMT_ASSERT(k >= float_info::min_k && k <= float_info::max_k, + "k is out of range"); + static constexpr const uint64_t pow10_significands[] = { + 0x81ceb32c4b43fcf5, 0xa2425ff75e14fc32, 0xcad2f7f5359a3b3f, + 0xfd87b5f28300ca0e, 0x9e74d1b791e07e49, 0xc612062576589ddb, + 0xf79687aed3eec552, 0x9abe14cd44753b53, 0xc16d9a0095928a28, + 0xf1c90080baf72cb2, 0x971da05074da7bef, 0xbce5086492111aeb, + 0xec1e4a7db69561a6, 0x9392ee8e921d5d08, 0xb877aa3236a4b44a, + 0xe69594bec44de15c, 0x901d7cf73ab0acda, 0xb424dc35095cd810, + 0xe12e13424bb40e14, 0x8cbccc096f5088cc, 0xafebff0bcb24aaff, + 0xdbe6fecebdedd5bf, 0x89705f4136b4a598, 0xabcc77118461cefd, + 0xd6bf94d5e57a42bd, 0x8637bd05af6c69b6, 0xa7c5ac471b478424, + 0xd1b71758e219652c, 0x83126e978d4fdf3c, 0xa3d70a3d70a3d70b, + 0xcccccccccccccccd, 0x8000000000000000, 0xa000000000000000, + 0xc800000000000000, 0xfa00000000000000, 0x9c40000000000000, + 0xc350000000000000, 0xf424000000000000, 0x9896800000000000, + 0xbebc200000000000, 0xee6b280000000000, 0x9502f90000000000, + 0xba43b74000000000, 0xe8d4a51000000000, 0x9184e72a00000000, + 0xb5e620f480000000, 0xe35fa931a0000000, 0x8e1bc9bf04000000, + 0xb1a2bc2ec5000000, 0xde0b6b3a76400000, 0x8ac7230489e80000, + 0xad78ebc5ac620000, 0xd8d726b7177a8000, 0x878678326eac9000, + 0xa968163f0a57b400, 0xd3c21bcecceda100, 0x84595161401484a0, + 0xa56fa5b99019a5c8, 0xcecb8f27f4200f3a, 0x813f3978f8940985, + 0xa18f07d736b90be6, 0xc9f2c9cd04674edf, 0xfc6f7c4045812297, + 0x9dc5ada82b70b59e, 0xc5371912364ce306, 0xf684df56c3e01bc7, + 0x9a130b963a6c115d, 0xc097ce7bc90715b4, 0xf0bdc21abb48db21, + 0x96769950b50d88f5, 0xbc143fa4e250eb32, 0xeb194f8e1ae525fe, + 0x92efd1b8d0cf37bf, 0xb7abc627050305ae, 0xe596b7b0c643c71a, + 0x8f7e32ce7bea5c70, 0xb35dbf821ae4f38c, 0xe0352f62a19e306f}; + return pow10_significands[k - float_info::min_k]; + } + + struct compute_mul_result { + carrier_uint result; + bool is_integer; + }; + struct compute_mul_parity_result { + bool parity; + bool is_integer; + }; + + static compute_mul_result compute_mul( + carrier_uint u, const cache_entry_type& cache) noexcept { + auto r = umul96_upper64(u, cache); + return {static_cast(r >> 32), + static_cast(r) == 0}; + } + + static uint32_t compute_delta(const cache_entry_type& cache, + int beta) noexcept { + return static_cast(cache >> (64 - 1 - beta)); + } + + static compute_mul_parity_result compute_mul_parity( + carrier_uint two_f, const cache_entry_type& cache, int beta) noexcept { + FMT_ASSERT(beta >= 1, ""); + FMT_ASSERT(beta < 64, ""); + + auto r = umul96_lower64(two_f, cache); + return {((r >> (64 - beta)) & 1) != 0, + static_cast(r >> (32 - beta)) == 0}; + } + + static carrier_uint compute_left_endpoint_for_shorter_interval_case( + const cache_entry_type& cache, int beta) noexcept { + return static_cast( + (cache - (cache >> (num_significand_bits() + 2))) >> + (64 - num_significand_bits() - 1 - beta)); + } + + static carrier_uint compute_right_endpoint_for_shorter_interval_case( + const cache_entry_type& cache, int beta) noexcept { + return static_cast( + (cache + (cache >> (num_significand_bits() + 1))) >> + (64 - num_significand_bits() - 1 - beta)); + } + + static carrier_uint compute_round_up_for_shorter_interval_case( + const cache_entry_type& cache, int beta) noexcept { + return (static_cast( + cache >> (64 - num_significand_bits() - 2 - beta)) + + 1) / + 2; + } +}; + +template <> struct cache_accessor { + using carrier_uint = float_info::carrier_uint; + using cache_entry_type = uint128_fallback; + + static uint128_fallback get_cached_power(int k) noexcept { + FMT_ASSERT(k >= float_info::min_k && k <= float_info::max_k, + "k is out of range"); + + static constexpr const uint128_fallback pow10_significands[] = { +#if FMT_USE_FULL_CACHE_DRAGONBOX + {0xff77b1fcbebcdc4f, 0x25e8e89c13bb0f7b}, + {0x9faacf3df73609b1, 0x77b191618c54e9ad}, + {0xc795830d75038c1d, 0xd59df5b9ef6a2418}, + {0xf97ae3d0d2446f25, 0x4b0573286b44ad1e}, + {0x9becce62836ac577, 0x4ee367f9430aec33}, + {0xc2e801fb244576d5, 0x229c41f793cda740}, + {0xf3a20279ed56d48a, 0x6b43527578c11110}, + {0x9845418c345644d6, 0x830a13896b78aaaa}, + {0xbe5691ef416bd60c, 0x23cc986bc656d554}, + {0xedec366b11c6cb8f, 0x2cbfbe86b7ec8aa9}, + {0x94b3a202eb1c3f39, 0x7bf7d71432f3d6aa}, + {0xb9e08a83a5e34f07, 0xdaf5ccd93fb0cc54}, + {0xe858ad248f5c22c9, 0xd1b3400f8f9cff69}, + {0x91376c36d99995be, 0x23100809b9c21fa2}, + {0xb58547448ffffb2d, 0xabd40a0c2832a78b}, + {0xe2e69915b3fff9f9, 0x16c90c8f323f516d}, + {0x8dd01fad907ffc3b, 0xae3da7d97f6792e4}, + {0xb1442798f49ffb4a, 0x99cd11cfdf41779d}, + {0xdd95317f31c7fa1d, 0x40405643d711d584}, + {0x8a7d3eef7f1cfc52, 0x482835ea666b2573}, + {0xad1c8eab5ee43b66, 0xda3243650005eed0}, + {0xd863b256369d4a40, 0x90bed43e40076a83}, + {0x873e4f75e2224e68, 0x5a7744a6e804a292}, + {0xa90de3535aaae202, 0x711515d0a205cb37}, + {0xd3515c2831559a83, 0x0d5a5b44ca873e04}, + {0x8412d9991ed58091, 0xe858790afe9486c3}, + {0xa5178fff668ae0b6, 0x626e974dbe39a873}, + {0xce5d73ff402d98e3, 0xfb0a3d212dc81290}, + {0x80fa687f881c7f8e, 0x7ce66634bc9d0b9a}, + {0xa139029f6a239f72, 0x1c1fffc1ebc44e81}, + {0xc987434744ac874e, 0xa327ffb266b56221}, + {0xfbe9141915d7a922, 0x4bf1ff9f0062baa9}, + {0x9d71ac8fada6c9b5, 0x6f773fc3603db4aa}, + {0xc4ce17b399107c22, 0xcb550fb4384d21d4}, + {0xf6019da07f549b2b, 0x7e2a53a146606a49}, + {0x99c102844f94e0fb, 0x2eda7444cbfc426e}, + {0xc0314325637a1939, 0xfa911155fefb5309}, + {0xf03d93eebc589f88, 0x793555ab7eba27cb}, + {0x96267c7535b763b5, 0x4bc1558b2f3458df}, + {0xbbb01b9283253ca2, 0x9eb1aaedfb016f17}, + {0xea9c227723ee8bcb, 0x465e15a979c1cadd}, + {0x92a1958a7675175f, 0x0bfacd89ec191eca}, + {0xb749faed14125d36, 0xcef980ec671f667c}, + {0xe51c79a85916f484, 0x82b7e12780e7401b}, + {0x8f31cc0937ae58d2, 0xd1b2ecb8b0908811}, + {0xb2fe3f0b8599ef07, 0x861fa7e6dcb4aa16}, + {0xdfbdcece67006ac9, 0x67a791e093e1d49b}, + {0x8bd6a141006042bd, 0xe0c8bb2c5c6d24e1}, + {0xaecc49914078536d, 0x58fae9f773886e19}, + {0xda7f5bf590966848, 0xaf39a475506a899f}, + {0x888f99797a5e012d, 0x6d8406c952429604}, + {0xaab37fd7d8f58178, 0xc8e5087ba6d33b84}, + {0xd5605fcdcf32e1d6, 0xfb1e4a9a90880a65}, + {0x855c3be0a17fcd26, 0x5cf2eea09a550680}, + {0xa6b34ad8c9dfc06f, 0xf42faa48c0ea481f}, + {0xd0601d8efc57b08b, 0xf13b94daf124da27}, + {0x823c12795db6ce57, 0x76c53d08d6b70859}, + {0xa2cb1717b52481ed, 0x54768c4b0c64ca6f}, + {0xcb7ddcdda26da268, 0xa9942f5dcf7dfd0a}, + {0xfe5d54150b090b02, 0xd3f93b35435d7c4d}, + {0x9efa548d26e5a6e1, 0xc47bc5014a1a6db0}, + {0xc6b8e9b0709f109a, 0x359ab6419ca1091c}, + {0xf867241c8cc6d4c0, 0xc30163d203c94b63}, + {0x9b407691d7fc44f8, 0x79e0de63425dcf1e}, + {0xc21094364dfb5636, 0x985915fc12f542e5}, + {0xf294b943e17a2bc4, 0x3e6f5b7b17b2939e}, + {0x979cf3ca6cec5b5a, 0xa705992ceecf9c43}, + {0xbd8430bd08277231, 0x50c6ff782a838354}, + {0xece53cec4a314ebd, 0xa4f8bf5635246429}, + {0x940f4613ae5ed136, 0x871b7795e136be9a}, + {0xb913179899f68584, 0x28e2557b59846e40}, + {0xe757dd7ec07426e5, 0x331aeada2fe589d0}, + {0x9096ea6f3848984f, 0x3ff0d2c85def7622}, + {0xb4bca50b065abe63, 0x0fed077a756b53aa}, + {0xe1ebce4dc7f16dfb, 0xd3e8495912c62895}, + {0x8d3360f09cf6e4bd, 0x64712dd7abbbd95d}, + {0xb080392cc4349dec, 0xbd8d794d96aacfb4}, + {0xdca04777f541c567, 0xecf0d7a0fc5583a1}, + {0x89e42caaf9491b60, 0xf41686c49db57245}, + {0xac5d37d5b79b6239, 0x311c2875c522ced6}, + {0xd77485cb25823ac7, 0x7d633293366b828c}, + {0x86a8d39ef77164bc, 0xae5dff9c02033198}, + {0xa8530886b54dbdeb, 0xd9f57f830283fdfd}, + {0xd267caa862a12d66, 0xd072df63c324fd7c}, + {0x8380dea93da4bc60, 0x4247cb9e59f71e6e}, + {0xa46116538d0deb78, 0x52d9be85f074e609}, + {0xcd795be870516656, 0x67902e276c921f8c}, + {0x806bd9714632dff6, 0x00ba1cd8a3db53b7}, + {0xa086cfcd97bf97f3, 0x80e8a40eccd228a5}, + {0xc8a883c0fdaf7df0, 0x6122cd128006b2ce}, + {0xfad2a4b13d1b5d6c, 0x796b805720085f82}, + {0x9cc3a6eec6311a63, 0xcbe3303674053bb1}, + {0xc3f490aa77bd60fc, 0xbedbfc4411068a9d}, + {0xf4f1b4d515acb93b, 0xee92fb5515482d45}, + {0x991711052d8bf3c5, 0x751bdd152d4d1c4b}, + {0xbf5cd54678eef0b6, 0xd262d45a78a0635e}, + {0xef340a98172aace4, 0x86fb897116c87c35}, + {0x9580869f0e7aac0e, 0xd45d35e6ae3d4da1}, + {0xbae0a846d2195712, 0x8974836059cca10a}, + {0xe998d258869facd7, 0x2bd1a438703fc94c}, + {0x91ff83775423cc06, 0x7b6306a34627ddd0}, + {0xb67f6455292cbf08, 0x1a3bc84c17b1d543}, + {0xe41f3d6a7377eeca, 0x20caba5f1d9e4a94}, + {0x8e938662882af53e, 0x547eb47b7282ee9d}, + {0xb23867fb2a35b28d, 0xe99e619a4f23aa44}, + {0xdec681f9f4c31f31, 0x6405fa00e2ec94d5}, + {0x8b3c113c38f9f37e, 0xde83bc408dd3dd05}, + {0xae0b158b4738705e, 0x9624ab50b148d446}, + {0xd98ddaee19068c76, 0x3badd624dd9b0958}, + {0x87f8a8d4cfa417c9, 0xe54ca5d70a80e5d7}, + {0xa9f6d30a038d1dbc, 0x5e9fcf4ccd211f4d}, + {0xd47487cc8470652b, 0x7647c32000696720}, + {0x84c8d4dfd2c63f3b, 0x29ecd9f40041e074}, + {0xa5fb0a17c777cf09, 0xf468107100525891}, + {0xcf79cc9db955c2cc, 0x7182148d4066eeb5}, + {0x81ac1fe293d599bf, 0xc6f14cd848405531}, + {0xa21727db38cb002f, 0xb8ada00e5a506a7d}, + {0xca9cf1d206fdc03b, 0xa6d90811f0e4851d}, + {0xfd442e4688bd304a, 0x908f4a166d1da664}, + {0x9e4a9cec15763e2e, 0x9a598e4e043287ff}, + {0xc5dd44271ad3cdba, 0x40eff1e1853f29fe}, + {0xf7549530e188c128, 0xd12bee59e68ef47d}, + {0x9a94dd3e8cf578b9, 0x82bb74f8301958cf}, + {0xc13a148e3032d6e7, 0xe36a52363c1faf02}, + {0xf18899b1bc3f8ca1, 0xdc44e6c3cb279ac2}, + {0x96f5600f15a7b7e5, 0x29ab103a5ef8c0ba}, + {0xbcb2b812db11a5de, 0x7415d448f6b6f0e8}, + {0xebdf661791d60f56, 0x111b495b3464ad22}, + {0x936b9fcebb25c995, 0xcab10dd900beec35}, + {0xb84687c269ef3bfb, 0x3d5d514f40eea743}, + {0xe65829b3046b0afa, 0x0cb4a5a3112a5113}, + {0x8ff71a0fe2c2e6dc, 0x47f0e785eaba72ac}, + {0xb3f4e093db73a093, 0x59ed216765690f57}, + {0xe0f218b8d25088b8, 0x306869c13ec3532d}, + {0x8c974f7383725573, 0x1e414218c73a13fc}, + {0xafbd2350644eeacf, 0xe5d1929ef90898fb}, + {0xdbac6c247d62a583, 0xdf45f746b74abf3a}, + {0x894bc396ce5da772, 0x6b8bba8c328eb784}, + {0xab9eb47c81f5114f, 0x066ea92f3f326565}, + {0xd686619ba27255a2, 0xc80a537b0efefebe}, + {0x8613fd0145877585, 0xbd06742ce95f5f37}, + {0xa798fc4196e952e7, 0x2c48113823b73705}, + {0xd17f3b51fca3a7a0, 0xf75a15862ca504c6}, + {0x82ef85133de648c4, 0x9a984d73dbe722fc}, + {0xa3ab66580d5fdaf5, 0xc13e60d0d2e0ebbb}, + {0xcc963fee10b7d1b3, 0x318df905079926a9}, + {0xffbbcfe994e5c61f, 0xfdf17746497f7053}, + {0x9fd561f1fd0f9bd3, 0xfeb6ea8bedefa634}, + {0xc7caba6e7c5382c8, 0xfe64a52ee96b8fc1}, + {0xf9bd690a1b68637b, 0x3dfdce7aa3c673b1}, + {0x9c1661a651213e2d, 0x06bea10ca65c084f}, + {0xc31bfa0fe5698db8, 0x486e494fcff30a63}, + {0xf3e2f893dec3f126, 0x5a89dba3c3efccfb}, + {0x986ddb5c6b3a76b7, 0xf89629465a75e01d}, + {0xbe89523386091465, 0xf6bbb397f1135824}, + {0xee2ba6c0678b597f, 0x746aa07ded582e2d}, + {0x94db483840b717ef, 0xa8c2a44eb4571cdd}, + {0xba121a4650e4ddeb, 0x92f34d62616ce414}, + {0xe896a0d7e51e1566, 0x77b020baf9c81d18}, + {0x915e2486ef32cd60, 0x0ace1474dc1d122f}, + {0xb5b5ada8aaff80b8, 0x0d819992132456bb}, + {0xe3231912d5bf60e6, 0x10e1fff697ed6c6a}, + {0x8df5efabc5979c8f, 0xca8d3ffa1ef463c2}, + {0xb1736b96b6fd83b3, 0xbd308ff8a6b17cb3}, + {0xddd0467c64bce4a0, 0xac7cb3f6d05ddbdf}, + {0x8aa22c0dbef60ee4, 0x6bcdf07a423aa96c}, + {0xad4ab7112eb3929d, 0x86c16c98d2c953c7}, + {0xd89d64d57a607744, 0xe871c7bf077ba8b8}, + {0x87625f056c7c4a8b, 0x11471cd764ad4973}, + {0xa93af6c6c79b5d2d, 0xd598e40d3dd89bd0}, + {0xd389b47879823479, 0x4aff1d108d4ec2c4}, + {0x843610cb4bf160cb, 0xcedf722a585139bb}, + {0xa54394fe1eedb8fe, 0xc2974eb4ee658829}, + {0xce947a3da6a9273e, 0x733d226229feea33}, + {0x811ccc668829b887, 0x0806357d5a3f5260}, + {0xa163ff802a3426a8, 0xca07c2dcb0cf26f8}, + {0xc9bcff6034c13052, 0xfc89b393dd02f0b6}, + {0xfc2c3f3841f17c67, 0xbbac2078d443ace3}, + {0x9d9ba7832936edc0, 0xd54b944b84aa4c0e}, + {0xc5029163f384a931, 0x0a9e795e65d4df12}, + {0xf64335bcf065d37d, 0x4d4617b5ff4a16d6}, + {0x99ea0196163fa42e, 0x504bced1bf8e4e46}, + {0xc06481fb9bcf8d39, 0xe45ec2862f71e1d7}, + {0xf07da27a82c37088, 0x5d767327bb4e5a4d}, + {0x964e858c91ba2655, 0x3a6a07f8d510f870}, + {0xbbe226efb628afea, 0x890489f70a55368c}, + {0xeadab0aba3b2dbe5, 0x2b45ac74ccea842f}, + {0x92c8ae6b464fc96f, 0x3b0b8bc90012929e}, + {0xb77ada0617e3bbcb, 0x09ce6ebb40173745}, + {0xe55990879ddcaabd, 0xcc420a6a101d0516}, + {0x8f57fa54c2a9eab6, 0x9fa946824a12232e}, + {0xb32df8e9f3546564, 0x47939822dc96abfa}, + {0xdff9772470297ebd, 0x59787e2b93bc56f8}, + {0x8bfbea76c619ef36, 0x57eb4edb3c55b65b}, + {0xaefae51477a06b03, 0xede622920b6b23f2}, + {0xdab99e59958885c4, 0xe95fab368e45ecee}, + {0x88b402f7fd75539b, 0x11dbcb0218ebb415}, + {0xaae103b5fcd2a881, 0xd652bdc29f26a11a}, + {0xd59944a37c0752a2, 0x4be76d3346f04960}, + {0x857fcae62d8493a5, 0x6f70a4400c562ddc}, + {0xa6dfbd9fb8e5b88e, 0xcb4ccd500f6bb953}, + {0xd097ad07a71f26b2, 0x7e2000a41346a7a8}, + {0x825ecc24c873782f, 0x8ed400668c0c28c9}, + {0xa2f67f2dfa90563b, 0x728900802f0f32fb}, + {0xcbb41ef979346bca, 0x4f2b40a03ad2ffba}, + {0xfea126b7d78186bc, 0xe2f610c84987bfa9}, + {0x9f24b832e6b0f436, 0x0dd9ca7d2df4d7ca}, + {0xc6ede63fa05d3143, 0x91503d1c79720dbc}, + {0xf8a95fcf88747d94, 0x75a44c6397ce912b}, + {0x9b69dbe1b548ce7c, 0xc986afbe3ee11abb}, + {0xc24452da229b021b, 0xfbe85badce996169}, + {0xf2d56790ab41c2a2, 0xfae27299423fb9c4}, + {0x97c560ba6b0919a5, 0xdccd879fc967d41b}, + {0xbdb6b8e905cb600f, 0x5400e987bbc1c921}, + {0xed246723473e3813, 0x290123e9aab23b69}, + {0x9436c0760c86e30b, 0xf9a0b6720aaf6522}, + {0xb94470938fa89bce, 0xf808e40e8d5b3e6a}, + {0xe7958cb87392c2c2, 0xb60b1d1230b20e05}, + {0x90bd77f3483bb9b9, 0xb1c6f22b5e6f48c3}, + {0xb4ecd5f01a4aa828, 0x1e38aeb6360b1af4}, + {0xe2280b6c20dd5232, 0x25c6da63c38de1b1}, + {0x8d590723948a535f, 0x579c487e5a38ad0f}, + {0xb0af48ec79ace837, 0x2d835a9df0c6d852}, + {0xdcdb1b2798182244, 0xf8e431456cf88e66}, + {0x8a08f0f8bf0f156b, 0x1b8e9ecb641b5900}, + {0xac8b2d36eed2dac5, 0xe272467e3d222f40}, + {0xd7adf884aa879177, 0x5b0ed81dcc6abb10}, + {0x86ccbb52ea94baea, 0x98e947129fc2b4ea}, + {0xa87fea27a539e9a5, 0x3f2398d747b36225}, + {0xd29fe4b18e88640e, 0x8eec7f0d19a03aae}, + {0x83a3eeeef9153e89, 0x1953cf68300424ad}, + {0xa48ceaaab75a8e2b, 0x5fa8c3423c052dd8}, + {0xcdb02555653131b6, 0x3792f412cb06794e}, + {0x808e17555f3ebf11, 0xe2bbd88bbee40bd1}, + {0xa0b19d2ab70e6ed6, 0x5b6aceaeae9d0ec5}, + {0xc8de047564d20a8b, 0xf245825a5a445276}, + {0xfb158592be068d2e, 0xeed6e2f0f0d56713}, + {0x9ced737bb6c4183d, 0x55464dd69685606c}, + {0xc428d05aa4751e4c, 0xaa97e14c3c26b887}, + {0xf53304714d9265df, 0xd53dd99f4b3066a9}, + {0x993fe2c6d07b7fab, 0xe546a8038efe402a}, + {0xbf8fdb78849a5f96, 0xde98520472bdd034}, + {0xef73d256a5c0f77c, 0x963e66858f6d4441}, + {0x95a8637627989aad, 0xdde7001379a44aa9}, + {0xbb127c53b17ec159, 0x5560c018580d5d53}, + {0xe9d71b689dde71af, 0xaab8f01e6e10b4a7}, + {0x9226712162ab070d, 0xcab3961304ca70e9}, + {0xb6b00d69bb55c8d1, 0x3d607b97c5fd0d23}, + {0xe45c10c42a2b3b05, 0x8cb89a7db77c506b}, + {0x8eb98a7a9a5b04e3, 0x77f3608e92adb243}, + {0xb267ed1940f1c61c, 0x55f038b237591ed4}, + {0xdf01e85f912e37a3, 0x6b6c46dec52f6689}, + {0x8b61313bbabce2c6, 0x2323ac4b3b3da016}, + {0xae397d8aa96c1b77, 0xabec975e0a0d081b}, + {0xd9c7dced53c72255, 0x96e7bd358c904a22}, + {0x881cea14545c7575, 0x7e50d64177da2e55}, + {0xaa242499697392d2, 0xdde50bd1d5d0b9ea}, + {0xd4ad2dbfc3d07787, 0x955e4ec64b44e865}, + {0x84ec3c97da624ab4, 0xbd5af13bef0b113f}, + {0xa6274bbdd0fadd61, 0xecb1ad8aeacdd58f}, + {0xcfb11ead453994ba, 0x67de18eda5814af3}, + {0x81ceb32c4b43fcf4, 0x80eacf948770ced8}, + {0xa2425ff75e14fc31, 0xa1258379a94d028e}, + {0xcad2f7f5359a3b3e, 0x096ee45813a04331}, + {0xfd87b5f28300ca0d, 0x8bca9d6e188853fd}, + {0x9e74d1b791e07e48, 0x775ea264cf55347e}, + {0xc612062576589dda, 0x95364afe032a819e}, + {0xf79687aed3eec551, 0x3a83ddbd83f52205}, + {0x9abe14cd44753b52, 0xc4926a9672793543}, + {0xc16d9a0095928a27, 0x75b7053c0f178294}, + {0xf1c90080baf72cb1, 0x5324c68b12dd6339}, + {0x971da05074da7bee, 0xd3f6fc16ebca5e04}, + {0xbce5086492111aea, 0x88f4bb1ca6bcf585}, + {0xec1e4a7db69561a5, 0x2b31e9e3d06c32e6}, + {0x9392ee8e921d5d07, 0x3aff322e62439fd0}, + {0xb877aa3236a4b449, 0x09befeb9fad487c3}, + {0xe69594bec44de15b, 0x4c2ebe687989a9b4}, + {0x901d7cf73ab0acd9, 0x0f9d37014bf60a11}, + {0xb424dc35095cd80f, 0x538484c19ef38c95}, + {0xe12e13424bb40e13, 0x2865a5f206b06fba}, + {0x8cbccc096f5088cb, 0xf93f87b7442e45d4}, + {0xafebff0bcb24aafe, 0xf78f69a51539d749}, + {0xdbe6fecebdedd5be, 0xb573440e5a884d1c}, + {0x89705f4136b4a597, 0x31680a88f8953031}, + {0xabcc77118461cefc, 0xfdc20d2b36ba7c3e}, + {0xd6bf94d5e57a42bc, 0x3d32907604691b4d}, + {0x8637bd05af6c69b5, 0xa63f9a49c2c1b110}, + {0xa7c5ac471b478423, 0x0fcf80dc33721d54}, + {0xd1b71758e219652b, 0xd3c36113404ea4a9}, + {0x83126e978d4fdf3b, 0x645a1cac083126ea}, + {0xa3d70a3d70a3d70a, 0x3d70a3d70a3d70a4}, + {0xcccccccccccccccc, 0xcccccccccccccccd}, + {0x8000000000000000, 0x0000000000000000}, + {0xa000000000000000, 0x0000000000000000}, + {0xc800000000000000, 0x0000000000000000}, + {0xfa00000000000000, 0x0000000000000000}, + {0x9c40000000000000, 0x0000000000000000}, + {0xc350000000000000, 0x0000000000000000}, + {0xf424000000000000, 0x0000000000000000}, + {0x9896800000000000, 0x0000000000000000}, + {0xbebc200000000000, 0x0000000000000000}, + {0xee6b280000000000, 0x0000000000000000}, + {0x9502f90000000000, 0x0000000000000000}, + {0xba43b74000000000, 0x0000000000000000}, + {0xe8d4a51000000000, 0x0000000000000000}, + {0x9184e72a00000000, 0x0000000000000000}, + {0xb5e620f480000000, 0x0000000000000000}, + {0xe35fa931a0000000, 0x0000000000000000}, + {0x8e1bc9bf04000000, 0x0000000000000000}, + {0xb1a2bc2ec5000000, 0x0000000000000000}, + {0xde0b6b3a76400000, 0x0000000000000000}, + {0x8ac7230489e80000, 0x0000000000000000}, + {0xad78ebc5ac620000, 0x0000000000000000}, + {0xd8d726b7177a8000, 0x0000000000000000}, + {0x878678326eac9000, 0x0000000000000000}, + {0xa968163f0a57b400, 0x0000000000000000}, + {0xd3c21bcecceda100, 0x0000000000000000}, + {0x84595161401484a0, 0x0000000000000000}, + {0xa56fa5b99019a5c8, 0x0000000000000000}, + {0xcecb8f27f4200f3a, 0x0000000000000000}, + {0x813f3978f8940984, 0x4000000000000000}, + {0xa18f07d736b90be5, 0x5000000000000000}, + {0xc9f2c9cd04674ede, 0xa400000000000000}, + {0xfc6f7c4045812296, 0x4d00000000000000}, + {0x9dc5ada82b70b59d, 0xf020000000000000}, + {0xc5371912364ce305, 0x6c28000000000000}, + {0xf684df56c3e01bc6, 0xc732000000000000}, + {0x9a130b963a6c115c, 0x3c7f400000000000}, + {0xc097ce7bc90715b3, 0x4b9f100000000000}, + {0xf0bdc21abb48db20, 0x1e86d40000000000}, + {0x96769950b50d88f4, 0x1314448000000000}, + {0xbc143fa4e250eb31, 0x17d955a000000000}, + {0xeb194f8e1ae525fd, 0x5dcfab0800000000}, + {0x92efd1b8d0cf37be, 0x5aa1cae500000000}, + {0xb7abc627050305ad, 0xf14a3d9e40000000}, + {0xe596b7b0c643c719, 0x6d9ccd05d0000000}, + {0x8f7e32ce7bea5c6f, 0xe4820023a2000000}, + {0xb35dbf821ae4f38b, 0xdda2802c8a800000}, + {0xe0352f62a19e306e, 0xd50b2037ad200000}, + {0x8c213d9da502de45, 0x4526f422cc340000}, + {0xaf298d050e4395d6, 0x9670b12b7f410000}, + {0xdaf3f04651d47b4c, 0x3c0cdd765f114000}, + {0x88d8762bf324cd0f, 0xa5880a69fb6ac800}, + {0xab0e93b6efee0053, 0x8eea0d047a457a00}, + {0xd5d238a4abe98068, 0x72a4904598d6d880}, + {0x85a36366eb71f041, 0x47a6da2b7f864750}, + {0xa70c3c40a64e6c51, 0x999090b65f67d924}, + {0xd0cf4b50cfe20765, 0xfff4b4e3f741cf6d}, + {0x82818f1281ed449f, 0xbff8f10e7a8921a5}, + {0xa321f2d7226895c7, 0xaff72d52192b6a0e}, + {0xcbea6f8ceb02bb39, 0x9bf4f8a69f764491}, + {0xfee50b7025c36a08, 0x02f236d04753d5b5}, + {0x9f4f2726179a2245, 0x01d762422c946591}, + {0xc722f0ef9d80aad6, 0x424d3ad2b7b97ef6}, + {0xf8ebad2b84e0d58b, 0xd2e0898765a7deb3}, + {0x9b934c3b330c8577, 0x63cc55f49f88eb30}, + {0xc2781f49ffcfa6d5, 0x3cbf6b71c76b25fc}, + {0xf316271c7fc3908a, 0x8bef464e3945ef7b}, + {0x97edd871cfda3a56, 0x97758bf0e3cbb5ad}, + {0xbde94e8e43d0c8ec, 0x3d52eeed1cbea318}, + {0xed63a231d4c4fb27, 0x4ca7aaa863ee4bde}, + {0x945e455f24fb1cf8, 0x8fe8caa93e74ef6b}, + {0xb975d6b6ee39e436, 0xb3e2fd538e122b45}, + {0xe7d34c64a9c85d44, 0x60dbbca87196b617}, + {0x90e40fbeea1d3a4a, 0xbc8955e946fe31ce}, + {0xb51d13aea4a488dd, 0x6babab6398bdbe42}, + {0xe264589a4dcdab14, 0xc696963c7eed2dd2}, + {0x8d7eb76070a08aec, 0xfc1e1de5cf543ca3}, + {0xb0de65388cc8ada8, 0x3b25a55f43294bcc}, + {0xdd15fe86affad912, 0x49ef0eb713f39ebf}, + {0x8a2dbf142dfcc7ab, 0x6e3569326c784338}, + {0xacb92ed9397bf996, 0x49c2c37f07965405}, + {0xd7e77a8f87daf7fb, 0xdc33745ec97be907}, + {0x86f0ac99b4e8dafd, 0x69a028bb3ded71a4}, + {0xa8acd7c0222311bc, 0xc40832ea0d68ce0d}, + {0xd2d80db02aabd62b, 0xf50a3fa490c30191}, + {0x83c7088e1aab65db, 0x792667c6da79e0fb}, + {0xa4b8cab1a1563f52, 0x577001b891185939}, + {0xcde6fd5e09abcf26, 0xed4c0226b55e6f87}, + {0x80b05e5ac60b6178, 0x544f8158315b05b5}, + {0xa0dc75f1778e39d6, 0x696361ae3db1c722}, + {0xc913936dd571c84c, 0x03bc3a19cd1e38ea}, + {0xfb5878494ace3a5f, 0x04ab48a04065c724}, + {0x9d174b2dcec0e47b, 0x62eb0d64283f9c77}, + {0xc45d1df942711d9a, 0x3ba5d0bd324f8395}, + {0xf5746577930d6500, 0xca8f44ec7ee3647a}, + {0x9968bf6abbe85f20, 0x7e998b13cf4e1ecc}, + {0xbfc2ef456ae276e8, 0x9e3fedd8c321a67f}, + {0xefb3ab16c59b14a2, 0xc5cfe94ef3ea101f}, + {0x95d04aee3b80ece5, 0xbba1f1d158724a13}, + {0xbb445da9ca61281f, 0x2a8a6e45ae8edc98}, + {0xea1575143cf97226, 0xf52d09d71a3293be}, + {0x924d692ca61be758, 0x593c2626705f9c57}, + {0xb6e0c377cfa2e12e, 0x6f8b2fb00c77836d}, + {0xe498f455c38b997a, 0x0b6dfb9c0f956448}, + {0x8edf98b59a373fec, 0x4724bd4189bd5ead}, + {0xb2977ee300c50fe7, 0x58edec91ec2cb658}, + {0xdf3d5e9bc0f653e1, 0x2f2967b66737e3ee}, + {0x8b865b215899f46c, 0xbd79e0d20082ee75}, + {0xae67f1e9aec07187, 0xecd8590680a3aa12}, + {0xda01ee641a708de9, 0xe80e6f4820cc9496}, + {0x884134fe908658b2, 0x3109058d147fdcde}, + {0xaa51823e34a7eede, 0xbd4b46f0599fd416}, + {0xd4e5e2cdc1d1ea96, 0x6c9e18ac7007c91b}, + {0x850fadc09923329e, 0x03e2cf6bc604ddb1}, + {0xa6539930bf6bff45, 0x84db8346b786151d}, + {0xcfe87f7cef46ff16, 0xe612641865679a64}, + {0x81f14fae158c5f6e, 0x4fcb7e8f3f60c07f}, + {0xa26da3999aef7749, 0xe3be5e330f38f09e}, + {0xcb090c8001ab551c, 0x5cadf5bfd3072cc6}, + {0xfdcb4fa002162a63, 0x73d9732fc7c8f7f7}, + {0x9e9f11c4014dda7e, 0x2867e7fddcdd9afb}, + {0xc646d63501a1511d, 0xb281e1fd541501b9}, + {0xf7d88bc24209a565, 0x1f225a7ca91a4227}, + {0x9ae757596946075f, 0x3375788de9b06959}, + {0xc1a12d2fc3978937, 0x0052d6b1641c83af}, + {0xf209787bb47d6b84, 0xc0678c5dbd23a49b}, + {0x9745eb4d50ce6332, 0xf840b7ba963646e1}, + {0xbd176620a501fbff, 0xb650e5a93bc3d899}, + {0xec5d3fa8ce427aff, 0xa3e51f138ab4cebf}, + {0x93ba47c980e98cdf, 0xc66f336c36b10138}, + {0xb8a8d9bbe123f017, 0xb80b0047445d4185}, + {0xe6d3102ad96cec1d, 0xa60dc059157491e6}, + {0x9043ea1ac7e41392, 0x87c89837ad68db30}, + {0xb454e4a179dd1877, 0x29babe4598c311fc}, + {0xe16a1dc9d8545e94, 0xf4296dd6fef3d67b}, + {0x8ce2529e2734bb1d, 0x1899e4a65f58660d}, + {0xb01ae745b101e9e4, 0x5ec05dcff72e7f90}, + {0xdc21a1171d42645d, 0x76707543f4fa1f74}, + {0x899504ae72497eba, 0x6a06494a791c53a9}, + {0xabfa45da0edbde69, 0x0487db9d17636893}, + {0xd6f8d7509292d603, 0x45a9d2845d3c42b7}, + {0x865b86925b9bc5c2, 0x0b8a2392ba45a9b3}, + {0xa7f26836f282b732, 0x8e6cac7768d7141f}, + {0xd1ef0244af2364ff, 0x3207d795430cd927}, + {0x8335616aed761f1f, 0x7f44e6bd49e807b9}, + {0xa402b9c5a8d3a6e7, 0x5f16206c9c6209a7}, + {0xcd036837130890a1, 0x36dba887c37a8c10}, + {0x802221226be55a64, 0xc2494954da2c978a}, + {0xa02aa96b06deb0fd, 0xf2db9baa10b7bd6d}, + {0xc83553c5c8965d3d, 0x6f92829494e5acc8}, + {0xfa42a8b73abbf48c, 0xcb772339ba1f17fa}, + {0x9c69a97284b578d7, 0xff2a760414536efc}, + {0xc38413cf25e2d70d, 0xfef5138519684abb}, + {0xf46518c2ef5b8cd1, 0x7eb258665fc25d6a}, + {0x98bf2f79d5993802, 0xef2f773ffbd97a62}, + {0xbeeefb584aff8603, 0xaafb550ffacfd8fb}, + {0xeeaaba2e5dbf6784, 0x95ba2a53f983cf39}, + {0x952ab45cfa97a0b2, 0xdd945a747bf26184}, + {0xba756174393d88df, 0x94f971119aeef9e5}, + {0xe912b9d1478ceb17, 0x7a37cd5601aab85e}, + {0x91abb422ccb812ee, 0xac62e055c10ab33b}, + {0xb616a12b7fe617aa, 0x577b986b314d600a}, + {0xe39c49765fdf9d94, 0xed5a7e85fda0b80c}, + {0x8e41ade9fbebc27d, 0x14588f13be847308}, + {0xb1d219647ae6b31c, 0x596eb2d8ae258fc9}, + {0xde469fbd99a05fe3, 0x6fca5f8ed9aef3bc}, + {0x8aec23d680043bee, 0x25de7bb9480d5855}, + {0xada72ccc20054ae9, 0xaf561aa79a10ae6b}, + {0xd910f7ff28069da4, 0x1b2ba1518094da05}, + {0x87aa9aff79042286, 0x90fb44d2f05d0843}, + {0xa99541bf57452b28, 0x353a1607ac744a54}, + {0xd3fa922f2d1675f2, 0x42889b8997915ce9}, + {0x847c9b5d7c2e09b7, 0x69956135febada12}, + {0xa59bc234db398c25, 0x43fab9837e699096}, + {0xcf02b2c21207ef2e, 0x94f967e45e03f4bc}, + {0x8161afb94b44f57d, 0x1d1be0eebac278f6}, + {0xa1ba1ba79e1632dc, 0x6462d92a69731733}, + {0xca28a291859bbf93, 0x7d7b8f7503cfdcff}, + {0xfcb2cb35e702af78, 0x5cda735244c3d43f}, + {0x9defbf01b061adab, 0x3a0888136afa64a8}, + {0xc56baec21c7a1916, 0x088aaa1845b8fdd1}, + {0xf6c69a72a3989f5b, 0x8aad549e57273d46}, + {0x9a3c2087a63f6399, 0x36ac54e2f678864c}, + {0xc0cb28a98fcf3c7f, 0x84576a1bb416a7de}, + {0xf0fdf2d3f3c30b9f, 0x656d44a2a11c51d6}, + {0x969eb7c47859e743, 0x9f644ae5a4b1b326}, + {0xbc4665b596706114, 0x873d5d9f0dde1fef}, + {0xeb57ff22fc0c7959, 0xa90cb506d155a7eb}, + {0x9316ff75dd87cbd8, 0x09a7f12442d588f3}, + {0xb7dcbf5354e9bece, 0x0c11ed6d538aeb30}, + {0xe5d3ef282a242e81, 0x8f1668c8a86da5fb}, + {0x8fa475791a569d10, 0xf96e017d694487bd}, + {0xb38d92d760ec4455, 0x37c981dcc395a9ad}, + {0xe070f78d3927556a, 0x85bbe253f47b1418}, + {0x8c469ab843b89562, 0x93956d7478ccec8f}, + {0xaf58416654a6babb, 0x387ac8d1970027b3}, + {0xdb2e51bfe9d0696a, 0x06997b05fcc0319f}, + {0x88fcf317f22241e2, 0x441fece3bdf81f04}, + {0xab3c2fddeeaad25a, 0xd527e81cad7626c4}, + {0xd60b3bd56a5586f1, 0x8a71e223d8d3b075}, + {0x85c7056562757456, 0xf6872d5667844e4a}, + {0xa738c6bebb12d16c, 0xb428f8ac016561dc}, + {0xd106f86e69d785c7, 0xe13336d701beba53}, + {0x82a45b450226b39c, 0xecc0024661173474}, + {0xa34d721642b06084, 0x27f002d7f95d0191}, + {0xcc20ce9bd35c78a5, 0x31ec038df7b441f5}, + {0xff290242c83396ce, 0x7e67047175a15272}, + {0x9f79a169bd203e41, 0x0f0062c6e984d387}, + {0xc75809c42c684dd1, 0x52c07b78a3e60869}, + {0xf92e0c3537826145, 0xa7709a56ccdf8a83}, + {0x9bbcc7a142b17ccb, 0x88a66076400bb692}, + {0xc2abf989935ddbfe, 0x6acff893d00ea436}, + {0xf356f7ebf83552fe, 0x0583f6b8c4124d44}, + {0x98165af37b2153de, 0xc3727a337a8b704b}, + {0xbe1bf1b059e9a8d6, 0x744f18c0592e4c5d}, + {0xeda2ee1c7064130c, 0x1162def06f79df74}, + {0x9485d4d1c63e8be7, 0x8addcb5645ac2ba9}, + {0xb9a74a0637ce2ee1, 0x6d953e2bd7173693}, + {0xe8111c87c5c1ba99, 0xc8fa8db6ccdd0438}, + {0x910ab1d4db9914a0, 0x1d9c9892400a22a3}, + {0xb54d5e4a127f59c8, 0x2503beb6d00cab4c}, + {0xe2a0b5dc971f303a, 0x2e44ae64840fd61e}, + {0x8da471a9de737e24, 0x5ceaecfed289e5d3}, + {0xb10d8e1456105dad, 0x7425a83e872c5f48}, + {0xdd50f1996b947518, 0xd12f124e28f7771a}, + {0x8a5296ffe33cc92f, 0x82bd6b70d99aaa70}, + {0xace73cbfdc0bfb7b, 0x636cc64d1001550c}, + {0xd8210befd30efa5a, 0x3c47f7e05401aa4f}, + {0x8714a775e3e95c78, 0x65acfaec34810a72}, + {0xa8d9d1535ce3b396, 0x7f1839a741a14d0e}, + {0xd31045a8341ca07c, 0x1ede48111209a051}, + {0x83ea2b892091e44d, 0x934aed0aab460433}, + {0xa4e4b66b68b65d60, 0xf81da84d56178540}, + {0xce1de40642e3f4b9, 0x36251260ab9d668f}, + {0x80d2ae83e9ce78f3, 0xc1d72b7c6b42601a}, + {0xa1075a24e4421730, 0xb24cf65b8612f820}, + {0xc94930ae1d529cfc, 0xdee033f26797b628}, + {0xfb9b7cd9a4a7443c, 0x169840ef017da3b2}, + {0x9d412e0806e88aa5, 0x8e1f289560ee864f}, + {0xc491798a08a2ad4e, 0xf1a6f2bab92a27e3}, + {0xf5b5d7ec8acb58a2, 0xae10af696774b1dc}, + {0x9991a6f3d6bf1765, 0xacca6da1e0a8ef2a}, + {0xbff610b0cc6edd3f, 0x17fd090a58d32af4}, + {0xeff394dcff8a948e, 0xddfc4b4cef07f5b1}, + {0x95f83d0a1fb69cd9, 0x4abdaf101564f98f}, + {0xbb764c4ca7a4440f, 0x9d6d1ad41abe37f2}, + {0xea53df5fd18d5513, 0x84c86189216dc5ee}, + {0x92746b9be2f8552c, 0x32fd3cf5b4e49bb5}, + {0xb7118682dbb66a77, 0x3fbc8c33221dc2a2}, + {0xe4d5e82392a40515, 0x0fabaf3feaa5334b}, + {0x8f05b1163ba6832d, 0x29cb4d87f2a7400f}, + {0xb2c71d5bca9023f8, 0x743e20e9ef511013}, + {0xdf78e4b2bd342cf6, 0x914da9246b255417}, + {0x8bab8eefb6409c1a, 0x1ad089b6c2f7548f}, + {0xae9672aba3d0c320, 0xa184ac2473b529b2}, + {0xda3c0f568cc4f3e8, 0xc9e5d72d90a2741f}, + {0x8865899617fb1871, 0x7e2fa67c7a658893}, + {0xaa7eebfb9df9de8d, 0xddbb901b98feeab8}, + {0xd51ea6fa85785631, 0x552a74227f3ea566}, + {0x8533285c936b35de, 0xd53a88958f872760}, + {0xa67ff273b8460356, 0x8a892abaf368f138}, + {0xd01fef10a657842c, 0x2d2b7569b0432d86}, + {0x8213f56a67f6b29b, 0x9c3b29620e29fc74}, + {0xa298f2c501f45f42, 0x8349f3ba91b47b90}, + {0xcb3f2f7642717713, 0x241c70a936219a74}, + {0xfe0efb53d30dd4d7, 0xed238cd383aa0111}, + {0x9ec95d1463e8a506, 0xf4363804324a40ab}, + {0xc67bb4597ce2ce48, 0xb143c6053edcd0d6}, + {0xf81aa16fdc1b81da, 0xdd94b7868e94050b}, + {0x9b10a4e5e9913128, 0xca7cf2b4191c8327}, + {0xc1d4ce1f63f57d72, 0xfd1c2f611f63a3f1}, + {0xf24a01a73cf2dccf, 0xbc633b39673c8ced}, + {0x976e41088617ca01, 0xd5be0503e085d814}, + {0xbd49d14aa79dbc82, 0x4b2d8644d8a74e19}, + {0xec9c459d51852ba2, 0xddf8e7d60ed1219f}, + {0x93e1ab8252f33b45, 0xcabb90e5c942b504}, + {0xb8da1662e7b00a17, 0x3d6a751f3b936244}, + {0xe7109bfba19c0c9d, 0x0cc512670a783ad5}, + {0x906a617d450187e2, 0x27fb2b80668b24c6}, + {0xb484f9dc9641e9da, 0xb1f9f660802dedf7}, + {0xe1a63853bbd26451, 0x5e7873f8a0396974}, + {0x8d07e33455637eb2, 0xdb0b487b6423e1e9}, + {0xb049dc016abc5e5f, 0x91ce1a9a3d2cda63}, + {0xdc5c5301c56b75f7, 0x7641a140cc7810fc}, + {0x89b9b3e11b6329ba, 0xa9e904c87fcb0a9e}, + {0xac2820d9623bf429, 0x546345fa9fbdcd45}, + {0xd732290fbacaf133, 0xa97c177947ad4096}, + {0x867f59a9d4bed6c0, 0x49ed8eabcccc485e}, + {0xa81f301449ee8c70, 0x5c68f256bfff5a75}, + {0xd226fc195c6a2f8c, 0x73832eec6fff3112}, + {0x83585d8fd9c25db7, 0xc831fd53c5ff7eac}, + {0xa42e74f3d032f525, 0xba3e7ca8b77f5e56}, + {0xcd3a1230c43fb26f, 0x28ce1bd2e55f35ec}, + {0x80444b5e7aa7cf85, 0x7980d163cf5b81b4}, + {0xa0555e361951c366, 0xd7e105bcc3326220}, + {0xc86ab5c39fa63440, 0x8dd9472bf3fefaa8}, + {0xfa856334878fc150, 0xb14f98f6f0feb952}, + {0x9c935e00d4b9d8d2, 0x6ed1bf9a569f33d4}, + {0xc3b8358109e84f07, 0x0a862f80ec4700c9}, + {0xf4a642e14c6262c8, 0xcd27bb612758c0fb}, + {0x98e7e9cccfbd7dbd, 0x8038d51cb897789d}, + {0xbf21e44003acdd2c, 0xe0470a63e6bd56c4}, + {0xeeea5d5004981478, 0x1858ccfce06cac75}, + {0x95527a5202df0ccb, 0x0f37801e0c43ebc9}, + {0xbaa718e68396cffd, 0xd30560258f54e6bb}, + {0xe950df20247c83fd, 0x47c6b82ef32a206a}, + {0x91d28b7416cdd27e, 0x4cdc331d57fa5442}, + {0xb6472e511c81471d, 0xe0133fe4adf8e953}, + {0xe3d8f9e563a198e5, 0x58180fddd97723a7}, + {0x8e679c2f5e44ff8f, 0x570f09eaa7ea7649}, + {0xb201833b35d63f73, 0x2cd2cc6551e513db}, + {0xde81e40a034bcf4f, 0xf8077f7ea65e58d2}, + {0x8b112e86420f6191, 0xfb04afaf27faf783}, + {0xadd57a27d29339f6, 0x79c5db9af1f9b564}, + {0xd94ad8b1c7380874, 0x18375281ae7822bd}, + {0x87cec76f1c830548, 0x8f2293910d0b15b6}, + {0xa9c2794ae3a3c69a, 0xb2eb3875504ddb23}, + {0xd433179d9c8cb841, 0x5fa60692a46151ec}, + {0x849feec281d7f328, 0xdbc7c41ba6bcd334}, + {0xa5c7ea73224deff3, 0x12b9b522906c0801}, + {0xcf39e50feae16bef, 0xd768226b34870a01}, + {0x81842f29f2cce375, 0xe6a1158300d46641}, + {0xa1e53af46f801c53, 0x60495ae3c1097fd1}, + {0xca5e89b18b602368, 0x385bb19cb14bdfc5}, + {0xfcf62c1dee382c42, 0x46729e03dd9ed7b6}, + {0x9e19db92b4e31ba9, 0x6c07a2c26a8346d2}, + {0xc5a05277621be293, 0xc7098b7305241886}, + {0xf70867153aa2db38, 0xb8cbee4fc66d1ea8}, + {0x9a65406d44a5c903, 0x737f74f1dc043329}, + {0xc0fe908895cf3b44, 0x505f522e53053ff3}, + {0xf13e34aabb430a15, 0x647726b9e7c68ff0}, + {0x96c6e0eab509e64d, 0x5eca783430dc19f6}, + {0xbc789925624c5fe0, 0xb67d16413d132073}, + {0xeb96bf6ebadf77d8, 0xe41c5bd18c57e890}, + {0x933e37a534cbaae7, 0x8e91b962f7b6f15a}, + {0xb80dc58e81fe95a1, 0x723627bbb5a4adb1}, + {0xe61136f2227e3b09, 0xcec3b1aaa30dd91d}, + {0x8fcac257558ee4e6, 0x213a4f0aa5e8a7b2}, + {0xb3bd72ed2af29e1f, 0xa988e2cd4f62d19e}, + {0xe0accfa875af45a7, 0x93eb1b80a33b8606}, + {0x8c6c01c9498d8b88, 0xbc72f130660533c4}, + {0xaf87023b9bf0ee6a, 0xeb8fad7c7f8680b5}, + { 0xdb68c2ca82ed2a05, + 0xa67398db9f6820e2 } +#else + {0xff77b1fcbebcdc4f, 0x25e8e89c13bb0f7b}, + {0xce5d73ff402d98e3, 0xfb0a3d212dc81290}, + {0xa6b34ad8c9dfc06f, 0xf42faa48c0ea481f}, + {0x86a8d39ef77164bc, 0xae5dff9c02033198}, + {0xd98ddaee19068c76, 0x3badd624dd9b0958}, + {0xafbd2350644eeacf, 0xe5d1929ef90898fb}, + {0x8df5efabc5979c8f, 0xca8d3ffa1ef463c2}, + {0xe55990879ddcaabd, 0xcc420a6a101d0516}, + {0xb94470938fa89bce, 0xf808e40e8d5b3e6a}, + {0x95a8637627989aad, 0xdde7001379a44aa9}, + {0xf1c90080baf72cb1, 0x5324c68b12dd6339}, + {0xc350000000000000, 0x0000000000000000}, + {0x9dc5ada82b70b59d, 0xf020000000000000}, + {0xfee50b7025c36a08, 0x02f236d04753d5b5}, + {0xcde6fd5e09abcf26, 0xed4c0226b55e6f87}, + {0xa6539930bf6bff45, 0x84db8346b786151d}, + {0x865b86925b9bc5c2, 0x0b8a2392ba45a9b3}, + {0xd910f7ff28069da4, 0x1b2ba1518094da05}, + {0xaf58416654a6babb, 0x387ac8d1970027b3}, + {0x8da471a9de737e24, 0x5ceaecfed289e5d3}, + {0xe4d5e82392a40515, 0x0fabaf3feaa5334b}, + {0xb8da1662e7b00a17, 0x3d6a751f3b936244}, + {0x95527a5202df0ccb, 0x0f37801e0c43ebc9}, + {0xf13e34aabb430a15, 0x647726b9e7c68ff0} +#endif + }; + +#if FMT_USE_FULL_CACHE_DRAGONBOX + return pow10_significands[k - float_info::min_k]; +#else + static constexpr const uint64_t powers_of_5_64[] = { + 0x0000000000000001, 0x0000000000000005, 0x0000000000000019, + 0x000000000000007d, 0x0000000000000271, 0x0000000000000c35, + 0x0000000000003d09, 0x000000000001312d, 0x000000000005f5e1, + 0x00000000001dcd65, 0x00000000009502f9, 0x0000000002e90edd, + 0x000000000e8d4a51, 0x0000000048c27395, 0x000000016bcc41e9, + 0x000000071afd498d, 0x0000002386f26fc1, 0x000000b1a2bc2ec5, + 0x000003782dace9d9, 0x00001158e460913d, 0x000056bc75e2d631, + 0x0001b1ae4d6e2ef5, 0x000878678326eac9, 0x002a5a058fc295ed, + 0x00d3c21bcecceda1, 0x0422ca8b0a00a425, 0x14adf4b7320334b9}; + + static const int compression_ratio = 27; + + // Compute base index. + int cache_index = (k - float_info::min_k) / compression_ratio; + int kb = cache_index * compression_ratio + float_info::min_k; + int offset = k - kb; + + // Get base cache. + uint128_fallback base_cache = pow10_significands[cache_index]; + if (offset == 0) return base_cache; + + // Compute the required amount of bit-shift. + int alpha = floor_log2_pow10(kb + offset) - floor_log2_pow10(kb) - offset; + FMT_ASSERT(alpha > 0 && alpha < 64, "shifting error detected"); + + // Try to recover the real cache. + uint64_t pow5 = powers_of_5_64[offset]; + uint128_fallback recovered_cache = umul128(base_cache.high(), pow5); + uint128_fallback middle_low = umul128(base_cache.low(), pow5); + + recovered_cache += middle_low.high(); + + uint64_t high_to_middle = recovered_cache.high() << (64 - alpha); + uint64_t middle_to_low = recovered_cache.low() << (64 - alpha); + + recovered_cache = + uint128_fallback{(recovered_cache.low() >> alpha) | high_to_middle, + ((middle_low.low() >> alpha) | middle_to_low)}; + FMT_ASSERT(recovered_cache.low() + 1 != 0, ""); + return {recovered_cache.high(), recovered_cache.low() + 1}; +#endif + } + + struct compute_mul_result { + carrier_uint result; + bool is_integer; + }; + struct compute_mul_parity_result { + bool parity; + bool is_integer; + }; + + static compute_mul_result compute_mul( + carrier_uint u, const cache_entry_type& cache) noexcept { + auto r = umul192_upper128(u, cache); + return {r.high(), r.low() == 0}; + } + + static uint32_t compute_delta(cache_entry_type const& cache, + int beta) noexcept { + return static_cast(cache.high() >> (64 - 1 - beta)); + } + + static compute_mul_parity_result compute_mul_parity( + carrier_uint two_f, const cache_entry_type& cache, int beta) noexcept { + FMT_ASSERT(beta >= 1, ""); + FMT_ASSERT(beta < 64, ""); + + auto r = umul192_lower128(two_f, cache); + return {((r.high() >> (64 - beta)) & 1) != 0, + ((r.high() << beta) | (r.low() >> (64 - beta))) == 0}; + } + + static carrier_uint compute_left_endpoint_for_shorter_interval_case( + const cache_entry_type& cache, int beta) noexcept { + return (cache.high() - + (cache.high() >> (num_significand_bits() + 2))) >> + (64 - num_significand_bits() - 1 - beta); + } + + static carrier_uint compute_right_endpoint_for_shorter_interval_case( + const cache_entry_type& cache, int beta) noexcept { + return (cache.high() + + (cache.high() >> (num_significand_bits() + 1))) >> + (64 - num_significand_bits() - 1 - beta); + } + + static carrier_uint compute_round_up_for_shorter_interval_case( + const cache_entry_type& cache, int beta) noexcept { + return ((cache.high() >> (64 - num_significand_bits() - 2 - beta)) + + 1) / + 2; + } +}; + +FMT_FUNC uint128_fallback get_cached_power(int k) noexcept { + return cache_accessor::get_cached_power(k); +} + +// Various integer checks +template +bool is_left_endpoint_integer_shorter_interval(int exponent) noexcept { + const int case_shorter_interval_left_endpoint_lower_threshold = 2; + const int case_shorter_interval_left_endpoint_upper_threshold = 3; + return exponent >= case_shorter_interval_left_endpoint_lower_threshold && + exponent <= case_shorter_interval_left_endpoint_upper_threshold; +} + +// Remove trailing zeros from n and return the number of zeros removed (float) +FMT_INLINE int remove_trailing_zeros(uint32_t& n, int s = 0) noexcept { + FMT_ASSERT(n != 0, ""); + // Modular inverse of 5 (mod 2^32): (mod_inv_5 * 5) mod 2^32 = 1. + constexpr uint32_t mod_inv_5 = 0xcccccccd; + constexpr uint32_t mod_inv_25 = 0xc28f5c29; // = mod_inv_5 * mod_inv_5 + + while (true) { + auto q = rotr(n * mod_inv_25, 2); + if (q > max_value() / 100) break; + n = q; + s += 2; + } + auto q = rotr(n * mod_inv_5, 1); + if (q <= max_value() / 10) { + n = q; + s |= 1; + } + return s; +} + +// Removes trailing zeros and returns the number of zeros removed (double) +FMT_INLINE int remove_trailing_zeros(uint64_t& n) noexcept { + FMT_ASSERT(n != 0, ""); + + // This magic number is ceil(2^90 / 10^8). + constexpr uint64_t magic_number = 12379400392853802749ull; + auto nm = umul128(n, magic_number); + + // Is n is divisible by 10^8? + if ((nm.high() & ((1ull << (90 - 64)) - 1)) == 0 && nm.low() < magic_number) { + // If yes, work with the quotient... + auto n32 = static_cast(nm.high() >> (90 - 64)); + // ... and use the 32 bit variant of the function + int s = remove_trailing_zeros(n32, 8); + n = n32; + return s; + } + + // If n is not divisible by 10^8, work with n itself. + constexpr uint64_t mod_inv_5 = 0xcccccccccccccccd; + constexpr uint64_t mod_inv_25 = 0x8f5c28f5c28f5c29; // = mod_inv_5 * mod_inv_5 + + int s = 0; + while (true) { + auto q = rotr(n * mod_inv_25, 2); + if (q > max_value() / 100) break; + n = q; + s += 2; + } + auto q = rotr(n * mod_inv_5, 1); + if (q <= max_value() / 10) { + n = q; + s |= 1; + } + + return s; +} + +// The main algorithm for shorter interval case +template +FMT_INLINE decimal_fp shorter_interval_case(int exponent) noexcept { + decimal_fp ret_value; + // Compute k and beta + const int minus_k = floor_log10_pow2_minus_log10_4_over_3(exponent); + const int beta = exponent + floor_log2_pow10(-minus_k); + + // Compute xi and zi + using cache_entry_type = typename cache_accessor::cache_entry_type; + const cache_entry_type cache = cache_accessor::get_cached_power(-minus_k); + + auto xi = cache_accessor::compute_left_endpoint_for_shorter_interval_case( + cache, beta); + auto zi = cache_accessor::compute_right_endpoint_for_shorter_interval_case( + cache, beta); + + // If the left endpoint is not an integer, increase it + if (!is_left_endpoint_integer_shorter_interval(exponent)) ++xi; + + // Try bigger divisor + ret_value.significand = zi / 10; + + // If succeed, remove trailing zeros if necessary and return + if (ret_value.significand * 10 >= xi) { + ret_value.exponent = minus_k + 1; + ret_value.exponent += remove_trailing_zeros(ret_value.significand); + return ret_value; + } + + // Otherwise, compute the round-up of y + ret_value.significand = + cache_accessor::compute_round_up_for_shorter_interval_case(cache, + beta); + ret_value.exponent = minus_k; + + // When tie occurs, choose one of them according to the rule + if (exponent >= float_info::shorter_interval_tie_lower_threshold && + exponent <= float_info::shorter_interval_tie_upper_threshold) { + ret_value.significand = ret_value.significand % 2 == 0 + ? ret_value.significand + : ret_value.significand - 1; + } else if (ret_value.significand < xi) { + ++ret_value.significand; + } + return ret_value; +} + +template decimal_fp to_decimal(T x) noexcept { + // Step 1: integer promotion & Schubfach multiplier calculation. + + using carrier_uint = typename float_info::carrier_uint; + using cache_entry_type = typename cache_accessor::cache_entry_type; + auto br = bit_cast(x); + + // Extract significand bits and exponent bits. + const carrier_uint significand_mask = + (static_cast(1) << num_significand_bits()) - 1; + carrier_uint significand = (br & significand_mask); + int exponent = + static_cast((br & exponent_mask()) >> num_significand_bits()); + + if (exponent != 0) { // Check if normal. + exponent -= exponent_bias() + num_significand_bits(); + + // Shorter interval case; proceed like Schubfach. + // In fact, when exponent == 1 and significand == 0, the interval is + // regular. However, it can be shown that the end-results are anyway same. + if (significand == 0) return shorter_interval_case(exponent); + + significand |= (static_cast(1) << num_significand_bits()); + } else { + // Subnormal case; the interval is always regular. + if (significand == 0) return {0, 0}; + exponent = + std::numeric_limits::min_exponent - num_significand_bits() - 1; + } + + const bool include_left_endpoint = (significand % 2 == 0); + const bool include_right_endpoint = include_left_endpoint; + + // Compute k and beta. + const int minus_k = floor_log10_pow2(exponent) - float_info::kappa; + const cache_entry_type cache = cache_accessor::get_cached_power(-minus_k); + const int beta = exponent + floor_log2_pow10(-minus_k); + + // Compute zi and deltai. + // 10^kappa <= deltai < 10^(kappa + 1) + const uint32_t deltai = cache_accessor::compute_delta(cache, beta); + const carrier_uint two_fc = significand << 1; + + // For the case of binary32, the result of integer check is not correct for + // 29711844 * 2^-82 + // = 6.1442653300000000008655037797566933477355632930994033813476... * 10^-18 + // and 29711844 * 2^-81 + // = 1.2288530660000000001731007559513386695471126586198806762695... * 10^-17, + // and they are the unique counterexamples. However, since 29711844 is even, + // this does not cause any problem for the endpoints calculations; it can only + // cause a problem when we need to perform integer check for the center. + // Fortunately, with these inputs, that branch is never executed, so we are + // fine. + const typename cache_accessor::compute_mul_result z_mul = + cache_accessor::compute_mul((two_fc | 1) << beta, cache); + + // Step 2: Try larger divisor; remove trailing zeros if necessary. + + // Using an upper bound on zi, we might be able to optimize the division + // better than the compiler; we are computing zi / big_divisor here. + decimal_fp ret_value; + ret_value.significand = divide_by_10_to_kappa_plus_1(z_mul.result); + uint32_t r = static_cast(z_mul.result - float_info::big_divisor * + ret_value.significand); + + if (r < deltai) { + // Exclude the right endpoint if necessary. + if (r == 0 && (z_mul.is_integer & !include_right_endpoint)) { + --ret_value.significand; + r = float_info::big_divisor; + goto small_divisor_case_label; + } + } else if (r > deltai) { + goto small_divisor_case_label; + } else { + // r == deltai; compare fractional parts. + const typename cache_accessor::compute_mul_parity_result x_mul = + cache_accessor::compute_mul_parity(two_fc - 1, cache, beta); + + if (!(x_mul.parity | (x_mul.is_integer & include_left_endpoint))) + goto small_divisor_case_label; + } + ret_value.exponent = minus_k + float_info::kappa + 1; + + // We may need to remove trailing zeros. + ret_value.exponent += remove_trailing_zeros(ret_value.significand); + return ret_value; + + // Step 3: Find the significand with the smaller divisor. + +small_divisor_case_label: + ret_value.significand *= 10; + ret_value.exponent = minus_k + float_info::kappa; + + uint32_t dist = r - (deltai / 2) + (float_info::small_divisor / 2); + const bool approx_y_parity = + ((dist ^ (float_info::small_divisor / 2)) & 1) != 0; + + // Is dist divisible by 10^kappa? + const bool divisible_by_small_divisor = + check_divisibility_and_divide_by_pow10::kappa>(dist); + + // Add dist / 10^kappa to the significand. + ret_value.significand += dist; + + if (!divisible_by_small_divisor) return ret_value; + + // Check z^(f) >= epsilon^(f). + // We have either yi == zi - epsiloni or yi == (zi - epsiloni) - 1, + // where yi == zi - epsiloni if and only if z^(f) >= epsilon^(f). + // Since there are only 2 possibilities, we only need to care about the + // parity. Also, zi and r should have the same parity since the divisor + // is an even number. + const auto y_mul = cache_accessor::compute_mul_parity(two_fc, cache, beta); + + // If z^(f) >= epsilon^(f), we might have a tie when z^(f) == epsilon^(f), + // or equivalently, when y is an integer. + if (y_mul.parity != approx_y_parity) + --ret_value.significand; + else if (y_mul.is_integer & (ret_value.significand % 2 != 0)) + --ret_value.significand; + return ret_value; +} +} // namespace dragonbox +} // namespace detail + +template <> struct formatter { + FMT_CONSTEXPR auto parse(format_parse_context& ctx) + -> format_parse_context::iterator { + return ctx.begin(); + } + + auto format(const detail::bigint& n, format_context& ctx) const + -> format_context::iterator { + auto out = ctx.out(); + bool first = true; + for (auto i = n.bigits_.size(); i > 0; --i) { + auto value = n.bigits_[i - 1u]; + if (first) { + out = format_to(out, FMT_STRING("{:x}"), value); + first = false; + continue; + } + out = format_to(out, FMT_STRING("{:08x}"), value); + } + if (n.exp_ > 0) + out = format_to(out, FMT_STRING("p{}"), + n.exp_ * detail::bigint::bigit_bits); + return out; + } +}; + +FMT_FUNC detail::utf8_to_utf16::utf8_to_utf16(string_view s) { + for_each_codepoint(s, [this](uint32_t cp, string_view) { + if (cp == invalid_code_point) FMT_THROW(std::runtime_error("invalid utf8")); + if (cp <= 0xFFFF) { + buffer_.push_back(static_cast(cp)); + } else { + cp -= 0x10000; + buffer_.push_back(static_cast(0xD800 + (cp >> 10))); + buffer_.push_back(static_cast(0xDC00 + (cp & 0x3FF))); + } + return true; + }); + buffer_.push_back(0); +} + +FMT_FUNC void format_system_error(detail::buffer& out, int error_code, + const char* message) noexcept { + FMT_TRY { + auto ec = std::error_code(error_code, std::generic_category()); + write(std::back_inserter(out), std::system_error(ec, message).what()); + return; + } + FMT_CATCH(...) {} + format_error_code(out, error_code, message); +} + +FMT_FUNC void report_system_error(int error_code, + const char* message) noexcept { + report_error(format_system_error, error_code, message); +} + +FMT_FUNC std::string vformat(string_view fmt, format_args args) { + // Don't optimize the "{}" case to keep the binary size small and because it + // can be better optimized in fmt::format anyway. + auto buffer = memory_buffer(); + detail::vformat_to(buffer, fmt, args); + return to_string(buffer); +} + +namespace detail { +#ifndef _WIN32 +FMT_FUNC bool write_console(std::FILE*, string_view) { return false; } +#else +using dword = conditional_t; +extern "C" __declspec(dllimport) int __stdcall WriteConsoleW( // + void*, const void*, dword, dword*, void*); + +FMT_FUNC bool write_console(std::FILE* f, string_view text) { + auto fd = _fileno(f); + if (!_isatty(fd)) return false; + auto u16 = utf8_to_utf16(text); + auto written = dword(); + return WriteConsoleW(reinterpret_cast(_get_osfhandle(fd)), u16.c_str(), + static_cast(u16.size()), &written, nullptr) != 0; +} + +// Print assuming legacy (non-Unicode) encoding. +FMT_FUNC void vprint_mojibake(std::FILE* f, string_view fmt, format_args args) { + auto buffer = memory_buffer(); + detail::vformat_to(buffer, fmt, + basic_format_args>(args)); + fwrite_fully(buffer.data(), 1, buffer.size(), f); +} +#endif + +FMT_FUNC void print(std::FILE* f, string_view text) { + if (!write_console(f, text)) fwrite_fully(text.data(), 1, text.size(), f); +} +} // namespace detail + +FMT_FUNC void vprint(std::FILE* f, string_view fmt, format_args args) { + auto buffer = memory_buffer(); + detail::vformat_to(buffer, fmt, args); + detail::print(f, {buffer.data(), buffer.size()}); +} + +FMT_FUNC void vprint(string_view fmt, format_args args) { + vprint(stdout, fmt, args); +} + +namespace detail { + +struct singleton { + unsigned char upper; + unsigned char lower_count; +}; + +inline auto is_printable(uint16_t x, const singleton* singletons, + size_t singletons_size, + const unsigned char* singleton_lowers, + const unsigned char* normal, size_t normal_size) + -> bool { + auto upper = x >> 8; + auto lower_start = 0; + for (size_t i = 0; i < singletons_size; ++i) { + auto s = singletons[i]; + auto lower_end = lower_start + s.lower_count; + if (upper < s.upper) break; + if (upper == s.upper) { + for (auto j = lower_start; j < lower_end; ++j) { + if (singleton_lowers[j] == (x & 0xff)) return false; + } + } + lower_start = lower_end; + } + + auto xsigned = static_cast(x); + auto current = true; + for (size_t i = 0; i < normal_size; ++i) { + auto v = static_cast(normal[i]); + auto len = (v & 0x80) != 0 ? (v & 0x7f) << 8 | normal[++i] : v; + xsigned -= len; + if (xsigned < 0) break; + current = !current; + } + return current; +} + +// This code is generated by support/printable.py. +FMT_FUNC auto is_printable(uint32_t cp) -> bool { + static constexpr singleton singletons0[] = { + {0x00, 1}, {0x03, 5}, {0x05, 6}, {0x06, 3}, {0x07, 6}, {0x08, 8}, + {0x09, 17}, {0x0a, 28}, {0x0b, 25}, {0x0c, 20}, {0x0d, 16}, {0x0e, 13}, + {0x0f, 4}, {0x10, 3}, {0x12, 18}, {0x13, 9}, {0x16, 1}, {0x17, 5}, + {0x18, 2}, {0x19, 3}, {0x1a, 7}, {0x1c, 2}, {0x1d, 1}, {0x1f, 22}, + {0x20, 3}, {0x2b, 3}, {0x2c, 2}, {0x2d, 11}, {0x2e, 1}, {0x30, 3}, + {0x31, 2}, {0x32, 1}, {0xa7, 2}, {0xa9, 2}, {0xaa, 4}, {0xab, 8}, + {0xfa, 2}, {0xfb, 5}, {0xfd, 4}, {0xfe, 3}, {0xff, 9}, + }; + static constexpr unsigned char singletons0_lower[] = { + 0xad, 0x78, 0x79, 0x8b, 0x8d, 0xa2, 0x30, 0x57, 0x58, 0x8b, 0x8c, 0x90, + 0x1c, 0x1d, 0xdd, 0x0e, 0x0f, 0x4b, 0x4c, 0xfb, 0xfc, 0x2e, 0x2f, 0x3f, + 0x5c, 0x5d, 0x5f, 0xb5, 0xe2, 0x84, 0x8d, 0x8e, 0x91, 0x92, 0xa9, 0xb1, + 0xba, 0xbb, 0xc5, 0xc6, 0xc9, 0xca, 0xde, 0xe4, 0xe5, 0xff, 0x00, 0x04, + 0x11, 0x12, 0x29, 0x31, 0x34, 0x37, 0x3a, 0x3b, 0x3d, 0x49, 0x4a, 0x5d, + 0x84, 0x8e, 0x92, 0xa9, 0xb1, 0xb4, 0xba, 0xbb, 0xc6, 0xca, 0xce, 0xcf, + 0xe4, 0xe5, 0x00, 0x04, 0x0d, 0x0e, 0x11, 0x12, 0x29, 0x31, 0x34, 0x3a, + 0x3b, 0x45, 0x46, 0x49, 0x4a, 0x5e, 0x64, 0x65, 0x84, 0x91, 0x9b, 0x9d, + 0xc9, 0xce, 0xcf, 0x0d, 0x11, 0x29, 0x45, 0x49, 0x57, 0x64, 0x65, 0x8d, + 0x91, 0xa9, 0xb4, 0xba, 0xbb, 0xc5, 0xc9, 0xdf, 0xe4, 0xe5, 0xf0, 0x0d, + 0x11, 0x45, 0x49, 0x64, 0x65, 0x80, 0x84, 0xb2, 0xbc, 0xbe, 0xbf, 0xd5, + 0xd7, 0xf0, 0xf1, 0x83, 0x85, 0x8b, 0xa4, 0xa6, 0xbe, 0xbf, 0xc5, 0xc7, + 0xce, 0xcf, 0xda, 0xdb, 0x48, 0x98, 0xbd, 0xcd, 0xc6, 0xce, 0xcf, 0x49, + 0x4e, 0x4f, 0x57, 0x59, 0x5e, 0x5f, 0x89, 0x8e, 0x8f, 0xb1, 0xb6, 0xb7, + 0xbf, 0xc1, 0xc6, 0xc7, 0xd7, 0x11, 0x16, 0x17, 0x5b, 0x5c, 0xf6, 0xf7, + 0xfe, 0xff, 0x80, 0x0d, 0x6d, 0x71, 0xde, 0xdf, 0x0e, 0x0f, 0x1f, 0x6e, + 0x6f, 0x1c, 0x1d, 0x5f, 0x7d, 0x7e, 0xae, 0xaf, 0xbb, 0xbc, 0xfa, 0x16, + 0x17, 0x1e, 0x1f, 0x46, 0x47, 0x4e, 0x4f, 0x58, 0x5a, 0x5c, 0x5e, 0x7e, + 0x7f, 0xb5, 0xc5, 0xd4, 0xd5, 0xdc, 0xf0, 0xf1, 0xf5, 0x72, 0x73, 0x8f, + 0x74, 0x75, 0x96, 0x2f, 0x5f, 0x26, 0x2e, 0x2f, 0xa7, 0xaf, 0xb7, 0xbf, + 0xc7, 0xcf, 0xd7, 0xdf, 0x9a, 0x40, 0x97, 0x98, 0x30, 0x8f, 0x1f, 0xc0, + 0xc1, 0xce, 0xff, 0x4e, 0x4f, 0x5a, 0x5b, 0x07, 0x08, 0x0f, 0x10, 0x27, + 0x2f, 0xee, 0xef, 0x6e, 0x6f, 0x37, 0x3d, 0x3f, 0x42, 0x45, 0x90, 0x91, + 0xfe, 0xff, 0x53, 0x67, 0x75, 0xc8, 0xc9, 0xd0, 0xd1, 0xd8, 0xd9, 0xe7, + 0xfe, 0xff, + }; + static constexpr singleton singletons1[] = { + {0x00, 6}, {0x01, 1}, {0x03, 1}, {0x04, 2}, {0x08, 8}, {0x09, 2}, + {0x0a, 5}, {0x0b, 2}, {0x0e, 4}, {0x10, 1}, {0x11, 2}, {0x12, 5}, + {0x13, 17}, {0x14, 1}, {0x15, 2}, {0x17, 2}, {0x19, 13}, {0x1c, 5}, + {0x1d, 8}, {0x24, 1}, {0x6a, 3}, {0x6b, 2}, {0xbc, 2}, {0xd1, 2}, + {0xd4, 12}, {0xd5, 9}, {0xd6, 2}, {0xd7, 2}, {0xda, 1}, {0xe0, 5}, + {0xe1, 2}, {0xe8, 2}, {0xee, 32}, {0xf0, 4}, {0xf8, 2}, {0xf9, 2}, + {0xfa, 2}, {0xfb, 1}, + }; + static constexpr unsigned char singletons1_lower[] = { + 0x0c, 0x27, 0x3b, 0x3e, 0x4e, 0x4f, 0x8f, 0x9e, 0x9e, 0x9f, 0x06, 0x07, + 0x09, 0x36, 0x3d, 0x3e, 0x56, 0xf3, 0xd0, 0xd1, 0x04, 0x14, 0x18, 0x36, + 0x37, 0x56, 0x57, 0x7f, 0xaa, 0xae, 0xaf, 0xbd, 0x35, 0xe0, 0x12, 0x87, + 0x89, 0x8e, 0x9e, 0x04, 0x0d, 0x0e, 0x11, 0x12, 0x29, 0x31, 0x34, 0x3a, + 0x45, 0x46, 0x49, 0x4a, 0x4e, 0x4f, 0x64, 0x65, 0x5c, 0xb6, 0xb7, 0x1b, + 0x1c, 0x07, 0x08, 0x0a, 0x0b, 0x14, 0x17, 0x36, 0x39, 0x3a, 0xa8, 0xa9, + 0xd8, 0xd9, 0x09, 0x37, 0x90, 0x91, 0xa8, 0x07, 0x0a, 0x3b, 0x3e, 0x66, + 0x69, 0x8f, 0x92, 0x6f, 0x5f, 0xee, 0xef, 0x5a, 0x62, 0x9a, 0x9b, 0x27, + 0x28, 0x55, 0x9d, 0xa0, 0xa1, 0xa3, 0xa4, 0xa7, 0xa8, 0xad, 0xba, 0xbc, + 0xc4, 0x06, 0x0b, 0x0c, 0x15, 0x1d, 0x3a, 0x3f, 0x45, 0x51, 0xa6, 0xa7, + 0xcc, 0xcd, 0xa0, 0x07, 0x19, 0x1a, 0x22, 0x25, 0x3e, 0x3f, 0xc5, 0xc6, + 0x04, 0x20, 0x23, 0x25, 0x26, 0x28, 0x33, 0x38, 0x3a, 0x48, 0x4a, 0x4c, + 0x50, 0x53, 0x55, 0x56, 0x58, 0x5a, 0x5c, 0x5e, 0x60, 0x63, 0x65, 0x66, + 0x6b, 0x73, 0x78, 0x7d, 0x7f, 0x8a, 0xa4, 0xaa, 0xaf, 0xb0, 0xc0, 0xd0, + 0xae, 0xaf, 0x79, 0xcc, 0x6e, 0x6f, 0x93, + }; + static constexpr unsigned char normal0[] = { + 0x00, 0x20, 0x5f, 0x22, 0x82, 0xdf, 0x04, 0x82, 0x44, 0x08, 0x1b, 0x04, + 0x06, 0x11, 0x81, 0xac, 0x0e, 0x80, 0xab, 0x35, 0x28, 0x0b, 0x80, 0xe0, + 0x03, 0x19, 0x08, 0x01, 0x04, 0x2f, 0x04, 0x34, 0x04, 0x07, 0x03, 0x01, + 0x07, 0x06, 0x07, 0x11, 0x0a, 0x50, 0x0f, 0x12, 0x07, 0x55, 0x07, 0x03, + 0x04, 0x1c, 0x0a, 0x09, 0x03, 0x08, 0x03, 0x07, 0x03, 0x02, 0x03, 0x03, + 0x03, 0x0c, 0x04, 0x05, 0x03, 0x0b, 0x06, 0x01, 0x0e, 0x15, 0x05, 0x3a, + 0x03, 0x11, 0x07, 0x06, 0x05, 0x10, 0x07, 0x57, 0x07, 0x02, 0x07, 0x15, + 0x0d, 0x50, 0x04, 0x43, 0x03, 0x2d, 0x03, 0x01, 0x04, 0x11, 0x06, 0x0f, + 0x0c, 0x3a, 0x04, 0x1d, 0x25, 0x5f, 0x20, 0x6d, 0x04, 0x6a, 0x25, 0x80, + 0xc8, 0x05, 0x82, 0xb0, 0x03, 0x1a, 0x06, 0x82, 0xfd, 0x03, 0x59, 0x07, + 0x15, 0x0b, 0x17, 0x09, 0x14, 0x0c, 0x14, 0x0c, 0x6a, 0x06, 0x0a, 0x06, + 0x1a, 0x06, 0x59, 0x07, 0x2b, 0x05, 0x46, 0x0a, 0x2c, 0x04, 0x0c, 0x04, + 0x01, 0x03, 0x31, 0x0b, 0x2c, 0x04, 0x1a, 0x06, 0x0b, 0x03, 0x80, 0xac, + 0x06, 0x0a, 0x06, 0x21, 0x3f, 0x4c, 0x04, 0x2d, 0x03, 0x74, 0x08, 0x3c, + 0x03, 0x0f, 0x03, 0x3c, 0x07, 0x38, 0x08, 0x2b, 0x05, 0x82, 0xff, 0x11, + 0x18, 0x08, 0x2f, 0x11, 0x2d, 0x03, 0x20, 0x10, 0x21, 0x0f, 0x80, 0x8c, + 0x04, 0x82, 0x97, 0x19, 0x0b, 0x15, 0x88, 0x94, 0x05, 0x2f, 0x05, 0x3b, + 0x07, 0x02, 0x0e, 0x18, 0x09, 0x80, 0xb3, 0x2d, 0x74, 0x0c, 0x80, 0xd6, + 0x1a, 0x0c, 0x05, 0x80, 0xff, 0x05, 0x80, 0xdf, 0x0c, 0xee, 0x0d, 0x03, + 0x84, 0x8d, 0x03, 0x37, 0x09, 0x81, 0x5c, 0x14, 0x80, 0xb8, 0x08, 0x80, + 0xcb, 0x2a, 0x38, 0x03, 0x0a, 0x06, 0x38, 0x08, 0x46, 0x08, 0x0c, 0x06, + 0x74, 0x0b, 0x1e, 0x03, 0x5a, 0x04, 0x59, 0x09, 0x80, 0x83, 0x18, 0x1c, + 0x0a, 0x16, 0x09, 0x4c, 0x04, 0x80, 0x8a, 0x06, 0xab, 0xa4, 0x0c, 0x17, + 0x04, 0x31, 0xa1, 0x04, 0x81, 0xda, 0x26, 0x07, 0x0c, 0x05, 0x05, 0x80, + 0xa5, 0x11, 0x81, 0x6d, 0x10, 0x78, 0x28, 0x2a, 0x06, 0x4c, 0x04, 0x80, + 0x8d, 0x04, 0x80, 0xbe, 0x03, 0x1b, 0x03, 0x0f, 0x0d, + }; + static constexpr unsigned char normal1[] = { + 0x5e, 0x22, 0x7b, 0x05, 0x03, 0x04, 0x2d, 0x03, 0x66, 0x03, 0x01, 0x2f, + 0x2e, 0x80, 0x82, 0x1d, 0x03, 0x31, 0x0f, 0x1c, 0x04, 0x24, 0x09, 0x1e, + 0x05, 0x2b, 0x05, 0x44, 0x04, 0x0e, 0x2a, 0x80, 0xaa, 0x06, 0x24, 0x04, + 0x24, 0x04, 0x28, 0x08, 0x34, 0x0b, 0x01, 0x80, 0x90, 0x81, 0x37, 0x09, + 0x16, 0x0a, 0x08, 0x80, 0x98, 0x39, 0x03, 0x63, 0x08, 0x09, 0x30, 0x16, + 0x05, 0x21, 0x03, 0x1b, 0x05, 0x01, 0x40, 0x38, 0x04, 0x4b, 0x05, 0x2f, + 0x04, 0x0a, 0x07, 0x09, 0x07, 0x40, 0x20, 0x27, 0x04, 0x0c, 0x09, 0x36, + 0x03, 0x3a, 0x05, 0x1a, 0x07, 0x04, 0x0c, 0x07, 0x50, 0x49, 0x37, 0x33, + 0x0d, 0x33, 0x07, 0x2e, 0x08, 0x0a, 0x81, 0x26, 0x52, 0x4e, 0x28, 0x08, + 0x2a, 0x56, 0x1c, 0x14, 0x17, 0x09, 0x4e, 0x04, 0x1e, 0x0f, 0x43, 0x0e, + 0x19, 0x07, 0x0a, 0x06, 0x48, 0x08, 0x27, 0x09, 0x75, 0x0b, 0x3f, 0x41, + 0x2a, 0x06, 0x3b, 0x05, 0x0a, 0x06, 0x51, 0x06, 0x01, 0x05, 0x10, 0x03, + 0x05, 0x80, 0x8b, 0x62, 0x1e, 0x48, 0x08, 0x0a, 0x80, 0xa6, 0x5e, 0x22, + 0x45, 0x0b, 0x0a, 0x06, 0x0d, 0x13, 0x39, 0x07, 0x0a, 0x36, 0x2c, 0x04, + 0x10, 0x80, 0xc0, 0x3c, 0x64, 0x53, 0x0c, 0x48, 0x09, 0x0a, 0x46, 0x45, + 0x1b, 0x48, 0x08, 0x53, 0x1d, 0x39, 0x81, 0x07, 0x46, 0x0a, 0x1d, 0x03, + 0x47, 0x49, 0x37, 0x03, 0x0e, 0x08, 0x0a, 0x06, 0x39, 0x07, 0x0a, 0x81, + 0x36, 0x19, 0x80, 0xb7, 0x01, 0x0f, 0x32, 0x0d, 0x83, 0x9b, 0x66, 0x75, + 0x0b, 0x80, 0xc4, 0x8a, 0xbc, 0x84, 0x2f, 0x8f, 0xd1, 0x82, 0x47, 0xa1, + 0xb9, 0x82, 0x39, 0x07, 0x2a, 0x04, 0x02, 0x60, 0x26, 0x0a, 0x46, 0x0a, + 0x28, 0x05, 0x13, 0x82, 0xb0, 0x5b, 0x65, 0x4b, 0x04, 0x39, 0x07, 0x11, + 0x40, 0x05, 0x0b, 0x02, 0x0e, 0x97, 0xf8, 0x08, 0x84, 0xd6, 0x2a, 0x09, + 0xa2, 0xf7, 0x81, 0x1f, 0x31, 0x03, 0x11, 0x04, 0x08, 0x81, 0x8c, 0x89, + 0x04, 0x6b, 0x05, 0x0d, 0x03, 0x09, 0x07, 0x10, 0x93, 0x60, 0x80, 0xf6, + 0x0a, 0x73, 0x08, 0x6e, 0x17, 0x46, 0x80, 0x9a, 0x14, 0x0c, 0x57, 0x09, + 0x19, 0x80, 0x87, 0x81, 0x47, 0x03, 0x85, 0x42, 0x0f, 0x15, 0x85, 0x50, + 0x2b, 0x80, 0xd5, 0x2d, 0x03, 0x1a, 0x04, 0x02, 0x81, 0x70, 0x3a, 0x05, + 0x01, 0x85, 0x00, 0x80, 0xd7, 0x29, 0x4c, 0x04, 0x0a, 0x04, 0x02, 0x83, + 0x11, 0x44, 0x4c, 0x3d, 0x80, 0xc2, 0x3c, 0x06, 0x01, 0x04, 0x55, 0x05, + 0x1b, 0x34, 0x02, 0x81, 0x0e, 0x2c, 0x04, 0x64, 0x0c, 0x56, 0x0a, 0x80, + 0xae, 0x38, 0x1d, 0x0d, 0x2c, 0x04, 0x09, 0x07, 0x02, 0x0e, 0x06, 0x80, + 0x9a, 0x83, 0xd8, 0x08, 0x0d, 0x03, 0x0d, 0x03, 0x74, 0x0c, 0x59, 0x07, + 0x0c, 0x14, 0x0c, 0x04, 0x38, 0x08, 0x0a, 0x06, 0x28, 0x08, 0x22, 0x4e, + 0x81, 0x54, 0x0c, 0x15, 0x03, 0x03, 0x05, 0x07, 0x09, 0x19, 0x07, 0x07, + 0x09, 0x03, 0x0d, 0x07, 0x29, 0x80, 0xcb, 0x25, 0x0a, 0x84, 0x06, + }; + auto lower = static_cast(cp); + if (cp < 0x10000) { + return is_printable(lower, singletons0, + sizeof(singletons0) / sizeof(*singletons0), + singletons0_lower, normal0, sizeof(normal0)); + } + if (cp < 0x20000) { + return is_printable(lower, singletons1, + sizeof(singletons1) / sizeof(*singletons1), + singletons1_lower, normal1, sizeof(normal1)); + } + if (0x2a6de <= cp && cp < 0x2a700) return false; + if (0x2b735 <= cp && cp < 0x2b740) return false; + if (0x2b81e <= cp && cp < 0x2b820) return false; + if (0x2cea2 <= cp && cp < 0x2ceb0) return false; + if (0x2ebe1 <= cp && cp < 0x2f800) return false; + if (0x2fa1e <= cp && cp < 0x30000) return false; + if (0x3134b <= cp && cp < 0xe0100) return false; + if (0xe01f0 <= cp && cp < 0x110000) return false; + return cp < 0x110000; +} + +} // namespace detail + +FMT_END_NAMESPACE + +#endif // FMT_FORMAT_INL_H_ diff --git a/src/fmt/format.h b/src/fmt/format.h new file mode 100644 index 0000000..87a34b9 --- /dev/null +++ b/src/fmt/format.h @@ -0,0 +1,4510 @@ +/* + Formatting library for C++ + + Copyright (c) 2012 - present, Victor Zverovich + + Permission is hereby granted, free of charge, to any person obtaining + a copy of this software and associated documentation files (the + "Software"), to deal in the Software without restriction, including + without limitation the rights to use, copy, modify, merge, publish, + distribute, sublicense, and/or sell copies of the Software, and to + permit persons to whom the Software is furnished to do so, subject to + the following conditions: + + The above copyright notice and this permission notice shall be + included in all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE + LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION + OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + --- Optional exception to the license --- + + As an exception, if, as a result of your compiling your source code, portions + of this Software are embedded into a machine-executable object form of such + source code, you may redistribute such embedded portions in such object form + without including the above copyright and permission notices. + */ + +#ifndef FMT_FORMAT_H_ +#define FMT_FORMAT_H_ + +#include // std::signbit +#include // uint32_t +#include // std::memcpy +#include // std::initializer_list +#include // std::numeric_limits +#include // std::uninitialized_copy +#include // std::runtime_error +#include // std::system_error + +#ifdef __cpp_lib_bit_cast +# include // std::bitcast +#endif + +#include "core.h" + +#if defined __cpp_inline_variables && __cpp_inline_variables >= 201606L +# define FMT_INLINE_VARIABLE inline +#else +# define FMT_INLINE_VARIABLE +#endif + +#if FMT_HAS_CPP17_ATTRIBUTE(fallthrough) +# define FMT_FALLTHROUGH [[fallthrough]] +#elif defined(__clang__) +# define FMT_FALLTHROUGH [[clang::fallthrough]] +#elif FMT_GCC_VERSION >= 700 && \ + (!defined(__EDG_VERSION__) || __EDG_VERSION__ >= 520) +# define FMT_FALLTHROUGH [[gnu::fallthrough]] +#else +# define FMT_FALLTHROUGH +#endif + +#ifndef FMT_DEPRECATED +# if FMT_HAS_CPP14_ATTRIBUTE(deprecated) || FMT_MSC_VERSION >= 1900 +# define FMT_DEPRECATED [[deprecated]] +# else +# if (defined(__GNUC__) && !defined(__LCC__)) || defined(__clang__) +# define FMT_DEPRECATED __attribute__((deprecated)) +# elif FMT_MSC_VERSION +# define FMT_DEPRECATED __declspec(deprecated) +# else +# define FMT_DEPRECATED /* deprecated */ +# endif +# endif +#endif + +#ifndef FMT_NO_UNIQUE_ADDRESS +# if FMT_CPLUSPLUS >= 202002L +# if FMT_HAS_CPP_ATTRIBUTE(no_unique_address) +# define FMT_NO_UNIQUE_ADDRESS [[no_unique_address]] +// VS2019 v16.10 and later except clang-cl (https://reviews.llvm.org/D110485) +# elif (FMT_MSC_VERSION >= 1929) && !FMT_CLANG_VERSION +# define FMT_NO_UNIQUE_ADDRESS [[msvc::no_unique_address]] +# endif +# endif +#endif +#ifndef FMT_NO_UNIQUE_ADDRESS +# define FMT_NO_UNIQUE_ADDRESS +#endif + +#if FMT_GCC_VERSION || defined(__clang__) +# define FMT_VISIBILITY(value) __attribute__((visibility(value))) +#else +# define FMT_VISIBILITY(value) +#endif + +#ifdef __has_builtin +# define FMT_HAS_BUILTIN(x) __has_builtin(x) +#else +# define FMT_HAS_BUILTIN(x) 0 +#endif + +#if FMT_GCC_VERSION || FMT_CLANG_VERSION +# define FMT_NOINLINE __attribute__((noinline)) +#else +# define FMT_NOINLINE +#endif + +#ifndef FMT_THROW +# if FMT_EXCEPTIONS +# if FMT_MSC_VERSION || defined(__NVCC__) +FMT_BEGIN_NAMESPACE +namespace detail { +template inline void do_throw(const Exception& x) { + // Silence unreachable code warnings in MSVC and NVCC because these + // are nearly impossible to fix in a generic code. + volatile bool b = true; + if (b) throw x; +} +} // namespace detail +FMT_END_NAMESPACE +# define FMT_THROW(x) detail::do_throw(x) +# else +# define FMT_THROW(x) throw x +# endif +# else +# define FMT_THROW(x) \ + ::fmt::detail::assert_fail(__FILE__, __LINE__, (x).what()) +# endif +#endif + +#if FMT_EXCEPTIONS +# define FMT_TRY try +# define FMT_CATCH(x) catch (x) +#else +# define FMT_TRY if (true) +# define FMT_CATCH(x) if (false) +#endif + +#ifndef FMT_MAYBE_UNUSED +# if FMT_HAS_CPP17_ATTRIBUTE(maybe_unused) +# define FMT_MAYBE_UNUSED [[maybe_unused]] +# else +# define FMT_MAYBE_UNUSED +# endif +#endif + +#ifndef FMT_USE_USER_DEFINED_LITERALS +// EDG based compilers (Intel, NVIDIA, Elbrus, etc), GCC and MSVC support UDLs. +# if (FMT_HAS_FEATURE(cxx_user_literals) || FMT_GCC_VERSION >= 407 || \ + FMT_MSC_VERSION >= 1900) && \ + (!defined(__EDG_VERSION__) || __EDG_VERSION__ >= /* UDL feature */ 480) +# define FMT_USE_USER_DEFINED_LITERALS 1 +# else +# define FMT_USE_USER_DEFINED_LITERALS 0 +# endif +#endif + +// Defining FMT_REDUCE_INT_INSTANTIATIONS to 1, will reduce the number of +// integer formatter template instantiations to just one by only using the +// largest integer type. This results in a reduction in binary size but will +// cause a decrease in integer formatting performance. +#if !defined(FMT_REDUCE_INT_INSTANTIATIONS) +# define FMT_REDUCE_INT_INSTANTIATIONS 0 +#endif + +// __builtin_clz is broken in clang with Microsoft CodeGen: +// https://github.com/fmtlib/fmt/issues/519. +#if !FMT_MSC_VERSION +# if FMT_HAS_BUILTIN(__builtin_clz) || FMT_GCC_VERSION || FMT_ICC_VERSION +# define FMT_BUILTIN_CLZ(n) __builtin_clz(n) +# endif +# if FMT_HAS_BUILTIN(__builtin_clzll) || FMT_GCC_VERSION || FMT_ICC_VERSION +# define FMT_BUILTIN_CLZLL(n) __builtin_clzll(n) +# endif +#endif + +// __builtin_ctz is broken in Intel Compiler Classic on Windows: +// https://github.com/fmtlib/fmt/issues/2510. +#ifndef __ICL +# if FMT_HAS_BUILTIN(__builtin_ctz) || FMT_GCC_VERSION || FMT_ICC_VERSION || \ + defined(__NVCOMPILER) +# define FMT_BUILTIN_CTZ(n) __builtin_ctz(n) +# endif +# if FMT_HAS_BUILTIN(__builtin_ctzll) || FMT_GCC_VERSION || \ + FMT_ICC_VERSION || defined(__NVCOMPILER) +# define FMT_BUILTIN_CTZLL(n) __builtin_ctzll(n) +# endif +#endif + +#if FMT_MSC_VERSION +# include // _BitScanReverse[64], _BitScanForward[64], _umul128 +#endif + +// Some compilers masquerade as both MSVC and GCC-likes or otherwise support +// __builtin_clz and __builtin_clzll, so only define FMT_BUILTIN_CLZ using the +// MSVC intrinsics if the clz and clzll builtins are not available. +#if FMT_MSC_VERSION && !defined(FMT_BUILTIN_CLZLL) && \ + !defined(FMT_BUILTIN_CTZLL) +FMT_BEGIN_NAMESPACE +namespace detail { +// Avoid Clang with Microsoft CodeGen's -Wunknown-pragmas warning. +# if !defined(__clang__) +# pragma intrinsic(_BitScanForward) +# pragma intrinsic(_BitScanReverse) +# if defined(_WIN64) +# pragma intrinsic(_BitScanForward64) +# pragma intrinsic(_BitScanReverse64) +# endif +# endif + +inline auto clz(uint32_t x) -> int { + unsigned long r = 0; + _BitScanReverse(&r, x); + FMT_ASSERT(x != 0, ""); + // Static analysis complains about using uninitialized data + // "r", but the only way that can happen is if "x" is 0, + // which the callers guarantee to not happen. + FMT_MSC_WARNING(suppress : 6102) + return 31 ^ static_cast(r); +} +# define FMT_BUILTIN_CLZ(n) detail::clz(n) + +inline auto clzll(uint64_t x) -> int { + unsigned long r = 0; +# ifdef _WIN64 + _BitScanReverse64(&r, x); +# else + // Scan the high 32 bits. + if (_BitScanReverse(&r, static_cast(x >> 32))) + return 63 ^ static_cast(r + 32); + // Scan the low 32 bits. + _BitScanReverse(&r, static_cast(x)); +# endif + FMT_ASSERT(x != 0, ""); + FMT_MSC_WARNING(suppress : 6102) // Suppress a bogus static analysis warning. + return 63 ^ static_cast(r); +} +# define FMT_BUILTIN_CLZLL(n) detail::clzll(n) + +inline auto ctz(uint32_t x) -> int { + unsigned long r = 0; + _BitScanForward(&r, x); + FMT_ASSERT(x != 0, ""); + FMT_MSC_WARNING(suppress : 6102) // Suppress a bogus static analysis warning. + return static_cast(r); +} +# define FMT_BUILTIN_CTZ(n) detail::ctz(n) + +inline auto ctzll(uint64_t x) -> int { + unsigned long r = 0; + FMT_ASSERT(x != 0, ""); + FMT_MSC_WARNING(suppress : 6102) // Suppress a bogus static analysis warning. +# ifdef _WIN64 + _BitScanForward64(&r, x); +# else + // Scan the low 32 bits. + if (_BitScanForward(&r, static_cast(x))) return static_cast(r); + // Scan the high 32 bits. + _BitScanForward(&r, static_cast(x >> 32)); + r += 32; +# endif + return static_cast(r); +} +# define FMT_BUILTIN_CTZLL(n) detail::ctzll(n) +} // namespace detail +FMT_END_NAMESPACE +#endif + +FMT_BEGIN_NAMESPACE + +template struct disjunction : std::false_type {}; +template struct disjunction

: P {}; +template +struct disjunction + : conditional_t> {}; + +template struct conjunction : std::true_type {}; +template struct conjunction

: P {}; +template +struct conjunction + : conditional_t, P1> {}; + +namespace detail { + +FMT_CONSTEXPR inline void abort_fuzzing_if(bool condition) { + ignore_unused(condition); +#ifdef FMT_FUZZ + if (condition) throw std::runtime_error("fuzzing limit reached"); +#endif +} + +template struct string_literal { + static constexpr CharT value[sizeof...(C)] = {C...}; + constexpr operator basic_string_view() const { + return {value, sizeof...(C)}; + } +}; + +#if FMT_CPLUSPLUS < 201703L +template +constexpr CharT string_literal::value[sizeof...(C)]; +#endif + +template class formatbuf : public Streambuf { + private: + using char_type = typename Streambuf::char_type; + using streamsize = decltype(std::declval().sputn(nullptr, 0)); + using int_type = typename Streambuf::int_type; + using traits_type = typename Streambuf::traits_type; + + buffer& buffer_; + + public: + explicit formatbuf(buffer& buf) : buffer_(buf) {} + + protected: + // The put area is always empty. This makes the implementation simpler and has + // the advantage that the streambuf and the buffer are always in sync and + // sputc never writes into uninitialized memory. A disadvantage is that each + // call to sputc always results in a (virtual) call to overflow. There is no + // disadvantage here for sputn since this always results in a call to xsputn. + + auto overflow(int_type ch) -> int_type override { + if (!traits_type::eq_int_type(ch, traits_type::eof())) + buffer_.push_back(static_cast(ch)); + return ch; + } + + auto xsputn(const char_type* s, streamsize count) -> streamsize override { + buffer_.append(s, s + count); + return count; + } +}; + +// Implementation of std::bit_cast for pre-C++20. +template +FMT_CONSTEXPR20 auto bit_cast(const From& from) -> To { +#ifdef __cpp_lib_bit_cast + if (is_constant_evaluated()) return std::bit_cast(from); +#endif + auto to = To(); + // The cast suppresses a bogus -Wclass-memaccess on GCC. + std::memcpy(static_cast(&to), &from, sizeof(to)); + return to; +} + +inline auto is_big_endian() -> bool { +#ifdef _WIN32 + return false; +#elif defined(__BIG_ENDIAN__) + return true; +#elif defined(__BYTE_ORDER__) && defined(__ORDER_BIG_ENDIAN__) + return __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__; +#else + struct bytes { + char data[sizeof(int)]; + }; + return bit_cast(1).data[0] == 0; +#endif +} + +class uint128_fallback { + private: + uint64_t lo_, hi_; + + public: + constexpr uint128_fallback(uint64_t hi, uint64_t lo) : lo_(lo), hi_(hi) {} + constexpr uint128_fallback(uint64_t value = 0) : lo_(value), hi_(0) {} + + constexpr uint64_t high() const noexcept { return hi_; } + constexpr uint64_t low() const noexcept { return lo_; } + + template ::value)> + constexpr explicit operator T() const { + return static_cast(lo_); + } + + friend constexpr auto operator==(const uint128_fallback& lhs, + const uint128_fallback& rhs) -> bool { + return lhs.hi_ == rhs.hi_ && lhs.lo_ == rhs.lo_; + } + friend constexpr auto operator!=(const uint128_fallback& lhs, + const uint128_fallback& rhs) -> bool { + return !(lhs == rhs); + } + friend constexpr auto operator>(const uint128_fallback& lhs, + const uint128_fallback& rhs) -> bool { + return lhs.hi_ != rhs.hi_ ? lhs.hi_ > rhs.hi_ : lhs.lo_ > rhs.lo_; + } + friend constexpr auto operator|(const uint128_fallback& lhs, + const uint128_fallback& rhs) + -> uint128_fallback { + return {lhs.hi_ | rhs.hi_, lhs.lo_ | rhs.lo_}; + } + friend constexpr auto operator&(const uint128_fallback& lhs, + const uint128_fallback& rhs) + -> uint128_fallback { + return {lhs.hi_ & rhs.hi_, lhs.lo_ & rhs.lo_}; + } + friend constexpr auto operator~(const uint128_fallback& n) + -> uint128_fallback { + return {~n.hi_, ~n.lo_}; + } + friend auto operator+(const uint128_fallback& lhs, + const uint128_fallback& rhs) -> uint128_fallback { + auto result = uint128_fallback(lhs); + result += rhs; + return result; + } + friend auto operator*(const uint128_fallback& lhs, uint32_t rhs) + -> uint128_fallback { + FMT_ASSERT(lhs.hi_ == 0, ""); + uint64_t hi = (lhs.lo_ >> 32) * rhs; + uint64_t lo = (lhs.lo_ & ~uint32_t()) * rhs; + uint64_t new_lo = (hi << 32) + lo; + return {(hi >> 32) + (new_lo < lo ? 1 : 0), new_lo}; + } + friend auto operator-(const uint128_fallback& lhs, uint64_t rhs) + -> uint128_fallback { + return {lhs.hi_ - (lhs.lo_ < rhs ? 1 : 0), lhs.lo_ - rhs}; + } + FMT_CONSTEXPR auto operator>>(int shift) const -> uint128_fallback { + if (shift == 64) return {0, hi_}; + if (shift > 64) return uint128_fallback(0, hi_) >> (shift - 64); + return {hi_ >> shift, (hi_ << (64 - shift)) | (lo_ >> shift)}; + } + FMT_CONSTEXPR auto operator<<(int shift) const -> uint128_fallback { + if (shift == 64) return {lo_, 0}; + if (shift > 64) return uint128_fallback(lo_, 0) << (shift - 64); + return {hi_ << shift | (lo_ >> (64 - shift)), (lo_ << shift)}; + } + FMT_CONSTEXPR auto operator>>=(int shift) -> uint128_fallback& { + return *this = *this >> shift; + } + FMT_CONSTEXPR void operator+=(uint128_fallback n) { + uint64_t new_lo = lo_ + n.lo_; + uint64_t new_hi = hi_ + n.hi_ + (new_lo < lo_ ? 1 : 0); + FMT_ASSERT(new_hi >= hi_, ""); + lo_ = new_lo; + hi_ = new_hi; + } + FMT_CONSTEXPR void operator&=(uint128_fallback n) { + lo_ &= n.lo_; + hi_ &= n.hi_; + } + + FMT_CONSTEXPR20 uint128_fallback& operator+=(uint64_t n) noexcept { + if (is_constant_evaluated()) { + lo_ += n; + hi_ += (lo_ < n ? 1 : 0); + return *this; + } +#if FMT_HAS_BUILTIN(__builtin_addcll) && !defined(__ibmxl__) + unsigned long long carry; + lo_ = __builtin_addcll(lo_, n, 0, &carry); + hi_ += carry; +#elif FMT_HAS_BUILTIN(__builtin_ia32_addcarryx_u64) && !defined(__ibmxl__) + unsigned long long result; + auto carry = __builtin_ia32_addcarryx_u64(0, lo_, n, &result); + lo_ = result; + hi_ += carry; +#elif defined(_MSC_VER) && defined(_M_X64) + auto carry = _addcarry_u64(0, lo_, n, &lo_); + _addcarry_u64(carry, hi_, 0, &hi_); +#else + lo_ += n; + hi_ += (lo_ < n ? 1 : 0); +#endif + return *this; + } +}; + +using uint128_t = conditional_t; + +#ifdef UINTPTR_MAX +using uintptr_t = ::uintptr_t; +#else +using uintptr_t = uint128_t; +#endif + +// Returns the largest possible value for type T. Same as +// std::numeric_limits::max() but shorter and not affected by the max macro. +template constexpr auto max_value() -> T { + return (std::numeric_limits::max)(); +} +template constexpr auto num_bits() -> int { + return std::numeric_limits::digits; +} +// std::numeric_limits::digits may return 0 for 128-bit ints. +template <> constexpr auto num_bits() -> int { return 128; } +template <> constexpr auto num_bits() -> int { return 128; } + +// A heterogeneous bit_cast used for converting 96-bit long double to uint128_t +// and 128-bit pointers to uint128_fallback. +template sizeof(From))> +inline auto bit_cast(const From& from) -> To { + constexpr auto size = static_cast(sizeof(From) / sizeof(unsigned)); + struct data_t { + unsigned value[static_cast(size)]; + } data = bit_cast(from); + auto result = To(); + if (const_check(is_big_endian())) { + for (int i = 0; i < size; ++i) + result = (result << num_bits()) | data.value[i]; + } else { + for (int i = size - 1; i >= 0; --i) + result = (result << num_bits()) | data.value[i]; + } + return result; +} + +template +FMT_CONSTEXPR20 inline auto countl_zero_fallback(UInt n) -> int { + int lz = 0; + constexpr UInt msb_mask = static_cast(1) << (num_bits() - 1); + for (; (n & msb_mask) == 0; n <<= 1) lz++; + return lz; +} + +FMT_CONSTEXPR20 inline auto countl_zero(uint32_t n) -> int { +#ifdef FMT_BUILTIN_CLZ + if (!is_constant_evaluated()) return FMT_BUILTIN_CLZ(n); +#endif + return countl_zero_fallback(n); +} + +FMT_CONSTEXPR20 inline auto countl_zero(uint64_t n) -> int { +#ifdef FMT_BUILTIN_CLZLL + if (!is_constant_evaluated()) return FMT_BUILTIN_CLZLL(n); +#endif + return countl_zero_fallback(n); +} + +FMT_INLINE void assume(bool condition) { + (void)condition; +#if FMT_HAS_BUILTIN(__builtin_assume) && !FMT_ICC_VERSION + __builtin_assume(condition); +#elif FMT_GCC_VERSION + if (!condition) __builtin_unreachable(); +#endif +} + +// An approximation of iterator_t for pre-C++20 systems. +template +using iterator_t = decltype(std::begin(std::declval())); +template using sentinel_t = decltype(std::end(std::declval())); + +// A workaround for std::string not having mutable data() until C++17. +template +inline auto get_data(std::basic_string& s) -> Char* { + return &s[0]; +} +template +inline auto get_data(Container& c) -> typename Container::value_type* { + return c.data(); +} + +// Attempts to reserve space for n extra characters in the output range. +// Returns a pointer to the reserved range or a reference to it. +template ::value)> +#if FMT_CLANG_VERSION >= 307 && !FMT_ICC_VERSION +__attribute__((no_sanitize("undefined"))) +#endif +inline auto +reserve(std::back_insert_iterator it, size_t n) -> + typename Container::value_type* { + Container& c = get_container(it); + size_t size = c.size(); + c.resize(size + n); + return get_data(c) + size; +} + +template +inline auto reserve(buffer_appender it, size_t n) -> buffer_appender { + buffer& buf = get_container(it); + buf.try_reserve(buf.size() + n); + return it; +} + +template +constexpr auto reserve(Iterator& it, size_t) -> Iterator& { + return it; +} + +template +using reserve_iterator = + remove_reference_t(), 0))>; + +template +constexpr auto to_pointer(OutputIt, size_t) -> T* { + return nullptr; +} +template auto to_pointer(buffer_appender it, size_t n) -> T* { + buffer& buf = get_container(it); + auto size = buf.size(); + if (buf.capacity() < size + n) return nullptr; + buf.try_resize(size + n); + return buf.data() + size; +} + +template ::value)> +inline auto base_iterator(std::back_insert_iterator it, + typename Container::value_type*) + -> std::back_insert_iterator { + return it; +} + +template +constexpr auto base_iterator(Iterator, Iterator it) -> Iterator { + return it; +} + +// is spectacularly slow to compile in C++20 so use a simple fill_n +// instead (#1998). +template +FMT_CONSTEXPR auto fill_n(OutputIt out, Size count, const T& value) + -> OutputIt { + for (Size i = 0; i < count; ++i) *out++ = value; + return out; +} +template +FMT_CONSTEXPR20 auto fill_n(T* out, Size count, char value) -> T* { + if (is_constant_evaluated()) { + return fill_n(out, count, value); + } + std::memset(out, value, to_unsigned(count)); + return out + count; +} + +#ifdef __cpp_char8_t +using char8_type = char8_t; +#else +enum char8_type : unsigned char {}; +#endif + +template +FMT_CONSTEXPR FMT_NOINLINE auto copy_str_noinline(InputIt begin, InputIt end, + OutputIt out) -> OutputIt { + return copy_str(begin, end, out); +} + +// A public domain branchless UTF-8 decoder by Christopher Wellons: +// https://github.com/skeeto/branchless-utf8 +/* Decode the next character, c, from s, reporting errors in e. + * + * Since this is a branchless decoder, four bytes will be read from the + * buffer regardless of the actual length of the next character. This + * means the buffer _must_ have at least three bytes of zero padding + * following the end of the data stream. + * + * Errors are reported in e, which will be non-zero if the parsed + * character was somehow invalid: invalid byte sequence, non-canonical + * encoding, or a surrogate half. + * + * The function returns a pointer to the next character. When an error + * occurs, this pointer will be a guess that depends on the particular + * error, but it will always advance at least one byte. + */ +FMT_CONSTEXPR inline auto utf8_decode(const char* s, uint32_t* c, int* e) + -> const char* { + constexpr const int masks[] = {0x00, 0x7f, 0x1f, 0x0f, 0x07}; + constexpr const uint32_t mins[] = {4194304, 0, 128, 2048, 65536}; + constexpr const int shiftc[] = {0, 18, 12, 6, 0}; + constexpr const int shifte[] = {0, 6, 4, 2, 0}; + + int len = "\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\0\0\0\0\0\0\0\0\2\2\2\2\3\3\4" + [static_cast(*s) >> 3]; + // Compute the pointer to the next character early so that the next + // iteration can start working on the next character. Neither Clang + // nor GCC figure out this reordering on their own. + const char* next = s + len + !len; + + using uchar = unsigned char; + + // Assume a four-byte character and load four bytes. Unused bits are + // shifted out. + *c = uint32_t(uchar(s[0]) & masks[len]) << 18; + *c |= uint32_t(uchar(s[1]) & 0x3f) << 12; + *c |= uint32_t(uchar(s[2]) & 0x3f) << 6; + *c |= uint32_t(uchar(s[3]) & 0x3f) << 0; + *c >>= shiftc[len]; + + // Accumulate the various error conditions. + *e = (*c < mins[len]) << 6; // non-canonical encoding + *e |= ((*c >> 11) == 0x1b) << 7; // surrogate half? + *e |= (*c > 0x10FFFF) << 8; // out of range? + *e |= (uchar(s[1]) & 0xc0) >> 2; + *e |= (uchar(s[2]) & 0xc0) >> 4; + *e |= uchar(s[3]) >> 6; + *e ^= 0x2a; // top two bits of each tail byte correct? + *e >>= shifte[len]; + + return next; +} + +constexpr FMT_INLINE_VARIABLE uint32_t invalid_code_point = ~uint32_t(); + +// Invokes f(cp, sv) for every code point cp in s with sv being the string view +// corresponding to the code point. cp is invalid_code_point on error. +template +FMT_CONSTEXPR void for_each_codepoint(string_view s, F f) { + auto decode = [f](const char* buf_ptr, const char* ptr) { + auto cp = uint32_t(); + auto error = 0; + auto end = utf8_decode(buf_ptr, &cp, &error); + bool result = f(error ? invalid_code_point : cp, + string_view(ptr, error ? 1 : to_unsigned(end - buf_ptr))); + return result ? (error ? buf_ptr + 1 : end) : nullptr; + }; + auto p = s.data(); + const size_t block_size = 4; // utf8_decode always reads blocks of 4 chars. + if (s.size() >= block_size) { + for (auto end = p + s.size() - block_size + 1; p < end;) { + p = decode(p, p); + if (!p) return; + } + } + if (auto num_chars_left = s.data() + s.size() - p) { + char buf[2 * block_size - 1] = {}; + copy_str(p, p + num_chars_left, buf); + const char* buf_ptr = buf; + do { + auto end = decode(buf_ptr, p); + if (!end) return; + p += end - buf_ptr; + buf_ptr = end; + } while (buf_ptr - buf < num_chars_left); + } +} + +template +inline auto compute_width(basic_string_view s) -> size_t { + return s.size(); +} + +// Computes approximate display width of a UTF-8 string. +FMT_CONSTEXPR inline size_t compute_width(string_view s) { + size_t num_code_points = 0; + // It is not a lambda for compatibility with C++14. + struct count_code_points { + size_t* count; + FMT_CONSTEXPR auto operator()(uint32_t cp, string_view) const -> bool { + *count += detail::to_unsigned( + 1 + + (cp >= 0x1100 && + (cp <= 0x115f || // Hangul Jamo init. consonants + cp == 0x2329 || // LEFT-POINTING ANGLE BRACKET + cp == 0x232a || // RIGHT-POINTING ANGLE BRACKET + // CJK ... Yi except IDEOGRAPHIC HALF FILL SPACE: + (cp >= 0x2e80 && cp <= 0xa4cf && cp != 0x303f) || + (cp >= 0xac00 && cp <= 0xd7a3) || // Hangul Syllables + (cp >= 0xf900 && cp <= 0xfaff) || // CJK Compatibility Ideographs + (cp >= 0xfe10 && cp <= 0xfe19) || // Vertical Forms + (cp >= 0xfe30 && cp <= 0xfe6f) || // CJK Compatibility Forms + (cp >= 0xff00 && cp <= 0xff60) || // Fullwidth Forms + (cp >= 0xffe0 && cp <= 0xffe6) || // Fullwidth Forms + (cp >= 0x20000 && cp <= 0x2fffd) || // CJK + (cp >= 0x30000 && cp <= 0x3fffd) || + // Miscellaneous Symbols and Pictographs + Emoticons: + (cp >= 0x1f300 && cp <= 0x1f64f) || + // Supplemental Symbols and Pictographs: + (cp >= 0x1f900 && cp <= 0x1f9ff)))); + return true; + } + }; + // We could avoid branches by using utf8_decode directly. + for_each_codepoint(s, count_code_points{&num_code_points}); + return num_code_points; +} + +inline auto compute_width(basic_string_view s) -> size_t { + return compute_width( + string_view(reinterpret_cast(s.data()), s.size())); +} + +template +inline auto code_point_index(basic_string_view s, size_t n) -> size_t { + size_t size = s.size(); + return n < size ? n : size; +} + +// Calculates the index of the nth code point in a UTF-8 string. +inline auto code_point_index(string_view s, size_t n) -> size_t { + const char* data = s.data(); + size_t num_code_points = 0; + for (size_t i = 0, size = s.size(); i != size; ++i) { + if ((data[i] & 0xc0) != 0x80 && ++num_code_points > n) return i; + } + return s.size(); +} + +inline auto code_point_index(basic_string_view s, size_t n) + -> size_t { + return code_point_index( + string_view(reinterpret_cast(s.data()), s.size()), n); +} + +template struct is_integral : std::is_integral {}; +template <> struct is_integral : std::true_type {}; +template <> struct is_integral : std::true_type {}; + +template +using is_signed = + std::integral_constant::is_signed || + std::is_same::value>; + +template +using is_integer = + bool_constant::value && !std::is_same::value && + !std::is_same::value && + !std::is_same::value>; + +#ifndef FMT_USE_FLOAT +# define FMT_USE_FLOAT 1 +#endif +#ifndef FMT_USE_DOUBLE +# define FMT_USE_DOUBLE 1 +#endif +#ifndef FMT_USE_LONG_DOUBLE +# define FMT_USE_LONG_DOUBLE 1 +#endif + +#ifndef FMT_USE_FLOAT128 +# ifdef __clang__ +// Clang emulates GCC, so it has to appear early. +# if FMT_HAS_INCLUDE() +# define FMT_USE_FLOAT128 1 +# endif +# elif defined(__GNUC__) +// GNU C++: +# if defined(_GLIBCXX_USE_FLOAT128) && !defined(__STRICT_ANSI__) +# define FMT_USE_FLOAT128 1 +# endif +# endif +# ifndef FMT_USE_FLOAT128 +# define FMT_USE_FLOAT128 0 +# endif +#endif + +#if FMT_USE_FLOAT128 +using float128 = __float128; +#else +using float128 = void; +#endif +template using is_float128 = std::is_same; + +template +using is_floating_point = + bool_constant::value || is_float128::value>; + +template ::value> +struct is_fast_float : bool_constant::is_iec559 && + sizeof(T) <= sizeof(double)> {}; +template struct is_fast_float : std::false_type {}; + +template +using is_double_double = bool_constant::digits == 106>; + +#ifndef FMT_USE_FULL_CACHE_DRAGONBOX +# define FMT_USE_FULL_CACHE_DRAGONBOX 0 +#endif + +template +template +void buffer::append(const U* begin, const U* end) { + while (begin != end) { + auto count = to_unsigned(end - begin); + try_reserve(size_ + count); + auto free_cap = capacity_ - size_; + if (free_cap < count) count = free_cap; + std::uninitialized_copy_n(begin, count, ptr_ + size_); + size_ += count; + begin += count; + } +} + +template +struct is_locale : std::false_type {}; +template +struct is_locale> : std::true_type {}; +} // namespace detail + +FMT_BEGIN_EXPORT + +// The number of characters to store in the basic_memory_buffer object itself +// to avoid dynamic memory allocation. +enum { inline_buffer_size = 500 }; + +/** + \rst + A dynamically growing memory buffer for trivially copyable/constructible types + with the first ``SIZE`` elements stored in the object itself. + + You can use the ``memory_buffer`` type alias for ``char`` instead. + + **Example**:: + + auto out = fmt::memory_buffer(); + format_to(std::back_inserter(out), "The answer is {}.", 42); + + This will append the following output to the ``out`` object: + + .. code-block:: none + + The answer is 42. + + The output can be converted to an ``std::string`` with ``to_string(out)``. + \endrst + */ +template > +class basic_memory_buffer final : public detail::buffer { + private: + T store_[SIZE]; + + // Don't inherit from Allocator to avoid generating type_info for it. + FMT_NO_UNIQUE_ADDRESS Allocator alloc_; + + // Deallocate memory allocated by the buffer. + FMT_CONSTEXPR20 void deallocate() { + T* data = this->data(); + if (data != store_) alloc_.deallocate(data, this->capacity()); + } + + protected: + FMT_CONSTEXPR20 void grow(size_t size) override { + detail::abort_fuzzing_if(size > 5000); + const size_t max_size = std::allocator_traits::max_size(alloc_); + size_t old_capacity = this->capacity(); + size_t new_capacity = old_capacity + old_capacity / 2; + if (size > new_capacity) + new_capacity = size; + else if (new_capacity > max_size) + new_capacity = size > max_size ? size : max_size; + T* old_data = this->data(); + T* new_data = + std::allocator_traits::allocate(alloc_, new_capacity); + // Suppress a bogus -Wstringop-overflow in gcc 13.1 (#3481). + detail::assume(this->size() <= new_capacity); + // The following code doesn't throw, so the raw pointer above doesn't leak. + std::uninitialized_copy_n(old_data, this->size(), new_data); + this->set(new_data, new_capacity); + // deallocate must not throw according to the standard, but even if it does, + // the buffer already uses the new storage and will deallocate it in + // destructor. + if (old_data != store_) alloc_.deallocate(old_data, old_capacity); + } + + public: + using value_type = T; + using const_reference = const T&; + + FMT_CONSTEXPR20 explicit basic_memory_buffer( + const Allocator& alloc = Allocator()) + : alloc_(alloc) { + this->set(store_, SIZE); + if (detail::is_constant_evaluated()) detail::fill_n(store_, SIZE, T()); + } + FMT_CONSTEXPR20 ~basic_memory_buffer() { deallocate(); } + + private: + // Move data from other to this buffer. + FMT_CONSTEXPR20 void move(basic_memory_buffer& other) { + alloc_ = std::move(other.alloc_); + T* data = other.data(); + size_t size = other.size(), capacity = other.capacity(); + if (data == other.store_) { + this->set(store_, capacity); + detail::copy_str(other.store_, other.store_ + size, store_); + } else { + this->set(data, capacity); + // Set pointer to the inline array so that delete is not called + // when deallocating. + other.set(other.store_, 0); + other.clear(); + } + this->resize(size); + } + + public: + /** + \rst + Constructs a :class:`fmt::basic_memory_buffer` object moving the content + of the other object to it. + \endrst + */ + FMT_CONSTEXPR20 basic_memory_buffer(basic_memory_buffer&& other) noexcept { + move(other); + } + + /** + \rst + Moves the content of the other ``basic_memory_buffer`` object to this one. + \endrst + */ + auto operator=(basic_memory_buffer&& other) noexcept -> basic_memory_buffer& { + FMT_ASSERT(this != &other, ""); + deallocate(); + move(other); + return *this; + } + + // Returns a copy of the allocator associated with this buffer. + auto get_allocator() const -> Allocator { return alloc_; } + + /** + Resizes the buffer to contain *count* elements. If T is a POD type new + elements may not be initialized. + */ + FMT_CONSTEXPR20 void resize(size_t count) { this->try_resize(count); } + + /** Increases the buffer capacity to *new_capacity*. */ + void reserve(size_t new_capacity) { this->try_reserve(new_capacity); } + + // Directly append data into the buffer + using detail::buffer::append; + template + void append(const ContiguousRange& range) { + append(range.data(), range.data() + range.size()); + } +}; + +using memory_buffer = basic_memory_buffer; + +template +struct is_contiguous> : std::true_type { +}; + +FMT_END_EXPORT +namespace detail { +FMT_API bool write_console(std::FILE* f, string_view text); +FMT_API void print(std::FILE*, string_view); +} // namespace detail + +FMT_BEGIN_EXPORT + +// Suppress a misleading warning in older versions of clang. +#if FMT_CLANG_VERSION +# pragma clang diagnostic ignored "-Wweak-vtables" +#endif + +/** An error reported from a formatting function. */ +class FMT_VISIBILITY("default") format_error : public std::runtime_error { + public: + using std::runtime_error::runtime_error; +}; + +namespace detail_exported { +#if FMT_USE_NONTYPE_TEMPLATE_ARGS +template struct fixed_string { + constexpr fixed_string(const Char (&str)[N]) { + detail::copy_str(static_cast(str), + str + N, data); + } + Char data[N] = {}; +}; +#endif + +// Converts a compile-time string to basic_string_view. +template +constexpr auto compile_string_to_view(const Char (&s)[N]) + -> basic_string_view { + // Remove trailing NUL character if needed. Won't be present if this is used + // with a raw character array (i.e. not defined as a string). + return {s, N - (std::char_traits::to_int_type(s[N - 1]) == 0 ? 1 : 0)}; +} +template +constexpr auto compile_string_to_view(detail::std_string_view s) + -> basic_string_view { + return {s.data(), s.size()}; +} +} // namespace detail_exported + +class loc_value { + private: + basic_format_arg value_; + + public: + template ::value)> + loc_value(T value) : value_(detail::make_arg(value)) {} + + template ::value)> + loc_value(T) {} + + template auto visit(Visitor&& vis) -> decltype(vis(0)) { + return visit_format_arg(vis, value_); + } +}; + +// A locale facet that formats values in UTF-8. +// It is parameterized on the locale to avoid the heavy include. +template class format_facet : public Locale::facet { + private: + std::string separator_; + std::string grouping_; + std::string decimal_point_; + + protected: + virtual auto do_put(appender out, loc_value val, + const format_specs<>& specs) const -> bool; + + public: + static FMT_API typename Locale::id id; + + explicit format_facet(Locale& loc); + explicit format_facet(string_view sep = "", + std::initializer_list g = {3}, + std::string decimal_point = ".") + : separator_(sep.data(), sep.size()), + grouping_(g.begin(), g.end()), + decimal_point_(decimal_point) {} + + auto put(appender out, loc_value val, const format_specs<>& specs) const + -> bool { + return do_put(out, val, specs); + } +}; + +namespace detail { + +// Returns true if value is negative, false otherwise. +// Same as `value < 0` but doesn't produce warnings if T is an unsigned type. +template ::value)> +constexpr auto is_negative(T value) -> bool { + return value < 0; +} +template ::value)> +constexpr auto is_negative(T) -> bool { + return false; +} + +template +FMT_CONSTEXPR auto is_supported_floating_point(T) -> bool { + if (std::is_same()) return FMT_USE_FLOAT; + if (std::is_same()) return FMT_USE_DOUBLE; + if (std::is_same()) return FMT_USE_LONG_DOUBLE; + return true; +} + +// Smallest of uint32_t, uint64_t, uint128_t that is large enough to +// represent all values of an integral type T. +template +using uint32_or_64_or_128_t = + conditional_t() <= 32 && !FMT_REDUCE_INT_INSTANTIATIONS, + uint32_t, + conditional_t() <= 64, uint64_t, uint128_t>>; +template +using uint64_or_128_t = conditional_t() <= 64, uint64_t, uint128_t>; + +#define FMT_POWERS_OF_10(factor) \ + factor * 10, (factor)*100, (factor)*1000, (factor)*10000, (factor)*100000, \ + (factor)*1000000, (factor)*10000000, (factor)*100000000, \ + (factor)*1000000000 + +// Converts value in the range [0, 100) to a string. +constexpr const char* digits2(size_t value) { + // GCC generates slightly better code when value is pointer-size. + return &"0001020304050607080910111213141516171819" + "2021222324252627282930313233343536373839" + "4041424344454647484950515253545556575859" + "6061626364656667686970717273747576777879" + "8081828384858687888990919293949596979899"[value * 2]; +} + +// Sign is a template parameter to workaround a bug in gcc 4.8. +template constexpr Char sign(Sign s) { +#if !FMT_GCC_VERSION || FMT_GCC_VERSION >= 604 + static_assert(std::is_same::value, ""); +#endif + return static_cast("\0-+ "[s]); +} + +template FMT_CONSTEXPR auto count_digits_fallback(T n) -> int { + int count = 1; + for (;;) { + // Integer division is slow so do it for a group of four digits instead + // of for every digit. The idea comes from the talk by Alexandrescu + // "Three Optimization Tips for C++". See speed-test for a comparison. + if (n < 10) return count; + if (n < 100) return count + 1; + if (n < 1000) return count + 2; + if (n < 10000) return count + 3; + n /= 10000u; + count += 4; + } +} +#if FMT_USE_INT128 +FMT_CONSTEXPR inline auto count_digits(uint128_opt n) -> int { + return count_digits_fallback(n); +} +#endif + +#ifdef FMT_BUILTIN_CLZLL +// It is a separate function rather than a part of count_digits to workaround +// the lack of static constexpr in constexpr functions. +inline auto do_count_digits(uint64_t n) -> int { + // This has comparable performance to the version by Kendall Willets + // (https://github.com/fmtlib/format-benchmark/blob/master/digits10) + // but uses smaller tables. + // Maps bsr(n) to ceil(log10(pow(2, bsr(n) + 1) - 1)). + static constexpr uint8_t bsr2log10[] = { + 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, + 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, + 10, 11, 11, 11, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 15, 15, + 15, 16, 16, 16, 16, 17, 17, 17, 18, 18, 18, 19, 19, 19, 19, 20}; + auto t = bsr2log10[FMT_BUILTIN_CLZLL(n | 1) ^ 63]; + static constexpr const uint64_t zero_or_powers_of_10[] = { + 0, 0, FMT_POWERS_OF_10(1U), FMT_POWERS_OF_10(1000000000ULL), + 10000000000000000000ULL}; + return t - (n < zero_or_powers_of_10[t]); +} +#endif + +// Returns the number of decimal digits in n. Leading zeros are not counted +// except for n == 0 in which case count_digits returns 1. +FMT_CONSTEXPR20 inline auto count_digits(uint64_t n) -> int { +#ifdef FMT_BUILTIN_CLZLL + if (!is_constant_evaluated()) { + return do_count_digits(n); + } +#endif + return count_digits_fallback(n); +} + +// Counts the number of digits in n. BITS = log2(radix). +template +FMT_CONSTEXPR auto count_digits(UInt n) -> int { +#ifdef FMT_BUILTIN_CLZ + if (!is_constant_evaluated() && num_bits() == 32) + return (FMT_BUILTIN_CLZ(static_cast(n) | 1) ^ 31) / BITS + 1; +#endif + // Lambda avoids unreachable code warnings from NVHPC. + return [](UInt m) { + int num_digits = 0; + do { + ++num_digits; + } while ((m >>= BITS) != 0); + return num_digits; + }(n); +} + +#ifdef FMT_BUILTIN_CLZ +// It is a separate function rather than a part of count_digits to workaround +// the lack of static constexpr in constexpr functions. +FMT_INLINE auto do_count_digits(uint32_t n) -> int { +// An optimization by Kendall Willets from https://bit.ly/3uOIQrB. +// This increments the upper 32 bits (log10(T) - 1) when >= T is added. +# define FMT_INC(T) (((sizeof(#T) - 1ull) << 32) - T) + static constexpr uint64_t table[] = { + FMT_INC(0), FMT_INC(0), FMT_INC(0), // 8 + FMT_INC(10), FMT_INC(10), FMT_INC(10), // 64 + FMT_INC(100), FMT_INC(100), FMT_INC(100), // 512 + FMT_INC(1000), FMT_INC(1000), FMT_INC(1000), // 4096 + FMT_INC(10000), FMT_INC(10000), FMT_INC(10000), // 32k + FMT_INC(100000), FMT_INC(100000), FMT_INC(100000), // 256k + FMT_INC(1000000), FMT_INC(1000000), FMT_INC(1000000), // 2048k + FMT_INC(10000000), FMT_INC(10000000), FMT_INC(10000000), // 16M + FMT_INC(100000000), FMT_INC(100000000), FMT_INC(100000000), // 128M + FMT_INC(1000000000), FMT_INC(1000000000), FMT_INC(1000000000), // 1024M + FMT_INC(1000000000), FMT_INC(1000000000) // 4B + }; + auto inc = table[FMT_BUILTIN_CLZ(n | 1) ^ 31]; + return static_cast((n + inc) >> 32); +} +#endif + +// Optional version of count_digits for better performance on 32-bit platforms. +FMT_CONSTEXPR20 inline auto count_digits(uint32_t n) -> int { +#ifdef FMT_BUILTIN_CLZ + if (!is_constant_evaluated()) { + return do_count_digits(n); + } +#endif + return count_digits_fallback(n); +} + +template constexpr auto digits10() noexcept -> int { + return std::numeric_limits::digits10; +} +template <> constexpr auto digits10() noexcept -> int { return 38; } +template <> constexpr auto digits10() noexcept -> int { return 38; } + +template struct thousands_sep_result { + std::string grouping; + Char thousands_sep; +}; + +template +FMT_API auto thousands_sep_impl(locale_ref loc) -> thousands_sep_result; +template +inline auto thousands_sep(locale_ref loc) -> thousands_sep_result { + auto result = thousands_sep_impl(loc); + return {result.grouping, Char(result.thousands_sep)}; +} +template <> +inline auto thousands_sep(locale_ref loc) -> thousands_sep_result { + return thousands_sep_impl(loc); +} + +template +FMT_API auto decimal_point_impl(locale_ref loc) -> Char; +template inline auto decimal_point(locale_ref loc) -> Char { + return Char(decimal_point_impl(loc)); +} +template <> inline auto decimal_point(locale_ref loc) -> wchar_t { + return decimal_point_impl(loc); +} + +// Compares two characters for equality. +template auto equal2(const Char* lhs, const char* rhs) -> bool { + return lhs[0] == Char(rhs[0]) && lhs[1] == Char(rhs[1]); +} +inline auto equal2(const char* lhs, const char* rhs) -> bool { + return memcmp(lhs, rhs, 2) == 0; +} + +// Copies two characters from src to dst. +template +FMT_CONSTEXPR20 FMT_INLINE void copy2(Char* dst, const char* src) { + if (!is_constant_evaluated() && sizeof(Char) == sizeof(char)) { + memcpy(dst, src, 2); + return; + } + *dst++ = static_cast(*src++); + *dst = static_cast(*src); +} + +template struct format_decimal_result { + Iterator begin; + Iterator end; +}; + +// Formats a decimal unsigned integer value writing into out pointing to a +// buffer of specified size. The caller must ensure that the buffer is large +// enough. +template +FMT_CONSTEXPR20 auto format_decimal(Char* out, UInt value, int size) + -> format_decimal_result { + FMT_ASSERT(size >= count_digits(value), "invalid digit count"); + out += size; + Char* end = out; + while (value >= 100) { + // Integer division is slow so do it for a group of two digits instead + // of for every digit. The idea comes from the talk by Alexandrescu + // "Three Optimization Tips for C++". See speed-test for a comparison. + out -= 2; + copy2(out, digits2(static_cast(value % 100))); + value /= 100; + } + if (value < 10) { + *--out = static_cast('0' + value); + return {out, end}; + } + out -= 2; + copy2(out, digits2(static_cast(value))); + return {out, end}; +} + +template >::value)> +FMT_CONSTEXPR inline auto format_decimal(Iterator out, UInt value, int size) + -> format_decimal_result { + // Buffer is large enough to hold all digits (digits10 + 1). + Char buffer[digits10() + 1] = {}; + auto end = format_decimal(buffer, value, size).end; + return {out, detail::copy_str_noinline(buffer, end, out)}; +} + +template +FMT_CONSTEXPR auto format_uint(Char* buffer, UInt value, int num_digits, + bool upper = false) -> Char* { + buffer += num_digits; + Char* end = buffer; + do { + const char* digits = upper ? "0123456789ABCDEF" : "0123456789abcdef"; + unsigned digit = static_cast(value & ((1 << BASE_BITS) - 1)); + *--buffer = static_cast(BASE_BITS < 4 ? static_cast('0' + digit) + : digits[digit]); + } while ((value >>= BASE_BITS) != 0); + return end; +} + +template +FMT_CONSTEXPR inline auto format_uint(It out, UInt value, int num_digits, + bool upper = false) -> It { + if (auto ptr = to_pointer(out, to_unsigned(num_digits))) { + format_uint(ptr, value, num_digits, upper); + return out; + } + // Buffer should be large enough to hold all digits (digits / BASE_BITS + 1). + char buffer[num_bits() / BASE_BITS + 1]; + format_uint(buffer, value, num_digits, upper); + return detail::copy_str_noinline(buffer, buffer + num_digits, out); +} + +// A converter from UTF-8 to UTF-16. +class utf8_to_utf16 { + private: + basic_memory_buffer buffer_; + + public: + FMT_API explicit utf8_to_utf16(string_view s); + operator basic_string_view() const { return {&buffer_[0], size()}; } + auto size() const -> size_t { return buffer_.size() - 1; } + auto c_str() const -> const wchar_t* { return &buffer_[0]; } + auto str() const -> std::wstring { return {&buffer_[0], size()}; } +}; + +enum class to_utf8_error_policy { abort, replace }; + +// A converter from UTF-16/UTF-32 (host endian) to UTF-8. +template class to_utf8 { + private: + Buffer buffer_; + + public: + to_utf8() {} + explicit to_utf8(basic_string_view s, + to_utf8_error_policy policy = to_utf8_error_policy::abort) { + static_assert(sizeof(WChar) == 2 || sizeof(WChar) == 4, + "Expect utf16 or utf32"); + if (!convert(s, policy)) + FMT_THROW(std::runtime_error(sizeof(WChar) == 2 ? "invalid utf16" + : "invalid utf32")); + } + operator string_view() const { return string_view(&buffer_[0], size()); } + size_t size() const { return buffer_.size() - 1; } + const char* c_str() const { return &buffer_[0]; } + std::string str() const { return std::string(&buffer_[0], size()); } + + // Performs conversion returning a bool instead of throwing exception on + // conversion error. This method may still throw in case of memory allocation + // error. + bool convert(basic_string_view s, + to_utf8_error_policy policy = to_utf8_error_policy::abort) { + if (!convert(buffer_, s, policy)) return false; + buffer_.push_back(0); + return true; + } + static bool convert( + Buffer& buf, basic_string_view s, + to_utf8_error_policy policy = to_utf8_error_policy::abort) { + for (auto p = s.begin(); p != s.end(); ++p) { + uint32_t c = static_cast(*p); + if (sizeof(WChar) == 2 && c >= 0xd800 && c <= 0xdfff) { + // Handle a surrogate pair. + ++p; + if (p == s.end() || (c & 0xfc00) != 0xd800 || (*p & 0xfc00) != 0xdc00) { + if (policy == to_utf8_error_policy::abort) return false; + buf.append(string_view("\xEF\xBF\xBD")); + --p; + } else { + c = (c << 10) + static_cast(*p) - 0x35fdc00; + } + } else if (c < 0x80) { + buf.push_back(static_cast(c)); + } else if (c < 0x800) { + buf.push_back(static_cast(0xc0 | (c >> 6))); + buf.push_back(static_cast(0x80 | (c & 0x3f))); + } else if ((c >= 0x800 && c <= 0xd7ff) || (c >= 0xe000 && c <= 0xffff)) { + buf.push_back(static_cast(0xe0 | (c >> 12))); + buf.push_back(static_cast(0x80 | ((c & 0xfff) >> 6))); + buf.push_back(static_cast(0x80 | (c & 0x3f))); + } else if (c >= 0x10000 && c <= 0x10ffff) { + buf.push_back(static_cast(0xf0 | (c >> 18))); + buf.push_back(static_cast(0x80 | ((c & 0x3ffff) >> 12))); + buf.push_back(static_cast(0x80 | ((c & 0xfff) >> 6))); + buf.push_back(static_cast(0x80 | (c & 0x3f))); + } else { + return false; + } + } + return true; + } +}; + +// Computes 128-bit result of multiplication of two 64-bit unsigned integers. +inline uint128_fallback umul128(uint64_t x, uint64_t y) noexcept { +#if FMT_USE_INT128 + auto p = static_cast(x) * static_cast(y); + return {static_cast(p >> 64), static_cast(p)}; +#elif defined(_MSC_VER) && defined(_M_X64) + auto hi = uint64_t(); + auto lo = _umul128(x, y, &hi); + return {hi, lo}; +#else + const uint64_t mask = static_cast(max_value()); + + uint64_t a = x >> 32; + uint64_t b = x & mask; + uint64_t c = y >> 32; + uint64_t d = y & mask; + + uint64_t ac = a * c; + uint64_t bc = b * c; + uint64_t ad = a * d; + uint64_t bd = b * d; + + uint64_t intermediate = (bd >> 32) + (ad & mask) + (bc & mask); + + return {ac + (intermediate >> 32) + (ad >> 32) + (bc >> 32), + (intermediate << 32) + (bd & mask)}; +#endif +} + +namespace dragonbox { +// Computes floor(log10(pow(2, e))) for e in [-2620, 2620] using the method from +// https://fmt.dev/papers/Dragonbox.pdf#page=28, section 6.1. +inline int floor_log10_pow2(int e) noexcept { + FMT_ASSERT(e <= 2620 && e >= -2620, "too large exponent"); + static_assert((-1 >> 1) == -1, "right shift is not arithmetic"); + return (e * 315653) >> 20; +} + +inline int floor_log2_pow10(int e) noexcept { + FMT_ASSERT(e <= 1233 && e >= -1233, "too large exponent"); + return (e * 1741647) >> 19; +} + +// Computes upper 64 bits of multiplication of two 64-bit unsigned integers. +inline uint64_t umul128_upper64(uint64_t x, uint64_t y) noexcept { +#if FMT_USE_INT128 + auto p = static_cast(x) * static_cast(y); + return static_cast(p >> 64); +#elif defined(_MSC_VER) && defined(_M_X64) + return __umulh(x, y); +#else + return umul128(x, y).high(); +#endif +} + +// Computes upper 128 bits of multiplication of a 64-bit unsigned integer and a +// 128-bit unsigned integer. +inline uint128_fallback umul192_upper128(uint64_t x, + uint128_fallback y) noexcept { + uint128_fallback r = umul128(x, y.high()); + r += umul128_upper64(x, y.low()); + return r; +} + +FMT_API uint128_fallback get_cached_power(int k) noexcept; + +// Type-specific information that Dragonbox uses. +template struct float_info; + +template <> struct float_info { + using carrier_uint = uint32_t; + static const int exponent_bits = 8; + static const int kappa = 1; + static const int big_divisor = 100; + static const int small_divisor = 10; + static const int min_k = -31; + static const int max_k = 46; + static const int shorter_interval_tie_lower_threshold = -35; + static const int shorter_interval_tie_upper_threshold = -35; +}; + +template <> struct float_info { + using carrier_uint = uint64_t; + static const int exponent_bits = 11; + static const int kappa = 2; + static const int big_divisor = 1000; + static const int small_divisor = 100; + static const int min_k = -292; + static const int max_k = 341; + static const int shorter_interval_tie_lower_threshold = -77; + static const int shorter_interval_tie_upper_threshold = -77; +}; + +// An 80- or 128-bit floating point number. +template +struct float_info::digits == 64 || + std::numeric_limits::digits == 113 || + is_float128::value>> { + using carrier_uint = detail::uint128_t; + static const int exponent_bits = 15; +}; + +// A double-double floating point number. +template +struct float_info::value>> { + using carrier_uint = detail::uint128_t; +}; + +template struct decimal_fp { + using significand_type = typename float_info::carrier_uint; + significand_type significand; + int exponent; +}; + +template FMT_API auto to_decimal(T x) noexcept -> decimal_fp; +} // namespace dragonbox + +// Returns true iff Float has the implicit bit which is not stored. +template constexpr bool has_implicit_bit() { + // An 80-bit FP number has a 64-bit significand an no implicit bit. + return std::numeric_limits::digits != 64; +} + +// Returns the number of significand bits stored in Float. The implicit bit is +// not counted since it is not stored. +template constexpr int num_significand_bits() { + // std::numeric_limits may not support __float128. + return is_float128() ? 112 + : (std::numeric_limits::digits - + (has_implicit_bit() ? 1 : 0)); +} + +template +constexpr auto exponent_mask() -> + typename dragonbox::float_info::carrier_uint { + using float_uint = typename dragonbox::float_info::carrier_uint; + return ((float_uint(1) << dragonbox::float_info::exponent_bits) - 1) + << num_significand_bits(); +} +template constexpr auto exponent_bias() -> int { + // std::numeric_limits may not support __float128. + return is_float128() ? 16383 + : std::numeric_limits::max_exponent - 1; +} + +// Writes the exponent exp in the form "[+-]d{2,3}" to buffer. +template +FMT_CONSTEXPR auto write_exponent(int exp, It it) -> It { + FMT_ASSERT(-10000 < exp && exp < 10000, "exponent out of range"); + if (exp < 0) { + *it++ = static_cast('-'); + exp = -exp; + } else { + *it++ = static_cast('+'); + } + if (exp >= 100) { + const char* top = digits2(to_unsigned(exp / 100)); + if (exp >= 1000) *it++ = static_cast(top[0]); + *it++ = static_cast(top[1]); + exp %= 100; + } + const char* d = digits2(to_unsigned(exp)); + *it++ = static_cast(d[0]); + *it++ = static_cast(d[1]); + return it; +} + +// A floating-point number f * pow(2, e) where F is an unsigned type. +template struct basic_fp { + F f; + int e; + + static constexpr const int num_significand_bits = + static_cast(sizeof(F) * num_bits()); + + constexpr basic_fp() : f(0), e(0) {} + constexpr basic_fp(uint64_t f_val, int e_val) : f(f_val), e(e_val) {} + + // Constructs fp from an IEEE754 floating-point number. + template FMT_CONSTEXPR basic_fp(Float n) { assign(n); } + + // Assigns n to this and return true iff predecessor is closer than successor. + template ::value)> + FMT_CONSTEXPR auto assign(Float n) -> bool { + static_assert(std::numeric_limits::digits <= 113, "unsupported FP"); + // Assume Float is in the format [sign][exponent][significand]. + using carrier_uint = typename dragonbox::float_info::carrier_uint; + const auto num_float_significand_bits = + detail::num_significand_bits(); + const auto implicit_bit = carrier_uint(1) << num_float_significand_bits; + const auto significand_mask = implicit_bit - 1; + auto u = bit_cast(n); + f = static_cast(u & significand_mask); + auto biased_e = static_cast((u & exponent_mask()) >> + num_float_significand_bits); + // The predecessor is closer if n is a normalized power of 2 (f == 0) + // other than the smallest normalized number (biased_e > 1). + auto is_predecessor_closer = f == 0 && biased_e > 1; + if (biased_e == 0) + biased_e = 1; // Subnormals use biased exponent 1 (min exponent). + else if (has_implicit_bit()) + f += static_cast(implicit_bit); + e = biased_e - exponent_bias() - num_float_significand_bits; + if (!has_implicit_bit()) ++e; + return is_predecessor_closer; + } + + template ::value)> + FMT_CONSTEXPR auto assign(Float n) -> bool { + static_assert(std::numeric_limits::is_iec559, "unsupported FP"); + return assign(static_cast(n)); + } +}; + +using fp = basic_fp; + +// Normalizes the value converted from double and multiplied by (1 << SHIFT). +template +FMT_CONSTEXPR basic_fp normalize(basic_fp value) { + // Handle subnormals. + const auto implicit_bit = F(1) << num_significand_bits(); + const auto shifted_implicit_bit = implicit_bit << SHIFT; + while ((value.f & shifted_implicit_bit) == 0) { + value.f <<= 1; + --value.e; + } + // Subtract 1 to account for hidden bit. + const auto offset = basic_fp::num_significand_bits - + num_significand_bits() - SHIFT - 1; + value.f <<= offset; + value.e -= offset; + return value; +} + +// Computes lhs * rhs / pow(2, 64) rounded to nearest with half-up tie breaking. +FMT_CONSTEXPR inline uint64_t multiply(uint64_t lhs, uint64_t rhs) { +#if FMT_USE_INT128 + auto product = static_cast<__uint128_t>(lhs) * rhs; + auto f = static_cast(product >> 64); + return (static_cast(product) & (1ULL << 63)) != 0 ? f + 1 : f; +#else + // Multiply 32-bit parts of significands. + uint64_t mask = (1ULL << 32) - 1; + uint64_t a = lhs >> 32, b = lhs & mask; + uint64_t c = rhs >> 32, d = rhs & mask; + uint64_t ac = a * c, bc = b * c, ad = a * d, bd = b * d; + // Compute mid 64-bit of result and round. + uint64_t mid = (bd >> 32) + (ad & mask) + (bc & mask) + (1U << 31); + return ac + (ad >> 32) + (bc >> 32) + (mid >> 32); +#endif +} + +FMT_CONSTEXPR inline fp operator*(fp x, fp y) { + return {multiply(x.f, y.f), x.e + y.e + 64}; +} + +template struct basic_data { + // For checking rounding thresholds. + // The kth entry is chosen to be the smallest integer such that the + // upper 32-bits of 10^(k+1) times it is strictly bigger than 5 * 10^k. + static constexpr uint32_t fractional_part_rounding_thresholds[8] = { + 2576980378U, // ceil(2^31 + 2^32/10^1) + 2190433321U, // ceil(2^31 + 2^32/10^2) + 2151778616U, // ceil(2^31 + 2^32/10^3) + 2147913145U, // ceil(2^31 + 2^32/10^4) + 2147526598U, // ceil(2^31 + 2^32/10^5) + 2147487943U, // ceil(2^31 + 2^32/10^6) + 2147484078U, // ceil(2^31 + 2^32/10^7) + 2147483691U // ceil(2^31 + 2^32/10^8) + }; +}; +// This is a struct rather than an alias to avoid shadowing warnings in gcc. +struct data : basic_data<> {}; + +#if FMT_CPLUSPLUS < 201703L +template +constexpr uint32_t basic_data::fractional_part_rounding_thresholds[]; +#endif + +template () == num_bits()> +using convert_float_result = + conditional_t::value || doublish, double, T>; + +template +constexpr auto convert_float(T value) -> convert_float_result { + return static_cast>(value); +} + +template +FMT_NOINLINE FMT_CONSTEXPR auto fill(OutputIt it, size_t n, + const fill_t& fill) -> OutputIt { + auto fill_size = fill.size(); + if (fill_size == 1) return detail::fill_n(it, n, fill[0]); + auto data = fill.data(); + for (size_t i = 0; i < n; ++i) + it = copy_str(data, data + fill_size, it); + return it; +} + +// Writes the output of f, padded according to format specifications in specs. +// size: output size in code units. +// width: output display width in (terminal) column positions. +template +FMT_CONSTEXPR auto write_padded(OutputIt out, const format_specs& specs, + size_t size, size_t width, F&& f) -> OutputIt { + static_assert(align == align::left || align == align::right, ""); + unsigned spec_width = to_unsigned(specs.width); + size_t padding = spec_width > width ? spec_width - width : 0; + // Shifts are encoded as string literals because static constexpr is not + // supported in constexpr functions. + auto* shifts = align == align::left ? "\x1f\x1f\x00\x01" : "\x00\x1f\x00\x01"; + size_t left_padding = padding >> shifts[specs.align]; + size_t right_padding = padding - left_padding; + auto it = reserve(out, size + padding * specs.fill.size()); + if (left_padding != 0) it = fill(it, left_padding, specs.fill); + it = f(it); + if (right_padding != 0) it = fill(it, right_padding, specs.fill); + return base_iterator(out, it); +} + +template +constexpr auto write_padded(OutputIt out, const format_specs& specs, + size_t size, F&& f) -> OutputIt { + return write_padded(out, specs, size, size, f); +} + +template +FMT_CONSTEXPR auto write_bytes(OutputIt out, string_view bytes, + const format_specs& specs) -> OutputIt { + return write_padded( + out, specs, bytes.size(), [bytes](reserve_iterator it) { + const char* data = bytes.data(); + return copy_str(data, data + bytes.size(), it); + }); +} + +template +auto write_ptr(OutputIt out, UIntPtr value, const format_specs* specs) + -> OutputIt { + int num_digits = count_digits<4>(value); + auto size = to_unsigned(num_digits) + size_t(2); + auto write = [=](reserve_iterator it) { + *it++ = static_cast('0'); + *it++ = static_cast('x'); + return format_uint<4, Char>(it, value, num_digits); + }; + return specs ? write_padded(out, *specs, size, write) + : base_iterator(out, write(reserve(out, size))); +} + +// Returns true iff the code point cp is printable. +FMT_API auto is_printable(uint32_t cp) -> bool; + +inline auto needs_escape(uint32_t cp) -> bool { + return cp < 0x20 || cp == 0x7f || cp == '"' || cp == '\\' || + !is_printable(cp); +} + +template struct find_escape_result { + const Char* begin; + const Char* end; + uint32_t cp; +}; + +template +using make_unsigned_char = + typename conditional_t::value, + std::make_unsigned, + type_identity>::type; + +template +auto find_escape(const Char* begin, const Char* end) + -> find_escape_result { + for (; begin != end; ++begin) { + uint32_t cp = static_cast>(*begin); + if (const_check(sizeof(Char) == 1) && cp >= 0x80) continue; + if (needs_escape(cp)) return {begin, begin + 1, cp}; + } + return {begin, nullptr, 0}; +} + +inline auto find_escape(const char* begin, const char* end) + -> find_escape_result { + if (!is_utf8()) return find_escape(begin, end); + auto result = find_escape_result{end, nullptr, 0}; + for_each_codepoint(string_view(begin, to_unsigned(end - begin)), + [&](uint32_t cp, string_view sv) { + if (needs_escape(cp)) { + result = {sv.begin(), sv.end(), cp}; + return false; + } + return true; + }); + return result; +} + +#define FMT_STRING_IMPL(s, base, explicit) \ + [] { \ + /* Use the hidden visibility as a workaround for a GCC bug (#1973). */ \ + /* Use a macro-like name to avoid shadowing warnings. */ \ + struct FMT_VISIBILITY("hidden") FMT_COMPILE_STRING : base { \ + using char_type FMT_MAYBE_UNUSED = fmt::remove_cvref_t; \ + FMT_MAYBE_UNUSED FMT_CONSTEXPR explicit \ + operator fmt::basic_string_view() const { \ + return fmt::detail_exported::compile_string_to_view(s); \ + } \ + }; \ + return FMT_COMPILE_STRING(); \ + }() + +/** + \rst + Constructs a compile-time format string from a string literal *s*. + + **Example**:: + + // A compile-time error because 'd' is an invalid specifier for strings. + std::string s = fmt::format(FMT_STRING("{:d}"), "foo"); + \endrst + */ +#define FMT_STRING(s) FMT_STRING_IMPL(s, fmt::detail::compile_string, ) + +template +auto write_codepoint(OutputIt out, char prefix, uint32_t cp) -> OutputIt { + *out++ = static_cast('\\'); + *out++ = static_cast(prefix); + Char buf[width]; + fill_n(buf, width, static_cast('0')); + format_uint<4>(buf, cp, width); + return copy_str(buf, buf + width, out); +} + +template +auto write_escaped_cp(OutputIt out, const find_escape_result& escape) + -> OutputIt { + auto c = static_cast(escape.cp); + switch (escape.cp) { + case '\n': + *out++ = static_cast('\\'); + c = static_cast('n'); + break; + case '\r': + *out++ = static_cast('\\'); + c = static_cast('r'); + break; + case '\t': + *out++ = static_cast('\\'); + c = static_cast('t'); + break; + case '"': + FMT_FALLTHROUGH; + case '\'': + FMT_FALLTHROUGH; + case '\\': + *out++ = static_cast('\\'); + break; + default: + if (escape.cp < 0x100) { + return write_codepoint<2, Char>(out, 'x', escape.cp); + } + if (escape.cp < 0x10000) { + return write_codepoint<4, Char>(out, 'u', escape.cp); + } + if (escape.cp < 0x110000) { + return write_codepoint<8, Char>(out, 'U', escape.cp); + } + for (Char escape_char : basic_string_view( + escape.begin, to_unsigned(escape.end - escape.begin))) { + out = write_codepoint<2, Char>(out, 'x', + static_cast(escape_char) & 0xFF); + } + return out; + } + *out++ = c; + return out; +} + +template +auto write_escaped_string(OutputIt out, basic_string_view str) + -> OutputIt { + *out++ = static_cast('"'); + auto begin = str.begin(), end = str.end(); + do { + auto escape = find_escape(begin, end); + out = copy_str(begin, escape.begin, out); + begin = escape.end; + if (!begin) break; + out = write_escaped_cp(out, escape); + } while (begin != end); + *out++ = static_cast('"'); + return out; +} + +template +auto write_escaped_char(OutputIt out, Char v) -> OutputIt { + *out++ = static_cast('\''); + if ((needs_escape(static_cast(v)) && v != static_cast('"')) || + v == static_cast('\'')) { + out = write_escaped_cp( + out, find_escape_result{&v, &v + 1, static_cast(v)}); + } else { + *out++ = v; + } + *out++ = static_cast('\''); + return out; +} + +template +FMT_CONSTEXPR auto write_char(OutputIt out, Char value, + const format_specs& specs) -> OutputIt { + bool is_debug = specs.type == presentation_type::debug; + return write_padded(out, specs, 1, [=](reserve_iterator it) { + if (is_debug) return write_escaped_char(it, value); + *it++ = value; + return it; + }); +} +template +FMT_CONSTEXPR auto write(OutputIt out, Char value, + const format_specs& specs, locale_ref loc = {}) + -> OutputIt { + // char is formatted as unsigned char for consistency across platforms. + using unsigned_type = + conditional_t::value, unsigned char, unsigned>; + return check_char_specs(specs) + ? write_char(out, value, specs) + : write(out, static_cast(value), specs, loc); +} + +// Data for write_int that doesn't depend on output iterator type. It is used to +// avoid template code bloat. +template struct write_int_data { + size_t size; + size_t padding; + + FMT_CONSTEXPR write_int_data(int num_digits, unsigned prefix, + const format_specs& specs) + : size((prefix >> 24) + to_unsigned(num_digits)), padding(0) { + if (specs.align == align::numeric) { + auto width = to_unsigned(specs.width); + if (width > size) { + padding = width - size; + size = width; + } + } else if (specs.precision > num_digits) { + size = (prefix >> 24) + to_unsigned(specs.precision); + padding = to_unsigned(specs.precision - num_digits); + } + } +}; + +// Writes an integer in the format +// +// where are written by write_digits(it). +// prefix contains chars in three lower bytes and the size in the fourth byte. +template +FMT_CONSTEXPR FMT_INLINE auto write_int(OutputIt out, int num_digits, + unsigned prefix, + const format_specs& specs, + W write_digits) -> OutputIt { + // Slightly faster check for specs.width == 0 && specs.precision == -1. + if ((specs.width | (specs.precision + 1)) == 0) { + auto it = reserve(out, to_unsigned(num_digits) + (prefix >> 24)); + if (prefix != 0) { + for (unsigned p = prefix & 0xffffff; p != 0; p >>= 8) + *it++ = static_cast(p & 0xff); + } + return base_iterator(out, write_digits(it)); + } + auto data = write_int_data(num_digits, prefix, specs); + return write_padded( + out, specs, data.size, [=](reserve_iterator it) { + for (unsigned p = prefix & 0xffffff; p != 0; p >>= 8) + *it++ = static_cast(p & 0xff); + it = detail::fill_n(it, data.padding, static_cast('0')); + return write_digits(it); + }); +} + +template class digit_grouping { + private: + std::string grouping_; + std::basic_string thousands_sep_; + + struct next_state { + std::string::const_iterator group; + int pos; + }; + next_state initial_state() const { return {grouping_.begin(), 0}; } + + // Returns the next digit group separator position. + int next(next_state& state) const { + if (thousands_sep_.empty()) return max_value(); + if (state.group == grouping_.end()) return state.pos += grouping_.back(); + if (*state.group <= 0 || *state.group == max_value()) + return max_value(); + state.pos += *state.group++; + return state.pos; + } + + public: + explicit digit_grouping(locale_ref loc, bool localized = true) { + if (!localized) return; + auto sep = thousands_sep(loc); + grouping_ = sep.grouping; + if (sep.thousands_sep) thousands_sep_.assign(1, sep.thousands_sep); + } + digit_grouping(std::string grouping, std::basic_string sep) + : grouping_(std::move(grouping)), thousands_sep_(std::move(sep)) {} + + bool has_separator() const { return !thousands_sep_.empty(); } + + int count_separators(int num_digits) const { + int count = 0; + auto state = initial_state(); + while (num_digits > next(state)) ++count; + return count; + } + + // Applies grouping to digits and write the output to out. + template + Out apply(Out out, basic_string_view digits) const { + auto num_digits = static_cast(digits.size()); + auto separators = basic_memory_buffer(); + separators.push_back(0); + auto state = initial_state(); + while (int i = next(state)) { + if (i >= num_digits) break; + separators.push_back(i); + } + for (int i = 0, sep_index = static_cast(separators.size() - 1); + i < num_digits; ++i) { + if (num_digits - i == separators[sep_index]) { + out = + copy_str(thousands_sep_.data(), + thousands_sep_.data() + thousands_sep_.size(), out); + --sep_index; + } + *out++ = static_cast(digits[to_unsigned(i)]); + } + return out; + } +}; + +// Writes a decimal integer with digit grouping. +template +auto write_int(OutputIt out, UInt value, unsigned prefix, + const format_specs& specs, + const digit_grouping& grouping) -> OutputIt { + static_assert(std::is_same, UInt>::value, ""); + int num_digits = count_digits(value); + char digits[40]; + format_decimal(digits, value, num_digits); + unsigned size = to_unsigned((prefix != 0 ? 1 : 0) + num_digits + + grouping.count_separators(num_digits)); + return write_padded( + out, specs, size, size, [&](reserve_iterator it) { + if (prefix != 0) { + char sign = static_cast(prefix); + *it++ = static_cast(sign); + } + return grouping.apply(it, string_view(digits, to_unsigned(num_digits))); + }); +} + +// Writes a localized value. +FMT_API auto write_loc(appender out, loc_value value, + const format_specs<>& specs, locale_ref loc) -> bool; +template +inline auto write_loc(OutputIt, loc_value, const format_specs&, + locale_ref) -> bool { + return false; +} + +FMT_CONSTEXPR inline void prefix_append(unsigned& prefix, unsigned value) { + prefix |= prefix != 0 ? value << 8 : value; + prefix += (1u + (value > 0xff ? 1 : 0)) << 24; +} + +template struct write_int_arg { + UInt abs_value; + unsigned prefix; +}; + +template +FMT_CONSTEXPR auto make_write_int_arg(T value, sign_t sign) + -> write_int_arg> { + auto prefix = 0u; + auto abs_value = static_cast>(value); + if (is_negative(value)) { + prefix = 0x01000000 | '-'; + abs_value = 0 - abs_value; + } else { + constexpr const unsigned prefixes[4] = {0, 0, 0x1000000u | '+', + 0x1000000u | ' '}; + prefix = prefixes[sign]; + } + return {abs_value, prefix}; +} + +template struct loc_writer { + buffer_appender out; + const format_specs& specs; + std::basic_string sep; + std::string grouping; + std::basic_string decimal_point; + + template ::value)> + auto operator()(T value) -> bool { + auto arg = make_write_int_arg(value, specs.sign); + write_int(out, static_cast>(arg.abs_value), arg.prefix, + specs, digit_grouping(grouping, sep)); + return true; + } + + template ::value)> + auto operator()(T) -> bool { + return false; + } +}; + +template +FMT_CONSTEXPR FMT_INLINE auto write_int(OutputIt out, write_int_arg arg, + const format_specs& specs, + locale_ref) -> OutputIt { + static_assert(std::is_same>::value, ""); + auto abs_value = arg.abs_value; + auto prefix = arg.prefix; + switch (specs.type) { + case presentation_type::none: + case presentation_type::dec: { + auto num_digits = count_digits(abs_value); + return write_int( + out, num_digits, prefix, specs, [=](reserve_iterator it) { + return format_decimal(it, abs_value, num_digits).end; + }); + } + case presentation_type::hex_lower: + case presentation_type::hex_upper: { + bool upper = specs.type == presentation_type::hex_upper; + if (specs.alt) + prefix_append(prefix, unsigned(upper ? 'X' : 'x') << 8 | '0'); + int num_digits = count_digits<4>(abs_value); + return write_int( + out, num_digits, prefix, specs, [=](reserve_iterator it) { + return format_uint<4, Char>(it, abs_value, num_digits, upper); + }); + } + case presentation_type::bin_lower: + case presentation_type::bin_upper: { + bool upper = specs.type == presentation_type::bin_upper; + if (specs.alt) + prefix_append(prefix, unsigned(upper ? 'B' : 'b') << 8 | '0'); + int num_digits = count_digits<1>(abs_value); + return write_int(out, num_digits, prefix, specs, + [=](reserve_iterator it) { + return format_uint<1, Char>(it, abs_value, num_digits); + }); + } + case presentation_type::oct: { + int num_digits = count_digits<3>(abs_value); + // Octal prefix '0' is counted as a digit, so only add it if precision + // is not greater than the number of digits. + if (specs.alt && specs.precision <= num_digits && abs_value != 0) + prefix_append(prefix, '0'); + return write_int(out, num_digits, prefix, specs, + [=](reserve_iterator it) { + return format_uint<3, Char>(it, abs_value, num_digits); + }); + } + case presentation_type::chr: + return write_char(out, static_cast(abs_value), specs); + default: + throw_format_error("invalid format specifier"); + } + return out; +} +template +FMT_CONSTEXPR FMT_NOINLINE auto write_int_noinline( + OutputIt out, write_int_arg arg, const format_specs& specs, + locale_ref loc) -> OutputIt { + return write_int(out, arg, specs, loc); +} +template ::value && + !std::is_same::value && + std::is_same>::value)> +FMT_CONSTEXPR FMT_INLINE auto write(OutputIt out, T value, + const format_specs& specs, + locale_ref loc) -> OutputIt { + if (specs.localized && write_loc(out, value, specs, loc)) return out; + return write_int_noinline(out, make_write_int_arg(value, specs.sign), specs, + loc); +} +// An inlined version of write used in format string compilation. +template ::value && + !std::is_same::value && + !std::is_same>::value)> +FMT_CONSTEXPR FMT_INLINE auto write(OutputIt out, T value, + const format_specs& specs, + locale_ref loc) -> OutputIt { + if (specs.localized && write_loc(out, value, specs, loc)) return out; + return write_int(out, make_write_int_arg(value, specs.sign), specs, loc); +} + +// An output iterator that counts the number of objects written to it and +// discards them. +class counting_iterator { + private: + size_t count_; + + public: + using iterator_category = std::output_iterator_tag; + using difference_type = std::ptrdiff_t; + using pointer = void; + using reference = void; + FMT_UNCHECKED_ITERATOR(counting_iterator); + + struct value_type { + template FMT_CONSTEXPR void operator=(const T&) {} + }; + + FMT_CONSTEXPR counting_iterator() : count_(0) {} + + FMT_CONSTEXPR size_t count() const { return count_; } + + FMT_CONSTEXPR counting_iterator& operator++() { + ++count_; + return *this; + } + FMT_CONSTEXPR counting_iterator operator++(int) { + auto it = *this; + ++*this; + return it; + } + + FMT_CONSTEXPR friend counting_iterator operator+(counting_iterator it, + difference_type n) { + it.count_ += static_cast(n); + return it; + } + + FMT_CONSTEXPR value_type operator*() const { return {}; } +}; + +template +FMT_CONSTEXPR auto write(OutputIt out, basic_string_view s, + const format_specs& specs) -> OutputIt { + auto data = s.data(); + auto size = s.size(); + if (specs.precision >= 0 && to_unsigned(specs.precision) < size) + size = code_point_index(s, to_unsigned(specs.precision)); + bool is_debug = specs.type == presentation_type::debug; + size_t width = 0; + if (specs.width != 0) { + if (is_debug) + width = write_escaped_string(counting_iterator{}, s).count(); + else + width = compute_width(basic_string_view(data, size)); + } + return write_padded(out, specs, size, width, + [=](reserve_iterator it) { + if (is_debug) return write_escaped_string(it, s); + return copy_str(data, data + size, it); + }); +} +template +FMT_CONSTEXPR auto write(OutputIt out, + basic_string_view> s, + const format_specs& specs, locale_ref) + -> OutputIt { + return write(out, s, specs); +} +template +FMT_CONSTEXPR auto write(OutputIt out, const Char* s, + const format_specs& specs, locale_ref) + -> OutputIt { + return specs.type != presentation_type::pointer + ? write(out, basic_string_view(s), specs, {}) + : write_ptr(out, bit_cast(s), &specs); +} + +template ::value && + !std::is_same::value && + !std::is_same::value)> +FMT_CONSTEXPR auto write(OutputIt out, T value) -> OutputIt { + auto abs_value = static_cast>(value); + bool negative = is_negative(value); + // Don't do -abs_value since it trips unsigned-integer-overflow sanitizer. + if (negative) abs_value = ~abs_value + 1; + int num_digits = count_digits(abs_value); + auto size = (negative ? 1 : 0) + static_cast(num_digits); + auto it = reserve(out, size); + if (auto ptr = to_pointer(it, size)) { + if (negative) *ptr++ = static_cast('-'); + format_decimal(ptr, abs_value, num_digits); + return out; + } + if (negative) *it++ = static_cast('-'); + it = format_decimal(it, abs_value, num_digits).end; + return base_iterator(out, it); +} + +// DEPRECATED! +template +FMT_CONSTEXPR auto parse_align(const Char* begin, const Char* end, + format_specs& specs) -> const Char* { + FMT_ASSERT(begin != end, ""); + auto align = align::none; + auto p = begin + code_point_length(begin); + if (end - p <= 0) p = begin; + for (;;) { + switch (to_ascii(*p)) { + case '<': + align = align::left; + break; + case '>': + align = align::right; + break; + case '^': + align = align::center; + break; + } + if (align != align::none) { + if (p != begin) { + auto c = *begin; + if (c == '}') return begin; + if (c == '{') { + throw_format_error("invalid fill character '{'"); + return begin; + } + specs.fill = {begin, to_unsigned(p - begin)}; + begin = p + 1; + } else { + ++begin; + } + break; + } else if (p == begin) { + break; + } + p = begin; + } + specs.align = align; + return begin; +} + +// A floating-point presentation format. +enum class float_format : unsigned char { + general, // General: exponent notation or fixed point based on magnitude. + exp, // Exponent notation with the default precision of 6, e.g. 1.2e-3. + fixed, // Fixed point with the default precision of 6, e.g. 0.0012. + hex +}; + +struct float_specs { + int precision; + float_format format : 8; + sign_t sign : 8; + bool upper : 1; + bool locale : 1; + bool binary32 : 1; + bool showpoint : 1; +}; + +template +FMT_CONSTEXPR auto parse_float_type_spec(const format_specs& specs, + ErrorHandler&& eh = {}) + -> float_specs { + auto result = float_specs(); + result.showpoint = specs.alt; + result.locale = specs.localized; + switch (specs.type) { + case presentation_type::none: + result.format = float_format::general; + break; + case presentation_type::general_upper: + result.upper = true; + FMT_FALLTHROUGH; + case presentation_type::general_lower: + result.format = float_format::general; + break; + case presentation_type::exp_upper: + result.upper = true; + FMT_FALLTHROUGH; + case presentation_type::exp_lower: + result.format = float_format::exp; + result.showpoint |= specs.precision != 0; + break; + case presentation_type::fixed_upper: + result.upper = true; + FMT_FALLTHROUGH; + case presentation_type::fixed_lower: + result.format = float_format::fixed; + result.showpoint |= specs.precision != 0; + break; + case presentation_type::hexfloat_upper: + result.upper = true; + FMT_FALLTHROUGH; + case presentation_type::hexfloat_lower: + result.format = float_format::hex; + break; + default: + eh.on_error("invalid format specifier"); + break; + } + return result; +} + +template +FMT_CONSTEXPR20 auto write_nonfinite(OutputIt out, bool isnan, + format_specs specs, + const float_specs& fspecs) -> OutputIt { + auto str = + isnan ? (fspecs.upper ? "NAN" : "nan") : (fspecs.upper ? "INF" : "inf"); + constexpr size_t str_size = 3; + auto sign = fspecs.sign; + auto size = str_size + (sign ? 1 : 0); + // Replace '0'-padding with space for non-finite values. + const bool is_zero_fill = + specs.fill.size() == 1 && *specs.fill.data() == static_cast('0'); + if (is_zero_fill) specs.fill[0] = static_cast(' '); + return write_padded(out, specs, size, [=](reserve_iterator it) { + if (sign) *it++ = detail::sign(sign); + return copy_str(str, str + str_size, it); + }); +} + +// A decimal floating-point number significand * pow(10, exp). +struct big_decimal_fp { + const char* significand; + int significand_size; + int exponent; +}; + +constexpr auto get_significand_size(const big_decimal_fp& f) -> int { + return f.significand_size; +} +template +inline auto get_significand_size(const dragonbox::decimal_fp& f) -> int { + return count_digits(f.significand); +} + +template +constexpr auto write_significand(OutputIt out, const char* significand, + int significand_size) -> OutputIt { + return copy_str(significand, significand + significand_size, out); +} +template +inline auto write_significand(OutputIt out, UInt significand, + int significand_size) -> OutputIt { + return format_decimal(out, significand, significand_size).end; +} +template +FMT_CONSTEXPR20 auto write_significand(OutputIt out, T significand, + int significand_size, int exponent, + const Grouping& grouping) -> OutputIt { + if (!grouping.has_separator()) { + out = write_significand(out, significand, significand_size); + return detail::fill_n(out, exponent, static_cast('0')); + } + auto buffer = memory_buffer(); + write_significand(appender(buffer), significand, significand_size); + detail::fill_n(appender(buffer), exponent, '0'); + return grouping.apply(out, string_view(buffer.data(), buffer.size())); +} + +template ::value)> +inline auto write_significand(Char* out, UInt significand, int significand_size, + int integral_size, Char decimal_point) -> Char* { + if (!decimal_point) + return format_decimal(out, significand, significand_size).end; + out += significand_size + 1; + Char* end = out; + int floating_size = significand_size - integral_size; + for (int i = floating_size / 2; i > 0; --i) { + out -= 2; + copy2(out, digits2(static_cast(significand % 100))); + significand /= 100; + } + if (floating_size % 2 != 0) { + *--out = static_cast('0' + significand % 10); + significand /= 10; + } + *--out = decimal_point; + format_decimal(out - integral_size, significand, integral_size); + return end; +} + +template >::value)> +inline auto write_significand(OutputIt out, UInt significand, + int significand_size, int integral_size, + Char decimal_point) -> OutputIt { + // Buffer is large enough to hold digits (digits10 + 1) and a decimal point. + Char buffer[digits10() + 2]; + auto end = write_significand(buffer, significand, significand_size, + integral_size, decimal_point); + return detail::copy_str_noinline(buffer, end, out); +} + +template +FMT_CONSTEXPR auto write_significand(OutputIt out, const char* significand, + int significand_size, int integral_size, + Char decimal_point) -> OutputIt { + out = detail::copy_str_noinline(significand, + significand + integral_size, out); + if (!decimal_point) return out; + *out++ = decimal_point; + return detail::copy_str_noinline(significand + integral_size, + significand + significand_size, out); +} + +template +FMT_CONSTEXPR20 auto write_significand(OutputIt out, T significand, + int significand_size, int integral_size, + Char decimal_point, + const Grouping& grouping) -> OutputIt { + if (!grouping.has_separator()) { + return write_significand(out, significand, significand_size, integral_size, + decimal_point); + } + auto buffer = basic_memory_buffer(); + write_significand(buffer_appender(buffer), significand, + significand_size, integral_size, decimal_point); + grouping.apply( + out, basic_string_view(buffer.data(), to_unsigned(integral_size))); + return detail::copy_str_noinline(buffer.data() + integral_size, + buffer.end(), out); +} + +template > +FMT_CONSTEXPR20 auto do_write_float(OutputIt out, const DecimalFP& f, + const format_specs& specs, + float_specs fspecs, locale_ref loc) + -> OutputIt { + auto significand = f.significand; + int significand_size = get_significand_size(f); + const Char zero = static_cast('0'); + auto sign = fspecs.sign; + size_t size = to_unsigned(significand_size) + (sign ? 1 : 0); + using iterator = reserve_iterator; + + Char decimal_point = + fspecs.locale ? detail::decimal_point(loc) : static_cast('.'); + + int output_exp = f.exponent + significand_size - 1; + auto use_exp_format = [=]() { + if (fspecs.format == float_format::exp) return true; + if (fspecs.format != float_format::general) return false; + // Use the fixed notation if the exponent is in [exp_lower, exp_upper), + // e.g. 0.0001 instead of 1e-04. Otherwise use the exponent notation. + const int exp_lower = -4, exp_upper = 16; + return output_exp < exp_lower || + output_exp >= (fspecs.precision > 0 ? fspecs.precision : exp_upper); + }; + if (use_exp_format()) { + int num_zeros = 0; + if (fspecs.showpoint) { + num_zeros = fspecs.precision - significand_size; + if (num_zeros < 0) num_zeros = 0; + size += to_unsigned(num_zeros); + } else if (significand_size == 1) { + decimal_point = Char(); + } + auto abs_output_exp = output_exp >= 0 ? output_exp : -output_exp; + int exp_digits = 2; + if (abs_output_exp >= 100) exp_digits = abs_output_exp >= 1000 ? 4 : 3; + + size += to_unsigned((decimal_point ? 1 : 0) + 2 + exp_digits); + char exp_char = fspecs.upper ? 'E' : 'e'; + auto write = [=](iterator it) { + if (sign) *it++ = detail::sign(sign); + // Insert a decimal point after the first digit and add an exponent. + it = write_significand(it, significand, significand_size, 1, + decimal_point); + if (num_zeros > 0) it = detail::fill_n(it, num_zeros, zero); + *it++ = static_cast(exp_char); + return write_exponent(output_exp, it); + }; + return specs.width > 0 ? write_padded(out, specs, size, write) + : base_iterator(out, write(reserve(out, size))); + } + + int exp = f.exponent + significand_size; + if (f.exponent >= 0) { + // 1234e5 -> 123400000[.0+] + size += to_unsigned(f.exponent); + int num_zeros = fspecs.precision - exp; + abort_fuzzing_if(num_zeros > 5000); + if (fspecs.showpoint) { + ++size; + if (num_zeros <= 0 && fspecs.format != float_format::fixed) num_zeros = 0; + if (num_zeros > 0) size += to_unsigned(num_zeros); + } + auto grouping = Grouping(loc, fspecs.locale); + size += to_unsigned(grouping.count_separators(exp)); + return write_padded(out, specs, size, [&](iterator it) { + if (sign) *it++ = detail::sign(sign); + it = write_significand(it, significand, significand_size, + f.exponent, grouping); + if (!fspecs.showpoint) return it; + *it++ = decimal_point; + return num_zeros > 0 ? detail::fill_n(it, num_zeros, zero) : it; + }); + } else if (exp > 0) { + // 1234e-2 -> 12.34[0+] + int num_zeros = fspecs.showpoint ? fspecs.precision - significand_size : 0; + size += 1 + to_unsigned(num_zeros > 0 ? num_zeros : 0); + auto grouping = Grouping(loc, fspecs.locale); + size += to_unsigned(grouping.count_separators(exp)); + return write_padded(out, specs, size, [&](iterator it) { + if (sign) *it++ = detail::sign(sign); + it = write_significand(it, significand, significand_size, exp, + decimal_point, grouping); + return num_zeros > 0 ? detail::fill_n(it, num_zeros, zero) : it; + }); + } + // 1234e-6 -> 0.001234 + int num_zeros = -exp; + if (significand_size == 0 && fspecs.precision >= 0 && + fspecs.precision < num_zeros) { + num_zeros = fspecs.precision; + } + bool pointy = num_zeros != 0 || significand_size != 0 || fspecs.showpoint; + size += 1 + (pointy ? 1 : 0) + to_unsigned(num_zeros); + return write_padded(out, specs, size, [&](iterator it) { + if (sign) *it++ = detail::sign(sign); + *it++ = zero; + if (!pointy) return it; + *it++ = decimal_point; + it = detail::fill_n(it, num_zeros, zero); + return write_significand(it, significand, significand_size); + }); +} + +template class fallback_digit_grouping { + public: + constexpr fallback_digit_grouping(locale_ref, bool) {} + + constexpr bool has_separator() const { return false; } + + constexpr int count_separators(int) const { return 0; } + + template + constexpr Out apply(Out out, basic_string_view) const { + return out; + } +}; + +template +FMT_CONSTEXPR20 auto write_float(OutputIt out, const DecimalFP& f, + const format_specs& specs, + float_specs fspecs, locale_ref loc) + -> OutputIt { + if (is_constant_evaluated()) { + return do_write_float>(out, f, specs, fspecs, + loc); + } else { + return do_write_float(out, f, specs, fspecs, loc); + } +} + +template constexpr bool isnan(T value) { + return !(value >= value); // std::isnan doesn't support __float128. +} + +template +struct has_isfinite : std::false_type {}; + +template +struct has_isfinite> + : std::true_type {}; + +template ::value&& + has_isfinite::value)> +FMT_CONSTEXPR20 bool isfinite(T value) { + constexpr T inf = T(std::numeric_limits::infinity()); + if (is_constant_evaluated()) + return !detail::isnan(value) && value < inf && value > -inf; + return std::isfinite(value); +} +template ::value)> +FMT_CONSTEXPR bool isfinite(T value) { + T inf = T(std::numeric_limits::infinity()); + // std::isfinite doesn't support __float128. + return !detail::isnan(value) && value < inf && value > -inf; +} + +template ::value)> +FMT_INLINE FMT_CONSTEXPR bool signbit(T value) { + if (is_constant_evaluated()) { +#ifdef __cpp_if_constexpr + if constexpr (std::numeric_limits::is_iec559) { + auto bits = detail::bit_cast(static_cast(value)); + return (bits >> (num_bits() - 1)) != 0; + } +#endif + } + return std::signbit(static_cast(value)); +} + +inline FMT_CONSTEXPR20 void adjust_precision(int& precision, int exp10) { + // Adjust fixed precision by exponent because it is relative to decimal + // point. + if (exp10 > 0 && precision > max_value() - exp10) + FMT_THROW(format_error("number is too big")); + precision += exp10; +} + +class bigint { + private: + // A bigint is stored as an array of bigits (big digits), with bigit at index + // 0 being the least significant one. + using bigit = uint32_t; + using double_bigit = uint64_t; + enum { bigits_capacity = 32 }; + basic_memory_buffer bigits_; + int exp_; + + FMT_CONSTEXPR20 bigit operator[](int index) const { + return bigits_[to_unsigned(index)]; + } + FMT_CONSTEXPR20 bigit& operator[](int index) { + return bigits_[to_unsigned(index)]; + } + + static constexpr const int bigit_bits = num_bits(); + + friend struct formatter; + + FMT_CONSTEXPR20 void subtract_bigits(int index, bigit other, bigit& borrow) { + auto result = static_cast((*this)[index]) - other - borrow; + (*this)[index] = static_cast(result); + borrow = static_cast(result >> (bigit_bits * 2 - 1)); + } + + FMT_CONSTEXPR20 void remove_leading_zeros() { + int num_bigits = static_cast(bigits_.size()) - 1; + while (num_bigits > 0 && (*this)[num_bigits] == 0) --num_bigits; + bigits_.resize(to_unsigned(num_bigits + 1)); + } + + // Computes *this -= other assuming aligned bigints and *this >= other. + FMT_CONSTEXPR20 void subtract_aligned(const bigint& other) { + FMT_ASSERT(other.exp_ >= exp_, "unaligned bigints"); + FMT_ASSERT(compare(*this, other) >= 0, ""); + bigit borrow = 0; + int i = other.exp_ - exp_; + for (size_t j = 0, n = other.bigits_.size(); j != n; ++i, ++j) + subtract_bigits(i, other.bigits_[j], borrow); + while (borrow > 0) subtract_bigits(i, 0, borrow); + remove_leading_zeros(); + } + + FMT_CONSTEXPR20 void multiply(uint32_t value) { + const double_bigit wide_value = value; + bigit carry = 0; + for (size_t i = 0, n = bigits_.size(); i < n; ++i) { + double_bigit result = bigits_[i] * wide_value + carry; + bigits_[i] = static_cast(result); + carry = static_cast(result >> bigit_bits); + } + if (carry != 0) bigits_.push_back(carry); + } + + template ::value || + std::is_same::value)> + FMT_CONSTEXPR20 void multiply(UInt value) { + using half_uint = + conditional_t::value, uint64_t, uint32_t>; + const int shift = num_bits() - bigit_bits; + const UInt lower = static_cast(value); + const UInt upper = value >> num_bits(); + UInt carry = 0; + for (size_t i = 0, n = bigits_.size(); i < n; ++i) { + UInt result = lower * bigits_[i] + static_cast(carry); + carry = (upper * bigits_[i] << shift) + (result >> bigit_bits) + + (carry >> bigit_bits); + bigits_[i] = static_cast(result); + } + while (carry != 0) { + bigits_.push_back(static_cast(carry)); + carry >>= bigit_bits; + } + } + + template ::value || + std::is_same::value)> + FMT_CONSTEXPR20 void assign(UInt n) { + size_t num_bigits = 0; + do { + bigits_[num_bigits++] = static_cast(n); + n >>= bigit_bits; + } while (n != 0); + bigits_.resize(num_bigits); + exp_ = 0; + } + + public: + FMT_CONSTEXPR20 bigint() : exp_(0) {} + explicit bigint(uint64_t n) { assign(n); } + + bigint(const bigint&) = delete; + void operator=(const bigint&) = delete; + + FMT_CONSTEXPR20 void assign(const bigint& other) { + auto size = other.bigits_.size(); + bigits_.resize(size); + auto data = other.bigits_.data(); + copy_str(data, data + size, bigits_.data()); + exp_ = other.exp_; + } + + template FMT_CONSTEXPR20 void operator=(Int n) { + FMT_ASSERT(n > 0, ""); + assign(uint64_or_128_t(n)); + } + + FMT_CONSTEXPR20 int num_bigits() const { + return static_cast(bigits_.size()) + exp_; + } + + FMT_NOINLINE FMT_CONSTEXPR20 bigint& operator<<=(int shift) { + FMT_ASSERT(shift >= 0, ""); + exp_ += shift / bigit_bits; + shift %= bigit_bits; + if (shift == 0) return *this; + bigit carry = 0; + for (size_t i = 0, n = bigits_.size(); i < n; ++i) { + bigit c = bigits_[i] >> (bigit_bits - shift); + bigits_[i] = (bigits_[i] << shift) + carry; + carry = c; + } + if (carry != 0) bigits_.push_back(carry); + return *this; + } + + template FMT_CONSTEXPR20 bigint& operator*=(Int value) { + FMT_ASSERT(value > 0, ""); + multiply(uint32_or_64_or_128_t(value)); + return *this; + } + + friend FMT_CONSTEXPR20 int compare(const bigint& lhs, const bigint& rhs) { + int num_lhs_bigits = lhs.num_bigits(), num_rhs_bigits = rhs.num_bigits(); + if (num_lhs_bigits != num_rhs_bigits) + return num_lhs_bigits > num_rhs_bigits ? 1 : -1; + int i = static_cast(lhs.bigits_.size()) - 1; + int j = static_cast(rhs.bigits_.size()) - 1; + int end = i - j; + if (end < 0) end = 0; + for (; i >= end; --i, --j) { + bigit lhs_bigit = lhs[i], rhs_bigit = rhs[j]; + if (lhs_bigit != rhs_bigit) return lhs_bigit > rhs_bigit ? 1 : -1; + } + if (i != j) return i > j ? 1 : -1; + return 0; + } + + // Returns compare(lhs1 + lhs2, rhs). + friend FMT_CONSTEXPR20 int add_compare(const bigint& lhs1, const bigint& lhs2, + const bigint& rhs) { + auto minimum = [](int a, int b) { return a < b ? a : b; }; + auto maximum = [](int a, int b) { return a > b ? a : b; }; + int max_lhs_bigits = maximum(lhs1.num_bigits(), lhs2.num_bigits()); + int num_rhs_bigits = rhs.num_bigits(); + if (max_lhs_bigits + 1 < num_rhs_bigits) return -1; + if (max_lhs_bigits > num_rhs_bigits) return 1; + auto get_bigit = [](const bigint& n, int i) -> bigit { + return i >= n.exp_ && i < n.num_bigits() ? n[i - n.exp_] : 0; + }; + double_bigit borrow = 0; + int min_exp = minimum(minimum(lhs1.exp_, lhs2.exp_), rhs.exp_); + for (int i = num_rhs_bigits - 1; i >= min_exp; --i) { + double_bigit sum = + static_cast(get_bigit(lhs1, i)) + get_bigit(lhs2, i); + bigit rhs_bigit = get_bigit(rhs, i); + if (sum > rhs_bigit + borrow) return 1; + borrow = rhs_bigit + borrow - sum; + if (borrow > 1) return -1; + borrow <<= bigit_bits; + } + return borrow != 0 ? -1 : 0; + } + + // Assigns pow(10, exp) to this bigint. + FMT_CONSTEXPR20 void assign_pow10(int exp) { + FMT_ASSERT(exp >= 0, ""); + if (exp == 0) return *this = 1; + // Find the top bit. + int bitmask = 1; + while (exp >= bitmask) bitmask <<= 1; + bitmask >>= 1; + // pow(10, exp) = pow(5, exp) * pow(2, exp). First compute pow(5, exp) by + // repeated squaring and multiplication. + *this = 5; + bitmask >>= 1; + while (bitmask != 0) { + square(); + if ((exp & bitmask) != 0) *this *= 5; + bitmask >>= 1; + } + *this <<= exp; // Multiply by pow(2, exp) by shifting. + } + + FMT_CONSTEXPR20 void square() { + int num_bigits = static_cast(bigits_.size()); + int num_result_bigits = 2 * num_bigits; + basic_memory_buffer n(std::move(bigits_)); + bigits_.resize(to_unsigned(num_result_bigits)); + auto sum = uint128_t(); + for (int bigit_index = 0; bigit_index < num_bigits; ++bigit_index) { + // Compute bigit at position bigit_index of the result by adding + // cross-product terms n[i] * n[j] such that i + j == bigit_index. + for (int i = 0, j = bigit_index; j >= 0; ++i, --j) { + // Most terms are multiplied twice which can be optimized in the future. + sum += static_cast(n[i]) * n[j]; + } + (*this)[bigit_index] = static_cast(sum); + sum >>= num_bits(); // Compute the carry. + } + // Do the same for the top half. + for (int bigit_index = num_bigits; bigit_index < num_result_bigits; + ++bigit_index) { + for (int j = num_bigits - 1, i = bigit_index - j; i < num_bigits;) + sum += static_cast(n[i++]) * n[j--]; + (*this)[bigit_index] = static_cast(sum); + sum >>= num_bits(); + } + remove_leading_zeros(); + exp_ *= 2; + } + + // If this bigint has a bigger exponent than other, adds trailing zero to make + // exponents equal. This simplifies some operations such as subtraction. + FMT_CONSTEXPR20 void align(const bigint& other) { + int exp_difference = exp_ - other.exp_; + if (exp_difference <= 0) return; + int num_bigits = static_cast(bigits_.size()); + bigits_.resize(to_unsigned(num_bigits + exp_difference)); + for (int i = num_bigits - 1, j = i + exp_difference; i >= 0; --i, --j) + bigits_[j] = bigits_[i]; + std::uninitialized_fill_n(bigits_.data(), exp_difference, 0); + exp_ -= exp_difference; + } + + // Divides this bignum by divisor, assigning the remainder to this and + // returning the quotient. + FMT_CONSTEXPR20 int divmod_assign(const bigint& divisor) { + FMT_ASSERT(this != &divisor, ""); + if (compare(*this, divisor) < 0) return 0; + FMT_ASSERT(divisor.bigits_[divisor.bigits_.size() - 1u] != 0, ""); + align(divisor); + int quotient = 0; + do { + subtract_aligned(divisor); + ++quotient; + } while (compare(*this, divisor) >= 0); + return quotient; + } +}; + +// format_dragon flags. +enum dragon { + predecessor_closer = 1, + fixup = 2, // Run fixup to correct exp10 which can be off by one. + fixed = 4, +}; + +// Formats a floating-point number using a variation of the Fixed-Precision +// Positive Floating-Point Printout ((FPP)^2) algorithm by Steele & White: +// https://fmt.dev/papers/p372-steele.pdf. +FMT_CONSTEXPR20 inline void format_dragon(basic_fp value, + unsigned flags, int num_digits, + buffer& buf, int& exp10) { + bigint numerator; // 2 * R in (FPP)^2. + bigint denominator; // 2 * S in (FPP)^2. + // lower and upper are differences between value and corresponding boundaries. + bigint lower; // (M^- in (FPP)^2). + bigint upper_store; // upper's value if different from lower. + bigint* upper = nullptr; // (M^+ in (FPP)^2). + // Shift numerator and denominator by an extra bit or two (if lower boundary + // is closer) to make lower and upper integers. This eliminates multiplication + // by 2 during later computations. + bool is_predecessor_closer = (flags & dragon::predecessor_closer) != 0; + int shift = is_predecessor_closer ? 2 : 1; + if (value.e >= 0) { + numerator = value.f; + numerator <<= value.e + shift; + lower = 1; + lower <<= value.e; + if (is_predecessor_closer) { + upper_store = 1; + upper_store <<= value.e + 1; + upper = &upper_store; + } + denominator.assign_pow10(exp10); + denominator <<= shift; + } else if (exp10 < 0) { + numerator.assign_pow10(-exp10); + lower.assign(numerator); + if (is_predecessor_closer) { + upper_store.assign(numerator); + upper_store <<= 1; + upper = &upper_store; + } + numerator *= value.f; + numerator <<= shift; + denominator = 1; + denominator <<= shift - value.e; + } else { + numerator = value.f; + numerator <<= shift; + denominator.assign_pow10(exp10); + denominator <<= shift - value.e; + lower = 1; + if (is_predecessor_closer) { + upper_store = 1ULL << 1; + upper = &upper_store; + } + } + int even = static_cast((value.f & 1) == 0); + if (!upper) upper = &lower; + bool shortest = num_digits < 0; + if ((flags & dragon::fixup) != 0) { + if (add_compare(numerator, *upper, denominator) + even <= 0) { + --exp10; + numerator *= 10; + if (num_digits < 0) { + lower *= 10; + if (upper != &lower) *upper *= 10; + } + } + if ((flags & dragon::fixed) != 0) adjust_precision(num_digits, exp10 + 1); + } + // Invariant: value == (numerator / denominator) * pow(10, exp10). + if (shortest) { + // Generate the shortest representation. + num_digits = 0; + char* data = buf.data(); + for (;;) { + int digit = numerator.divmod_assign(denominator); + bool low = compare(numerator, lower) - even < 0; // numerator <[=] lower. + // numerator + upper >[=] pow10: + bool high = add_compare(numerator, *upper, denominator) + even > 0; + data[num_digits++] = static_cast('0' + digit); + if (low || high) { + if (!low) { + ++data[num_digits - 1]; + } else if (high) { + int result = add_compare(numerator, numerator, denominator); + // Round half to even. + if (result > 0 || (result == 0 && (digit % 2) != 0)) + ++data[num_digits - 1]; + } + buf.try_resize(to_unsigned(num_digits)); + exp10 -= num_digits - 1; + return; + } + numerator *= 10; + lower *= 10; + if (upper != &lower) *upper *= 10; + } + } + // Generate the given number of digits. + exp10 -= num_digits - 1; + if (num_digits <= 0) { + denominator *= 10; + auto digit = add_compare(numerator, numerator, denominator) > 0 ? '1' : '0'; + buf.push_back(digit); + return; + } + buf.try_resize(to_unsigned(num_digits)); + for (int i = 0; i < num_digits - 1; ++i) { + int digit = numerator.divmod_assign(denominator); + buf[i] = static_cast('0' + digit); + numerator *= 10; + } + int digit = numerator.divmod_assign(denominator); + auto result = add_compare(numerator, numerator, denominator); + if (result > 0 || (result == 0 && (digit % 2) != 0)) { + if (digit == 9) { + const auto overflow = '0' + 10; + buf[num_digits - 1] = overflow; + // Propagate the carry. + for (int i = num_digits - 1; i > 0 && buf[i] == overflow; --i) { + buf[i] = '0'; + ++buf[i - 1]; + } + if (buf[0] == overflow) { + buf[0] = '1'; + if ((flags & dragon::fixed) != 0) buf.push_back('0'); + else ++exp10; + } + return; + } + ++digit; + } + buf[num_digits - 1] = static_cast('0' + digit); +} + +// Formats a floating-point number using the hexfloat format. +template ::value)> +FMT_CONSTEXPR20 void format_hexfloat(Float value, int precision, + float_specs specs, buffer& buf) { + // float is passed as double to reduce the number of instantiations and to + // simplify implementation. + static_assert(!std::is_same::value, ""); + + using info = dragonbox::float_info; + + // Assume Float is in the format [sign][exponent][significand]. + using carrier_uint = typename info::carrier_uint; + + constexpr auto num_float_significand_bits = + detail::num_significand_bits(); + + basic_fp f(value); + f.e += num_float_significand_bits; + if (!has_implicit_bit()) --f.e; + + constexpr auto num_fraction_bits = + num_float_significand_bits + (has_implicit_bit() ? 1 : 0); + constexpr auto num_xdigits = (num_fraction_bits + 3) / 4; + + constexpr auto leading_shift = ((num_xdigits - 1) * 4); + const auto leading_mask = carrier_uint(0xF) << leading_shift; + const auto leading_xdigit = + static_cast((f.f & leading_mask) >> leading_shift); + if (leading_xdigit > 1) f.e -= (32 - countl_zero(leading_xdigit) - 1); + + int print_xdigits = num_xdigits - 1; + if (precision >= 0 && print_xdigits > precision) { + const int shift = ((print_xdigits - precision - 1) * 4); + const auto mask = carrier_uint(0xF) << shift; + const auto v = static_cast((f.f & mask) >> shift); + + if (v >= 8) { + const auto inc = carrier_uint(1) << (shift + 4); + f.f += inc; + f.f &= ~(inc - 1); + } + + // Check long double overflow + if (!has_implicit_bit()) { + const auto implicit_bit = carrier_uint(1) << num_float_significand_bits; + if ((f.f & implicit_bit) == implicit_bit) { + f.f >>= 4; + f.e += 4; + } + } + + print_xdigits = precision; + } + + char xdigits[num_bits() / 4]; + detail::fill_n(xdigits, sizeof(xdigits), '0'); + format_uint<4>(xdigits, f.f, num_xdigits, specs.upper); + + // Remove zero tail + while (print_xdigits > 0 && xdigits[print_xdigits] == '0') --print_xdigits; + + buf.push_back('0'); + buf.push_back(specs.upper ? 'X' : 'x'); + buf.push_back(xdigits[0]); + if (specs.showpoint || print_xdigits > 0 || print_xdigits < precision) + buf.push_back('.'); + buf.append(xdigits + 1, xdigits + 1 + print_xdigits); + for (; print_xdigits < precision; ++print_xdigits) buf.push_back('0'); + + buf.push_back(specs.upper ? 'P' : 'p'); + + uint32_t abs_e; + if (f.e < 0) { + buf.push_back('-'); + abs_e = static_cast(-f.e); + } else { + buf.push_back('+'); + abs_e = static_cast(f.e); + } + format_decimal(appender(buf), abs_e, detail::count_digits(abs_e)); +} + +template ::value)> +FMT_CONSTEXPR20 void format_hexfloat(Float value, int precision, + float_specs specs, buffer& buf) { + format_hexfloat(static_cast(value), precision, specs, buf); +} + +template +FMT_CONSTEXPR20 auto format_float(Float value, int precision, float_specs specs, + buffer& buf) -> int { + // float is passed as double to reduce the number of instantiations. + static_assert(!std::is_same::value, ""); + FMT_ASSERT(value >= 0, "value is negative"); + auto converted_value = convert_float(value); + + const bool fixed = specs.format == float_format::fixed; + if (value <= 0) { // <= instead of == to silence a warning. + if (precision <= 0 || !fixed) { + buf.push_back('0'); + return 0; + } + buf.try_resize(to_unsigned(precision)); + fill_n(buf.data(), precision, '0'); + return -precision; + } + + int exp = 0; + bool use_dragon = true; + unsigned dragon_flags = 0; + if (!is_fast_float() || is_constant_evaluated()) { + const auto inv_log2_10 = 0.3010299956639812; // 1 / log2(10) + using info = dragonbox::float_info; + const auto f = basic_fp(converted_value); + // Compute exp, an approximate power of 10, such that + // 10^(exp - 1) <= value < 10^exp or 10^exp <= value < 10^(exp + 1). + // This is based on log10(value) == log2(value) / log2(10) and approximation + // of log2(value) by e + num_fraction_bits idea from double-conversion. + auto e = (f.e + count_digits<1>(f.f) - 1) * inv_log2_10 - 1e-10; + exp = static_cast(e); + if (e > exp) ++exp; // Compute ceil. + dragon_flags = dragon::fixup; + } else if (precision < 0) { + // Use Dragonbox for the shortest format. + if (specs.binary32) { + auto dec = dragonbox::to_decimal(static_cast(value)); + write(buffer_appender(buf), dec.significand); + return dec.exponent; + } + auto dec = dragonbox::to_decimal(static_cast(value)); + write(buffer_appender(buf), dec.significand); + return dec.exponent; + } else { + // Extract significand bits and exponent bits. + using info = dragonbox::float_info; + auto br = bit_cast(static_cast(value)); + + const uint64_t significand_mask = + (static_cast(1) << num_significand_bits()) - 1; + uint64_t significand = (br & significand_mask); + int exponent = static_cast((br & exponent_mask()) >> + num_significand_bits()); + + if (exponent != 0) { // Check if normal. + exponent -= exponent_bias() + num_significand_bits(); + significand |= + (static_cast(1) << num_significand_bits()); + significand <<= 1; + } else { + // Normalize subnormal inputs. + FMT_ASSERT(significand != 0, "zeros should not appear here"); + int shift = countl_zero(significand); + FMT_ASSERT(shift >= num_bits() - num_significand_bits(), + ""); + shift -= (num_bits() - num_significand_bits() - 2); + exponent = (std::numeric_limits::min_exponent - + num_significand_bits()) - + shift; + significand <<= shift; + } + + // Compute the first several nonzero decimal significand digits. + // We call the number we get the first segment. + const int k = info::kappa - dragonbox::floor_log10_pow2(exponent); + exp = -k; + const int beta = exponent + dragonbox::floor_log2_pow10(k); + uint64_t first_segment; + bool has_more_segments; + int digits_in_the_first_segment; + { + const auto r = dragonbox::umul192_upper128( + significand << beta, dragonbox::get_cached_power(k)); + first_segment = r.high(); + has_more_segments = r.low() != 0; + + // The first segment can have 18 ~ 19 digits. + if (first_segment >= 1000000000000000000ULL) { + digits_in_the_first_segment = 19; + } else { + // When it is of 18-digits, we align it to 19-digits by adding a bogus + // zero at the end. + digits_in_the_first_segment = 18; + first_segment *= 10; + } + } + + // Compute the actual number of decimal digits to print. + if (fixed) adjust_precision(precision, exp + digits_in_the_first_segment); + + // Use Dragon4 only when there might be not enough digits in the first + // segment. + if (digits_in_the_first_segment > precision) { + use_dragon = false; + + if (precision <= 0) { + exp += digits_in_the_first_segment; + + if (precision < 0) { + // Nothing to do, since all we have are just leading zeros. + buf.try_resize(0); + } else { + // We may need to round-up. + buf.try_resize(1); + if ((first_segment | static_cast(has_more_segments)) > + 5000000000000000000ULL) { + buf[0] = '1'; + } else { + buf[0] = '0'; + } + } + } // precision <= 0 + else { + exp += digits_in_the_first_segment - precision; + + // When precision > 0, we divide the first segment into three + // subsegments, each with 9, 9, and 0 ~ 1 digits so that each fits + // in 32-bits which usually allows faster calculation than in + // 64-bits. Since some compiler (e.g. MSVC) doesn't know how to optimize + // division-by-constant for large 64-bit divisors, we do it here + // manually. The magic number 7922816251426433760 below is equal to + // ceil(2^(64+32) / 10^10). + const uint32_t first_subsegment = static_cast( + dragonbox::umul128_upper64(first_segment, 7922816251426433760ULL) >> + 32); + const uint64_t second_third_subsegments = + first_segment - first_subsegment * 10000000000ULL; + + uint64_t prod; + uint32_t digits; + bool should_round_up; + int number_of_digits_to_print = precision > 9 ? 9 : precision; + + // Print a 9-digits subsegment, either the first or the second. + auto print_subsegment = [&](uint32_t subsegment, char* buffer) { + int number_of_digits_printed = 0; + + // If we want to print an odd number of digits from the subsegment, + if ((number_of_digits_to_print & 1) != 0) { + // Convert to 64-bit fixed-point fractional form with 1-digit + // integer part. The magic number 720575941 is a good enough + // approximation of 2^(32 + 24) / 10^8; see + // https://jk-jeon.github.io/posts/2022/12/fixed-precision-formatting/#fixed-length-case + // for details. + prod = ((subsegment * static_cast(720575941)) >> 24) + 1; + digits = static_cast(prod >> 32); + *buffer = static_cast('0' + digits); + number_of_digits_printed++; + } + // If we want to print an even number of digits from the + // first_subsegment, + else { + // Convert to 64-bit fixed-point fractional form with 2-digits + // integer part. The magic number 450359963 is a good enough + // approximation of 2^(32 + 20) / 10^7; see + // https://jk-jeon.github.io/posts/2022/12/fixed-precision-formatting/#fixed-length-case + // for details. + prod = ((subsegment * static_cast(450359963)) >> 20) + 1; + digits = static_cast(prod >> 32); + copy2(buffer, digits2(digits)); + number_of_digits_printed += 2; + } + + // Print all digit pairs. + while (number_of_digits_printed < number_of_digits_to_print) { + prod = static_cast(prod) * static_cast(100); + digits = static_cast(prod >> 32); + copy2(buffer + number_of_digits_printed, digits2(digits)); + number_of_digits_printed += 2; + } + }; + + // Print first subsegment. + print_subsegment(first_subsegment, buf.data()); + + // Perform rounding if the first subsegment is the last subsegment to + // print. + if (precision <= 9) { + // Rounding inside the subsegment. + // We round-up if: + // - either the fractional part is strictly larger than 1/2, or + // - the fractional part is exactly 1/2 and the last digit is odd. + // We rely on the following observations: + // - If fractional_part >= threshold, then the fractional part is + // strictly larger than 1/2. + // - If the MSB of fractional_part is set, then the fractional part + // must be at least 1/2. + // - When the MSB of fractional_part is set, either + // second_third_subsegments being nonzero or has_more_segments + // being true means there are further digits not printed, so the + // fractional part is strictly larger than 1/2. + if (precision < 9) { + uint32_t fractional_part = static_cast(prod); + should_round_up = fractional_part >= + data::fractional_part_rounding_thresholds + [8 - number_of_digits_to_print] || + ((fractional_part >> 31) & + ((digits & 1) | (second_third_subsegments != 0) | + has_more_segments)) != 0; + } + // Rounding at the subsegment boundary. + // In this case, the fractional part is at least 1/2 if and only if + // second_third_subsegments >= 5000000000ULL, and is strictly larger + // than 1/2 if we further have either second_third_subsegments > + // 5000000000ULL or has_more_segments == true. + else { + should_round_up = second_third_subsegments > 5000000000ULL || + (second_third_subsegments == 5000000000ULL && + ((digits & 1) != 0 || has_more_segments)); + } + } + // Otherwise, print the second subsegment. + else { + // Compilers are not aware of how to leverage the maximum value of + // second_third_subsegments to find out a better magic number which + // allows us to eliminate an additional shift. 1844674407370955162 = + // ceil(2^64/10) < ceil(2^64*(10^9/(10^10 - 1))). + const uint32_t second_subsegment = + static_cast(dragonbox::umul128_upper64( + second_third_subsegments, 1844674407370955162ULL)); + const uint32_t third_subsegment = + static_cast(second_third_subsegments) - + second_subsegment * 10; + + number_of_digits_to_print = precision - 9; + print_subsegment(second_subsegment, buf.data() + 9); + + // Rounding inside the subsegment. + if (precision < 18) { + // The condition third_subsegment != 0 implies that the segment was + // of 19 digits, so in this case the third segment should be + // consisting of a genuine digit from the input. + uint32_t fractional_part = static_cast(prod); + should_round_up = fractional_part >= + data::fractional_part_rounding_thresholds + [8 - number_of_digits_to_print] || + ((fractional_part >> 31) & + ((digits & 1) | (third_subsegment != 0) | + has_more_segments)) != 0; + } + // Rounding at the subsegment boundary. + else { + // In this case, the segment must be of 19 digits, thus + // the third subsegment should be consisting of a genuine digit from + // the input. + should_round_up = third_subsegment > 5 || + (third_subsegment == 5 && + ((digits & 1) != 0 || has_more_segments)); + } + } + + // Round-up if necessary. + if (should_round_up) { + ++buf[precision - 1]; + for (int i = precision - 1; i > 0 && buf[i] > '9'; --i) { + buf[i] = '0'; + ++buf[i - 1]; + } + if (buf[0] > '9') { + buf[0] = '1'; + if (fixed) + buf[precision++] = '0'; + else + ++exp; + } + } + buf.try_resize(to_unsigned(precision)); + } + } // if (digits_in_the_first_segment > precision) + else { + // Adjust the exponent for its use in Dragon4. + exp += digits_in_the_first_segment - 1; + } + } + if (use_dragon) { + auto f = basic_fp(); + bool is_predecessor_closer = specs.binary32 + ? f.assign(static_cast(value)) + : f.assign(converted_value); + if (is_predecessor_closer) dragon_flags |= dragon::predecessor_closer; + if (fixed) dragon_flags |= dragon::fixed; + // Limit precision to the maximum possible number of significant digits in + // an IEEE754 double because we don't need to generate zeros. + const int max_double_digits = 767; + if (precision > max_double_digits) precision = max_double_digits; + format_dragon(f, dragon_flags, precision, buf, exp); + } + if (!fixed && !specs.showpoint) { + // Remove trailing zeros. + auto num_digits = buf.size(); + while (num_digits > 0 && buf[num_digits - 1] == '0') { + --num_digits; + ++exp; + } + buf.try_resize(num_digits); + } + return exp; +} +template +FMT_CONSTEXPR20 auto write_float(OutputIt out, T value, + format_specs specs, locale_ref loc) + -> OutputIt { + float_specs fspecs = parse_float_type_spec(specs); + fspecs.sign = specs.sign; + if (detail::signbit(value)) { // value < 0 is false for NaN so use signbit. + fspecs.sign = sign::minus; + value = -value; + } else if (fspecs.sign == sign::minus) { + fspecs.sign = sign::none; + } + + if (!detail::isfinite(value)) + return write_nonfinite(out, detail::isnan(value), specs, fspecs); + + if (specs.align == align::numeric && fspecs.sign) { + auto it = reserve(out, 1); + *it++ = detail::sign(fspecs.sign); + out = base_iterator(out, it); + fspecs.sign = sign::none; + if (specs.width != 0) --specs.width; + } + + memory_buffer buffer; + if (fspecs.format == float_format::hex) { + if (fspecs.sign) buffer.push_back(detail::sign(fspecs.sign)); + format_hexfloat(convert_float(value), specs.precision, fspecs, buffer); + return write_bytes(out, {buffer.data(), buffer.size()}, + specs); + } + int precision = specs.precision >= 0 || specs.type == presentation_type::none + ? specs.precision + : 6; + if (fspecs.format == float_format::exp) { + if (precision == max_value()) + throw_format_error("number is too big"); + else + ++precision; + } else if (fspecs.format != float_format::fixed && precision == 0) { + precision = 1; + } + if (const_check(std::is_same())) fspecs.binary32 = true; + int exp = format_float(convert_float(value), precision, fspecs, buffer); + fspecs.precision = precision; + auto f = big_decimal_fp{buffer.data(), static_cast(buffer.size()), exp}; + return write_float(out, f, specs, fspecs, loc); +} + +template ::value)> +FMT_CONSTEXPR20 auto write(OutputIt out, T value, format_specs specs, + locale_ref loc = {}) -> OutputIt { + if (const_check(!is_supported_floating_point(value))) return out; + return specs.localized && write_loc(out, value, specs, loc) + ? out + : write_float(out, value, specs, loc); +} + +template ::value)> +FMT_CONSTEXPR20 auto write(OutputIt out, T value) -> OutputIt { + if (is_constant_evaluated()) return write(out, value, format_specs()); + if (const_check(!is_supported_floating_point(value))) return out; + + auto fspecs = float_specs(); + if (detail::signbit(value)) { + fspecs.sign = sign::minus; + value = -value; + } + + constexpr auto specs = format_specs(); + using floaty = conditional_t::value, double, T>; + using floaty_uint = typename dragonbox::float_info::carrier_uint; + floaty_uint mask = exponent_mask(); + if ((bit_cast(value) & mask) == mask) + return write_nonfinite(out, std::isnan(value), specs, fspecs); + + auto dec = dragonbox::to_decimal(static_cast(value)); + return write_float(out, dec, specs, fspecs, {}); +} + +template ::value && + !is_fast_float::value)> +inline auto write(OutputIt out, T value) -> OutputIt { + return write(out, value, format_specs()); +} + +template +auto write(OutputIt out, monostate, format_specs = {}, locale_ref = {}) + -> OutputIt { + FMT_ASSERT(false, ""); + return out; +} + +template +FMT_CONSTEXPR auto write(OutputIt out, basic_string_view value) + -> OutputIt { + auto it = reserve(out, value.size()); + it = copy_str_noinline(value.begin(), value.end(), it); + return base_iterator(out, it); +} + +template ::value)> +constexpr auto write(OutputIt out, const T& value) -> OutputIt { + return write(out, to_string_view(value)); +} + +// FMT_ENABLE_IF() condition separated to workaround an MSVC bug. +template < + typename Char, typename OutputIt, typename T, + bool check = + std::is_enum::value && !std::is_same::value && + mapped_type_constant>::value != + type::custom_type, + FMT_ENABLE_IF(check)> +FMT_CONSTEXPR auto write(OutputIt out, T value) -> OutputIt { + return write(out, static_cast>(value)); +} + +template ::value)> +FMT_CONSTEXPR auto write(OutputIt out, T value, + const format_specs& specs = {}, locale_ref = {}) + -> OutputIt { + return specs.type != presentation_type::none && + specs.type != presentation_type::string + ? write(out, value ? 1 : 0, specs, {}) + : write_bytes(out, value ? "true" : "false", specs); +} + +template +FMT_CONSTEXPR auto write(OutputIt out, Char value) -> OutputIt { + auto it = reserve(out, 1); + *it++ = value; + return base_iterator(out, it); +} + +template +FMT_CONSTEXPR_CHAR_TRAITS auto write(OutputIt out, const Char* value) + -> OutputIt { + if (value) return write(out, basic_string_view(value)); + throw_format_error("string pointer is null"); + return out; +} + +template ::value)> +auto write(OutputIt out, const T* value, const format_specs& specs = {}, + locale_ref = {}) -> OutputIt { + return write_ptr(out, bit_cast(value), &specs); +} + +// A write overload that handles implicit conversions. +template > +FMT_CONSTEXPR auto write(OutputIt out, const T& value) -> enable_if_t< + std::is_class::value && !is_string::value && + !is_floating_point::value && !std::is_same::value && + !std::is_same().map( + value))>>::value, + OutputIt> { + return write(out, arg_mapper().map(value)); +} + +template > +FMT_CONSTEXPR auto write(OutputIt out, const T& value) + -> enable_if_t::value == type::custom_type, + OutputIt> { + auto ctx = Context(out, {}, {}); + return typename Context::template formatter_type().format(value, ctx); +} + +// An argument visitor that formats the argument and writes it via the output +// iterator. It's a class and not a generic lambda for compatibility with C++11. +template struct default_arg_formatter { + using iterator = buffer_appender; + using context = buffer_context; + + iterator out; + basic_format_args args; + locale_ref loc; + + template auto operator()(T value) -> iterator { + return write(out, value); + } + auto operator()(typename basic_format_arg::handle h) -> iterator { + basic_format_parse_context parse_ctx({}); + context format_ctx(out, args, loc); + h.format(parse_ctx, format_ctx); + return format_ctx.out(); + } +}; + +template struct arg_formatter { + using iterator = buffer_appender; + using context = buffer_context; + + iterator out; + const format_specs& specs; + locale_ref locale; + + template + FMT_CONSTEXPR FMT_INLINE auto operator()(T value) -> iterator { + return detail::write(out, value, specs, locale); + } + auto operator()(typename basic_format_arg::handle) -> iterator { + // User-defined types are handled separately because they require access + // to the parse context. + return out; + } +}; + +template struct custom_formatter { + basic_format_parse_context& parse_ctx; + buffer_context& ctx; + + void operator()( + typename basic_format_arg>::handle h) const { + h.format(parse_ctx, ctx); + } + template void operator()(T) const {} +}; + +template class width_checker { + public: + explicit FMT_CONSTEXPR width_checker(ErrorHandler& eh) : handler_(eh) {} + + template ::value)> + FMT_CONSTEXPR auto operator()(T value) -> unsigned long long { + if (is_negative(value)) handler_.on_error("negative width"); + return static_cast(value); + } + + template ::value)> + FMT_CONSTEXPR auto operator()(T) -> unsigned long long { + handler_.on_error("width is not integer"); + return 0; + } + + private: + ErrorHandler& handler_; +}; + +template class precision_checker { + public: + explicit FMT_CONSTEXPR precision_checker(ErrorHandler& eh) : handler_(eh) {} + + template ::value)> + FMT_CONSTEXPR auto operator()(T value) -> unsigned long long { + if (is_negative(value)) handler_.on_error("negative precision"); + return static_cast(value); + } + + template ::value)> + FMT_CONSTEXPR auto operator()(T) -> unsigned long long { + handler_.on_error("precision is not integer"); + return 0; + } + + private: + ErrorHandler& handler_; +}; + +template