therubyracer-xcode 0.12.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +23 -0
- data/.travis.yml +14 -0
- data/Changelog.md +263 -0
- data/Gemfile +12 -0
- data/README.md +227 -0
- data/Rakefile +42 -0
- data/benchmarks.rb +218 -0
- data/ext/v8/accessor.cc +181 -0
- data/ext/v8/array.cc +26 -0
- data/ext/v8/backref.cc +45 -0
- data/ext/v8/constants.cc +34 -0
- data/ext/v8/constraints.cc +52 -0
- data/ext/v8/context.cc +130 -0
- data/ext/v8/date.cc +18 -0
- data/ext/v8/exception.cc +38 -0
- data/ext/v8/extconf.rb +34 -0
- data/ext/v8/external.cc +43 -0
- data/ext/v8/function.cc +58 -0
- data/ext/v8/gc.cc +43 -0
- data/ext/v8/handles.cc +34 -0
- data/ext/v8/heap.cc +35 -0
- data/ext/v8/init.cc +39 -0
- data/ext/v8/invocation.cc +86 -0
- data/ext/v8/locker.cc +77 -0
- data/ext/v8/message.cc +51 -0
- data/ext/v8/object.cc +335 -0
- data/ext/v8/primitive.cc +8 -0
- data/ext/v8/rr.cc +83 -0
- data/ext/v8/rr.h +934 -0
- data/ext/v8/script.cc +115 -0
- data/ext/v8/signature.cc +18 -0
- data/ext/v8/stack.cc +76 -0
- data/ext/v8/string.cc +47 -0
- data/ext/v8/template.cc +175 -0
- data/ext/v8/trycatch.cc +87 -0
- data/ext/v8/v8.cc +87 -0
- data/ext/v8/value.cc +239 -0
- data/lib/therubyracer.rb +1 -0
- data/lib/v8/access/indices.rb +40 -0
- data/lib/v8/access/invocation.rb +47 -0
- data/lib/v8/access/names.rb +65 -0
- data/lib/v8/access.rb +5 -0
- data/lib/v8/array.rb +26 -0
- data/lib/v8/context.rb +258 -0
- data/lib/v8/conversion/array.rb +11 -0
- data/lib/v8/conversion/class.rb +119 -0
- data/lib/v8/conversion/code.rb +38 -0
- data/lib/v8/conversion/fixnum.rb +11 -0
- data/lib/v8/conversion/fundamental.rb +11 -0
- data/lib/v8/conversion/hash.rb +11 -0
- data/lib/v8/conversion/indentity.rb +31 -0
- data/lib/v8/conversion/method.rb +26 -0
- data/lib/v8/conversion/object.rb +28 -0
- data/lib/v8/conversion/primitive.rb +7 -0
- data/lib/v8/conversion/proc.rb +5 -0
- data/lib/v8/conversion/reference.rb +16 -0
- data/lib/v8/conversion/string.rb +12 -0
- data/lib/v8/conversion/symbol.rb +7 -0
- data/lib/v8/conversion/time.rb +13 -0
- data/lib/v8/conversion.rb +36 -0
- data/lib/v8/error.rb +169 -0
- data/lib/v8/function.rb +28 -0
- data/lib/v8/object.rb +79 -0
- data/lib/v8/stack.rb +85 -0
- data/lib/v8/version.rb +3 -0
- data/lib/v8/weak.rb +82 -0
- data/lib/v8.rb +30 -0
- data/spec/c/array_spec.rb +19 -0
- data/spec/c/constants_spec.rb +22 -0
- data/spec/c/exception_spec.rb +28 -0
- data/spec/c/external_spec.rb +11 -0
- data/spec/c/function_spec.rb +48 -0
- data/spec/c/handles_spec.rb +31 -0
- data/spec/c/locker_spec.rb +36 -0
- data/spec/c/object_spec.rb +47 -0
- data/spec/c/script_spec.rb +30 -0
- data/spec/c/string_spec.rb +18 -0
- data/spec/c/template_spec.rb +31 -0
- data/spec/c/trycatch_spec.rb +52 -0
- data/spec/mem/blunt_spec.rb +42 -0
- data/spec/redjs_spec.rb +10 -0
- data/spec/spec_helper.rb +41 -0
- data/spec/threading_spec.rb +64 -0
- data/spec/v8/context_spec.rb +19 -0
- data/spec/v8/conversion_spec.rb +52 -0
- data/spec/v8/error_spec.rb +167 -0
- data/spec/v8/function_spec.rb +9 -0
- data/spec/v8/object_spec.rb +15 -0
- data/thefrontside.png +0 -0
- data/therubyracer.gemspec +22 -0
- metadata +186 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: 0648e002ee82460ca2d2573675f00dde30742b83
|
4
|
+
data.tar.gz: 5742afdd1b75323673779b97c0ff8fda91cb5250
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 55b4a3fea60525ff60238728a97d745d2899501bfc4fdea179af63ff20c3342e367f64050645135b27c9f95c90f062e99c4599ae8642bd065c4f153a0fea0db5
|
7
|
+
data.tar.gz: a8c868b5baa07747b876d7cd9ce0554dcf417c608496f83d6c15b8dec87735ed72058d03e9fda06220b1bea192c58763571ff53a31caa35c5cc56c4b3711684a
|
data/.gitignore
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
*.gem
|
2
|
+
*.rbc
|
3
|
+
.rbx/
|
4
|
+
.rvmrc
|
5
|
+
.bundle
|
6
|
+
.config
|
7
|
+
.yardoc
|
8
|
+
.project
|
9
|
+
.cproject
|
10
|
+
Gemfile.lock
|
11
|
+
InstalledFiles
|
12
|
+
_yardoc
|
13
|
+
coverage
|
14
|
+
doc/
|
15
|
+
lib/bundler/man
|
16
|
+
lib/v8/*.bundle
|
17
|
+
lib/v8/*.so
|
18
|
+
pkg
|
19
|
+
rdoc
|
20
|
+
spec/reports
|
21
|
+
test/tmp
|
22
|
+
test/version_tmp
|
23
|
+
tmp
|
data/.travis.yml
ADDED
data/Changelog.md
ADDED
@@ -0,0 +1,263 @@
|
|
1
|
+
# Changelog
|
2
|
+
|
3
|
+
## 0.12.2 2015/04/06
|
4
|
+
|
5
|
+
* fix memory leak where weak hash map entries were not being cleaned
|
6
|
+
up. Thanks to @SamSaffon
|
7
|
+
|
8
|
+
## 0.12.1 2014/02/03
|
9
|
+
|
10
|
+
* add `timeout` option to `V8::Context` to forcibly abort long running scripts (thanks to @SamSaffron)
|
11
|
+
* allow canonical require via `require "therubyracer"` instead of oddball `require "v8"`(thanks @gaffneyc)
|
12
|
+
|
13
|
+
## 0.12.0 2013/08/20
|
14
|
+
|
15
|
+
* upgrade v8 to 3.16.4 (thanks to @ignisf)
|
16
|
+
* enable native (and functional) weakref implementation for MRI > 2.0
|
17
|
+
* expose low level interface for `V8::C::HeapStatistics#total_physical_size`
|
18
|
+
|
19
|
+
## 0.11.1 2013/01/04
|
20
|
+
|
21
|
+
* reintroduce the dependency on libv8
|
22
|
+
* libv8 can be disabled by installing it with the --with-system-v8 flag
|
23
|
+
|
24
|
+
## 0.11.0 2012/12/04
|
25
|
+
|
26
|
+
* upgrade V8 version to 3.11.8
|
27
|
+
* remove dependency on libv8. enable compilation against system v8
|
28
|
+
* complete re-write of low-level C layer for dramatically increased stability and performance
|
29
|
+
* more faithful and complete coverage of the low-level C API
|
30
|
+
* ease the building of binary gems
|
31
|
+
* official support for Rubinius
|
32
|
+
* ability to query V8 for memory usage and set resource constraints
|
33
|
+
* extensible conversion framework for thunking Ruby values to V8 and vice-versa
|
34
|
+
* extensible invocation framework for calling Ruby code (Proc, Method, etc...) from JavaScript
|
35
|
+
* extensible access framework for interacting with Ruby properties from JavaScript
|
36
|
+
* provide explicit context teardown for distributed cycles of garbage.
|
37
|
+
|
38
|
+
|
39
|
+
## 0.10.1 2012/04/05
|
40
|
+
|
41
|
+
* [bugfix] V8::Object#respond_to? did not call super
|
42
|
+
|
43
|
+
## 0.10.0 2012/03/28
|
44
|
+
|
45
|
+
* [incompatible] embedded lambdas now take JS `this` object as first object
|
46
|
+
* add sponsorship image to the README
|
47
|
+
* enable Travis CI
|
48
|
+
|
49
|
+
## 0.9.9 2011/11/08
|
50
|
+
|
51
|
+
* remove GCC specific C++ extension to fix llvm build.
|
52
|
+
|
53
|
+
## 0.9.8 2011/11/07
|
54
|
+
|
55
|
+
* let Rake version float again.
|
56
|
+
|
57
|
+
## 0.9.7 2011/10/06
|
58
|
+
* build fixes
|
59
|
+
* fix rake dependency at 0.8.7 while the Rake team sorts some shit out.
|
60
|
+
|
61
|
+
## 0.9.6 2011/10/06
|
62
|
+
|
63
|
+
* make build compatible with Gentoo
|
64
|
+
|
65
|
+
## 0.9.5 - 2011/10/05
|
66
|
+
|
67
|
+
* remove GCC specific code to enable build on BSD
|
68
|
+
* let Rake dependency float
|
69
|
+
|
70
|
+
## 0.9.4 - 2011/08/22
|
71
|
+
|
72
|
+
* Fix an issue with the compilation include paths which allowed compilation against conflicting libv8's
|
73
|
+
|
74
|
+
## 0.9.3 - 2011/08/11
|
75
|
+
|
76
|
+
* Better documentation for the C extension memory management
|
77
|
+
* Always lock V8 operations, always.
|
78
|
+
* GH-86 Context#[], Context#[]= always looks up values from the JavaScript scope, even when it's a Ruby object
|
79
|
+
|
80
|
+
## 0.9.2 - 2011/06/23
|
81
|
+
|
82
|
+
* fix issue with 1.8.7 where object allocation inside of GC was segfaulting
|
83
|
+
|
84
|
+
## 0.9.1 - 2011/06/17
|
85
|
+
|
86
|
+
* never perform V8 operations inside Ruby GC
|
87
|
+
* refactor locking interface
|
88
|
+
* add documentation for v8_handle
|
89
|
+
|
90
|
+
## 0.9.0 - 2011/06/10
|
91
|
+
|
92
|
+
* extract libv8 into installable binary for most platforms
|
93
|
+
* fix numerous memory leaks
|
94
|
+
* expose the V8 debugger via V8::C::Debug::EnableAgent()
|
95
|
+
* force UTf-8 encoding on strings returned from javascript in ruby 1.9
|
96
|
+
* remove deprecated evaluate() methods
|
97
|
+
* make the currently executing JavaScript stack available via Context#stack
|
98
|
+
|
99
|
+
## 0.8.1 - 2011/03/07
|
100
|
+
|
101
|
+
* upgrade to v8 3.1.8
|
102
|
+
* remove bin/v8 which conflicted with v8 executeable
|
103
|
+
* decruft all the crap that had accumulated in the gem
|
104
|
+
* Javascript Objects are now always mapped to the same V8::Object when read from the context
|
105
|
+
|
106
|
+
## 0.8.0 - 2010/12/02
|
107
|
+
|
108
|
+
* every V8 Context gets its own unique access strategy
|
109
|
+
* ruby methods and procs embedded in javascript always return the same function per context.
|
110
|
+
* ruby classes and subclasses are now all connected via the javascript prototype chain
|
111
|
+
* better error reporting on syntax errors
|
112
|
+
* upgrade to rspec 2
|
113
|
+
* several bug fixes and stability fixes
|
114
|
+
|
115
|
+
## 0.7.5 - 2010/08/03
|
116
|
+
|
117
|
+
* upgrade to V8 2.3.3
|
118
|
+
* property interceptors from ruby via [] and []=
|
119
|
+
* indexed property access via [] and []=
|
120
|
+
* property
|
121
|
+
* several bugfixes
|
122
|
+
* stability: eliminate many segfaults
|
123
|
+
* don't enumerate property setters such as foo= from javascript
|
124
|
+
|
125
|
+
## 0.7.4 - 2010/06/15
|
126
|
+
|
127
|
+
* bug fix for rvm ruby installs incorrectly detected as 32bit
|
128
|
+
|
129
|
+
## 0.7.3 - 2010/06/15
|
130
|
+
|
131
|
+
* don't catch SystemExit and NoMemoryError
|
132
|
+
* fix bug bundling gem
|
133
|
+
|
134
|
+
## 0.7.2 - 2010/06/14
|
135
|
+
|
136
|
+
* embed ruby classes as constructors
|
137
|
+
* support for rubinius
|
138
|
+
* uniform backtrace() function on JSError mixes the ruby
|
139
|
+
* String::NewSymbol() is now scriptable
|
140
|
+
* InstanceTemplate(), PrototypeTemplate(), Inherit() methods on v8::FunctionTemplate now scriptable.
|
141
|
+
* reuse the standard ruby object access template
|
142
|
+
* fix a bunch of compile warnings
|
143
|
+
* Store any ruby object in V8 with V8::C::External
|
144
|
+
|
145
|
+
## 0.7.1 - 2010/06/03
|
146
|
+
|
147
|
+
* Function#call() now uses the global scope for 'this' by default
|
148
|
+
* Function#methodcall() added to allow passing in 'this' object
|
149
|
+
* Function#new() method to invoke javascript constructor from ruby
|
150
|
+
* access javascript properties and call javascript methods from ruby
|
151
|
+
* bundled Jasmine DOM-Less browser testing framework.
|
152
|
+
|
153
|
+
* added Object::GetHiddenValue() to v8 metal
|
154
|
+
* added Handle::IsEmpty() to v8 metal
|
155
|
+
* fixed bug where iterating over arrays sometimes failed
|
156
|
+
* numerous bug /segfault fixes.
|
157
|
+
|
158
|
+
## 0.7.0 - 2010/05/31
|
159
|
+
|
160
|
+
* upgraded to V8 2.1.10
|
161
|
+
* added low level scripting interface for V8 objects
|
162
|
+
* ruby object property/method access is now implemented in ruby
|
163
|
+
* auto-convert javascript arrays to rb arrays and vice-versa
|
164
|
+
* auto-convert ruby hashes into javascript objects
|
165
|
+
* auto-convert javascript Date into ruby Time object and vice versa.
|
166
|
+
* better exception handling when passing through multiple language boundaries
|
167
|
+
* objects maintain referential integrity when passing objects from ruby to javascript and vice-versa
|
168
|
+
* added debug compile option for getting C/C++ backtraces whenever segfaults occur.
|
169
|
+
* official support for REE 1.8.7
|
170
|
+
* fixed numerous segfaults
|
171
|
+
* implemented V8::Value#to_s
|
172
|
+
* the global scope is available to every V8::Context as the 'scope' attribute
|
173
|
+
* properly convert ruby boolean values into V8 booleans.
|
174
|
+
|
175
|
+
## 0.6.3 - 2010/05/07
|
176
|
+
|
177
|
+
* FIX: linkage error on OSX /usr/bin/ruby
|
178
|
+
|
179
|
+
## 0.6.2 - 2010/05/06
|
180
|
+
|
181
|
+
* FIX: linkage error on OSX 10.5
|
182
|
+
|
183
|
+
## 0.6.1 - 2010/05/03
|
184
|
+
|
185
|
+
* call JavaScript functions from Ruby
|
186
|
+
|
187
|
+
## 0.6.0 - 2010/03/31
|
188
|
+
|
189
|
+
* ruby 1.9 compatible
|
190
|
+
* full featured command line bin/v8 and bin/therubyracer
|
191
|
+
* self validating install (v8 --selftest)
|
192
|
+
* Only dependency to build gem from source is rubygems.
|
193
|
+
|
194
|
+
## 0.5.5 - 2010/03/15
|
195
|
+
|
196
|
+
* fix string encoding issue that was breaking RHEL 5.x
|
197
|
+
* fix pthread linking issue on RHEL 5.2
|
198
|
+
|
199
|
+
## 0.5.4 - 2010/03/09
|
200
|
+
|
201
|
+
* add ext directory to gem require paths which was causing problems for non-binary gems
|
202
|
+
|
203
|
+
## 0.5.3 - 2010/03/01
|
204
|
+
|
205
|
+
* added full back trace to javascript code
|
206
|
+
|
207
|
+
## 0.5.2 - 2010/02/26
|
208
|
+
|
209
|
+
* added javascript shell (bin/therubyracer)
|
210
|
+
* added to_s method for embedded ruby objects
|
211
|
+
* added line number and file name to error message.
|
212
|
+
|
213
|
+
## 0.5.1 - 2010/02/17
|
214
|
+
|
215
|
+
* fix bug in 1.8.6 by creating Object#tap if it does not exist
|
216
|
+
|
217
|
+
## 0.5.0 - 2010/02/17
|
218
|
+
|
219
|
+
* support for Linux 64 bit
|
220
|
+
|
221
|
+
## 0.4.9 - 2010/02/16
|
222
|
+
|
223
|
+
* support for Linux 32 bit
|
224
|
+
|
225
|
+
## 0.4.8 - 2010/02/08
|
226
|
+
|
227
|
+
* expose line number and source name on JavascriptErrors.
|
228
|
+
|
229
|
+
## 0.4.5 - 2010/01/18
|
230
|
+
|
231
|
+
* case munging so that ruby methods(perl_case) are accessed through javascript in camelCase.
|
232
|
+
* access 0-arity ruby methods as javascript properties
|
233
|
+
* invoke ruby setters from javascript as properties
|
234
|
+
* contexts detect whether they are open or not and open when needed
|
235
|
+
|
236
|
+
## 0.4.4 - 2010/01/14
|
237
|
+
|
238
|
+
* Ruby objects embedded into javascript are passed back to ruby as themselves and not a wrapped V8 object wrapping a ruby object.
|
239
|
+
* Use any ruby object as the scope of eval().
|
240
|
+
* quick and dirty V8.eval() method added
|
241
|
+
* native objects have a reference to the context that created them.
|
242
|
+
* context now has equality check.
|
243
|
+
* expose InContext() and GetCurrent() methods.
|
244
|
+
* fix a couple of segmentation faults
|
245
|
+
|
246
|
+
## 0.4.3 - 2010/10/11
|
247
|
+
|
248
|
+
* access properties on Ruby objects with their camel case equivalents
|
249
|
+
* reflect JavaScript objects into Ruby and access their properties
|
250
|
+
* load JavaScript source from an IO object or by filename
|
251
|
+
|
252
|
+
## 0.4.2 - 2010/10/10
|
253
|
+
|
254
|
+
* embed Ruby Objects into Javascript and call their methods
|
255
|
+
|
256
|
+
## 0.4.1 - 2010/01/09
|
257
|
+
|
258
|
+
* embed bare Proc and Method objects into JavaScript and call them
|
259
|
+
* catch JavaScript exceptions from Ruby
|
260
|
+
|
261
|
+
## 0.4.0 - 2009/12/21
|
262
|
+
|
263
|
+
* evaluate JavaScript code from inside Ruby.
|
data/Gemfile
ADDED
@@ -0,0 +1,12 @@
|
|
1
|
+
source 'http://rubygems.org'
|
2
|
+
|
3
|
+
gemspec
|
4
|
+
|
5
|
+
group :development do
|
6
|
+
gem "rubysl", :platforms => :rbx
|
7
|
+
gem 'redjs', :git => 'https://github.com/cowboyd/redjs.git'
|
8
|
+
gem "rake"
|
9
|
+
gem "rspec", "~> 2.0"
|
10
|
+
gem "rake-compiler"
|
11
|
+
gem "gem-compiler", :platforms => :mri
|
12
|
+
end
|
data/README.md
ADDED
@@ -0,0 +1,227 @@
|
|
1
|
+
# therubyracer
|
2
|
+
|
3
|
+
## This version compiles with XCode 7.3
|
4
|
+
|
5
|
+
[![Gem Version](https://badge.fury.io/rb/therubyracer.png)](http://badge.fury.io/rb/therubyracer)
|
6
|
+
[![Build Status](https://travis-ci.org/cowboyd/therubyracer.png?branch=master)](https://travis-ci.org/cowboyd/therubyracer)
|
7
|
+
[![Build status](https://ci.appveyor.com/api/projects/status/aqw06doke164dca7?svg=true)](https://ci.appveyor.com/project/cowboyd/therubyracer)
|
8
|
+
[![Dependency Status](https://gemnasium.com/cowboyd/therubyracer.png)](https://gemnasium.com/cowboyd/therubyracer)
|
9
|
+
[![Join the chat at https://gitter.im/cowboyd/therubyracer](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/cowboyd/therubyracer?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
10
|
+
|
11
|
+
|
12
|
+
* GitHub Project: [http://github.com/cowboyd/therubyracer](http://github.com/cowboyd/therubyracer)
|
13
|
+
* Mailing List: [http://groups.google.com/group/therubyracer](http://groups.google.com/group/therubyracer)
|
14
|
+
* Documentation: [GitHub Wiki](https://github.com/cowboyd/therubyracer/wiki) and [RubyDoc](http://rubydoc.info/gems/therubyracer)
|
15
|
+
|
16
|
+
### DESCRIPTION
|
17
|
+
|
18
|
+
Embed the V8 JavaScript interpreter into Ruby.
|
19
|
+
|
20
|
+
### FEATURES
|
21
|
+
|
22
|
+
* Evaluate JavaScript from within Ruby
|
23
|
+
* Embed your Ruby objects into the JavaScript world
|
24
|
+
* Manipulate JavaScript objects and call JavaScript functions from Ruby
|
25
|
+
* API compatible with the The Ruby Rhino (for JRuby: http://github.com/cowboyd/therubyrhino)
|
26
|
+
|
27
|
+
### SYNOPSIS
|
28
|
+
|
29
|
+
gem install therubyracer
|
30
|
+
|
31
|
+
then in your Ruby code
|
32
|
+
|
33
|
+
require 'v8'
|
34
|
+
|
35
|
+
or if using bundler (as with Rails), add the following to your Gemfile
|
36
|
+
|
37
|
+
gem "therubyracer"
|
38
|
+
|
39
|
+
evaluate some simple JavaScript
|
40
|
+
|
41
|
+
cxt = V8::Context.new
|
42
|
+
cxt.eval('7 * 6') #=> 42
|
43
|
+
|
44
|
+
access values inside your JavaScript context from Ruby
|
45
|
+
|
46
|
+
cxt.eval 'var val = {num: 5, isTruthy: function (arg) { return !!arg }}'
|
47
|
+
val = cxt[:val] #=> V8::Object
|
48
|
+
cxt[:val] == cxt.scope.val #=> true
|
49
|
+
val.num #=> 5
|
50
|
+
val.isTruthy(1) #=> true
|
51
|
+
|
52
|
+
this includes references to JavaScript functions
|
53
|
+
|
54
|
+
truthy = val[:isTruthy] #=> V8::Function
|
55
|
+
truthy.call(' ') #=> true
|
56
|
+
truthy.call(0) #=> false
|
57
|
+
|
58
|
+
|
59
|
+
embed values into the scope of your context
|
60
|
+
|
61
|
+
cxt['foo'] = "bar"
|
62
|
+
cxt.eval('foo') # => "bar"
|
63
|
+
|
64
|
+
embed Ruby code into your scope and call it from JavaScript
|
65
|
+
|
66
|
+
cxt["say"] = lambda {|this, word, times| word * times}
|
67
|
+
cxt.eval("say('Hello', 3)") #=> HelloHelloHello
|
68
|
+
|
69
|
+
embed a Ruby object into your scope and access its properties/methods
|
70
|
+
from JavaScript
|
71
|
+
|
72
|
+
class MyMath
|
73
|
+
def plus(lhs, rhs)
|
74
|
+
lhs + rhs
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
cxt['math'] = MyMath.new
|
79
|
+
cxt.eval("math.plus(20,22)") #=> 42
|
80
|
+
|
81
|
+
make a Ruby object *be* your global JavaScript scope.
|
82
|
+
|
83
|
+
math = MyMath.new
|
84
|
+
V8::Context.new(:with => math) do |cxt|
|
85
|
+
cxt.eval("plus(20,22)") #=> 42
|
86
|
+
end
|
87
|
+
|
88
|
+
you can do the same thing with Object#eval_js
|
89
|
+
|
90
|
+
math.eval_js("plus(20,22)")
|
91
|
+
|
92
|
+
### Different ways of loading JavaScript source
|
93
|
+
|
94
|
+
In addition to just evaluating strings, you can also use streams, such
|
95
|
+
as files.
|
96
|
+
|
97
|
+
evaluate bytes read from any File/IO object:
|
98
|
+
|
99
|
+
File.open("mysource.js") do |file|
|
100
|
+
cxt.eval(file, "mysource.js")
|
101
|
+
end
|
102
|
+
|
103
|
+
or load it by filename
|
104
|
+
|
105
|
+
cxt.load("mysource.js")
|
106
|
+
|
107
|
+
### Safe by default, dangerous by demand
|
108
|
+
|
109
|
+
The Ruby Racer is designed to let you evaluate JavaScript as safely as
|
110
|
+
possible unless you tell it to do something more dangerous. The
|
111
|
+
default context is a hermetically sealed JavaScript environment with
|
112
|
+
only the standard JavaScript objects and functions. Nothing from the
|
113
|
+
Ruby world is accessible at all.
|
114
|
+
|
115
|
+
For Ruby objects that you explicitly embed into JavaScript, by default
|
116
|
+
only the _public_ methods _below_ `Object` are exposed by default.
|
117
|
+
E.g.
|
118
|
+
|
119
|
+
class A
|
120
|
+
def a
|
121
|
+
"a"
|
122
|
+
end
|
123
|
+
|
124
|
+
def to_s
|
125
|
+
super
|
126
|
+
end
|
127
|
+
end
|
128
|
+
|
129
|
+
class B < A
|
130
|
+
def b
|
131
|
+
"b"
|
132
|
+
end
|
133
|
+
end
|
134
|
+
|
135
|
+
|
136
|
+
V8::Context.new do |cxt|
|
137
|
+
cxt['a'] = A.new
|
138
|
+
cxt['b'] = B.new
|
139
|
+
cxt.eval("a.a") # => 'a'
|
140
|
+
cxt.eval("b.b") # => 'b'
|
141
|
+
cxt.eval("b.a") # => 'a'
|
142
|
+
cxt.eval("b.to_s") # => #<B:0x101776be8> (because A explicitly defined it)
|
143
|
+
cxt.eval("b.object_id") #=> undefined, object_id is on Object
|
144
|
+
end
|
145
|
+
|
146
|
+
If needed, you can override the [Ruby Access][access] to allow whatever
|
147
|
+
behavior you'd like.
|
148
|
+
|
149
|
+
[access]:https://github.com/cowboyd/therubyracer/blob/master/lib/v8/access.rb
|
150
|
+
|
151
|
+
More documentation can be found on the [GitHub wiki](https://github.com/cowboyd/therubyracer/wiki)
|
152
|
+
|
153
|
+
### Protecting Your CPU cycles
|
154
|
+
|
155
|
+
When running untrusted JavaScript code, you not only have to protect
|
156
|
+
which functions it has access to, but also how much of your CPU it can
|
157
|
+
consume. Take this simple, yet thoroughly malicious script:
|
158
|
+
|
159
|
+
```javascript
|
160
|
+
while (true) {}
|
161
|
+
```
|
162
|
+
|
163
|
+
It will loop forever and never return control to the calling Ruby
|
164
|
+
thread. To protect against such JavaScript code that either
|
165
|
+
deliberately or accidentally runs longer that it should, you can
|
166
|
+
set an explicit timeout on your context. If the code runs longer that
|
167
|
+
the allowed timeout, then it will throw an exception. Note that this
|
168
|
+
exception could be raised at any point in the execution of the
|
169
|
+
JavaScript.
|
170
|
+
|
171
|
+
To specify the timeout (in milliseconds), pass in the `timeout` option
|
172
|
+
to the constructor.
|
173
|
+
|
174
|
+
```ruby
|
175
|
+
cxt = V8::Context.new timeout: 700
|
176
|
+
cxt.eval "while (true);" #= exception after 700ms!
|
177
|
+
```
|
178
|
+
|
179
|
+
### PREREQUISITES
|
180
|
+
|
181
|
+
The Ruby Racer requires the V8 Javascript engine, but it offloads the
|
182
|
+
handling of this dependency to the
|
183
|
+
[libv8](https://github.com/cowboyd/libv8) gem. Because libv8 is now a
|
184
|
+
gem dependency, you do not need a separate libv8 entry in your
|
185
|
+
project's Gemfile.
|
186
|
+
|
187
|
+
Please see [libv8](https://github.com/cowboyd/libv8) for V8 runtime
|
188
|
+
installation options.
|
189
|
+
|
190
|
+
### DEVELOP
|
191
|
+
|
192
|
+
git clone git://github.com/cowboyd/therubyracer.git
|
193
|
+
cd therubyracer
|
194
|
+
bundle install
|
195
|
+
rake compile
|
196
|
+
|
197
|
+
### Sponsored by
|
198
|
+
|
199
|
+
<a href="http://thefrontside.net">![The Frontside](http://github.com/cowboyd/therubyracer/raw/master/thefrontside.png)</a>
|
200
|
+
|
201
|
+
### LICENSE:
|
202
|
+
|
203
|
+
(The MIT License)
|
204
|
+
|
205
|
+
Copyright (c) 2009,2010,2011,2012 Charles Lowell
|
206
|
+
|
207
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
208
|
+
a copy of this software and associated documentation files (the
|
209
|
+
'Software'), to deal in the Software without restriction, including
|
210
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
211
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
212
|
+
permit persons to whom the Software is furnished to do so, subject to
|
213
|
+
the following conditions:
|
214
|
+
|
215
|
+
The above copyright notice and this permission notice shall be
|
216
|
+
included in all copies or substantial portions of the Software.
|
217
|
+
|
218
|
+
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
219
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
220
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
221
|
+
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
222
|
+
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
223
|
+
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
224
|
+
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
225
|
+
|
226
|
+
[1]: https://github.com/cowboyd/libv8
|
227
|
+
[2]: http://code.google.com/p/v8/wiki/BuildingWithGYP
|
data/Rakefile
ADDED
@@ -0,0 +1,42 @@
|
|
1
|
+
#!/usr/bin/env rake
|
2
|
+
require 'bundler/setup'
|
3
|
+
require "bundler/gem_tasks"
|
4
|
+
|
5
|
+
task :clean do
|
6
|
+
sh "rm -rf lib/v8/init.bundle lib/v8/init.so"
|
7
|
+
sh "rm -rf pkg"
|
8
|
+
end
|
9
|
+
|
10
|
+
require "rake/extensiontask"
|
11
|
+
Rake::ExtensionTask.new("init", eval(File.read("therubyracer.gemspec"))) do |ext|
|
12
|
+
ext.ext_dir = "ext/v8"
|
13
|
+
ext.lib_dir = "lib/v8"
|
14
|
+
ext.source_pattern = "*.{cc,h}"
|
15
|
+
end
|
16
|
+
|
17
|
+
require 'rspec/core/rake_task'
|
18
|
+
RSpec::Core::RakeTask.new(:spec) do |task|
|
19
|
+
task.rspec_opts = '--tag ~memory --tag ~threads'
|
20
|
+
end
|
21
|
+
|
22
|
+
task :sanity => [:clean, :compile] do
|
23
|
+
sh %q{ruby -Ilib -e "require 'v8'"}
|
24
|
+
end
|
25
|
+
|
26
|
+
NativeGem = "pkg/therubyracer-#{V8::VERSION}-#{Gem::Platform.new(RUBY_PLATFORM)}.gem"
|
27
|
+
file NativeGem => :build do
|
28
|
+
require "rubygems/compiler"
|
29
|
+
compiler = Gem::Compiler.new("pkg/therubyracer-#{V8::VERSION}.gem", 'pkg')
|
30
|
+
compiler.compile
|
31
|
+
end
|
32
|
+
|
33
|
+
desc "Build #{NativeGem} into the pkg directory"
|
34
|
+
task "build:native" => NativeGem
|
35
|
+
|
36
|
+
desc "Build and install #{File.basename NativeGem} into system gems"
|
37
|
+
task "install:native" => "build:native" do
|
38
|
+
sh "gem install #{NativeGem}"
|
39
|
+
end
|
40
|
+
|
41
|
+
task :default => :spec
|
42
|
+
|