redsnow 0.3.2 → 0.3.3
Sign up to get free protection for your applications and to get access to all the features.
- 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
|