-
Notifications
You must be signed in to change notification settings - Fork 671
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
improved logger, support for more js shells, and quit() env module #79
base: master
Are you sure you want to change the base?
Conversation
* Added support for 'spartan' shell environments. These are defined to be environments that expose global print() and load() functions, and that expose command-line arguments on top-level Arguments array. This now works for spidermonkey (Mozilla), jsc (Webkit), and v8 (Chrome) implementations. v8 must be patched to expose command-line arguments as top-level Arguments array. Rhino can also be considered a spartan shell environment. * Improved logger module to accept multiple arguments, like console.log. * Added quit() module for node, rhino, and spartan shell environments.
I'm open to supporting more environments, but I want to be sure I can run all the tests in those environments before calling them officially supported. So on that note:
Hmm, the more I think about this, what is your motivation for these changes? Is it to do builds or something else? In particular, I'm not sure when the quit module would be used. |
The motivation behind the patch for "spartan" shell environments is to be able to use requirejs to load modules in shell environments that only expose print(), load() and quit() functions on the global object, as well as optionally exposing command-line arguments on the top-level Arguments array, and not much else. Examples of such shells are the example shells that ship with the spidermonkey, jsc, and v8 interpreters. I've used this to develop a performance testing harness for a library I've written. This harness is able to use the patched r.js to load requirejs modules, which are then able to run equivalently in: the browser, nodejs, rhino, spidermonkey, jsc and v8 JavaScript shell environments. This enables me to benchmark my code under all major js interpreters, without needing to script a browser instance, and to precisely measure memory usage and performance of my library under these shells, independent of the browser environment. The downside to this approach is that these "spartan" shells are quite minimal out of the box, and, for example, jsc and v8 shells are unable to read files. spidermonkey has rudimentary support for reading from files. This means that r.js will not have the same capabilities under spartan environments as it does in node.js or rhino, which do expose file APIs. I think, right now, you only need file support for the optimizer, so this means that the requirejs optimizer would be unable to run under the spartan environments, thus leading to some fragmentation of r.js capabilities. For example, if the user ran "jsc r.js -o", r.js would need to warn the user that the optimizer is not supported under that environment, and to instead run with node.js or rhino. As owner of r.js, it's up to you to decide whether support for "spartan" shells is something that should get merged into the r.js core. In its favor, I'll mention that I think JavaScript gets embedded in many different contexts, and the need to run requirejs in minimal or unexpected environments has come up a few times in my work, for example using RequireJS in Ant: https://groups.google.com/d/msg/requirejs/w7z9Rn0NpwQ/dYBglloMKTIJ Essentially, getting requirejs to work in environments that only support print() and load() makes it more versatile, but makes it more complicated to support. I don't yet have a detailed understanding of how this affects automated testing of r.js. |
OK, that helps explain the motivation. I like the idea, but I would like to see the patch done differently. In particular:
|
Hi, Thanks for taking the time to respond, and sorry it took me so long to get back to you. All of the changes you request sound reasonable and easy to implement, but there are a few issues that I want to bring up.
Please let me know what you think. Thanks. |
|
Sorry this is a bit of a messy patch - I made a bunch of changes in an anonymous clone of r.js before forking and cloning my own, so it includes a number of small contributions.
This is my first contribution to r.js, but I think I sent a CLA in a few months ago.
Changes: