redsnow 0.3.2 → 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile.lock +39 -8
- data/Guardfile +7 -0
- data/Rakefile +18 -21
- data/Vagrantfile +9 -9
- data/lib/redsnow.rb +19 -32
- data/lib/redsnow/binding.rb +161 -166
- data/lib/redsnow/blueprint.rb +95 -103
- data/lib/redsnow/object.rb +3 -4
- data/lib/redsnow/parseresult.rb +31 -40
- data/lib/redsnow/sourcemap.rb +71 -96
- data/lib/redsnow/version.rb +2 -1
- data/redsnow.gemspec +23 -23
- metadata +22 -531
- data/doc/RedSnow.html +0 -321
- data/doc/RedSnow/Action.html +0 -702
- data/doc/RedSnow/Binding.html +0 -135
- data/doc/RedSnow/Blueprint.html +0 -657
- data/doc/RedSnow/BlueprintNode.html +0 -139
- data/doc/RedSnow/ErrorCodes.html +0 -165
- data/doc/RedSnow/Headers.html +0 -456
- data/doc/RedSnow/KeyValueCollection.html +0 -343
- data/doc/RedSnow/Location.html +0 -391
- data/doc/RedSnow/Metadata.html +0 -343
- data/doc/RedSnow/NamedBlueprintNode.html +0 -444
- data/doc/RedSnow/Object.html +0 -295
- data/doc/RedSnow/Parameter.html +0 -881
- data/doc/RedSnow/Parameters.html +0 -349
- data/doc/RedSnow/ParseResult.html +0 -570
- data/doc/RedSnow/Payload.html +0 -775
- data/doc/RedSnow/Resource.html +0 -790
- data/doc/RedSnow/ResourceGroup.html +0 -521
- data/doc/RedSnow/TransactionExample.html +0 -700
- data/doc/RedSnow/WarningCodes.html +0 -210
- data/doc/_index.html +0 -342
- data/doc/class_list.html +0 -54
- data/doc/css/common.css +0 -1
- data/doc/css/full_list.css +0 -57
- data/doc/css/style.css +0 -339
- data/doc/file.README.html +0 -136
- data/doc/file_list.html +0 -56
- data/doc/frames.html +0 -26
- data/doc/index.html +0 -136
- data/doc/js/app.js +0 -219
- data/doc/js/full_list.js +0 -178
- data/doc/js/jquery.js +0 -4
- data/doc/method_list.html +0 -347
- data/doc/top-level-namespace.html +0 -112
- data/ext/snowcrash/Gemfile +0 -8
- data/ext/snowcrash/Gemfile.lock +0 -40
- data/ext/snowcrash/LICENSE +0 -22
- data/ext/snowcrash/README.md +0 -118
- data/ext/snowcrash/bin/test-libsnowcrash +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ActionParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-AssetParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-Blueprint.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-BlueprintParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-HeaderParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-HeadersParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-Indentation.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ListUtility.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-MarkdownBlock.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-MarkdownParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ParameterDefinitonParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ParameterParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ParametersParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-Parser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-PayloadParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-RegexMatch.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ResouceGroupParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ResourceGroupParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ResourceParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-SectionParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-SymbolIdentifier.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-SymbolTable.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-UriTemplateParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-ValuesParser.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-Warnings.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-csnowcrash.o +0 -0
- data/ext/snowcrash/build/out/Release/obj.target/test-libsnowcrash/test/test-snowcrash.o +0 -0
- data/ext/snowcrash/build/out/Release/test-libsnowcrash +0 -0
- data/ext/snowcrash/build/test-libsnowcrash.target.mk +0 -170
- data/ext/snowcrash/ext/cmdline/LICENSE +0 -30
- data/ext/snowcrash/ext/cmdline/README.rst +0 -191
- data/ext/snowcrash/ext/cmdline/cmdline.h +0 -817
- data/ext/snowcrash/ext/cmdline/test.cpp +0 -50
- data/ext/snowcrash/ext/cmdline/test2.cpp +0 -61
- data/ext/snowcrash/ext/markdown-parser/LICENSE +0 -22
- data/ext/snowcrash/ext/markdown-parser/README.md +0 -11
- data/ext/snowcrash/ext/markdown-parser/ext/sundown/README.markdown +0 -141
- data/ext/snowcrash/ext/markdown-parser/markdownparser.xcodeproj/project.pbxproj +0 -448
- data/ext/snowcrash/ext/markdown-parser/msvc/test-markdown/test-markdown.vcproj +0 -195
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/LICENSE_1_0.txt +0 -23
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/README.md +0 -24
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/catch-logo-small.png +0 -0
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/assertions.md +0 -64
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/build-systems.md +0 -36
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/command-line.md +0 -155
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/contributing.md +0 -19
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/logging.md +0 -52
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/own-main.md +0 -68
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/reference-index.md +0 -14
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/test-cases-and-sections.md +0 -60
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/test-fixtures.md +0 -32
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/tutorial.md +0 -228
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/whats-changed.md +0 -24
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/docs/why-catch.md +0 -42
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/catch.hpp +0 -202
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/catch_runner.hpp +0 -224
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/catch_with_main.hpp +0 -15
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/external/clara.h +0 -868
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/external/tbc_text_format.h +0 -153
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_approx.hpp +0 -91
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_assertionresult.h +0 -71
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_assertionresult.hpp +0 -91
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_capture.hpp +0 -179
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_clara.h +0 -32
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_commandline.hpp +0 -145
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_common.h +0 -119
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_common.hpp +0 -86
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_compiler_capabilities.h +0 -123
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_config.hpp +0 -178
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_console_colour.hpp +0 -66
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_console_colour_impl.hpp +0 -166
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_context.h +0 -53
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_context_impl.hpp +0 -112
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_debugger.h +0 -49
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_debugger.hpp +0 -100
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_default_main.hpp +0 -38
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_evaluate.hpp +0 -178
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_exception_translator_registry.hpp +0 -75
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_expression_decomposer.hpp +0 -31
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_expression_lhs.hpp +0 -105
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_expressionresult_builder.h +0 -63
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_expressionresult_builder.hpp +0 -98
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_generators.hpp +0 -190
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_generators_impl.hpp +0 -86
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_impl.hpp +0 -92
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_capture.h +0 -46
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_config.h +0 -54
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_exception.h +0 -66
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_generators.h +0 -32
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_registry_hub.h +0 -44
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_reporter.h +0 -265
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_runner.h +0 -19
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_interfaces_testcase.h +0 -37
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_legacy_reporter_adapter.h +0 -59
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_legacy_reporter_adapter.hpp +0 -82
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_list.hpp +0 -150
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_matchers.hpp +0 -233
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_message.h +0 -65
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_message.hpp +0 -43
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_notimplemented_exception.h +0 -35
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_notimplemented_exception.hpp +0 -30
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_objc.hpp +0 -203
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_objc_arc.hpp +0 -51
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_option.hpp +0 -75
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_platform.h +0 -20
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_ptr.hpp +0 -94
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_registry_hub.hpp +0 -83
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_reporter_registrars.hpp +0 -74
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_reporter_registry.hpp +0 -45
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_result_type.h +0 -66
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_runner_impl.hpp +0 -319
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_section.h +0 -55
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_section.hpp +0 -40
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_section_info.h +0 -31
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_section_info.hpp +0 -113
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_sfinae.hpp +0 -44
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_stream.h +0 -33
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_stream.hpp +0 -83
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_streambuf.h +0 -23
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_tags.h +0 -109
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_tags.hpp +0 -137
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_case_info.h +0 -84
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_case_info.hpp +0 -166
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_case_registry_impl.hpp +0 -146
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_case_tracker.hpp +0 -148
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_registry.hpp +0 -120
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_spec.h +0 -65
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_test_spec.hpp +0 -133
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_text.h +0 -24
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_timer.h +0 -35
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_timer.hpp +0 -63
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_tostring.hpp +0 -276
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_totals.hpp +0 -67
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_version.h +0 -37
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_version.hpp +0 -19
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/internal/catch_xmlwriter.hpp +0 -218
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/reporters/catch_reporter_bases.hpp +0 -203
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/reporters/catch_reporter_console.hpp +0 -411
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/reporters/catch_reporter_junit.hpp +0 -226
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/include/reporters/catch_reporter_xml.hpp +0 -151
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/CMake/CMakeLists.txt +0 -38
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/ApproxTests.cpp +0 -112
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/BDDTests.cpp +0 -68
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/Baselines/console.std.approved.txt +0 -778
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/Baselines/console.sw.approved.txt +0 -6995
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/Baselines/console.swa4.approved.txt +0 -322
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/Baselines/junit.sw.approved.txt +0 -562
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/Baselines/xml.sw.approved.txt +0 -7251
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/ClassTests.cpp +0 -57
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/ConditionTests.cpp +0 -334
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/ExceptionTests.cpp +0 -153
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/GeneratorTests.cpp +0 -42
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/MessageTests.cpp +0 -121
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/MiscTests.cpp +0 -341
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SectionTrackerTests.cpp +0 -164
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_common.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_console_colour.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_debugger.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_capture.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_config.cpp +0 -1
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_exception.cpp +0 -1
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_generators.cpp +0 -1
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_registry_hub.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_reporter.cpp +0 -1
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_runner.cpp +0 -1
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_testcase.cpp +0 -1
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_message.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_option.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_ptr.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_stream.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_streambuf.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_tags.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/SurrogateCpps/catch_xmlwriter.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/TestMain.cpp +0 -541
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/TrickyTests.cpp +0 -396
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/VariadicMacrosTests.cpp +0 -31
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/SelfTest/makefile +0 -21
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/VS2008/TestCatch/TestCatch.sln +0 -20
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/VS2008/TestCatch/TestCatch/TestCatch.cpp +0 -8
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/VS2008/TestCatch/TestCatch/TestCatch.vcproj +0 -394
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/VS2010/TestCatch/TestCatch.sln +0 -20
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/VS2010/TestCatch/TestCatch/TestCatch.vcxproj +0 -148
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTest.xcodeproj/project.pbxproj +0 -685
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTest.xcodeproj/project.xcworkspace/xcshareddata/CatchSelfTest.xccheckout +0 -41
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTest/CatchSelfTest.1 +0 -79
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTest/catch_text.cpp +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTestSingle.xcodeproj/project.pbxproj +0 -258
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTestSingle.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTestSingle.xcodeproj/project.xcworkspace/xcshareddata/CatchSelfTestSingle.xccheckout +0 -41
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/CatchSelfTest/CatchSelfTestSingle/dummy.txt +0 -0
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest.xcodeproj/project.pbxproj +0 -265
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest.xcodeproj/project.xcworkspace/xcshareddata/OCTest.xccheckout +0 -41
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/CatchOCTestCase.h +0 -25
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/CatchOCTestCase.mm +0 -83
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/Main.mm +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/OCTest.1 +0 -79
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/OCTest.mm +0 -28
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/TestObj.h +0 -28
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/OCTest/OCTest/TestObj.m +0 -25
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest.xcodeproj/project.pbxproj +0 -299
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest/OCTest.mm +0 -27
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest/TestObj.h +0 -25
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest/TestObj.m +0 -18
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest/en.lproj/InfoPlist.strings +0 -2
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest/iOSTest-Info.plist +0 -47
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/XCode/iOSTest/iOSTest/iOSTest-Prefix.pch +0 -14
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/runners/iTchRunner/internal/iTchRunnerAppDelegate.h +0 -114
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/runners/iTchRunner/internal/iTchRunnerMainView.h +0 -189
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/runners/iTchRunner/internal/iTchRunnerReporter.h +0 -115
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/runners/iTchRunner/itChRunnerMain.mm +0 -27
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/projects/runners/iTchRunner/readme +0 -6
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/scripts/approvalTests.py +0 -99
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/scripts/approve.py +0 -29
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/scripts/generateSingleHeader.py +0 -152
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/scripts/scriptCommon.py +0 -4
- data/ext/snowcrash/ext/markdown-parser/test/ext/Catch/single_include/catch.hpp +0 -8544
- data/ext/snowcrash/ext/markdown-parser/test/test-ByteBuffer.cc +0 -83
- data/ext/snowcrash/ext/markdown-parser/test/test-MarkdownParser.cc +0 -628
- data/ext/snowcrash/ext/markdown-parser/test/test-libmarkdownparser.cc +0 -10
- data/ext/snowcrash/features/fixtures/ast.json +0 -154
- data/ext/snowcrash/features/fixtures/ast.yaml +0 -87
- data/ext/snowcrash/features/fixtures/blueprint.apib +0 -84
- data/ext/snowcrash/features/fixtures/invalid_blueprint.apib +0 -4
- data/ext/snowcrash/features/parse.feature +0 -23
- data/ext/snowcrash/features/step_definitions/file_content_step.rb +0 -8
- data/ext/snowcrash/features/support/env.rb +0 -7
- data/ext/snowcrash/features/support/setup.rb +0 -1
- data/ext/snowcrash/features/validate.feature +0 -37
- data/ext/snowcrash/features/version.feature +0 -10
- data/ext/snowcrash/snowcrash.xcodeproj/project.pbxproj +0 -798
- data/ext/snowcrash/test/README.md +0 -7
- data/ext/snowcrash/test/performance/fixtures/fixture-1.apib +0 -174
- data/ext/snowcrash/test/performance/fixtures/fixture-2.apib +0 -2455
- data/ext/snowcrash/test/performance/fixtures/fixture-3.apib +0 -10363
- data/ext/snowcrash/test/performance/fixtures/fixture-4.apib +0 -8390
- data/ext/snowcrash/test/performance/perf-snowcrash.cc +0 -162
- data/ext/snowcrash/test/snowcrashtest.h +0 -88
- data/ext/snowcrash/test/test-ActionParser.cc +0 -491
- data/ext/snowcrash/test/test-AssetParser.cc +0 -224
- data/ext/snowcrash/test/test-Blueprint.cc +0 -32
- data/ext/snowcrash/test/test-BlueprintParser.cc +0 -462
- data/ext/snowcrash/test/test-HeadersParser.cc +0 -256
- data/ext/snowcrash/test/test-Indentation.cc +0 -336
- data/ext/snowcrash/test/test-ParameterParser.cc +0 -499
- data/ext/snowcrash/test/test-ParametersParser.cc +0 -355
- data/ext/snowcrash/test/test-PayloadParser.cc +0 -657
- data/ext/snowcrash/test/test-RegexMatch.cc +0 -35
- data/ext/snowcrash/test/test-ResourceGroupParser.cc +0 -457
- data/ext/snowcrash/test/test-ResourceParser.cc +0 -947
- data/ext/snowcrash/test/test-SectionParser.cc +0 -81
- data/ext/snowcrash/test/test-StringUtility.cc +0 -65
- data/ext/snowcrash/test/test-SymbolIdentifier.cc +0 -53
- data/ext/snowcrash/test/test-SymbolTable.cc +0 -31
- data/ext/snowcrash/test/test-UriTemplateParser.cc +0 -333
- data/ext/snowcrash/test/test-ValuesParser.cc +0 -106
- data/ext/snowcrash/test/test-Warnings.cc +0 -94
- data/ext/snowcrash/test/test-csnowcrash.cc +0 -404
- data/ext/snowcrash/test/test-snowcrash.cc +0 -664
- data/ext/snowcrash/test/vendor/Catch/LICENSE_1_0.txt +0 -23
- data/ext/snowcrash/test/vendor/Catch/README.md +0 -24
- data/ext/snowcrash/test/vendor/Catch/catch-logo-small.png +0 -0
- data/ext/snowcrash/test/vendor/Catch/docs/assertions.md +0 -59
- data/ext/snowcrash/test/vendor/Catch/docs/command-line.md +0 -137
- data/ext/snowcrash/test/vendor/Catch/docs/logging.md +0 -52
- data/ext/snowcrash/test/vendor/Catch/docs/own-main.md +0 -68
- data/ext/snowcrash/test/vendor/Catch/docs/reference-index.md +0 -13
- data/ext/snowcrash/test/vendor/Catch/docs/test-fixtures.md +0 -32
- data/ext/snowcrash/test/vendor/Catch/docs/tutorial.md +0 -100
- data/ext/snowcrash/test/vendor/Catch/docs/whats-changed.md +0 -24
- data/ext/snowcrash/test/vendor/Catch/docs/why-catch.md +0 -42
- data/ext/snowcrash/test/vendor/Catch/include/catch.hpp +0 -182
- data/ext/snowcrash/test/vendor/Catch/include/catch_runner.hpp +0 -236
- data/ext/snowcrash/test/vendor/Catch/include/catch_with_main.hpp +0 -15
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_approx.hpp +0 -91
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_assertionresult.h +0 -65
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_assertionresult.hpp +0 -91
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_capture.hpp +0 -175
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_commandline.hpp +0 -129
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_common.h +0 -148
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_compiler_capabilities.h +0 -85
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_config.hpp +0 -182
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_console_colour.hpp +0 -66
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_console_colour_impl.hpp +0 -153
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_context.h +0 -53
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_context_impl.hpp +0 -112
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_debugger.hpp +0 -116
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_default_main.hpp +0 -38
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_evaluate.hpp +0 -178
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_exception_translator_registry.hpp +0 -74
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_expression_decomposer.hpp +0 -31
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_expression_lhs.hpp +0 -97
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_expressionresult_builder.h +0 -63
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_expressionresult_builder.hpp +0 -98
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_generators.hpp +0 -190
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_generators_impl.hpp +0 -86
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_impl.hpp +0 -97
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_capture.h +0 -46
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_config.h +0 -32
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_exception.h +0 -66
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_generators.h +0 -32
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_registry_hub.h +0 -45
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_reporter.h +0 -339
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_runner.h +0 -23
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_interfaces_testcase.h +0 -34
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_legacy_reporter_adapter.h +0 -39
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_legacy_reporter_adapter.hpp +0 -84
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_list.hpp +0 -198
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_matchers.hpp +0 -233
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_message.h +0 -65
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_message.hpp +0 -43
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_notimplemented_exception.h +0 -35
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_notimplemented_exception.hpp +0 -30
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_objc.hpp +0 -202
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_objc_arc.hpp +0 -51
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_option.hpp +0 -67
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_ptr.hpp +0 -94
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_registry_hub.hpp +0 -83
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_reporter_registrars.hpp +0 -75
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_reporter_registry.hpp +0 -45
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_result_type.h +0 -66
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_runner_impl.hpp +0 -326
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_running_test.hpp +0 -117
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_section.hpp +0 -56
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_section_info.hpp +0 -113
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_sfinae.hpp +0 -44
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_stream.hpp +0 -90
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_streambuf.h +0 -21
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_tags.hpp +0 -193
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_test_case_info.h +0 -82
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_test_case_info.hpp +0 -127
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_test_case_registry_impl.hpp +0 -151
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_test_registry.hpp +0 -120
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_test_spec.h +0 -166
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_text.h +0 -61
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_text.hpp +0 -92
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_tostring.hpp +0 -224
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_totals.hpp +0 -67
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_version.h +0 -37
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_version.hpp +0 -19
- data/ext/snowcrash/test/vendor/Catch/include/internal/catch_xmlwriter.hpp +0 -211
- data/ext/snowcrash/test/vendor/Catch/include/internal/clara.h +0 -553
- data/ext/snowcrash/test/vendor/Catch/include/reporters/catch_reporter_basic.hpp +0 -353
- data/ext/snowcrash/test/vendor/Catch/include/reporters/catch_reporter_console.hpp +0 -397
- data/ext/snowcrash/test/vendor/Catch/include/reporters/catch_reporter_junit.hpp +0 -252
- data/ext/snowcrash/test/vendor/Catch/include/reporters/catch_reporter_xml.hpp +0 -145
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/ApproxTests.cpp +0 -112
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/BDDTests.cpp +0 -68
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/Baselines/approvedResults.txt +0 -14686
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/ClassTests.cpp +0 -57
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/CmdLineTests.cpp +0 -191
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/ConditionTests.cpp +0 -348
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/ExceptionTests.cpp +0 -143
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/GeneratorTests.cpp +0 -42
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/MessageTests.cpp +0 -102
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/MiscTests.cpp +0 -343
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_common.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_console_colour.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_debugger.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_capture.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_config.cpp +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_exception.cpp +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_generators.cpp +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_registry_hub.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_reporter.cpp +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_runner.cpp +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_interfaces_testcase.cpp +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_message.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_option.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_ptr.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_stream.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_streambuf.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_tags.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/SurrogateCpps/catch_xmlwriter.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/TestMain.cpp +0 -561
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/TrickyTests.cpp +0 -382
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/VariadicMacrosTests.cpp +0 -31
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/catch_self_test.cpp +0 -31
- data/ext/snowcrash/test/vendor/Catch/projects/SelfTest/catch_self_test.hpp +0 -177
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/TestCatch.sln +0 -20
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/TestCatch/ReadMe.txt +0 -33
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/TestCatch/TestCatch.cpp +0 -8
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/TestCatch/TestCatch.vcproj +0 -398
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/UpgradeLog.XML +0 -12
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/_UpgradeReport_Files/UpgradeReport.css +0 -207
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/_UpgradeReport_Files/UpgradeReport.xslt +0 -232
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/_UpgradeReport_Files/UpgradeReport_Minus.gif +0 -0
- data/ext/snowcrash/test/vendor/Catch/projects/VS2008/TestCatch/_UpgradeReport_Files/UpgradeReport_Plus.gif +0 -0
- data/ext/snowcrash/test/vendor/Catch/projects/VS2010/TestCatch/TestCatch.sln +0 -20
- data/ext/snowcrash/test/vendor/Catch/projects/VS2010/TestCatch/TestCatch/ReadMe.txt +0 -33
- data/ext/snowcrash/test/vendor/Catch/projects/VS2010/TestCatch/TestCatch/TestCatch.cpp +0 -8
- data/ext/snowcrash/test/vendor/Catch/projects/VS2010/TestCatch/TestCatch/TestCatch.vcxproj +0 -149
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTest.xcodeproj/project.pbxproj +0 -440
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTest.xcodeproj/xcuserdata/phil.xcuserdatad/xcdebugger/Breakpoints.xcbkptlist +0 -81
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTest.xcodeproj/xcuserdata/phil.xcuserdatad/xcschemes/Test.xcscheme +0 -154
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTest.xcodeproj/xcuserdata/phil.xcuserdatad/xcschemes/xcschememanagement.plist +0 -22
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTestSingle/CatchSelfTestSingle.1 +0 -79
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/CatchSelfTestSingle/CatchSelfTestSingle.xcodeproj/project.pbxproj +0 -246
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/CatchOCTestCase.h +0 -25
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/CatchOCTestCase.mm +0 -45
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/Main.mm +0 -1
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/OCTest.1 +0 -79
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/OCTest.mm +0 -28
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/OCTest.xcodeproj/project.pbxproj +0 -259
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/OCTest_Prefix.pch +0 -7
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/TestObj.h +0 -25
- data/ext/snowcrash/test/vendor/Catch/projects/XCode3/OCTest/TestObj.m +0 -18
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTest.xcodeproj/project.pbxproj +0 -667
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTest.xcodeproj/xcuserdata/Phil.xcuserdatad/xcschemes/xcschememanagement.plist +0 -22
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTest/CatchSelfTest.1 +0 -79
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTest/catch_text.cpp +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTestSingle.xcodeproj/project.pbxproj +0 -264
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTestSingle.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/CatchSelfTest/CatchSelfTestSingle/dummy.txt +0 -0
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest.xcodeproj/project.pbxproj +0 -249
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/CatchOCTestCase.h +0 -25
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/CatchOCTestCase.mm +0 -82
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/Main.mm +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/OCTest.1 +0 -79
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/OCTest.mm +0 -28
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/TestObj.h +0 -28
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/OCTest/OCTest/TestObj.m +0 -25
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest.xcodeproj/project.pbxproj +0 -299
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest/OCTest.mm +0 -27
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest/TestObj.h +0 -25
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest/TestObj.m +0 -18
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest/en.lproj/InfoPlist.strings +0 -2
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest/iOSTest-Info.plist +0 -47
- data/ext/snowcrash/test/vendor/Catch/projects/XCode4/iOSTest/iOSTest/iOSTest-Prefix.pch +0 -14
- data/ext/snowcrash/test/vendor/Catch/projects/runners/iTchRunner/internal/iTchRunnerAppDelegate.h +0 -114
- data/ext/snowcrash/test/vendor/Catch/projects/runners/iTchRunner/internal/iTchRunnerMainView.h +0 -189
- data/ext/snowcrash/test/vendor/Catch/projects/runners/iTchRunner/internal/iTchRunnerReporter.h +0 -115
- data/ext/snowcrash/test/vendor/Catch/projects/runners/iTchRunner/itChRunnerMain.mm +0 -27
- data/ext/snowcrash/test/vendor/Catch/projects/runners/iTchRunner/readme +0 -6
- data/ext/snowcrash/test/vendor/Catch/scripts/approvalTests.py +0 -63
- data/ext/snowcrash/test/vendor/Catch/scripts/approve.py +0 -14
- data/ext/snowcrash/test/vendor/Catch/scripts/generateSingleHeader.py +0 -117
- data/ext/snowcrash/test/vendor/Catch/scripts/scriptCommon.py +0 -4
- data/ext/snowcrash/test/vendor/Catch/single_include/catch.hpp +0 -8046
- data/ext/snowcrash/tools/README.md +0 -27
- data/ext/snowcrash/tools/gyp/LICENSE +0 -27
- data/ext/snowcrash/tools/gyp/gyptest.py +0 -274
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSSettings_test.py +0 -1483
- data/ext/snowcrash/tools/gyp/pylib/gyp/common_test.py +0 -72
- data/ext/snowcrash/tools/gyp/pylib/gyp/easy_xml_test.py +0 -103
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/msvs_test.py +0 -37
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/ninja_test.py +0 -44
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/xcode_test.py +0 -23
- data/ext/snowcrash/tools/gyp/pylib/gyp/input_test.py +0 -90
- data/ext/snowcrash/tools/gyp/tools/README +0 -15
- data/ext/snowcrash/tools/gyp/tools/Xcode/README +0 -5
- data/ext/snowcrash/tools/gyp/tools/emacs/README +0 -12
- data/ext/snowcrash/tools/gyp/tools/emacs/gyp-tests.el +0 -63
- data/ext/snowcrash/tools/gyp/tools/emacs/run-unit-tests.sh +0 -7
- data/ext/snowcrash/tools/gyp/tools/emacs/testdata/media.gyp +0 -1105
- data/ext/snowcrash/tools/gyp/tools/emacs/testdata/media.gyp.fontified +0 -1107
- data/pkg/redsnow-0.1.3.gem +0 -0
- data/pkg/redsnow-0.1.4.gem +0 -0
- data/pkg/redsnow-0.1.5.gem +0 -0
- data/pkg/redsnow-0.1.6.gem +0 -0
- data/pkg/redsnow-0.2.0.gem +0 -0
- data/pkg/redsnow-0.2.1.gem +0 -0
- data/pkg/redsnow-0.3.1.gem +0 -0
- data/test/_helper.rb +0 -15
- data/test/fixtures/sample-api-ast.json +0 -97
- data/test/fixtures/sample-api-sourcemap.json +0 -169
- data/test/fixtures/sample-api.apib +0 -20
- data/test/redsnow_binding_test.rb +0 -52
- data/test/redsnow_options_test.rb +0 -42
- data/test/redsnow_parseresult_test.rb +0 -54
- data/test/redsnow_test.rb +0 -323
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
Copyright (c) 2009, Hideyuki Tanaka
|
|
2
|
-
|
|
3
|
-
All rights reserved.
|
|
4
|
-
|
|
5
|
-
Redistribution and use in source and binary forms, with or without
|
|
6
|
-
modification, are permitted provided that the following conditions are met:
|
|
7
|
-
|
|
8
|
-
* Redistributions of source code must retain the above copyright
|
|
9
|
-
notice, this list of conditions and the following disclaimer.
|
|
10
|
-
|
|
11
|
-
* Redistributions in binary form must reproduce the above
|
|
12
|
-
copyright notice, this list of conditions and the following
|
|
13
|
-
disclaimer in the documentation and/or other materials provided
|
|
14
|
-
with the distribution.
|
|
15
|
-
|
|
16
|
-
* Neither the name of Hideyuki Tanaka nor the names of other
|
|
17
|
-
contributors may be used to endorse or promote products derived
|
|
18
|
-
from this software without specific prior written permission.
|
|
19
|
-
|
|
20
|
-
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
21
|
-
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
22
|
-
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
23
|
-
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
24
|
-
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
25
|
-
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
26
|
-
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
27
|
-
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
28
|
-
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
29
|
-
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
30
|
-
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
=============================================
|
|
2
|
-
cmdline: A simple command line parser for C++
|
|
3
|
-
=============================================
|
|
4
|
-
|
|
5
|
-
About
|
|
6
|
-
-----
|
|
7
|
-
|
|
8
|
-
This is a simple command line parser for C++.
|
|
9
|
-
|
|
10
|
-
- Easy to use
|
|
11
|
-
- Only one header file
|
|
12
|
-
- Automatic type check
|
|
13
|
-
|
|
14
|
-
Sample
|
|
15
|
-
------
|
|
16
|
-
|
|
17
|
-
Here show sample usages of cmdline.
|
|
18
|
-
|
|
19
|
-
Normal usage
|
|
20
|
-
============
|
|
21
|
-
|
|
22
|
-
This is an example of simple usage.
|
|
23
|
-
|
|
24
|
-
::
|
|
25
|
-
|
|
26
|
-
// include cmdline.h
|
|
27
|
-
#include "cmdline.h"
|
|
28
|
-
|
|
29
|
-
int main(int argc, char *argv[])
|
|
30
|
-
{
|
|
31
|
-
// create a parser
|
|
32
|
-
cmdline::parser a;
|
|
33
|
-
|
|
34
|
-
// add specified type of variable.
|
|
35
|
-
// 1st argument is long name
|
|
36
|
-
// 2nd argument is short name (no short name if '\0' specified)
|
|
37
|
-
// 3rd argument is description
|
|
38
|
-
// 4th argument is mandatory (optional. default is false)
|
|
39
|
-
// 5th argument is default value (optional. it used when mandatory is false)
|
|
40
|
-
a.add<string>("host", 'h', "host name", true, "");
|
|
41
|
-
|
|
42
|
-
// 6th argument is extra constraint.
|
|
43
|
-
// Here, port number must be 1 to 65535 by cmdline::range().
|
|
44
|
-
a.add<int>("port", 'p', "port number", false, 80, cmdline::range(1, 65535));
|
|
45
|
-
|
|
46
|
-
// cmdline::oneof() can restrict options.
|
|
47
|
-
a.add<string>("type", 't', "protocol type", false, "http", cmdline::oneof<string>("http", "https", "ssh", "ftp"));
|
|
48
|
-
|
|
49
|
-
// Boolean flags also can be defined.
|
|
50
|
-
// Call add method without a type parameter.
|
|
51
|
-
a.add("gzip", '\0', "gzip when transfer");
|
|
52
|
-
|
|
53
|
-
// Run parser.
|
|
54
|
-
// It returns only if command line arguments are valid.
|
|
55
|
-
// If arguments are invalid, a parser output error msgs then exit program.
|
|
56
|
-
// If help flag ('--help' or '-?') is specified, a parser output usage message then exit program.
|
|
57
|
-
a.parse_check(argc, argv);
|
|
58
|
-
|
|
59
|
-
// use flag values
|
|
60
|
-
cout << a.get<string>("type") << "://"
|
|
61
|
-
<< a.get<string>("host") << ":"
|
|
62
|
-
<< a.get<int>("port") << endl;
|
|
63
|
-
|
|
64
|
-
// boolean flags are referred by calling exist() method.
|
|
65
|
-
if (a.exist("gzip")) cout << "gzip" << endl;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
Here are some execution results:
|
|
69
|
-
|
|
70
|
-
::
|
|
71
|
-
|
|
72
|
-
$ ./test
|
|
73
|
-
usage: ./test --host=string [options] ...
|
|
74
|
-
options:
|
|
75
|
-
-h, --host host name (string)
|
|
76
|
-
-p, --port port number (int [=80])
|
|
77
|
-
-t, --type protocol type (string [=http])
|
|
78
|
-
--gzip gzip when transfer
|
|
79
|
-
-?, --help print this message
|
|
80
|
-
|
|
81
|
-
::
|
|
82
|
-
|
|
83
|
-
$ ./test -?
|
|
84
|
-
usage: ./test --host=string [options] ...
|
|
85
|
-
options:
|
|
86
|
-
-h, --host host name (string)
|
|
87
|
-
-p, --port port number (int [=80])
|
|
88
|
-
-t, --type protocol type (string [=http])
|
|
89
|
-
--gzip gzip when transfer
|
|
90
|
-
-?, --help print this message
|
|
91
|
-
|
|
92
|
-
::
|
|
93
|
-
|
|
94
|
-
$ ./test --host=github.com
|
|
95
|
-
http://github.com:80
|
|
96
|
-
|
|
97
|
-
::
|
|
98
|
-
|
|
99
|
-
$ ./test --host=github.com -t ftp
|
|
100
|
-
ftp://github.com:80
|
|
101
|
-
|
|
102
|
-
::
|
|
103
|
-
|
|
104
|
-
$ ./test --host=github.com -t ttp
|
|
105
|
-
option value is invalid: --type=ttp
|
|
106
|
-
usage: ./test --host=string [options] ...
|
|
107
|
-
options:
|
|
108
|
-
-h, --host host name (string)
|
|
109
|
-
-p, --port port number (int [=80])
|
|
110
|
-
-t, --type protocol type (string [=http])
|
|
111
|
-
--gzip gzip when transfer
|
|
112
|
-
-?, --help print this message
|
|
113
|
-
|
|
114
|
-
::
|
|
115
|
-
|
|
116
|
-
$ ./test --host=github.com -p 4545
|
|
117
|
-
http://github.com:4545
|
|
118
|
-
|
|
119
|
-
::
|
|
120
|
-
|
|
121
|
-
$ ./test --host=github.com -p 100000
|
|
122
|
-
option value is invalid: --port=100000
|
|
123
|
-
usage: ./test --host=string [options] ...
|
|
124
|
-
options:
|
|
125
|
-
-h, --host host name (string)
|
|
126
|
-
-p, --port port number (int [=80])
|
|
127
|
-
-t, --type protocol type (string [=http])
|
|
128
|
-
--gzip gzip when transfer
|
|
129
|
-
-?, --help print this message
|
|
130
|
-
|
|
131
|
-
::
|
|
132
|
-
|
|
133
|
-
$ ./test --host=github.com --gzip
|
|
134
|
-
http://github.com:80
|
|
135
|
-
gzip
|
|
136
|
-
|
|
137
|
-
Extra Options
|
|
138
|
-
=============
|
|
139
|
-
|
|
140
|
-
- rest of arguments
|
|
141
|
-
|
|
142
|
-
Rest of arguments are referenced by rest() method.
|
|
143
|
-
It returns vector of string.
|
|
144
|
-
Usualy, they are used to specify filenames, and so on.
|
|
145
|
-
|
|
146
|
-
::
|
|
147
|
-
|
|
148
|
-
for (int i = 0; i < a.rest().size(); i++)
|
|
149
|
-
cout << a.rest()[i] << endl\;
|
|
150
|
-
|
|
151
|
-
- footer
|
|
152
|
-
|
|
153
|
-
footer() method is add a footer text of usage.
|
|
154
|
-
|
|
155
|
-
::
|
|
156
|
-
|
|
157
|
-
...
|
|
158
|
-
a.footer("filename ...");
|
|
159
|
-
...
|
|
160
|
-
|
|
161
|
-
Result is:
|
|
162
|
-
|
|
163
|
-
::
|
|
164
|
-
|
|
165
|
-
$ ./test
|
|
166
|
-
usage: ./test --host=string [options] ... filename ...
|
|
167
|
-
options:
|
|
168
|
-
-h, --host host name (string)
|
|
169
|
-
-p, --port port number (int [=80])
|
|
170
|
-
-t, --type protocol type (string [=http])
|
|
171
|
-
--gzip gzip when transfer
|
|
172
|
-
-?, --help print this message
|
|
173
|
-
|
|
174
|
-
- program name
|
|
175
|
-
|
|
176
|
-
A parser shows program name to usage message.
|
|
177
|
-
Default program name is determin by argv[0].
|
|
178
|
-
set_program_name() method can set any string to program name.
|
|
179
|
-
|
|
180
|
-
Process flags manually
|
|
181
|
-
----------------------
|
|
182
|
-
|
|
183
|
-
parse_check() method parses command line arguments and
|
|
184
|
-
check error and help flag.
|
|
185
|
-
|
|
186
|
-
You can do this process mannually.
|
|
187
|
-
bool parse() method parses command line arguments then
|
|
188
|
-
returns if they are valid.
|
|
189
|
-
You should check the result, and do what you want yourself.
|
|
190
|
-
|
|
191
|
-
(For more information, you may read test2.cpp.)
|
|
@@ -1,817 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright (c) 2009, Hideyuki Tanaka
|
|
3
|
-
All rights reserved.
|
|
4
|
-
|
|
5
|
-
Redistribution and use in source and binary forms, with or without
|
|
6
|
-
modification, are permitted provided that the following conditions are met:
|
|
7
|
-
* Redistributions of source code must retain the above copyright
|
|
8
|
-
notice, this list of conditions and the following disclaimer.
|
|
9
|
-
* Redistributions in binary form must reproduce the above copyright
|
|
10
|
-
notice, this list of conditions and the following disclaimer in the
|
|
11
|
-
documentation and/or other materials provided with the distribution.
|
|
12
|
-
* Neither the name of the <organization> nor the
|
|
13
|
-
names of its contributors may be used to endorse or promote products
|
|
14
|
-
derived from this software without specific prior written permission.
|
|
15
|
-
|
|
16
|
-
THIS SOFTWARE IS PROVIDED BY <copyright holder> ''AS IS'' AND ANY
|
|
17
|
-
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
18
|
-
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
19
|
-
DISCLAIMED. IN NO EVENT SHALL <copyright holder> BE LIABLE FOR ANY
|
|
20
|
-
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
21
|
-
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
22
|
-
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
23
|
-
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
24
|
-
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
25
|
-
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
26
|
-
*/
|
|
27
|
-
|
|
28
|
-
#pragma once
|
|
29
|
-
|
|
30
|
-
#include <iostream>
|
|
31
|
-
#include <sstream>
|
|
32
|
-
#include <vector>
|
|
33
|
-
#include <map>
|
|
34
|
-
#include <string>
|
|
35
|
-
#include <stdexcept>
|
|
36
|
-
#include <typeinfo>
|
|
37
|
-
#include <cstring>
|
|
38
|
-
#include <algorithm>
|
|
39
|
-
|
|
40
|
-
#if defined(__clang__) || defined(__GNUC__)
|
|
41
|
-
#include <cxxabi.h>
|
|
42
|
-
#endif
|
|
43
|
-
|
|
44
|
-
#include <cstdlib>
|
|
45
|
-
|
|
46
|
-
namespace cmdline{
|
|
47
|
-
|
|
48
|
-
namespace detail{
|
|
49
|
-
|
|
50
|
-
template <typename Target, typename Source, bool Same>
|
|
51
|
-
class lexical_cast_t{
|
|
52
|
-
public:
|
|
53
|
-
static Target cast(const Source &arg){
|
|
54
|
-
Target ret;
|
|
55
|
-
std::stringstream ss;
|
|
56
|
-
if (!(ss<<arg && ss>>ret && ss.eof()))
|
|
57
|
-
throw std::bad_cast();
|
|
58
|
-
|
|
59
|
-
return ret;
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
template <typename Target, typename Source>
|
|
64
|
-
class lexical_cast_t<Target, Source, true>{
|
|
65
|
-
public:
|
|
66
|
-
static Target cast(const Source &arg){
|
|
67
|
-
return arg;
|
|
68
|
-
}
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
template <typename Source>
|
|
72
|
-
class lexical_cast_t<std::string, Source, false>{
|
|
73
|
-
public:
|
|
74
|
-
static std::string cast(const Source &arg){
|
|
75
|
-
std::ostringstream ss;
|
|
76
|
-
ss<<arg;
|
|
77
|
-
return ss.str();
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
template <typename Target>
|
|
82
|
-
class lexical_cast_t<Target, std::string, false>{
|
|
83
|
-
public:
|
|
84
|
-
static Target cast(const std::string &arg){
|
|
85
|
-
Target ret;
|
|
86
|
-
std::istringstream ss(arg);
|
|
87
|
-
if (!(ss>>ret && ss.eof()))
|
|
88
|
-
throw std::bad_cast();
|
|
89
|
-
return ret;
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
template <typename T1, typename T2>
|
|
94
|
-
struct is_same {
|
|
95
|
-
static const bool value = false;
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
template <typename T>
|
|
99
|
-
struct is_same<T, T>{
|
|
100
|
-
static const bool value = true;
|
|
101
|
-
};
|
|
102
|
-
|
|
103
|
-
template<typename Target, typename Source>
|
|
104
|
-
Target lexical_cast(const Source &arg)
|
|
105
|
-
{
|
|
106
|
-
return lexical_cast_t<Target, Source, detail::is_same<Target, Source>::value>::cast(arg);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
static inline std::string demangle(const std::string &name)
|
|
110
|
-
{
|
|
111
|
-
#if defined(__clang__) || defined(__GNUC__)
|
|
112
|
-
int status=0;
|
|
113
|
-
char *p=abi::__cxa_demangle(name.c_str(), 0, 0, &status);
|
|
114
|
-
std::string ret(p);
|
|
115
|
-
free(p);
|
|
116
|
-
return ret;
|
|
117
|
-
#else
|
|
118
|
-
return name;
|
|
119
|
-
#endif
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
template <class T>
|
|
123
|
-
std::string readable_typename()
|
|
124
|
-
{
|
|
125
|
-
return demangle(typeid(T).name());
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
template <class T>
|
|
129
|
-
std::string default_value(T def)
|
|
130
|
-
{
|
|
131
|
-
return detail::lexical_cast<std::string>(def);
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
template <>
|
|
135
|
-
inline std::string readable_typename<std::string>()
|
|
136
|
-
{
|
|
137
|
-
return "string";
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
} // detail
|
|
141
|
-
|
|
142
|
-
//-----
|
|
143
|
-
|
|
144
|
-
class cmdline_error : public std::exception {
|
|
145
|
-
public:
|
|
146
|
-
cmdline_error(const std::string &msg): msg(msg){}
|
|
147
|
-
~cmdline_error() throw() {}
|
|
148
|
-
const char *what() const throw() { return msg.c_str(); }
|
|
149
|
-
private:
|
|
150
|
-
std::string msg;
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
template <class T>
|
|
154
|
-
struct default_reader{
|
|
155
|
-
T operator()(const std::string &str){
|
|
156
|
-
return detail::lexical_cast<T>(str);
|
|
157
|
-
}
|
|
158
|
-
};
|
|
159
|
-
|
|
160
|
-
template <class T>
|
|
161
|
-
struct range_reader{
|
|
162
|
-
range_reader(const T &low, const T &high): low(low), high(high) {}
|
|
163
|
-
T operator()(const std::string &s) const {
|
|
164
|
-
T ret=default_reader<T>()(s);
|
|
165
|
-
if (!(ret>=low && ret<=high)) throw cmdline::cmdline_error("range_error");
|
|
166
|
-
return ret;
|
|
167
|
-
}
|
|
168
|
-
private:
|
|
169
|
-
T low, high;
|
|
170
|
-
};
|
|
171
|
-
|
|
172
|
-
template <class T>
|
|
173
|
-
range_reader<T> range(const T &low, const T &high)
|
|
174
|
-
{
|
|
175
|
-
return range_reader<T>(low, high);
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
template <class T>
|
|
179
|
-
struct oneof_reader{
|
|
180
|
-
T operator()(const std::string &s){
|
|
181
|
-
T ret=default_reader<T>()(s);
|
|
182
|
-
if (std::find(alt.begin(), alt.end(), ret)==alt.end())
|
|
183
|
-
throw cmdline_error("");
|
|
184
|
-
return ret;
|
|
185
|
-
}
|
|
186
|
-
void add(const T &v){ alt.push_back(v); }
|
|
187
|
-
private:
|
|
188
|
-
std::vector<T> alt;
|
|
189
|
-
};
|
|
190
|
-
|
|
191
|
-
template <class T>
|
|
192
|
-
oneof_reader<T> oneof(T a1)
|
|
193
|
-
{
|
|
194
|
-
oneof_reader<T> ret;
|
|
195
|
-
ret.add(a1);
|
|
196
|
-
return ret;
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
template <class T>
|
|
200
|
-
oneof_reader<T> oneof(T a1, T a2)
|
|
201
|
-
{
|
|
202
|
-
oneof_reader<T> ret;
|
|
203
|
-
ret.add(a1);
|
|
204
|
-
ret.add(a2);
|
|
205
|
-
return ret;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
template <class T>
|
|
209
|
-
oneof_reader<T> oneof(T a1, T a2, T a3)
|
|
210
|
-
{
|
|
211
|
-
oneof_reader<T> ret;
|
|
212
|
-
ret.add(a1);
|
|
213
|
-
ret.add(a2);
|
|
214
|
-
ret.add(a3);
|
|
215
|
-
return ret;
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
template <class T>
|
|
219
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4)
|
|
220
|
-
{
|
|
221
|
-
oneof_reader<T> ret;
|
|
222
|
-
ret.add(a1);
|
|
223
|
-
ret.add(a2);
|
|
224
|
-
ret.add(a3);
|
|
225
|
-
ret.add(a4);
|
|
226
|
-
return ret;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
template <class T>
|
|
230
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4, T a5)
|
|
231
|
-
{
|
|
232
|
-
oneof_reader<T> ret;
|
|
233
|
-
ret.add(a1);
|
|
234
|
-
ret.add(a2);
|
|
235
|
-
ret.add(a3);
|
|
236
|
-
ret.add(a4);
|
|
237
|
-
ret.add(a5);
|
|
238
|
-
return ret;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
template <class T>
|
|
242
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4, T a5, T a6)
|
|
243
|
-
{
|
|
244
|
-
oneof_reader<T> ret;
|
|
245
|
-
ret.add(a1);
|
|
246
|
-
ret.add(a2);
|
|
247
|
-
ret.add(a3);
|
|
248
|
-
ret.add(a4);
|
|
249
|
-
ret.add(a5);
|
|
250
|
-
ret.add(a6);
|
|
251
|
-
return ret;
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
template <class T>
|
|
255
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4, T a5, T a6, T a7)
|
|
256
|
-
{
|
|
257
|
-
oneof_reader<T> ret;
|
|
258
|
-
ret.add(a1);
|
|
259
|
-
ret.add(a2);
|
|
260
|
-
ret.add(a3);
|
|
261
|
-
ret.add(a4);
|
|
262
|
-
ret.add(a5);
|
|
263
|
-
ret.add(a6);
|
|
264
|
-
ret.add(a7);
|
|
265
|
-
return ret;
|
|
266
|
-
}
|
|
267
|
-
|
|
268
|
-
template <class T>
|
|
269
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4, T a5, T a6, T a7, T a8)
|
|
270
|
-
{
|
|
271
|
-
oneof_reader<T> ret;
|
|
272
|
-
ret.add(a1);
|
|
273
|
-
ret.add(a2);
|
|
274
|
-
ret.add(a3);
|
|
275
|
-
ret.add(a4);
|
|
276
|
-
ret.add(a5);
|
|
277
|
-
ret.add(a6);
|
|
278
|
-
ret.add(a7);
|
|
279
|
-
ret.add(a8);
|
|
280
|
-
return ret;
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
template <class T>
|
|
284
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4, T a5, T a6, T a7, T a8, T a9)
|
|
285
|
-
{
|
|
286
|
-
oneof_reader<T> ret;
|
|
287
|
-
ret.add(a1);
|
|
288
|
-
ret.add(a2);
|
|
289
|
-
ret.add(a3);
|
|
290
|
-
ret.add(a4);
|
|
291
|
-
ret.add(a5);
|
|
292
|
-
ret.add(a6);
|
|
293
|
-
ret.add(a7);
|
|
294
|
-
ret.add(a8);
|
|
295
|
-
ret.add(a9);
|
|
296
|
-
return ret;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
template <class T>
|
|
300
|
-
oneof_reader<T> oneof(T a1, T a2, T a3, T a4, T a5, T a6, T a7, T a8, T a9, T a10)
|
|
301
|
-
{
|
|
302
|
-
oneof_reader<T> ret;
|
|
303
|
-
ret.add(a1);
|
|
304
|
-
ret.add(a2);
|
|
305
|
-
ret.add(a3);
|
|
306
|
-
ret.add(a4);
|
|
307
|
-
ret.add(a5);
|
|
308
|
-
ret.add(a6);
|
|
309
|
-
ret.add(a7);
|
|
310
|
-
ret.add(a8);
|
|
311
|
-
ret.add(a9);
|
|
312
|
-
ret.add(a10);
|
|
313
|
-
return ret;
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
//-----
|
|
317
|
-
|
|
318
|
-
class parser{
|
|
319
|
-
public:
|
|
320
|
-
parser(){
|
|
321
|
-
}
|
|
322
|
-
~parser(){
|
|
323
|
-
for (std::map<std::string, option_base*>::iterator p=options.begin();
|
|
324
|
-
p!=options.end(); p++)
|
|
325
|
-
delete p->second;
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
void add(const std::string &name,
|
|
329
|
-
char short_name=0,
|
|
330
|
-
const std::string &desc=""){
|
|
331
|
-
if (options.count(name)) throw cmdline_error("multiple definition: "+name);
|
|
332
|
-
options[name]=new option_without_value(name, short_name, desc);
|
|
333
|
-
ordered.push_back(options[name]);
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
template <class T>
|
|
337
|
-
void add(const std::string &name,
|
|
338
|
-
char short_name=0,
|
|
339
|
-
const std::string &desc="",
|
|
340
|
-
bool need=true,
|
|
341
|
-
const T def=T()){
|
|
342
|
-
add(name, short_name, desc, need, def, default_reader<T>());
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
template <class T, class F>
|
|
346
|
-
void add(const std::string &name,
|
|
347
|
-
char short_name=0,
|
|
348
|
-
const std::string &desc="",
|
|
349
|
-
bool need=true,
|
|
350
|
-
const T def=T(),
|
|
351
|
-
F reader=F()){
|
|
352
|
-
if (options.count(name)) throw cmdline_error("multiple definition: "+name);
|
|
353
|
-
options[name]=new option_with_value_with_reader<T, F>(name, short_name, need, def, desc, reader);
|
|
354
|
-
ordered.push_back(options[name]);
|
|
355
|
-
}
|
|
356
|
-
|
|
357
|
-
void footer(const std::string &f){
|
|
358
|
-
ftr=f;
|
|
359
|
-
}
|
|
360
|
-
|
|
361
|
-
void set_program_name(const std::string &name){
|
|
362
|
-
prog_name=name;
|
|
363
|
-
}
|
|
364
|
-
|
|
365
|
-
bool exist(const std::string &name) const {
|
|
366
|
-
if (options.count(name)==0) throw cmdline_error("there is no flag: --"+name);
|
|
367
|
-
return options.find(name)->second->has_set();
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
template <class T>
|
|
371
|
-
const T &get(const std::string &name) const {
|
|
372
|
-
if (options.count(name)==0) throw cmdline_error("there is no flag: --"+name);
|
|
373
|
-
const option_with_value<T> *p=dynamic_cast<const option_with_value<T>*>(options.find(name)->second);
|
|
374
|
-
if (p==NULL) throw cmdline_error("type mismatch flag '"+name+"'");
|
|
375
|
-
return p->get();
|
|
376
|
-
}
|
|
377
|
-
|
|
378
|
-
const std::vector<std::string> &rest() const {
|
|
379
|
-
return others;
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
bool parse(const std::string &arg){
|
|
383
|
-
std::vector<std::string> args;
|
|
384
|
-
|
|
385
|
-
std::string buf;
|
|
386
|
-
bool in_quote=false;
|
|
387
|
-
for (std::string::size_type i=0; i<arg.length(); i++){
|
|
388
|
-
if (arg[i]=='\"'){
|
|
389
|
-
in_quote=!in_quote;
|
|
390
|
-
continue;
|
|
391
|
-
}
|
|
392
|
-
|
|
393
|
-
if (arg[i]==' ' && !in_quote){
|
|
394
|
-
args.push_back(buf);
|
|
395
|
-
buf="";
|
|
396
|
-
continue;
|
|
397
|
-
}
|
|
398
|
-
|
|
399
|
-
if (arg[i]=='\\'){
|
|
400
|
-
i++;
|
|
401
|
-
if (i>=arg.length()){
|
|
402
|
-
errors.push_back("unexpected occurrence of '\\' at end of string");
|
|
403
|
-
return false;
|
|
404
|
-
}
|
|
405
|
-
}
|
|
406
|
-
|
|
407
|
-
buf+=arg[i];
|
|
408
|
-
}
|
|
409
|
-
|
|
410
|
-
if (in_quote){
|
|
411
|
-
errors.push_back("quote is not closed");
|
|
412
|
-
return false;
|
|
413
|
-
}
|
|
414
|
-
|
|
415
|
-
if (buf.length()>0)
|
|
416
|
-
args.push_back(buf);
|
|
417
|
-
|
|
418
|
-
for (size_t i=0; i<args.size(); i++)
|
|
419
|
-
std::cout<<"\""<<args[i]<<"\""<<std::endl;
|
|
420
|
-
|
|
421
|
-
return parse(args);
|
|
422
|
-
}
|
|
423
|
-
|
|
424
|
-
bool parse(const std::vector<std::string> &args){
|
|
425
|
-
int argc=static_cast<int>(args.size());
|
|
426
|
-
std::vector<const char*> argv(argc);
|
|
427
|
-
|
|
428
|
-
for (int i=0; i<argc; i++)
|
|
429
|
-
argv[i]=args[i].c_str();
|
|
430
|
-
|
|
431
|
-
return parse(argc, &argv[0]);
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
bool parse(int argc, const char * const argv[]){
|
|
435
|
-
errors.clear();
|
|
436
|
-
others.clear();
|
|
437
|
-
|
|
438
|
-
if (argc<1){
|
|
439
|
-
errors.push_back("argument number must be longer than 0");
|
|
440
|
-
return false;
|
|
441
|
-
}
|
|
442
|
-
if (prog_name=="")
|
|
443
|
-
prog_name=argv[0];
|
|
444
|
-
|
|
445
|
-
std::map<char, std::string> lookup;
|
|
446
|
-
for (std::map<std::string, option_base*>::iterator p=options.begin();
|
|
447
|
-
p!=options.end(); p++){
|
|
448
|
-
if (p->first.length()==0) continue;
|
|
449
|
-
char initial=p->second->short_name();
|
|
450
|
-
if (initial){
|
|
451
|
-
if (lookup.count(initial)>0){
|
|
452
|
-
lookup[initial]="";
|
|
453
|
-
errors.push_back(std::string("short option '")+initial+"' is ambiguous");
|
|
454
|
-
return false;
|
|
455
|
-
}
|
|
456
|
-
else lookup[initial]=p->first;
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
|
|
460
|
-
for (int i=1; i<argc; i++){
|
|
461
|
-
if (strncmp(argv[i], "--", 2)==0){
|
|
462
|
-
const char *p=strchr(argv[i]+2, '=');
|
|
463
|
-
if (p){
|
|
464
|
-
std::string name(argv[i]+2, p);
|
|
465
|
-
std::string val(p+1);
|
|
466
|
-
set_option(name, val);
|
|
467
|
-
}
|
|
468
|
-
else{
|
|
469
|
-
std::string name(argv[i]+2);
|
|
470
|
-
if (options.count(name)==0){
|
|
471
|
-
errors.push_back("undefined option: --"+name);
|
|
472
|
-
continue;
|
|
473
|
-
}
|
|
474
|
-
if (options[name]->has_value()){
|
|
475
|
-
if (i+1>=argc){
|
|
476
|
-
errors.push_back("option needs value: --"+name);
|
|
477
|
-
continue;
|
|
478
|
-
}
|
|
479
|
-
else{
|
|
480
|
-
i++;
|
|
481
|
-
set_option(name, argv[i]);
|
|
482
|
-
}
|
|
483
|
-
}
|
|
484
|
-
else{
|
|
485
|
-
set_option(name);
|
|
486
|
-
}
|
|
487
|
-
}
|
|
488
|
-
}
|
|
489
|
-
else if (strncmp(argv[i], "-", 1)==0){
|
|
490
|
-
if (!argv[i][1]) continue;
|
|
491
|
-
char last=argv[i][1];
|
|
492
|
-
for (int j=2; argv[i][j]; j++){
|
|
493
|
-
last=argv[i][j];
|
|
494
|
-
if (lookup.count(argv[i][j-1])==0){
|
|
495
|
-
errors.push_back(std::string("undefined short option: -")+argv[i][j-1]);
|
|
496
|
-
continue;
|
|
497
|
-
}
|
|
498
|
-
if (lookup[argv[i][j-1]]==""){
|
|
499
|
-
errors.push_back(std::string("ambiguous short option: -")+argv[i][j-1]);
|
|
500
|
-
continue;
|
|
501
|
-
}
|
|
502
|
-
set_option(lookup[argv[i][j-1]]);
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
if (lookup.count(last)==0){
|
|
506
|
-
errors.push_back(std::string("undefined short option: -")+last);
|
|
507
|
-
continue;
|
|
508
|
-
}
|
|
509
|
-
if (lookup[last]==""){
|
|
510
|
-
errors.push_back(std::string("ambiguous short option: -")+last);
|
|
511
|
-
continue;
|
|
512
|
-
}
|
|
513
|
-
|
|
514
|
-
if (i+1<argc && options[lookup[last]]->has_value()){
|
|
515
|
-
set_option(lookup[last], argv[i+1]);
|
|
516
|
-
i++;
|
|
517
|
-
}
|
|
518
|
-
else{
|
|
519
|
-
set_option(lookup[last]);
|
|
520
|
-
}
|
|
521
|
-
}
|
|
522
|
-
else{
|
|
523
|
-
others.push_back(argv[i]);
|
|
524
|
-
}
|
|
525
|
-
}
|
|
526
|
-
|
|
527
|
-
for (std::map<std::string, option_base*>::iterator p=options.begin();
|
|
528
|
-
p!=options.end(); p++)
|
|
529
|
-
if (!p->second->valid())
|
|
530
|
-
errors.push_back("need option: --"+std::string(p->first));
|
|
531
|
-
|
|
532
|
-
return errors.size()==0;
|
|
533
|
-
}
|
|
534
|
-
|
|
535
|
-
void parse_check(const std::string &arg){
|
|
536
|
-
if (!options.count("help"))
|
|
537
|
-
add("help", '?', "print this message");
|
|
538
|
-
check(0, parse(arg));
|
|
539
|
-
}
|
|
540
|
-
|
|
541
|
-
void parse_check(const std::vector<std::string> &args){
|
|
542
|
-
if (!options.count("help"))
|
|
543
|
-
add("help", '?', "print this message");
|
|
544
|
-
check(static_cast<int>(args.size()), parse(args));
|
|
545
|
-
}
|
|
546
|
-
|
|
547
|
-
void parse_check(int argc, const char *argv[]){
|
|
548
|
-
if (!options.count("help"))
|
|
549
|
-
add("help", '?', "print this message");
|
|
550
|
-
check(argc, parse(argc, argv));
|
|
551
|
-
}
|
|
552
|
-
|
|
553
|
-
std::string error() const{
|
|
554
|
-
return errors.size()>0?errors[0]:"";
|
|
555
|
-
}
|
|
556
|
-
|
|
557
|
-
std::string error_full() const{
|
|
558
|
-
std::ostringstream oss;
|
|
559
|
-
for (size_t i=0; i<errors.size(); i++)
|
|
560
|
-
oss<<errors[i]<<std::endl;
|
|
561
|
-
return oss.str();
|
|
562
|
-
}
|
|
563
|
-
|
|
564
|
-
std::string usage() const {
|
|
565
|
-
std::ostringstream oss;
|
|
566
|
-
oss<<"usage: "<<prog_name<<" ";
|
|
567
|
-
for (size_t i=0; i<ordered.size(); i++){
|
|
568
|
-
if (ordered[i]->must())
|
|
569
|
-
oss<<ordered[i]->short_description()<<" ";
|
|
570
|
-
}
|
|
571
|
-
|
|
572
|
-
oss<<"[options] ... "<<ftr<<std::endl;
|
|
573
|
-
oss<<"options:"<<std::endl;
|
|
574
|
-
|
|
575
|
-
size_t max_width=0;
|
|
576
|
-
for (size_t i=0; i<ordered.size(); i++){
|
|
577
|
-
max_width=std::max(max_width, ordered[i]->name().length());
|
|
578
|
-
}
|
|
579
|
-
for (size_t i=0; i<ordered.size(); i++){
|
|
580
|
-
if (ordered[i]->short_name()){
|
|
581
|
-
oss<<" -"<<ordered[i]->short_name()<<", ";
|
|
582
|
-
}
|
|
583
|
-
else{
|
|
584
|
-
oss<<" ";
|
|
585
|
-
}
|
|
586
|
-
|
|
587
|
-
oss<<"--"<<ordered[i]->name();
|
|
588
|
-
for (size_t j=ordered[i]->name().length(); j<max_width+4; j++)
|
|
589
|
-
oss<<' ';
|
|
590
|
-
oss<<ordered[i]->description()<<std::endl;
|
|
591
|
-
}
|
|
592
|
-
return oss.str();
|
|
593
|
-
}
|
|
594
|
-
|
|
595
|
-
private:
|
|
596
|
-
|
|
597
|
-
void check(int argc, bool ok){
|
|
598
|
-
if ((argc==1 && !ok) || exist("help")){
|
|
599
|
-
std::cerr<<usage();
|
|
600
|
-
exit(0);
|
|
601
|
-
}
|
|
602
|
-
|
|
603
|
-
if (!ok){
|
|
604
|
-
std::cerr<<error()<<std::endl<<usage();
|
|
605
|
-
exit(1);
|
|
606
|
-
}
|
|
607
|
-
}
|
|
608
|
-
|
|
609
|
-
void set_option(const std::string &name){
|
|
610
|
-
if (options.count(name)==0){
|
|
611
|
-
errors.push_back("undefined option: --"+name);
|
|
612
|
-
return;
|
|
613
|
-
}
|
|
614
|
-
if (!options[name]->set()){
|
|
615
|
-
errors.push_back("option needs value: --"+name);
|
|
616
|
-
return;
|
|
617
|
-
}
|
|
618
|
-
}
|
|
619
|
-
|
|
620
|
-
void set_option(const std::string &name, const std::string &value){
|
|
621
|
-
if (options.count(name)==0){
|
|
622
|
-
errors.push_back("undefined option: --"+name);
|
|
623
|
-
return;
|
|
624
|
-
}
|
|
625
|
-
if (!options[name]->set(value)){
|
|
626
|
-
errors.push_back("option value is invalid: --"+name+"="+value);
|
|
627
|
-
return;
|
|
628
|
-
}
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
class option_base{
|
|
632
|
-
public:
|
|
633
|
-
virtual ~option_base(){}
|
|
634
|
-
|
|
635
|
-
virtual bool has_value() const=0;
|
|
636
|
-
virtual bool set()=0;
|
|
637
|
-
virtual bool set(const std::string &value)=0;
|
|
638
|
-
virtual bool has_set() const=0;
|
|
639
|
-
virtual bool valid() const=0;
|
|
640
|
-
virtual bool must() const=0;
|
|
641
|
-
|
|
642
|
-
virtual const std::string &name() const=0;
|
|
643
|
-
virtual char short_name() const=0;
|
|
644
|
-
virtual const std::string &description() const=0;
|
|
645
|
-
virtual std::string short_description() const=0;
|
|
646
|
-
};
|
|
647
|
-
|
|
648
|
-
class option_without_value : public option_base {
|
|
649
|
-
public:
|
|
650
|
-
option_without_value(const std::string &name,
|
|
651
|
-
char short_name,
|
|
652
|
-
const std::string &desc)
|
|
653
|
-
:nam(name), snam(short_name), desc(desc), has(false){
|
|
654
|
-
}
|
|
655
|
-
~option_without_value(){}
|
|
656
|
-
|
|
657
|
-
bool has_value() const { return false; }
|
|
658
|
-
|
|
659
|
-
bool set(){
|
|
660
|
-
has=true;
|
|
661
|
-
return true;
|
|
662
|
-
}
|
|
663
|
-
|
|
664
|
-
bool set(const std::string &){
|
|
665
|
-
return false;
|
|
666
|
-
}
|
|
667
|
-
|
|
668
|
-
bool has_set() const {
|
|
669
|
-
return has;
|
|
670
|
-
}
|
|
671
|
-
|
|
672
|
-
bool valid() const{
|
|
673
|
-
return true;
|
|
674
|
-
}
|
|
675
|
-
|
|
676
|
-
bool must() const{
|
|
677
|
-
return false;
|
|
678
|
-
}
|
|
679
|
-
|
|
680
|
-
const std::string &name() const{
|
|
681
|
-
return nam;
|
|
682
|
-
}
|
|
683
|
-
|
|
684
|
-
char short_name() const{
|
|
685
|
-
return snam;
|
|
686
|
-
}
|
|
687
|
-
|
|
688
|
-
const std::string &description() const {
|
|
689
|
-
return desc;
|
|
690
|
-
}
|
|
691
|
-
|
|
692
|
-
std::string short_description() const{
|
|
693
|
-
return "--"+nam;
|
|
694
|
-
}
|
|
695
|
-
|
|
696
|
-
private:
|
|
697
|
-
std::string nam;
|
|
698
|
-
char snam;
|
|
699
|
-
std::string desc;
|
|
700
|
-
bool has;
|
|
701
|
-
};
|
|
702
|
-
|
|
703
|
-
template <class T>
|
|
704
|
-
class option_with_value : public option_base {
|
|
705
|
-
public:
|
|
706
|
-
option_with_value(const std::string &name,
|
|
707
|
-
char short_name,
|
|
708
|
-
bool need,
|
|
709
|
-
const T &def,
|
|
710
|
-
const std::string &desc)
|
|
711
|
-
: nam(name), snam(short_name), need(need), has(false)
|
|
712
|
-
, def(def), actual(def) {
|
|
713
|
-
this->desc=full_description(desc);
|
|
714
|
-
}
|
|
715
|
-
~option_with_value(){}
|
|
716
|
-
|
|
717
|
-
const T &get() const {
|
|
718
|
-
return actual;
|
|
719
|
-
}
|
|
720
|
-
|
|
721
|
-
bool has_value() const { return true; }
|
|
722
|
-
|
|
723
|
-
bool set(){
|
|
724
|
-
return false;
|
|
725
|
-
}
|
|
726
|
-
|
|
727
|
-
bool set(const std::string &value){
|
|
728
|
-
try{
|
|
729
|
-
actual=read(value);
|
|
730
|
-
has=true;
|
|
731
|
-
}
|
|
732
|
-
catch(const std::exception &){
|
|
733
|
-
return false;
|
|
734
|
-
}
|
|
735
|
-
return true;
|
|
736
|
-
}
|
|
737
|
-
|
|
738
|
-
bool has_set() const{
|
|
739
|
-
return has;
|
|
740
|
-
}
|
|
741
|
-
|
|
742
|
-
bool valid() const{
|
|
743
|
-
if (need && !has) return false;
|
|
744
|
-
return true;
|
|
745
|
-
}
|
|
746
|
-
|
|
747
|
-
bool must() const{
|
|
748
|
-
return need;
|
|
749
|
-
}
|
|
750
|
-
|
|
751
|
-
const std::string &name() const{
|
|
752
|
-
return nam;
|
|
753
|
-
}
|
|
754
|
-
|
|
755
|
-
char short_name() const{
|
|
756
|
-
return snam;
|
|
757
|
-
}
|
|
758
|
-
|
|
759
|
-
const std::string &description() const {
|
|
760
|
-
return desc;
|
|
761
|
-
}
|
|
762
|
-
|
|
763
|
-
std::string short_description() const{
|
|
764
|
-
return "--"+nam+"="+detail::readable_typename<T>();
|
|
765
|
-
}
|
|
766
|
-
|
|
767
|
-
protected:
|
|
768
|
-
std::string full_description(const std::string &desc){
|
|
769
|
-
return
|
|
770
|
-
desc+" ("+detail::readable_typename<T>()+
|
|
771
|
-
(need?"":" [="+detail::default_value<T>(def)+"]")
|
|
772
|
-
+")";
|
|
773
|
-
}
|
|
774
|
-
|
|
775
|
-
virtual T read(const std::string &s)=0;
|
|
776
|
-
|
|
777
|
-
std::string nam;
|
|
778
|
-
char snam;
|
|
779
|
-
bool need;
|
|
780
|
-
std::string desc;
|
|
781
|
-
|
|
782
|
-
bool has;
|
|
783
|
-
T def;
|
|
784
|
-
T actual;
|
|
785
|
-
};
|
|
786
|
-
|
|
787
|
-
template <class T, class F>
|
|
788
|
-
class option_with_value_with_reader : public option_with_value<T> {
|
|
789
|
-
public:
|
|
790
|
-
option_with_value_with_reader(const std::string &name,
|
|
791
|
-
char short_name,
|
|
792
|
-
bool need,
|
|
793
|
-
const T def,
|
|
794
|
-
const std::string &desc,
|
|
795
|
-
F reader)
|
|
796
|
-
: option_with_value<T>(name, short_name, need, def, desc), reader(reader){
|
|
797
|
-
}
|
|
798
|
-
|
|
799
|
-
private:
|
|
800
|
-
T read(const std::string &s){
|
|
801
|
-
return reader(s);
|
|
802
|
-
}
|
|
803
|
-
|
|
804
|
-
F reader;
|
|
805
|
-
};
|
|
806
|
-
|
|
807
|
-
std::map<std::string, option_base*> options;
|
|
808
|
-
std::vector<option_base*> ordered;
|
|
809
|
-
std::string ftr;
|
|
810
|
-
|
|
811
|
-
std::string prog_name;
|
|
812
|
-
std::vector<std::string> others;
|
|
813
|
-
|
|
814
|
-
std::vector<std::string> errors;
|
|
815
|
-
};
|
|
816
|
-
|
|
817
|
-
} // cmdline
|