poison 0.1.0.dev

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,4 @@
1
+ require 'spec/custom/runner/relates'
2
+ require 'spec/custom/matchers/parse_as'
3
+ require 'spec/custom/utils/options'
4
+ require 'spec/custom/utils/script'
@@ -0,0 +1,21 @@
1
+ class ParseAsMatcher
2
+ def initialize(expected)
3
+ @expected = expected
4
+ end
5
+
6
+ def matches?(actual)
7
+ @actual = Poison::Compiler.new(actual).parse.to_sexp.last
8
+ @actual == @expected
9
+ end
10
+
11
+ def failure_message
12
+ ["Expected:\n#{@actual.inspect}\n",
13
+ "to equal:\n#{@expected.inspect}"]
14
+ end
15
+ end
16
+
17
+ class Object
18
+ def parse_as(sexp)
19
+ ParseAsMatcher.new sexp
20
+ end
21
+ end
@@ -0,0 +1,97 @@
1
+ # NOTE: Copied from Rubinius
2
+ #
3
+ # SpecDataRelation enables concise specs that involve several different forms
4
+ # of the same data. This is specifically useful for the parser and compiler
5
+ # specs where the output of each stage is essentially related to the input
6
+ # Ruby source. Together with the #relates spec method, it enables specs like:
7
+ #
8
+ # describe "An If node" do
9
+ # relates "a if b" do
10
+ # parse do
11
+ # # return the expected sexp
12
+ # end
13
+ #
14
+ # compile do |g|
15
+ # # return the expected bytecode
16
+ # end
17
+ #
18
+ # jit do |as|
19
+ # # return the expected asm/machine code
20
+ # end
21
+ # end
22
+ #
23
+ # relates "if a; b; end" do
24
+ # # ...
25
+ # end
26
+ # end
27
+
28
+ class SpecDataRelation
29
+ # Provides a simple configurability so that any one or more of the possible
30
+ # processes can be run. See the custom options in custom/utils/options.rb.
31
+ def self.enable(process)
32
+ @processors ||= []
33
+ @processors << process
34
+ end
35
+
36
+ # Returns true if no process is specifically set or if +process+ is in the
37
+ # list of enabled processes. In other words, all processes are enabled by
38
+ # default, or any combination of them may be enabled.
39
+ def self.enabled?(process)
40
+ @processors.nil? or @processors.include?(process)
41
+ end
42
+
43
+ def initialize(ruby)
44
+ @ruby = ruby
45
+ end
46
+
47
+ # Formats the Ruby source code for reabable output in the -fs formatter
48
+ # option. If the source contains no newline characters, wraps the source in
49
+ # single quotes to set if off from the rest of the description string. If
50
+ # the source does contain newline characters, sets the indent level to four
51
+ # characters.
52
+ def format(ruby)
53
+ if /\n/ =~ ruby
54
+ lines = ruby.rstrip.to_a
55
+ if /( *)/ =~ lines.first
56
+ if $1.size > 4
57
+ dedent = $1.size - 4
58
+ ruby = lines.map { |l| l[dedent..-1] }.join
59
+ else
60
+ indent = " " * (4 - $1.size)
61
+ ruby = lines.map { |l| "#{indent}#{l}" }.join
62
+ end
63
+ end
64
+ "\n#{ruby}"
65
+ else
66
+ "'#{ruby}'"
67
+ end
68
+ end
69
+
70
+ # Creates spec example blocks if the compile process is enabled.
71
+ def compile(*plugins, &block)
72
+ return unless self.class.enabled? :compiler
73
+
74
+ ruby = @ruby
75
+ it "is compiled from #{format ruby}" do
76
+ generator = Rubinius::TestGenerator.new
77
+ generator.instance_eval(&block)
78
+
79
+ ruby.should compile_as(generator, *plugins)
80
+ end
81
+ end
82
+
83
+ def parse(&block)
84
+ return unless self.class.enabled? :parser
85
+
86
+ ruby = @ruby
87
+ it "is parsed from #{format ruby}" do
88
+ ruby.should parse_as(block.call)
89
+ end
90
+ end
91
+ end
92
+
93
+ class Object
94
+ def relates(str, &block)
95
+ SpecDataRelation.new(str).instance_eval(&block)
96
+ end
97
+ end
@@ -0,0 +1,21 @@
1
+ # Custom MSpec options
2
+ #
3
+ class MSpecOptions
4
+ def compiler
5
+ # The require is inside the method because this file has to be able to be
6
+ # loaded in MRI and there are parts of the custom ensemble that are
7
+ # Rubinius specific (primarily iseq, which could potentially be fixed by
8
+ # better structuring the compiler).
9
+ require 'spec/custom/runner/relates'
10
+
11
+ on("--compiler", "Run only the compile part of the compiler specs") do
12
+ SpecDataRelation.enable :compiler
13
+ end
14
+ end
15
+
16
+ def parser
17
+ on("--parser", "Run only the parse part of the compiler specs") do
18
+ SpecDataRelation.enable :parser
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,26 @@
1
+ # Custom options for mspec-run
2
+ #
3
+ class MSpecRun
4
+ def custom_options(options)
5
+ options.compiler
6
+ options.parser
7
+ end
8
+ end
9
+
10
+ # Custom options for mspec-ci
11
+ #
12
+ class MSpecCI
13
+ def custom_options(options)
14
+ options.compiler
15
+ options.parser
16
+ end
17
+ end
18
+
19
+ # Custom options for mspec-tag
20
+ #
21
+ class MSpecTag
22
+ def custom_options(options)
23
+ options.compiler
24
+ options.parser
25
+ end
26
+ end
@@ -0,0 +1,3 @@
1
+ $: << File.expand_path('../../lib', __FILE__)
2
+
3
+ require 'poison'
metadata ADDED
@@ -0,0 +1,94 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: poison
3
+ version: !ruby/object:Gem::Version
4
+ prerelease: true
5
+ segments:
6
+ - 0
7
+ - 1
8
+ - 0
9
+ - dev
10
+ version: 0.1.0.dev
11
+ platform: ruby
12
+ authors:
13
+ - Brian Ford
14
+ autorequire:
15
+ bindir: bin
16
+ cert_chain: []
17
+
18
+ date: 2010-11-06 00:00:00 -07:00
19
+ default_executable:
20
+ dependencies: []
21
+
22
+ description: |
23
+ Poison is a programming language based on Potion by Why The Lucky Stiff
24
+ that runs on the Rubinius VM.
25
+
26
+ email: brixen@gmail.com
27
+ executables:
28
+ - poison
29
+ extensions: []
30
+
31
+ extra_rdoc_files:
32
+ - README
33
+ - LICENSE
34
+ files:
35
+ - lib/poison/bootstrap/compiler/compiler.rb
36
+ - lib/poison/bootstrap/compiler/grammar.rb
37
+ - lib/poison/bootstrap/compiler/node.rb
38
+ - lib/poison/bootstrap/compiler/parser.rb
39
+ - lib/poison/bootstrap/compiler.rb
40
+ - lib/poison/bootstrap/library/code_loader.rb
41
+ - lib/poison/bootstrap/library.rb
42
+ - lib/poison/bootstrap/parser.rb
43
+ - lib/poison/bootstrap/syntax.rb
44
+ - lib/poison/bootstrap.rb
45
+ - lib/poison/version.rb
46
+ - lib/poison.rb
47
+ - spec/compiler/assign_spec.rb
48
+ - spec/compiler/message_spec.rb
49
+ - spec/compiler/value_spec.rb
50
+ - spec/custom/matchers/parse_as.rb
51
+ - spec/custom/runner/relates.rb
52
+ - spec/custom/utils/options.rb
53
+ - spec/custom/utils/script.rb
54
+ - spec/custom.rb
55
+ - spec/spec_helper.rb
56
+ - Rakefile
57
+ - README
58
+ - LICENSE
59
+ has_rdoc: true
60
+ homepage: http://github.com/brixen/poison
61
+ licenses: []
62
+
63
+ post_install_message:
64
+ rdoc_options:
65
+ - --title
66
+ - Poison Gem
67
+ - --main
68
+ - README
69
+ - --line-numbers
70
+ require_paths:
71
+ - lib
72
+ required_ruby_version: !ruby/object:Gem::Requirement
73
+ requirements:
74
+ - - ">="
75
+ - !ruby/object:Gem::Version
76
+ segments:
77
+ - 0
78
+ version: "0"
79
+ required_rubygems_version: !ruby/object:Gem::Requirement
80
+ requirements:
81
+ - - ">="
82
+ - !ruby/object:Gem::Version
83
+ segments:
84
+ - 0
85
+ version: "0"
86
+ requirements: []
87
+
88
+ rubyforge_project:
89
+ rubygems_version: 1.3.6
90
+ signing_key:
91
+ specification_version: 2
92
+ summary: Poison is an interpretation of Potion on the Rubinius VM.
93
+ test_files: []
94
+