wisp
Version:
Homoiconic JS with clojure syntax, s-expressions & macros
99 lines (98 loc) • 15.7 kB
JavaScript
{
var _ns_ = {
id: 'wisp.wisp',
doc: 'Wisp program that reads wisp code from stdin and prints\n compiled javascript code into stdout'
};
var fs = require('fs');
var createReadStream = fs.createReadStream;
var path = require('path');
var basename = path.basename;
var dirname = path.dirname;
var join = path.join;
var resolve = path.resolve;
var module = require('module');
var Module = module.Module;
var commander = require('commander');
var wisp_package = require('./package');
var version = wisp_package.version;
var wisp_string = require('./string');
var split = wisp_string.split;
var join = wisp_string.join;
var upperCase = wisp_string.upperCase;
var replace = wisp_string.replace;
var wisp_sequence = require('./sequence');
var first = wisp_sequence.first;
var second = wisp_sequence.second;
var last = wisp_sequence.last;
var count = wisp_sequence.count;
var reduce = wisp_sequence.reduce;
var rest = wisp_sequence.rest;
var conj = wisp_sequence.conj;
var partition = wisp_sequence.partition;
var assoc = wisp_sequence.assoc;
var drop = wisp_sequence.drop;
var isEmpty = wisp_sequence.isEmpty;
var wisp_repl = require('./repl');
var startRepl = wisp_repl.start;
var wisp_engine_node = require('./engine/node');
var wisp_runtime = require('./runtime');
var str = wisp_runtime.str;
var subs = wisp_runtime.subs;
var isEqual = wisp_runtime.isEqual;
var isNil = wisp_runtime.isNil;
var wisp_ast = require('./ast');
var prStr = wisp_ast.prStr;
var name = wisp_ast.name;
var wisp_compiler = require('./compiler');
var compile = wisp_compiler.compile;
}
var compileStdin = exports.compileStdin = function compileStdin(options) {
return withStreamContent(process.stdin, compileString, conj({}, options));
};
var compileFile = exports.compileFile = function compileFile(path, options) {
return withStreamContent(createReadStream(path), compileString, conj({ 'source-uri': path }, options));
};
var compileString = exports.compileString = function compileString(source, options) {
return function () {
var channelø1 = (options || 0)['print'] || 'code';
var outputø1 = compile(source, options);
var contentø1 = isEqual(channelø1, 'code') ? (outputø1 || 0)['code'] : isEqual(channelø1, 'expansion') ? (outputø1 || 0)['expansion'] : 'else' ? JSON.stringify((outputø1 || 0)[channelø1], 2, 2) : void 0;
process.stdout.write(contentø1 || 'nil');
return (outputø1 || 0)['error'] ? (function () {
throw outputø1.error;
})() : void 0;
}.call(this);
};
var withStreamContent = exports.withStreamContent = function withStreamContent(input, resume, options) {
return function () {
var contentø1 = '';
input.setEncoding('utf8');
input.resume();
input.on('data', function ($1) {
return contentø1 = '' + contentø1 + $1;
});
return input.once('end', function () {
return resume(contentø1, options);
});
}.call(this);
};
var run = exports.run = function run(path) {
return Module._load(resolve(path), null, true);
};
void 0;
var parseParams = exports.parseParams = function parseParams(params) {
return function () {
var optionsø1 = commander.version(version).usage('[options] <file ...>').option('-r, --run', 'compile and execute the file (same as wisp path/to/file.wisp)').option('-c, --compile', 'compile given file and prints to stdout').option('-i, --interactive', 'run an interactive wisp REPL (same as wisp with no params)').option('--print <format>', 'use custom print output `expansion`,`forms`, `ast`, `js-ast` or (default) `code`', function (x, _) {
return '' + x;
}, 'code').option('--no-map', 'disable source map generation').option('--source-uri <uri>', 'uri input will be associated with in source maps').option('--output-uri <uri>', 'uri output will be associated with in source maps').parse(params);
return conj({ 'no-map': !(optionsø1 || 0)['map'] }, optionsø1);
}.call(this);
};
var main = exports.main = function main() {
return function () {
var optionsø1 = parseParams(process.argv);
var pathø1 = optionsø1.args[0];
return optionsø1.run ? run(pathø1) : !process.stdin.isTTY ? compileStdin(optionsø1) : optionsø1.interactive ? startRepl() : optionsø1.compile ? compileFile(pathø1, optionsø1) : pathø1 ? run(pathø1) : 'else' ? startRepl() : void 0;
}.call(this);
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["anonymous.wisp"],"names":["_ns_","id","doc","createReadStream","basename","dirname","join","resolve","Module","version","split","upperCase","replace","first","second","last","count","reduce","rest","conj","partition","assoc","drop","isEmpty","startRepl","start","str","subs","isEqual","isNil","prStr","name","compile","compileStdin","exports","options","withStreamContent","process","stdin","compileString","compileFile","path","source","channelø1","outputø1","contentø1","JSON","stringify","stdout","write","error","input","resume","setEncoding","on","$1","once","run","_load","null","parseParams","params","optionsø1","commander","usage","option","x","_","parse","main","argv","pathø1","args","stdin.isTTY","interactive"],"mappings":"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","sourcesContent":["(ns wisp.wisp\n  \"Wisp program that reads wisp code from stdin and prints\n  compiled javascript code into stdout\"\n  (:require [fs :refer [createReadStream]]\n            [path :refer [basename dirname join resolve]]\n            [module :refer [Module]]\n            [commander]\n            [wisp.package :refer [version]]\n\n            [wisp.string :refer [split join upper-case replace]]\n            [wisp.sequence :refer [first second last count reduce rest\n                                   conj partition assoc drop empty?]]\n\n            [wisp.repl :refer [start] :rename {start start-repl}]\n            [wisp.engine.node]\n            [wisp.runtime :refer [str subs = nil?]]\n            [wisp.ast :refer [pr-str name]]\n            [wisp.compiler :refer [compile]]))\n\n(defn compile-stdin\n  [options]\n  (with-stream-content process.stdin\n                       compile-string\n                       (conj {} options)))\n;; (conj {:source-uri options}) causes segfault for some reason\n\n(defn compile-file\n  [path options]\n  (with-stream-content (createReadStream path)\n                       compile-string\n                       (conj {:source-uri path} options)))\n\n(defn compile-string\n  [source options]\n  (let [channel (or (:print options) :code)\n        output (compile source options)\n        content (cond\n                  (= channel :code) (:code output)\n                  (= channel :expansion) (:expansion output)\n                  :else (JSON.stringify (get output channel) 2 2))]\n      (.write process.stdout (or content \"nil\"))\n    (if (:error output) (throw (.-error output)))))\n\n(defn with-stream-content\n  [input resume options]\n  (let [content \"\"]\n    (.setEncoding input \"utf8\")\n    (.resume input)\n    (.on input \"data\" #(set! content (str content %)))\n    (.once input \"end\" (fn [] (resume content options)))))\n\n\n(defn run\n  [path]\n  ;; Loading module as main one, same way as nodejs does it:\n  ;; https://github.com/joyent/node/blob/master/lib/module.js#L489-493\n  (Module._load (resolve path) null true))\n\n(defmacro ->\n  [& operations]\n  (reduce\n   (fn [form operation]\n     (cons (first operation)\n           (cons form (rest operation))))\n   (first operations)\n   (rest operations)))\n\n(defn parse-params\n  [params]\n  (let [options (-> commander\n                    (.version version)\n                    (.usage \"[options] <file ...>\")\n                    (.option \"-r, --run\"\n                             \"compile and execute the file (same as wisp path/to/file.wisp)\")\n                    (.option \"-c, --compile\"\n                             \"compile given file and prints to stdout\")\n                    (.option \"-i, --interactive\"\n                             \"run an interactive wisp REPL (same as wisp with no params)\")\n                    (.option \"--print <format>\"\n                             \"use custom print output `expansion`,`forms`, `ast`, `js-ast` or (default) `code`\"\n                             (fn [x _] (str x))\n                             \"code\")\n                    (.option \"--no-map\"\n                             \"disable source map generation\")\n                    (.option \"--source-uri <uri>\"\n                             \"uri input will be associated with in source maps\")\n                    (.option \"--output-uri <uri>\"\n                             \"uri output will be associated with in source maps\")\n                    (.parse params))]\n    (conj {:no-map (not (:map options))}\n          options)))\n\n(defn main\n  []\n  (let [options (parse-params process.argv)\n        path (aget options.args 0)]\n    (cond options.run (run path)\n          (not process.stdin.isTTY) (compile-stdin options)\n          options.interactive (start-repl)\n          options.compile (compile-file path options)\n          path (run path)\n          :else (start-repl))))\n"]}