opal 0.10.6 → 0.11.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.codeclimate.yml +19 -0
- data/.gitmodules +1 -1
- data/.jshintrc +1 -2
- data/.travis.yml +26 -18
- data/CHANGELOG.md +89 -23
- data/{CODE_OF_CONDUCT.md → CONDUCT.md} +0 -0
- data/Gemfile +19 -21
- data/HACKING.md +2 -0
- data/README.md +7 -6
- data/Rakefile +1 -1
- data/appveyor.yml +21 -4
- data/benchmark-ips/bm_case.rb +33 -0
- data/benchmark-ips/bm_constants_lookup.rb +13 -0
- data/benchmark-ips/bm_is_number.rb +29 -0
- data/benchmark-ips/bm_symbol_to_proc.rb +19 -0
- data/benchmark/bm_constant_lookup_big.rb +799 -0
- data/benchmark/bm_constant_lookup_small.rb +59 -0
- data/benchmark/bm_module_definition_big.rb +400 -0
- data/benchmark/bm_module_definition_small.rb +30 -0
- data/bin/opal-repl +23 -1
- data/docs/compiled_ruby.md +16 -14
- data/docs/faq.md +3 -3
- data/docs/rspec.md +2 -1
- data/docs/unsupported_features.md +6 -4
- data/examples/rack/Gemfile +1 -0
- data/examples/rack/app/application.rb +14 -3
- data/examples/rack/app/user.rb +2 -0
- data/examples/rack/config.ru +1 -1
- data/examples/rack/index.html.erb +1 -0
- data/lib/opal.rb +6 -1
- data/lib/opal/ast/builder.rb +17 -0
- data/lib/opal/ast/node.rb +30 -0
- data/lib/opal/builder.rb +14 -3
- data/lib/opal/builder_processors.rb +1 -0
- data/lib/opal/cli.rb +45 -59
- data/lib/opal/cli_options.rb +11 -7
- data/lib/opal/cli_runners.rb +1 -0
- data/lib/opal/cli_runners/applescript.rb +3 -3
- data/lib/opal/cli_runners/nashorn.rb +1 -0
- data/lib/opal/cli_runners/nodejs.rb +4 -1
- data/lib/opal/cli_runners/phantom.js +1 -2
- data/lib/opal/cli_runners/phantomjs.rb +3 -2
- data/lib/opal/cli_runners/server.rb +1 -0
- data/lib/opal/compiler.rb +145 -94
- data/lib/opal/config.rb +1 -0
- data/lib/opal/deprecations.rb +18 -0
- data/lib/opal/erb.rb +1 -0
- data/lib/opal/errors.rb +1 -0
- data/lib/opal/fragment.rb +1 -0
- data/lib/opal/hike_path_finder.rb +1 -0
- data/lib/opal/nodes.rb +3 -0
- data/lib/opal/nodes/arglist.rb +2 -1
- data/lib/opal/nodes/args/initialize_kwargs.rb +1 -0
- data/lib/opal/nodes/args/kwarg.rb +7 -7
- data/lib/opal/nodes/args/kwoptarg.rb +6 -7
- data/lib/opal/nodes/args/kwrestarg.rb +5 -5
- data/lib/opal/nodes/args/mlhsarg.rb +3 -2
- data/lib/opal/nodes/args/normarg.rb +6 -7
- data/lib/opal/nodes/args/optarg.rb +5 -7
- data/lib/opal/nodes/args/post_args.rb +6 -5
- data/lib/opal/nodes/args/post_kwargs.rb +1 -0
- data/lib/opal/nodes/args/restarg.rb +7 -7
- data/lib/opal/nodes/array.rb +1 -0
- data/lib/opal/nodes/base.rb +24 -3
- data/lib/opal/nodes/call.rb +167 -155
- data/lib/opal/nodes/call_special.rb +31 -217
- data/lib/opal/nodes/case.rb +36 -22
- data/lib/opal/nodes/class.rb +4 -3
- data/lib/opal/nodes/constants.rb +28 -48
- data/lib/opal/nodes/csend.rb +25 -0
- data/lib/opal/nodes/def.rb +49 -16
- data/lib/opal/nodes/defined.rb +170 -60
- data/lib/opal/nodes/definitions.rb +40 -133
- data/lib/opal/nodes/defs.rb +29 -0
- data/lib/opal/nodes/for.rb +52 -25
- data/lib/opal/nodes/hash.rb +12 -35
- data/lib/opal/nodes/helpers.rb +27 -54
- data/lib/opal/nodes/if.rb +21 -32
- data/lib/opal/nodes/inline_args.rb +12 -13
- data/lib/opal/nodes/iter.rb +61 -36
- data/lib/opal/nodes/literal.rb +189 -116
- data/lib/opal/nodes/logic.rb +20 -25
- data/lib/opal/nodes/masgn.rb +20 -18
- data/lib/opal/nodes/module.rb +10 -11
- data/lib/opal/nodes/node_with_args.rb +14 -17
- data/lib/opal/nodes/rescue.rb +37 -70
- data/lib/opal/nodes/runtime_helpers.rb +8 -3
- data/lib/opal/nodes/scope.rb +9 -5
- data/lib/opal/nodes/singleton_class.rb +4 -3
- data/lib/opal/nodes/super.rb +115 -87
- data/lib/opal/nodes/top.rb +7 -2
- data/lib/opal/nodes/variables.rb +46 -35
- data/lib/opal/nodes/while.rb +11 -1
- data/lib/opal/nodes/yield.rb +1 -17
- data/lib/opal/parser.rb +28 -770
- data/lib/opal/path_reader.rb +5 -1
- data/lib/opal/paths.rb +10 -4
- data/lib/opal/regexp_anchors.rb +1 -0
- data/lib/opal/rewriter.rb +60 -0
- data/lib/opal/rewriters/base.rb +60 -0
- data/lib/opal/rewriters/binary_operator_assignment.rb +144 -0
- data/lib/opal/rewriters/block_to_iter.rb +17 -0
- data/lib/opal/rewriters/break_finder.rb +34 -0
- data/lib/opal/rewriters/dot_js_syntax.rb +60 -0
- data/lib/opal/rewriters/explicit_writer_return.rb +58 -0
- data/lib/opal/rewriters/js_reserved_words.rb +111 -0
- data/lib/opal/rewriters/logical_operator_assignment.rb +155 -0
- data/lib/opal/rewriters/opal_engine_check.rb +42 -0
- data/lib/opal/rewriters/rubyspec/filters_rewriter.rb +67 -0
- data/lib/opal/server.rb +4 -0
- data/lib/opal/simple_server.rb +100 -0
- data/lib/opal/source_map.rb +1 -1
- data/lib/opal/util.rb +5 -5
- data/lib/opal/version.rb +2 -1
- data/lib/tilt/opal.rb +1 -0
- data/opal.gemspec +8 -7
- data/opal/README.md +1 -1
- data/opal/corelib/array.rb +137 -83
- data/opal/corelib/basic_object.rb +6 -6
- data/opal/corelib/class.rb +14 -11
- data/opal/corelib/complex.rb +5 -1
- data/opal/corelib/constants.rb +3 -3
- data/opal/corelib/enumerable.rb +129 -11
- data/opal/corelib/error.rb +35 -17
- data/opal/corelib/file.rb +65 -170
- data/opal/corelib/hash.rb +128 -13
- data/opal/corelib/helpers.rb +12 -15
- data/opal/corelib/io.rb +1 -0
- data/opal/corelib/kernel.rb +40 -21
- data/opal/corelib/marshal/read_buffer.rb +1 -1
- data/opal/corelib/method.rb +33 -13
- data/opal/corelib/module.rb +133 -81
- data/opal/corelib/number.rb +141 -25
- data/opal/corelib/numeric.rb +0 -8
- data/opal/corelib/process.rb +44 -4
- data/opal/corelib/random.rb +117 -0
- data/opal/corelib/random/seedrandom.js.rb +15 -0
- data/opal/corelib/range.rb +133 -10
- data/opal/corelib/regexp.rb +37 -9
- data/opal/corelib/runtime.js +601 -390
- data/opal/corelib/string.rb +39 -8
- data/opal/corelib/string/encoding.rb +51 -7
- data/opal/corelib/struct.rb +20 -0
- data/opal/corelib/time.rb +3 -3
- data/opal/corelib/variables.rb +1 -1
- data/opal/opal.rb +1 -0
- data/spec/filters/bugs/array.rb +5 -1
- data/spec/filters/bugs/basicobject.rb +2 -5
- data/spec/filters/bugs/bigdecimal.rb +8 -22
- data/spec/filters/bugs/class.rb +2 -1
- data/spec/filters/bugs/comparable.rb +5 -0
- data/spec/filters/bugs/date.rb +3 -3
- data/spec/filters/bugs/enumerable.rb +4 -11
- data/spec/filters/bugs/enumerator.rb +2 -4
- data/spec/filters/bugs/exception.rb +16 -2
- data/spec/filters/bugs/file.rb +8 -0
- data/spec/filters/bugs/float.rb +7 -1
- data/spec/filters/bugs/hash.rb +6 -2
- data/spec/filters/bugs/integer.rb +2 -0
- data/spec/filters/bugs/io.rb +8 -0
- data/spec/filters/bugs/kernel.rb +9 -138
- data/spec/filters/bugs/language.rb +89 -174
- data/spec/filters/bugs/marshal.rb +33 -35
- data/spec/filters/bugs/method.rb +0 -24
- data/spec/filters/bugs/module.rb +19 -55
- data/spec/filters/bugs/numeric.rb +0 -119
- data/spec/filters/bugs/pathname.rb +2 -0
- data/spec/filters/bugs/proc.rb +5 -4
- data/spec/filters/bugs/random.rb +7 -0
- data/spec/filters/bugs/range.rb +12 -120
- data/spec/filters/bugs/rational.rb +1 -1
- data/spec/filters/bugs/regexp.rb +2 -40
- data/spec/filters/bugs/set.rb +0 -1
- data/spec/filters/bugs/string.rb +5 -8
- data/spec/filters/bugs/stringscanner.rb +11 -19
- data/spec/filters/bugs/time.rb +7 -1
- data/spec/filters/bugs/unboundmethod.rb +1 -11
- data/spec/filters/unsupported/array.rb +5 -1
- data/spec/filters/unsupported/basicobject.rb +1 -1
- data/spec/filters/unsupported/bignum.rb +4 -1
- data/spec/filters/unsupported/class.rb +1 -1
- data/spec/filters/unsupported/delegator.rb +1 -1
- data/spec/filters/unsupported/enumerable.rb +1 -1
- data/spec/filters/unsupported/enumerator.rb +1 -1
- data/spec/filters/unsupported/file.rb +4 -0
- data/spec/filters/unsupported/fixnum.rb +1 -1
- data/spec/filters/unsupported/float.rb +4 -1
- data/spec/filters/unsupported/freeze.rb +27 -5
- data/spec/filters/unsupported/hash.rb +7 -15
- data/spec/filters/unsupported/integer.rb +1 -1
- data/spec/filters/unsupported/kernel.rb +2 -1
- data/spec/filters/unsupported/language.rb +6 -1
- data/spec/filters/unsupported/marshal.rb +1 -1
- data/spec/filters/unsupported/matchdata.rb +4 -1
- data/spec/filters/unsupported/math.rb +1 -1
- data/spec/filters/unsupported/pathname.rb +1 -1
- data/spec/filters/unsupported/privacy.rb +141 -9
- data/spec/filters/unsupported/proc.rb +1 -1
- data/spec/filters/unsupported/random.rb +4 -0
- data/spec/filters/unsupported/range.rb +7 -0
- data/spec/filters/unsupported/regexp.rb +25 -15
- data/spec/filters/unsupported/set.rb +1 -1
- data/spec/filters/unsupported/singleton.rb +1 -1
- data/spec/filters/unsupported/string.rb +110 -101
- data/spec/filters/unsupported/struct.rb +1 -1
- data/spec/filters/unsupported/symbol.rb +2 -1
- data/spec/filters/unsupported/taint.rb +22 -7
- data/spec/filters/unsupported/thread.rb +1 -1
- data/spec/filters/unsupported/time.rb +1 -1
- data/spec/lib/builder_spec.rb +17 -0
- data/spec/lib/cli_spec.rb +37 -8
- data/spec/lib/compiler/call_spec.rb +98 -66
- data/spec/lib/compiler_spec.rb +39 -30
- data/spec/lib/dependency_resolver_spec.rb +2 -2
- data/spec/lib/deprecations_spec.rb +16 -0
- data/spec/lib/fixtures/source_location_test.rb +7 -0
- data/spec/lib/rewriters/binary_operator_assignment_spec.rb +151 -0
- data/spec/lib/rewriters/block_to_iter_spec.rb +28 -0
- data/spec/lib/rewriters/dot_js_syntax_spec.rb +108 -0
- data/spec/lib/rewriters/explicit_writer_return_spec.rb +186 -0
- data/spec/lib/rewriters/js_reserved_words_spec.rb +116 -0
- data/spec/lib/rewriters/logical_operator_assignment_spec.rb +202 -0
- data/spec/lib/rewriters/opal_engine_check_spec.rb +82 -0
- data/spec/lib/rewriters/rubyspec/filters_rewriter_spec.rb +53 -0
- data/spec/lib/simple_server_spec.rb +54 -0
- data/spec/mspec-opal/formatters.rb +65 -17
- data/spec/mspec-opal/runner.rb +47 -67
- data/spec/opal/core/date_spec.rb +14 -0
- data/spec/opal/core/exception_spec.rb +10 -0
- data/spec/opal/core/hash/internals_spec.rb +10 -10
- data/spec/opal/core/kernel/rand_spec.rb +0 -4
- data/spec/opal/core/kernel/respond_to_spec.rb +5 -2
- data/spec/opal/core/language/constant_lookup_spec.rb +38 -0
- data/spec/opal/core/language/predefined_spec.rb +1 -1
- data/spec/opal/core/language/safe_navigator_spec.rb +7 -0
- data/spec/opal/core/language/send_spec.rb +1 -9
- data/spec/opal/core/language/string_spec.rb +8 -8
- data/spec/opal/core/language/versions/def_2_0_spec.rb +0 -4
- data/spec/opal/core/language_spec.rb +32 -0
- data/spec/opal/core/module/const_get_spec.rb +1 -1
- data/spec/opal/core/runtime/is_a_spec.rb +36 -0
- data/spec/opal/core/runtime/rescue_spec.rb +35 -0
- data/spec/opal/core/runtime_spec.rb +4 -4
- data/spec/opal/core/string_spec.rb +8 -8
- data/spec/opal/core/time_spec.rb +26 -17
- data/spec/opal/stdlib/erb/quoted.opalerb +1 -1
- data/spec/opal/stdlib/json/parse_spec.rb +4 -0
- data/spec/opal/stdlib/native/hash_spec.rb +16 -0
- data/spec/ruby_specs +2 -1
- data/spec/spec_helper.rb +1 -0
- data/spec/support/rewriters_helper.rb +24 -0
- data/stdlib/base64.rb +4 -2
- data/stdlib/bigdecimal/bignumber.js.rb +1 -1
- data/stdlib/date.rb +18 -19
- data/stdlib/json.rb +16 -4
- data/stdlib/nashorn/file.rb +15 -0
- data/stdlib/native.rb +21 -12
- data/stdlib/nodejs/dir.rb +1 -1
- data/stdlib/nodejs/file.rb +49 -20
- data/stdlib/nodejs/io.rb +22 -1
- data/stdlib/nodejs/{node_modules/js-yaml/dist/js-yaml.js → js-yaml-3-6-1.js} +815 -626
- data/stdlib/nodejs/kernel.rb +3 -1
- data/stdlib/nodejs/package.json +0 -1
- data/stdlib/nodejs/stacktrace.rb +163 -0
- data/stdlib/nodejs/yaml.rb +2 -1
- data/stdlib/opal-platform.rb +15 -0
- data/stdlib/opal/platform.rb +5 -13
- data/stdlib/pathname.rb +1 -1
- data/stdlib/strscan.rb +15 -1
- data/stdlib/yaml.rb +1 -1
- data/tasks/benchmarking.rake +9 -0
- data/tasks/building.rake +24 -20
- data/tasks/linting.rake +24 -13
- data/tasks/testing.rake +322 -205
- data/tasks/testing/mspec_special_calls.rb +44 -15
- data/tasks/testing/opal_rspec_smoketest.Gemfile +13 -0
- data/test/nodejs/fixtures/hello.rb +1 -0
- data/test/nodejs/test_file.rb +57 -0
- data/test/nodejs/test_io.rb +18 -0
- data/test/nodejs/test_opal_builder.rb +12 -0
- data/test/opal/unsupported_and_bugs.rb +9 -0
- metadata +127 -240
- data/lib/opal/parser/grammar.rb +0 -6157
- data/lib/opal/parser/grammar.y +0 -2011
- data/lib/opal/parser/keywords.rb +0 -66
- data/lib/opal/parser/lexer.rb +0 -1352
- data/lib/opal/parser/parser_scope.rb +0 -28
- data/lib/opal/parser/sexp.rb +0 -90
- data/lib/opal/sprockets.rb +0 -77
- data/lib/opal/sprockets/environment.rb +0 -23
- data/lib/opal/sprockets/erb.rb +0 -28
- data/lib/opal/sprockets/path_reader.rb +0 -36
- data/lib/opal/sprockets/processor.rb +0 -173
- data/lib/opal/sprockets/server.rb +0 -133
- data/lib/opal/sprockets/source_map_header_patch.rb +0 -41
- data/lib/opal/sprockets/source_map_server.rb +0 -117
- data/spec/filters/bugs/compiler_opal.rb +0 -5
- data/spec/filters/bugs/language_opal.rb +0 -88
- data/spec/filters/unsupported/module.rb +0 -8
- data/spec/lib/compiler/pre_processed_conditionals_spec.rb +0 -87
- data/spec/lib/lexer_spec.rb +0 -110
- data/spec/lib/parser/alias_spec.rb +0 -26
- data/spec/lib/parser/and_spec.rb +0 -13
- data/spec/lib/parser/aref_spec.rb +0 -10
- data/spec/lib/parser/attrasgn_spec.rb +0 -28
- data/spec/lib/parser/begin_spec.rb +0 -42
- data/spec/lib/parser/block_spec.rb +0 -12
- data/spec/lib/parser/break_spec.rb +0 -17
- data/spec/lib/parser/call_spec.rb +0 -201
- data/spec/lib/parser/class_spec.rb +0 -35
- data/spec/lib/parser/comments_spec.rb +0 -11
- data/spec/lib/parser/def_spec.rb +0 -109
- data/spec/lib/parser/if_spec.rb +0 -26
- data/spec/lib/parser/iter_spec.rb +0 -59
- data/spec/lib/parser/lambda_spec.rb +0 -219
- data/spec/lib/parser/literal_spec.rb +0 -118
- data/spec/lib/parser/masgn_spec.rb +0 -37
- data/spec/lib/parser/module_spec.rb +0 -27
- data/spec/lib/parser/not_spec.rb +0 -21
- data/spec/lib/parser/op_asgn1_spec.rb +0 -23
- data/spec/lib/parser/op_asgn2_spec.rb +0 -23
- data/spec/lib/parser/op_asgn_spec.rb +0 -17
- data/spec/lib/parser/or_spec.rb +0 -13
- data/spec/lib/parser/return_spec.rb +0 -22
- data/spec/lib/parser/sclass_spec.rb +0 -21
- data/spec/lib/parser/string_spec.rb +0 -286
- data/spec/lib/parser/super_spec.rb +0 -20
- data/spec/lib/parser/unary_spec.rb +0 -52
- data/spec/lib/parser/undef_spec.rb +0 -19
- data/spec/lib/parser/unless_spec.rb +0 -13
- data/spec/lib/parser/variables_spec.rb +0 -112
- data/spec/lib/parser/while_spec.rb +0 -15
- data/spec/lib/parser/yield_spec.rb +0 -20
- data/spec/lib/sprockets/erb_spec.rb +0 -38
- data/spec/lib/sprockets/path_reader_spec.rb +0 -41
- data/spec/lib/sprockets/processor_spec.rb +0 -79
- data/spec/lib/sprockets/server_spec.rb +0 -102
- data/spec/lib/sprockets_spec.rb +0 -39
- data/spec/lib/tilt/opal_spec.rb +0 -37
- data/spec/opal/core/language/block_spec.rb +0 -538
- data/spec/opal/core/language/proc_spec.rb +0 -263
- data/spec/opal/core/language/variables_spec.rb +0 -1366
- data/spec/opal/core/runtime/block_send_spec.rb +0 -28
- data/spec/opal/core/runtime/send_spec.rb +0 -34
- data/spec/support/parser_helpers.rb +0 -37
- data/stdlib/nodejs/node_modules/js-yaml/HISTORY.md +0 -277
- data/stdlib/nodejs/node_modules/js-yaml/LICENSE +0 -21
- data/stdlib/nodejs/node_modules/js-yaml/README.md +0 -288
- data/stdlib/nodejs/node_modules/js-yaml/bin/js-yaml.js +0 -140
- data/stdlib/nodejs/node_modules/js-yaml/bower.json +0 -23
- data/stdlib/nodejs/node_modules/js-yaml/dist/js-yaml.min.js +0 -3
- data/stdlib/nodejs/node_modules/js-yaml/examples/custom_types.js +0 -102
- data/stdlib/nodejs/node_modules/js-yaml/examples/custom_types.yml +0 -18
- data/stdlib/nodejs/node_modules/js-yaml/examples/dumper.js +0 -31
- data/stdlib/nodejs/node_modules/js-yaml/examples/dumper.json +0 -22
- data/stdlib/nodejs/node_modules/js-yaml/examples/sample_document.js +0 -18
- data/stdlib/nodejs/node_modules/js-yaml/examples/sample_document.yml +0 -197
- data/stdlib/nodejs/node_modules/js-yaml/index.js +0 -7
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml.js +0 -39
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/common.js +0 -62
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/dumper.js +0 -554
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/exception.js +0 -25
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/loader.js +0 -1581
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/mark.js +0 -78
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/schema.js +0 -103
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/schema/core.js +0 -18
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/schema/default_full.js +0 -25
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/schema/default_safe.js +0 -28
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/schema/failsafe.js +0 -17
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/schema/json.js +0 -25
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type.js +0 -61
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/binary.js +0 -133
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/bool.js +0 -37
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/float.js +0 -110
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/int.js +0 -183
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/js/function.js +0 -85
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/js/regexp.js +0 -84
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/js/undefined.js +0 -27
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/map.js +0 -8
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/merge.js +0 -12
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/null.js +0 -36
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/omap.js +0 -56
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/pairs.js +0 -61
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/seq.js +0 -8
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/set.js +0 -33
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/str.js +0 -8
- data/stdlib/nodejs/node_modules/js-yaml/lib/js-yaml/type/timestamp.js +0 -98
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/HISTORY.md +0 -115
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/LICENSE +0 -21
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/README.md +0 -239
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/arguments.js +0 -36
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/choice.js +0 -22
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/constants.js +0 -59
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/help.js +0 -13
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/nargs.js +0 -33
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/parents.js +0 -28
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/prefix_chars.js +0 -23
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/sub_commands.js +0 -49
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/sum.js +0 -35
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/examples/testformatters.js +0 -270
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/index.js +0 -1
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action.js +0 -146
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/append.js +0 -55
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/append/constant.js +0 -47
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/count.js +0 -40
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/help.js +0 -48
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/store.js +0 -50
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/store/constant.js +0 -43
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/store/false.js +0 -27
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/store/true.js +0 -26
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/subparsers.js +0 -148
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action/version.js +0 -50
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/action_container.js +0 -481
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/argparse.js +0 -14
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/argument/error.js +0 -50
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/argument/exclusive.js +0 -54
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/argument/group.js +0 -75
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/argument_parser.js +0 -1168
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/const.js +0 -18
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/help/added_formatters.js +0 -88
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/help/formatter.js +0 -798
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/lib/namespace.js +0 -77
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/.npmignore +0 -2
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/.travis.yml +0 -8
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/README.markdown +0 -825
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/bower.json +0 -33
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/component.json +0 -11
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/foo.js +0 -10
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/gulpfile.js +0 -26
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/lib/underscore.string.js +0 -673
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/libpeerconnection.log +0 -0
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore.string/package.json +0 -107
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore/LICENSE +0 -23
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore/README.md +0 -22
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore/package.json +0 -69
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore/underscore-min.js +0 -6
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/node_modules/underscore/underscore.js +0 -1415
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/argparse/package.json +0 -62
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/README.md +0 -73
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/bin/esparse.js +0 -117
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/bin/esvalidate.js +0 -177
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/esprima.js +0 -3908
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/package.json +0 -69
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/test/compat.js +0 -239
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/test/reflect.js +0 -422
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/test/run.js +0 -66
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/test/runner.js +0 -387
- data/stdlib/nodejs/node_modules/js-yaml/node_modules/esprima/test/test.js +0 -20238
- data/stdlib/nodejs/node_modules/js-yaml/package.json +0 -83
@@ -1,4 +1,4 @@
|
|
1
|
-
|
1
|
+
opal_unsupported_filter "Struct" do
|
2
2
|
fails "Struct#initialize is private"
|
3
3
|
fails "Struct.new does not create a constant with symbol as first argument"
|
4
4
|
fails "Struct.new fails with invalid constant name as first argument" # this invalid name gets interpreted as a struct member
|
@@ -1,4 +1,4 @@
|
|
1
|
-
|
1
|
+
opal_unsupported_filter "Symbol" do
|
2
2
|
fails "Numeric#coerce raises a TypeError when passed a Symbol"
|
3
3
|
fails "Fixnum#coerce raises a TypeError when given an Object that does not respond to #to_f"
|
4
4
|
fails "Symbol#to_proc produces a proc that always returns [[:rest]] for #parameters"
|
@@ -16,4 +16,5 @@ opal_filter "Symbol" do
|
|
16
16
|
fails "Marshal.dump with a Symbol dumps an encoded Symbol"
|
17
17
|
fails "Marshal.dump with a Symbol dumps a binary encoded Symbol"
|
18
18
|
fails "Marshal.dump with an Array dumps a non-empty Array" # this particular spec dumps a Symbol, spec with String instead of Symbol is in spec/opal/
|
19
|
+
fails "Hash literal raises a TypeError if any splatted elements keys are not symbols"
|
19
20
|
end
|
@@ -1,15 +1,30 @@
|
|
1
|
-
|
1
|
+
opal_unsupported_filter "taint" do
|
2
2
|
fails "Hash#reject with extra state does not taint the resulting hash"
|
3
|
-
|
4
|
-
fails "
|
3
|
+
fails "Kernel#inspect returns a tainted string if self is tainted"
|
4
|
+
fails "Module#append_features copies own tainted status to the given module"
|
5
|
+
fails "Module#append_features copies own untrusted status to the given module"
|
6
|
+
fails "Module#extend_object does not copy own tainted status to the given object"
|
7
|
+
fails "Module#extend_object does not copy own untrusted status to the given object"
|
8
|
+
fails "Module#prepend_features copies own tainted status to the given module"
|
9
|
+
fails "Module#prepend_features copies own untrusted status to the given module"
|
5
10
|
fails "String#% doesn't taint the result for %E when argument is tainted"
|
11
|
+
fails "String#% doesn't taint the result for %G when argument is tainted"
|
12
|
+
fails "String#% doesn't taint the result for %e when argument is tainted"
|
6
13
|
fails "String#% doesn't taint the result for %f when argument is tainted"
|
7
14
|
fails "String#% doesn't taint the result for %g when argument is tainted"
|
8
|
-
fails "String
|
9
|
-
fails "String#
|
15
|
+
fails "String#[] with Regexp always taints resulting strings when self or regexp is tainted"
|
16
|
+
fails "String#[] with Regexp returns an untrusted string if the regexp is untrusted"
|
10
17
|
fails "String#byteslice with Range always taints resulting strings when self is tainted"
|
11
|
-
|
12
|
-
fails "
|
18
|
+
fails "String#byteslice with index, length always taints resulting strings when self is tainted"
|
19
|
+
fails "String#dump taints the result if self is tainted"
|
20
|
+
fails "String#slice with Regexp always taints resulting strings when self or regexp is tainted"
|
21
|
+
fails "String#slice with Regexp returns an untrusted string if the regexp is untrusted"
|
22
|
+
fails "StringScanner#getbyte taints the returned String if the input was tainted"
|
23
|
+
fails "StringScanner#getch taints the returned String if the input was tainted"
|
24
|
+
fails "StringScanner#matched taints the returned String if the input was tainted"
|
25
|
+
fails "StringScanner#peek taints the returned String if the input was tainted"
|
26
|
+
fails "StringScanner#peep taints the returned String if the input was tainted"
|
13
27
|
fails "StringScanner#post_match taints the returned String if the input was tainted"
|
28
|
+
fails "StringScanner#pre_match taints the returned String if the input was tainted"
|
14
29
|
fails "StringScanner#rest taints the returned String if the input was tainted"
|
15
30
|
end
|
data/spec/lib/builder_spec.rb
CHANGED
@@ -69,4 +69,21 @@ describe Opal::Builder do
|
|
69
69
|
expect(builder.to_s).to start_with('(function(undefined)')
|
70
70
|
end
|
71
71
|
end
|
72
|
+
|
73
|
+
it 'defaults config from Opal::Config' do
|
74
|
+
Opal::Config.arity_check_enabled = false
|
75
|
+
expect(Opal::Config.arity_check_enabled).to eq(false)
|
76
|
+
expect(Opal::Config.compiler_options[:arity_check]).to eq(false)
|
77
|
+
builder = described_class.new
|
78
|
+
builder.build_str('def foo; end', 'foo')
|
79
|
+
expect(builder.to_s).not_to include('TMP_foo_1.$$parameters = []')
|
80
|
+
|
81
|
+
Opal::Config.arity_check_enabled = true
|
82
|
+
expect(Opal::Config.arity_check_enabled).to eq(true)
|
83
|
+
expect(Opal::Config.compiler_options[:arity_check]).to eq(true)
|
84
|
+
builder = described_class.new
|
85
|
+
builder.build_str('def foo; end', 'foo')
|
86
|
+
expect(builder.to_s).to include('TMP_foo_1.$$parameters = []')
|
87
|
+
end
|
88
|
+
|
72
89
|
end
|
data/spec/lib/cli_spec.rb
CHANGED
@@ -30,7 +30,7 @@ describe Opal::CLI do
|
|
30
30
|
expect { subject.run }.to raise_error(ArgumentError)
|
31
31
|
end
|
32
32
|
|
33
|
-
context 'with lib_only: true' do
|
33
|
+
context 'with lib_only: true and opal require' do
|
34
34
|
let(:options) { super().merge lib_only: true }
|
35
35
|
|
36
36
|
it 'does not raise an error' do
|
@@ -89,10 +89,16 @@ describe Opal::CLI do
|
|
89
89
|
end
|
90
90
|
|
91
91
|
context 'when true' do
|
92
|
-
let(:options) { {lib_only: true, compile: true,
|
92
|
+
let(:options) { {lib_only: true, compile: true, no_exit: true} }
|
93
|
+
it 'appends code block at the end of the source' do
|
94
|
+
expect_output_of{ subject.run }.not_to eq("\n")
|
95
|
+
end
|
93
96
|
|
94
|
-
|
95
|
-
|
97
|
+
context 'without any require' do
|
98
|
+
let(:options) { {lib_only: true, compile: true, skip_opal_require: true, no_exit: true} }
|
99
|
+
it 'raises ArgumentError' do
|
100
|
+
expect{subject.run}.to raise_error(ArgumentError)
|
101
|
+
end
|
96
102
|
end
|
97
103
|
end
|
98
104
|
end
|
@@ -123,7 +129,7 @@ describe Opal::CLI do
|
|
123
129
|
let(:options) { {:gems => [gem_name], :evals => ['']} }
|
124
130
|
|
125
131
|
it "adds the gem's lib paths to Opal.path" do
|
126
|
-
builder = cli.
|
132
|
+
builder = cli.builder
|
127
133
|
|
128
134
|
spec = Gem::Specification.find_by_name(gem_name)
|
129
135
|
spec.require_paths.each do |require_path|
|
@@ -176,21 +182,44 @@ describe Opal::CLI do
|
|
176
182
|
describe ':sexp option' do
|
177
183
|
let(:options) { {evals: ['puts 4'], sexp: true} }
|
178
184
|
it 'prints syntax expressions for the given code' do
|
179
|
-
expect_output_of{ subject.run }.to eq("(:
|
185
|
+
expect_output_of{ subject.run }.to eq("s(:send, nil, :puts,\n s(:int, 4))\n")
|
180
186
|
end
|
181
187
|
end
|
182
188
|
|
183
189
|
describe ':map option' do
|
184
|
-
let(:
|
190
|
+
let(:map_path) { "#{Dir.mktmpdir 'opal-map'}/file.map" }
|
191
|
+
let(:options) { {map: map_path, evals: ['123']} }
|
185
192
|
|
186
193
|
it 'sets the verbose flag (currently unused)' do
|
187
|
-
expect_output_of{ subject.run }.to
|
194
|
+
expect_output_of{ subject.run }.to eq('')
|
195
|
+
expect(File.read(map_path)).to include(%{"version":3})
|
188
196
|
end
|
189
197
|
end
|
190
198
|
|
199
|
+
describe ':parse_comments option' do
|
200
|
+
let(:code) do
|
201
|
+
<<-CODE
|
202
|
+
# multiline
|
203
|
+
# comment
|
204
|
+
def m
|
205
|
+
end
|
206
|
+
CODE
|
207
|
+
end
|
208
|
+
let(:options) { { parse_comments: true, evals: [code], compile: true } }
|
191
209
|
|
210
|
+
it 'sets $$comment prop for compiled methods' do
|
211
|
+
expect_output_of { subject.run }.to include('$$comments = ["# multiline", "# comment"]')
|
212
|
+
end
|
213
|
+
end
|
192
214
|
|
215
|
+
describe ':enable_source_location' do
|
216
|
+
let(:file) { File.expand_path('../fixtures/source_location_test.rb', __FILE__) }
|
217
|
+
let(:options) { { enable_source_location: true, compile: true, file: File.open(file) } }
|
193
218
|
|
219
|
+
it 'sets $$source_location prop for compiled methods' do
|
220
|
+
expect_output_of { subject.run }.to include("source_location_test.rb', 6]")
|
221
|
+
end
|
222
|
+
end
|
194
223
|
|
195
224
|
private
|
196
225
|
|
@@ -16,13 +16,13 @@ describe Opal::Compiler do
|
|
16
16
|
|
17
17
|
context 'outside block' do
|
18
18
|
context 'method missing on' do
|
19
|
-
it { is_expected.to include "return (!(Opal.find_super_dispatcher(self, 'some_method',
|
19
|
+
it { is_expected.to include "return (!(self, Opal.find_super_dispatcher(self, 'some_method', TMP_some_method_1, true).$$stub) ? \"super\" : nil)" }
|
20
20
|
end
|
21
21
|
|
22
22
|
context 'method missing off' do
|
23
23
|
let(:compiler) { Opal::Compiler.new(method, method_missing: false) }
|
24
24
|
|
25
|
-
it { is_expected.to include "return ((Opal.find_super_dispatcher(self, 'some_method',
|
25
|
+
it { is_expected.to include "return ((self, Opal.find_super_dispatcher(self, 'some_method', TMP_some_method_1, true)) != null ? \"super\" : nil)" }
|
26
26
|
end
|
27
27
|
end
|
28
28
|
|
@@ -30,13 +30,13 @@ describe Opal::Compiler do
|
|
30
30
|
context 'implicit' do
|
31
31
|
let(:method) { 'lambda { defined? super }' }
|
32
32
|
|
33
|
-
it { is_expected.to include "return (!(Opal.find_iter_super_dispatcher(self, null, (TMP_1.$$def || null), true, false).$$stub) ? \"super\" : nil)}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1)
|
33
|
+
it { is_expected.to include "return (!(self, Opal.find_iter_super_dispatcher(self, null, (TMP_1.$$def || null), true, false).$$stub) ? \"super\" : nil)}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1))" }
|
34
34
|
end
|
35
35
|
|
36
36
|
context 'explicit' do
|
37
37
|
let(:method) { 'lambda { defined? super() }' }
|
38
38
|
|
39
|
-
it { is_expected.to include "return (!(Opal.find_iter_super_dispatcher(self, null, (TMP_1.$$def || null), true, false).$$stub) ? \"super\" : nil)}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1)
|
39
|
+
it { is_expected.to include "return (!(self, Opal.find_iter_super_dispatcher(self, null, (TMP_1.$$def || null), true, false).$$stub) ? \"super\" : nil)}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1))" }
|
40
40
|
end
|
41
41
|
end
|
42
42
|
end
|
@@ -60,9 +60,9 @@ describe Opal::Compiler do
|
|
60
60
|
|
61
61
|
it do
|
62
62
|
is_expected.to include <<-CODE
|
63
|
-
return (
|
63
|
+
return $send(self, 'call_method', Opal.to_a(stuff), (TMP_2 = function(a){var self = TMP_2.$$s || this;
|
64
64
|
if (a == null) a = nil;
|
65
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
65
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
66
66
|
CODE
|
67
67
|
end
|
68
68
|
end
|
@@ -70,7 +70,7 @@ if (a == null) a = nil;
|
|
70
70
|
context 'via reference' do
|
71
71
|
let(:invocation) { 'call_method *stuff, &block2' }
|
72
72
|
|
73
|
-
it { is_expected.to include "return
|
73
|
+
it { is_expected.to include "return $send(self, 'call_method', Opal.to_a(stuff), block2.$to_proc())" }
|
74
74
|
end
|
75
75
|
end
|
76
76
|
end
|
@@ -82,9 +82,9 @@ if (a == null) a = nil;
|
|
82
82
|
|
83
83
|
it do
|
84
84
|
is_expected.to include <<-CODE
|
85
|
-
return
|
85
|
+
return $send(self, 'call_method', [], (TMP_2 = function(a){var self = TMP_2.$$s || this;
|
86
86
|
if (a == null) a = nil;
|
87
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
87
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
88
88
|
CODE
|
89
89
|
end
|
90
90
|
end
|
@@ -92,7 +92,7 @@ if (a == null) a = nil;
|
|
92
92
|
context 'via reference' do
|
93
93
|
let(:invocation) { 'call_method &block2' }
|
94
94
|
|
95
|
-
it { is_expected.to include "return
|
95
|
+
it { is_expected.to include "return $send(self, 'call_method', [], block2.$to_proc())" }
|
96
96
|
end
|
97
97
|
end
|
98
98
|
end
|
@@ -114,9 +114,9 @@ if (a == null) a = nil;
|
|
114
114
|
|
115
115
|
it do
|
116
116
|
is_expected.to include <<-CODE
|
117
|
-
return (
|
117
|
+
return $send(self, 'call_method', Opal.to_a(stuff), (TMP_1 = function(a){var self = TMP_1.$$s || this;
|
118
118
|
if (a == null) a = nil;
|
119
|
-
return self.$foobar()}, TMP_1.$$s = self, TMP_1.$$arity = 1, TMP_1)
|
119
|
+
return self.$foobar()}, TMP_1.$$s = self, TMP_1.$$arity = 1, TMP_1))
|
120
120
|
CODE
|
121
121
|
end
|
122
122
|
end
|
@@ -124,7 +124,7 @@ if (a == null) a = nil;
|
|
124
124
|
context 'via reference' do
|
125
125
|
let(:invocation) { 'call_method *stuff, &block2' }
|
126
126
|
|
127
|
-
it { is_expected.to include "return (
|
127
|
+
it { is_expected.to include "return $send(self, 'call_method', Opal.to_a(stuff), self.$block2().$to_proc())" }
|
128
128
|
end
|
129
129
|
end
|
130
130
|
end
|
@@ -136,9 +136,9 @@ if (a == null) a = nil;
|
|
136
136
|
|
137
137
|
it do
|
138
138
|
is_expected.to include <<-CODE
|
139
|
-
return
|
139
|
+
return $send(self, 'call_method', [], (TMP_1 = function(a){var self = TMP_1.$$s || this;
|
140
140
|
if (a == null) a = nil;
|
141
|
-
return self.$foobar()}, TMP_1.$$s = self, TMP_1.$$arity = 1, TMP_1)
|
141
|
+
return self.$foobar()}, TMP_1.$$s = self, TMP_1.$$arity = 1, TMP_1))
|
142
142
|
CODE
|
143
143
|
end
|
144
144
|
end
|
@@ -146,7 +146,7 @@ if (a == null) a = nil;
|
|
146
146
|
context 'via reference' do
|
147
147
|
let(:invocation) { 'call_method &block2' }
|
148
148
|
|
149
|
-
it { is_expected.to include "return
|
149
|
+
it { is_expected.to include "return $send(self, 'call_method', [], self.$block2().$to_proc())" }
|
150
150
|
end
|
151
151
|
end
|
152
152
|
end
|
@@ -165,27 +165,33 @@ if (a == null) a = nil;
|
|
165
165
|
context 'no splat' do
|
166
166
|
let(:invocation) { 'another_method(42)' }
|
167
167
|
|
168
|
-
it { is_expected.to include 'return self.$another_method(42)
|
168
|
+
it { is_expected.to include 'return self.$another_method(42)' }
|
169
169
|
end
|
170
170
|
|
171
171
|
context 'splat' do
|
172
172
|
context 'with no block' do
|
173
173
|
let(:invocation) { 'another_method(*args)' }
|
174
174
|
|
175
|
-
it { is_expected.to include
|
175
|
+
it { is_expected.to include "return $send(self, 'another_method', Opal.to_a(self.$args()))" }
|
176
176
|
end
|
177
177
|
|
178
178
|
context 'with block' do
|
179
179
|
context 'via variable' do
|
180
180
|
let(:invocation) { 'another_method(*args) {|b| foobar }' }
|
181
181
|
|
182
|
-
it
|
182
|
+
it do
|
183
|
+
is_expected.to include <<-CODE
|
184
|
+
return $send(self, 'another_method', Opal.to_a(self.$args()), (TMP_1 = function(b){var self = TMP_1.$$s || this;
|
185
|
+
if (b == null) b = nil;
|
186
|
+
return self.$foobar()}, TMP_1.$$s = self, TMP_1.$$arity = 1, TMP_1))
|
187
|
+
CODE
|
188
|
+
end
|
183
189
|
end
|
184
190
|
|
185
191
|
context 'via reference' do
|
186
192
|
let(:invocation) { 'another_method(*args, &block2)' }
|
187
193
|
|
188
|
-
it { is_expected.to include "return
|
194
|
+
it { is_expected.to include "return $send(self, 'another_method', Opal.to_a(self.$args()), self.$block2().$to_proc())" }
|
189
195
|
end
|
190
196
|
end
|
191
197
|
end
|
@@ -194,13 +200,19 @@ if (a == null) a = nil;
|
|
194
200
|
context 'via variable' do
|
195
201
|
let(:invocation) { 'another_method {|b| foobar }' }
|
196
202
|
|
197
|
-
it
|
203
|
+
it do
|
204
|
+
is_expected.to include <<-CODE
|
205
|
+
return $send(self, 'another_method', [], (TMP_1 = function(b){var self = TMP_1.$$s || this;
|
206
|
+
if (b == null) b = nil;
|
207
|
+
return self.$foobar()}, TMP_1.$$s = self, TMP_1.$$arity = 1, TMP_1))
|
208
|
+
CODE
|
209
|
+
end
|
198
210
|
end
|
199
211
|
|
200
212
|
context 'via reference' do
|
201
213
|
let(:invocation) { 'another_method(&block)' }
|
202
214
|
|
203
|
-
it { is_expected.to include
|
215
|
+
it { is_expected.to include "return $send(self, 'another_method', [], self.$block().$to_proc())" }
|
204
216
|
end
|
205
217
|
end
|
206
218
|
end
|
@@ -223,14 +235,14 @@ if (a == null) a = nil;
|
|
223
235
|
context 'no arguments' do
|
224
236
|
let(:invocation) { 'super()' }
|
225
237
|
|
226
|
-
it { is_expected.to include "return
|
238
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), [], null)" }
|
227
239
|
end
|
228
240
|
|
229
241
|
context 'implicit arguments' do
|
230
242
|
let(:invocation) { 'super' }
|
231
243
|
|
232
244
|
context 'no block' do
|
233
|
-
it { is_expected.to include "return
|
245
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), $zuper, $iter)" }
|
234
246
|
end
|
235
247
|
|
236
248
|
context 'block' do
|
@@ -244,7 +256,7 @@ if (a == null) a = nil;
|
|
244
256
|
CODE
|
245
257
|
end
|
246
258
|
|
247
|
-
it { is_expected.to include "return
|
259
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), $zuper, $iter)" }
|
248
260
|
end
|
249
261
|
end
|
250
262
|
end
|
@@ -268,9 +280,9 @@ if (a == null) a = nil;
|
|
268
280
|
|
269
281
|
it do
|
270
282
|
is_expected.to include <<-CODE
|
271
|
-
|
283
|
+
return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), Opal.to_a(stuff), (TMP_2 = function(a){var self = TMP_2.$$s || this;
|
272
284
|
if (a == null) a = nil;
|
273
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
285
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
274
286
|
CODE
|
275
287
|
end
|
276
288
|
end
|
@@ -278,7 +290,7 @@ if (a == null) a = nil;
|
|
278
290
|
context 'via reference' do
|
279
291
|
let(:invocation) { 'super *stuff, &block2' }
|
280
292
|
|
281
|
-
it { is_expected.to include "return
|
293
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), Opal.to_a(stuff), block2.$to_proc())" }
|
282
294
|
end
|
283
295
|
end
|
284
296
|
end
|
@@ -290,9 +302,9 @@ if (a == null) a = nil;
|
|
290
302
|
|
291
303
|
it do
|
292
304
|
is_expected.to include <<-CODE
|
293
|
-
|
305
|
+
return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), $zuper, (TMP_2 = function(a){var self = TMP_2.$$s || this;
|
294
306
|
if (a == null) a = nil;
|
295
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
307
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
296
308
|
CODE
|
297
309
|
end
|
298
310
|
end
|
@@ -300,7 +312,7 @@ if (a == null) a = nil;
|
|
300
312
|
context 'via reference' do
|
301
313
|
let(:invocation) { 'super &block2' }
|
302
314
|
|
303
|
-
it { is_expected.to include "return
|
315
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), [], block2.$to_proc())" }
|
304
316
|
end
|
305
317
|
end
|
306
318
|
end
|
@@ -308,7 +320,7 @@ if (a == null) a = nil;
|
|
308
320
|
context 'no arguments' do
|
309
321
|
let(:invocation) { 'super()' }
|
310
322
|
|
311
|
-
it { is_expected.to include "return
|
323
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), [], null)" }
|
312
324
|
end
|
313
325
|
end
|
314
326
|
|
@@ -330,9 +342,9 @@ if (a == null) a = nil;
|
|
330
342
|
|
331
343
|
it do
|
332
344
|
is_expected.to include <<-CODE
|
333
|
-
return
|
345
|
+
return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), Opal.to_a(stuff), (TMP_2 = function(a){var self = TMP_2.$$s || this;
|
334
346
|
if (a == null) a = nil;
|
335
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
347
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
336
348
|
CODE
|
337
349
|
end
|
338
350
|
end
|
@@ -340,7 +352,7 @@ if (a == null) a = nil;
|
|
340
352
|
context 'via reference' do
|
341
353
|
let(:invocation) { 'super *stuff, &block2' }
|
342
354
|
|
343
|
-
it { is_expected.to include "return
|
355
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), Opal.to_a(stuff), self.$block2().$to_proc())" }
|
344
356
|
end
|
345
357
|
end
|
346
358
|
end
|
@@ -352,9 +364,9 @@ if (a == null) a = nil;
|
|
352
364
|
|
353
365
|
it do
|
354
366
|
is_expected.to include <<-CODE
|
355
|
-
return
|
367
|
+
return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), $zuper, (TMP_2 = function(a){var self = TMP_2.$$s || this;
|
356
368
|
if (a == null) a = nil;
|
357
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
369
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
358
370
|
CODE
|
359
371
|
end
|
360
372
|
end
|
@@ -362,7 +374,7 @@ if (a == null) a = nil;
|
|
362
374
|
context 'via reference' do
|
363
375
|
let(:invocation) { 'super &block2' }
|
364
376
|
|
365
|
-
it { is_expected.to include "return
|
377
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), [], self.$block2().$to_proc())" }
|
366
378
|
end
|
367
379
|
end
|
368
380
|
end
|
@@ -370,7 +382,7 @@ if (a == null) a = nil;
|
|
370
382
|
context 'no arguments' do
|
371
383
|
let(:invocation) { 'super()' }
|
372
384
|
|
373
|
-
it { is_expected.to include "return
|
385
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false), [], null)" }
|
374
386
|
end
|
375
387
|
end
|
376
388
|
end
|
@@ -390,14 +402,14 @@ if (a == null) a = nil;
|
|
390
402
|
context 'no splat' do
|
391
403
|
let(:invocation) { 'super(42)' }
|
392
404
|
|
393
|
-
it { is_expected.to include "return
|
405
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), [42], null)" }
|
394
406
|
end
|
395
407
|
|
396
408
|
context 'splat' do
|
397
409
|
context 'with no block' do
|
398
410
|
let(:invocation) { "args=[1,2,3]\nsuper(*args)" }
|
399
411
|
|
400
|
-
it { is_expected.to include "return
|
412
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), Opal.to_a(args), null)" }
|
401
413
|
end
|
402
414
|
|
403
415
|
context 'with block' do
|
@@ -406,9 +418,9 @@ if (a == null) a = nil;
|
|
406
418
|
|
407
419
|
it do
|
408
420
|
is_expected.to include <<-CODE
|
409
|
-
return
|
421
|
+
return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), Opal.to_a(self.$args()), (TMP_2 = function(b){var self = TMP_2.$$s || this;
|
410
422
|
if (b == null) b = nil;
|
411
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
423
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
412
424
|
CODE
|
413
425
|
end
|
414
426
|
end
|
@@ -416,7 +428,7 @@ if (b == null) b = nil;
|
|
416
428
|
context 'via reference' do
|
417
429
|
let(:invocation) { 'super(*args, &block2)' }
|
418
430
|
|
419
|
-
it { is_expected.to include "return
|
431
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), Opal.to_a(self.$args()), self.$block2().$to_proc())" }
|
420
432
|
end
|
421
433
|
end
|
422
434
|
end
|
@@ -427,9 +439,9 @@ if (b == null) b = nil;
|
|
427
439
|
|
428
440
|
it do
|
429
441
|
is_expected.to include <<-CODE
|
430
|
-
|
442
|
+
return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), $zuper, (TMP_2 = function(b){var self = TMP_2.$$s || this;
|
431
443
|
if (b == null) b = nil;
|
432
|
-
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2)
|
444
|
+
return self.$foobar()}, TMP_2.$$s = self, TMP_2.$$arity = 1, TMP_2))
|
433
445
|
CODE
|
434
446
|
end
|
435
447
|
end
|
@@ -437,14 +449,14 @@ if (b == null) b = nil;
|
|
437
449
|
context 'via reference' do
|
438
450
|
let(:invocation) { 'super(&block)' }
|
439
451
|
|
440
|
-
it { is_expected.to include "return
|
452
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), [], self.$block().$to_proc())" }
|
441
453
|
end
|
442
454
|
end
|
443
455
|
|
444
456
|
context 'no arguments' do
|
445
457
|
let(:invocation) { 'super()' }
|
446
458
|
|
447
|
-
it { is_expected.to include "return
|
459
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'regular_method', TMP_Foobar_regular_method_1, false), [], null)" }
|
448
460
|
end
|
449
461
|
end
|
450
462
|
end
|
@@ -452,7 +464,7 @@ if (b == null) b = nil;
|
|
452
464
|
context 'block' do
|
453
465
|
let(:method) { 'stuff = lambda { super }'}
|
454
466
|
|
455
|
-
it { is_expected.to include "return
|
467
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_1.$$def || null), false, true), [], $iter)}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1)))" }
|
456
468
|
end
|
457
469
|
|
458
470
|
context 'block inside method' do
|
@@ -465,7 +477,7 @@ if (b == null) b = nil;
|
|
465
477
|
CODE
|
466
478
|
end
|
467
479
|
|
468
|
-
it { is_expected.to include "return
|
480
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, 'in_method', (TMP_1.$$def || TMP_in_method_2), false, true), $zuper, $iter)}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1))" }
|
469
481
|
end
|
470
482
|
|
471
483
|
context 'not first node' do
|
@@ -480,7 +492,7 @@ if (b == null) b = nil;
|
|
480
492
|
CODE
|
481
493
|
end
|
482
494
|
|
483
|
-
it { is_expected.to include "Opal.ret(
|
495
|
+
it { is_expected.to include "Opal.ret($send(self, Opal.find_iter_super_dispatcher(self, 'foo', (TMP_1.$$def || TMP_Foo_foo_2), false, true), $zuper, $iter))}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1))" }
|
484
496
|
end
|
485
497
|
|
486
498
|
context 'right method is called, IS THIS A NEW CASE??' do
|
@@ -505,7 +517,7 @@ if (b == null) b = nil;
|
|
505
517
|
end
|
506
518
|
|
507
519
|
# runtime if (current_func.$$def) code should take care of locating the correct method here
|
508
|
-
it { is_expected.to include "return
|
520
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, 'setup', (TMP_3.$$def || TMP_Foo_setup_4), false, false), Opal.to_a(args), null)" }
|
509
521
|
end
|
510
522
|
end
|
511
523
|
|
@@ -521,7 +533,13 @@ if (b == null) b = nil;
|
|
521
533
|
context 'implicit' do
|
522
534
|
let(:invocation) { 'define_method(:wilma) { super }' }
|
523
535
|
|
524
|
-
it
|
536
|
+
it do
|
537
|
+
is_expected.to include <<-CODE
|
538
|
+
return $send(self, 'define_method', ["wilma"], (TMP_Foobar_1 = function(){var self = TMP_Foobar_1.$$s || this;
|
539
|
+
|
540
|
+
return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_Foobar_1.$$def || null), false, true), [], $iter)}, TMP_Foobar_1.$$s = self, TMP_Foobar_1.$$arity = 0, TMP_Foobar_1))
|
541
|
+
CODE
|
542
|
+
end
|
525
543
|
end
|
526
544
|
|
527
545
|
context 'module' do
|
@@ -535,9 +553,9 @@ if (b == null) b = nil;
|
|
535
553
|
|
536
554
|
it do
|
537
555
|
is_expected.to include <<-CODE
|
538
|
-
|
556
|
+
$send(self, 'define_method', ["wilma"], (TMP_Foobar_1 = function(){var self = TMP_Foobar_1.$$s || this;
|
539
557
|
|
540
|
-
return
|
558
|
+
return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_Foobar_1.$$def || null), false, false), [], null)}, TMP_Foobar_1.$$s = self, TMP_Foobar_1.$$arity = 0, TMP_Foobar_1))
|
541
559
|
CODE
|
542
560
|
end
|
543
561
|
end
|
@@ -554,7 +572,13 @@ if (b == null) b = nil;
|
|
554
572
|
CODE
|
555
573
|
end
|
556
574
|
|
557
|
-
it
|
575
|
+
it do
|
576
|
+
is_expected.to include <<-CODE
|
577
|
+
return $send(self, 'define_method', ["foo"], (TMP_2 = function(){var self = TMP_2.$$s || this;
|
578
|
+
|
579
|
+
return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_2.$$def || TMP_1.$$def || null), false, false), [], null)}, TMP_2.$$s = self, TMP_2.$$arity = 0, TMP_2))}, TMP_1.$$s = self, TMP_1.$$arity = 0, TMP_1))
|
580
|
+
CODE
|
581
|
+
end
|
558
582
|
end
|
559
583
|
|
560
584
|
context 'alongside def''d method' do
|
@@ -576,7 +600,15 @@ if (b == null) b = nil;
|
|
576
600
|
CODE
|
577
601
|
end
|
578
602
|
|
579
|
-
it
|
603
|
+
it do
|
604
|
+
is_expected.to include <<-CODE.strip
|
605
|
+
return $send(self, 'define_method', ["a"], (TMP_5 = function(){var self = TMP_5.$$s || this, TMP_6;
|
606
|
+
|
607
|
+
return $send(self, 'fetch', [], (TMP_6 = function(){var self = TMP_6.$$s || this;
|
608
|
+
|
609
|
+
return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_6.$$def || TMP_5.$$def || TMP_3.$$def || null), false, false), [], nil.$to_proc())}, TMP_6.$$s = self, TMP_6.$$arity = 0, TMP_6))}, TMP_5.$$s = self, TMP_5.$$arity = 0, TMP_5));}
|
610
|
+
CODE
|
611
|
+
end
|
580
612
|
end
|
581
613
|
|
582
614
|
context 'alongside another define_method' do
|
@@ -598,7 +630,7 @@ if (b == null) b = nil;
|
|
598
630
|
CODE
|
599
631
|
end
|
600
632
|
|
601
|
-
it { is_expected.to include "return
|
633
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_6.$$def || TMP_5.$$def || TMP_3.$$def || null), false, false), [], nil.$to_proc())" }
|
602
634
|
end
|
603
635
|
|
604
636
|
context 'not last method in class' do
|
@@ -620,7 +652,7 @@ if (b == null) b = nil;
|
|
620
652
|
CODE
|
621
653
|
end
|
622
654
|
|
623
|
-
it { is_expected.to include "return
|
655
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_5.$$def || TMP_4.$$def || TMP_3.$$def || null), false, false), [], nil.$to_proc())" }
|
624
656
|
end
|
625
657
|
end
|
626
658
|
|
@@ -645,8 +677,8 @@ if (b == null) b = nil;
|
|
645
677
|
CODE
|
646
678
|
end
|
647
679
|
|
648
|
-
it { is_expected.to include "return
|
649
|
-
it { is_expected.to include "return
|
680
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, 'foo', (TMP_4.$$def || TMP_3.$$def || TMP_Bar_foo_5), false, false), [self.$some_arg()], block2.$to_proc())" }
|
681
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, 'foo', (TMP_7.$$def || TMP_6.$$def || TMP_Bar_foo_5), false, false), [], nil.$to_proc())" }
|
650
682
|
end
|
651
683
|
|
652
684
|
context 'explicit' do
|
@@ -654,9 +686,9 @@ if (b == null) b = nil;
|
|
654
686
|
|
655
687
|
it do
|
656
688
|
is_expected.to include <<-CODE
|
657
|
-
return
|
689
|
+
return $send(self, 'define_method', ["wilma"], (TMP_Foobar_1 = function(){var self = TMP_Foobar_1.$$s || this;
|
658
690
|
|
659
|
-
return
|
691
|
+
return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_Foobar_1.$$def || null), false, false), [], null)}, TMP_Foobar_1.$$s = self, TMP_Foobar_1.$$arity = 0, TMP_Foobar_1))
|
660
692
|
CODE
|
661
693
|
end
|
662
694
|
end
|
@@ -676,9 +708,9 @@ if (b == null) b = nil;
|
|
676
708
|
CODE
|
677
709
|
end
|
678
710
|
|
679
|
-
it { is_expected.to include "return
|
711
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, null, (TMP_2.$$def || TMP_1.$$def || null), false, true), [], $iter)" }
|
680
712
|
|
681
|
-
it { is_expected.to include "return
|
713
|
+
it { is_expected.to include "return $send(self, Opal.find_iter_super_dispatcher(self, 'm', (TMP_5.$$def || TMP_m_6), false, true), $zuper, $iter)" }
|
682
714
|
end
|
683
715
|
end
|
684
716
|
|
@@ -693,7 +725,7 @@ if (b == null) b = nil;
|
|
693
725
|
CODE
|
694
726
|
end
|
695
727
|
|
696
|
-
it { is_expected.to include "return
|
728
|
+
it { is_expected.to include "return $send(self, Opal.find_super_dispatcher(self, 'some_method', TMP_Foobar_some_method_1, false, $Foobar), $zuper, $iter)" }
|
697
729
|
end
|
698
730
|
end
|
699
731
|
end
|