UNPKG

wisp

Version:

Homoiconic JS with clojure syntax, s-expressions & macros

155 lines (154 loc) 28.9 kB
{ var _ns_ = { id: 'wisp.backend.javascript.writer', doc: 'Compiler backend for for writing JS output' }; var wisp_ast = require('./../../ast'); var name = wisp_ast.name; var namespace = wisp_ast.namespace; var symbol = wisp_ast.symbol; var isSymbol = wisp_ast.isSymbol; var isKeyword = wisp_ast.isKeyword; var wisp_sequence = require('./../../sequence'); var list = wisp_sequence.list; var first = wisp_sequence.first; var second = wisp_sequence.second; var third = wisp_sequence.third; var rest = wisp_sequence.rest; var isList = wisp_sequence.isList; var vec = wisp_sequence.vec; var map = wisp_sequence.map; var count = wisp_sequence.count; var last = wisp_sequence.last; var reduce = wisp_sequence.reduce; var isEmpty = wisp_sequence.isEmpty; var wisp_runtime = require('./../../runtime'); var isTrue = wisp_runtime.isTrue; var isNil = wisp_runtime.isNil; var isString = wisp_runtime.isString; var isNumber = wisp_runtime.isNumber; var isVector = wisp_runtime.isVector; var isDictionary = wisp_runtime.isDictionary; var isBoolean = wisp_runtime.isBoolean; var isRePattern = wisp_runtime.isRePattern; var reFind = wisp_runtime.reFind; var dec = wisp_runtime.dec; var subs = wisp_runtime.subs; var isEqual = wisp_runtime.isEqual; var wisp_string = require('./../../string'); var replace = wisp_string.replace; var join = wisp_string.join; var split = wisp_string.split; var upperCase = wisp_string.upperCase; } var writeReference = exports.writeReference = function writeReference(form) { 'Translates references from clojure convention to JS:\n\n **macros** __macros__\n list->vector listToVector\n set! set\n foo_bar foo_bar\n number? isNumber\n create-server createServer'; return function () { var idø1 = name(form); idø1 = idø1 === '*' ? 'multiply' : idø1 === '/' ? 'divide' : idø1 === '+' ? 'sum' : idø1 === '-' ? 'subtract' : idø1 === '=' ? 'equal?' : idø1 === '==' ? 'strict-equal?' : idø1 === '<=' ? 'not-greater-than' : idø1 === '>=' ? 'not-less-than' : idø1 === '>' ? 'greater-than' : idø1 === '<' ? 'less-than' : idø1 === '->' ? 'thread-first' : 'else' ? idø1 : void 0; idø1 = join('_', split(idø1, '*')); idø1 = join('-to-', split(idø1, '->')); idø1 = join(split(idø1, '!')); idø1 = join('$', split(idø1, '%')); idø1 = join('-plus-', split(idø1, '+')); idø1 = join('-and-', split(idø1, '&')); idø1 = last(idø1) === '?' ? '' + 'is-' + subs(idø1, 0, dec(count(idø1))) : idø1; idø1 = reduce(function (result, key) { return '' + result + (!isEmpty(result) && !isEmpty(key) ? '' + upperCase((key || 0)[0]) + subs(key, 1) : key); }, '', split(idø1, '-')); return idø1; }.call(this); }; var writeKeywordReference = exports.writeKeywordReference = function writeKeywordReference(form) { return '' + '"' + name(form) + '"'; }; var writeKeyword = exports.writeKeyword = function writeKeyword(form) { return '' + '"' + '\uA789' + name(form) + '"'; }; var writeSymbol = exports.writeSymbol = function writeSymbol(form) { return write(list(symbol(void 0, 'symbol'), namespace(form), name(form))); }; var writeNil = exports.writeNil = function writeNil(form) { return 'void(0)'; }; var writeNumber = exports.writeNumber = function writeNumber(form) { return form; }; var writeBoolean = exports.writeBoolean = function writeBoolean(form) { return isTrue(form) ? 'true' : 'false'; }; var writeString = exports.writeString = function writeString(form) { form = replace(form, RegExp('\\\\', 'g'), '\\\\'); form = replace(form, RegExp('\n', 'g'), '\\n'); form = replace(form, RegExp('\r', 'g'), '\\r'); form = replace(form, RegExp('\t', 'g'), '\\t'); form = replace(form, RegExp('"', 'g'), '\\"'); return '' + '"' + form + '"'; }; var writeTemplate = exports.writeTemplate = function writeTemplate() { var form = Array.prototype.slice.call(arguments, 0); return function () { var indentPatternø1 = /\n *$/; var lineBreakPatterø1 = RegExp('\n', 'g'); var getIndentationø1 = function (code) { return reFind(indentPatternø1, code) || '\n'; }; return function loop() { var recur = loop; var codeø1 = ''; var partsø1 = split(first(form), '~{}'); var valuesø1 = rest(form); do { recur = count(partsø1) > 1 ? (loop[0] = '' + codeø1 + first(partsø1) + replace('' + '' + first(valuesø1), lineBreakPatterø1, getIndentationø1(first(partsø1))), loop[1] = rest(partsø1), loop[2] = rest(valuesø1), loop) : '' + codeø1 + first(partsø1); } while (codeø1 = loop[0], partsø1 = loop[1], valuesø1 = loop[2], recur === loop); return recur; }.call(this); }.call(this); }; var writeGroup = exports.writeGroup = function writeGroup() { var forms = Array.prototype.slice.call(arguments, 0); return join(', ', forms); }; var writeInvoke = exports.writeInvoke = function writeInvoke(callee) { var params = Array.prototype.slice.call(arguments, 1); return writeTemplate('~{}(~{})', callee, writeGroup.apply(void 0, params)); }; var writeError = exports.writeError = function writeError(message) { return function () { return (function () { throw Error(message); })(); }; }; var writeVector = exports.writeVector = writeError('Vectors are not supported'); var writeDictionary = exports.writeDictionary = writeError('Dictionaries are not supported'); var escapePattern = function escapePattern(pattern) { pattern = join('/', split(pattern, '\\/')); pattern = join('\\/', split(pattern, '/')); return pattern; }; var writeRePattern = exports.writeRePattern = function writeRePattern(form) { return function () { var flagsø1 = '' + (form.multiline ? 'm' : '') + (form.ignoreCase ? 'i' : '') + (form.sticky ? 'y' : ''); var patternø1 = form.source; return '' + '/' + escapePattern(patternø1) + '/' + flagsø1; }.call(this); }; var compileComment = exports.compileComment = function compileComment(form) { return compileTemplate(list('//~{}\n', first(form))); }; var writeDef = exports.writeDef = function writeDef(form) { return function () { var idø1 = first(form); var isExportø1 = (meta(form) || {} || 0)['top'] && !(meta(idø1) || {} || 0)['private']; var attributeø1 = symbol(namespace(idø1), '' + '-' + name(idø1)); return isExportø1 ? compileTemplate(list('var ~{};\n~{}', compile(cons(symbol(void 0, 'set!'), form)), compile(list.apply(void 0, [symbol(void 0, 'set!')].concat([list.apply(void 0, [symbol(void 0, '.')].concat([symbol(void 0, 'exports')], [attributeø1]))], [idø1]))))) : compileTemplate(list('var ~{}', compile(cons(symbol(void 0, 'set!'), form)))); }.call(this); }; var isWriteInstance = exports.isWriteInstance = function isWriteInstance(form) { return writeTemplate('~{} instanceof ~{}', write(second(form)), write(first(form))); }; var write = exports.write = function write(form) { return isNil(form) ? writeNil(form) : isSymbol(form) ? writeReference(form) : isKeyword(form) ? writeKeywordReference(form) : isString(form) ? writeString(form) : isNumber(form) ? writeNumber(form) : isBoolean(form) ? writeBoolean(form) : isRePattern(form) ? writePattern(form) : isVector(form) ? writeVector(form) : isDictionary(form) ? writeDictionary() : isList(form) ? writeInvoke.apply(void 0, map(write, vec(form))) : 'else' ? writeError('Unsupported form') : void 0; }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["anonymous.wisp"],"names":["_ns_","id","doc","name","namespace","symbol","isSymbol","isKeyword","list","first","second","third","rest","isList","vec","map","count","last","reduce","isEmpty","isTrue","isNil","isString","isNumber","isVector","isDictionary","isBoolean","isRePattern","reFind","dec","subs","isEqual","replace","join","split","upperCase","writeReference","exports","form","idø1","result","key","writeKeywordReference","writeKeyword","writeSymbol","write","writeNil","writeNumber","writeBoolean","writeString","RegExp","writeTemplate","indentPatternø1","lineBreakPatterø1","getIndentationø1","code","codeø1","partsø1","valuesø1","writeGroup","forms","writeInvoke","callee","params","writeError","message","Error","writeVector","writeDictionary","escapePattern","pattern","writeRePattern","flagsø1","multiline","ignoreCase","sticky","patternø1","source","compileComment","compileTemplate","writeDef","isExportø1","meta","attributeø1","compile","cons","isWriteInstance","writePattern"],"mappings":"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","sourcesContent":["(ns wisp.backend.javascript.writer\n  \"Compiler backend for for writing JS output\"\n  (:require [wisp.ast :refer [name namespace symbol symbol? keyword?]]\n            [wisp.sequence :refer [list first second third rest list?\n                                   vec map count last reduce empty?]]\n            [wisp.runtime :refer [true? nil? string? number? vector?\n                                  dictionary? boolean? re-pattern?\n                                  re-find dec subs =]]\n            [wisp.string :refer [replace join split upper-case]]))\n\n;; Actual code\n\n(defn write-reference\n  [form]\n  \"Translates references from clojure convention to JS:\n\n  **macros**      __macros__\n  list->vector    listToVector\n  set!            set\n  foo_bar         foo_bar\n  number?         isNumber\n  create-server   createServer\"\n  (let [id (name form)]\n    (set! id (cond (identical? id  \"*\") \"multiply\"\n                   (identical? id \"/\") \"divide\"\n                   (identical? id \"+\") \"sum\"\n                   (identical? id \"-\") \"subtract\"\n                   (identical? id \"=\") \"equal?\"\n                   (identical? id \"==\") \"strict-equal?\"\n                   (identical? id \"<=\") \"not-greater-than\"\n                   (identical? id \">=\") \"not-less-than\"\n                   (identical? id \">\") \"greater-than\"\n                   (identical? id \"<\") \"less-than\"\n                   (identical? id \"->\") \"thread-first\"\n                   :else id))\n    ;; **macros** ->  __macros__\n    (set! id (join \"_\" (split id \"*\")))\n    ;; list->vector ->  listToVector\n    (set! id (join \"-to-\" (split id \"->\")))\n    ;; set! ->  set\n    (set! id (join (split id \"!\")))\n    (set! id (join \"$\" (split id \"%\")))\n    ;; foo= -> fooEqual\n    ;(set! id (join \"-equal-\" (split id \"=\"))\n    ;; foo+bar -> fooPlusBar\n    (set! id (join \"-plus-\" (split id \"+\")))\n    (set! id (join \"-and-\" (split id \"&\")))\n    ;; number? -> isNumber\n    (set! id (if (identical? (last id) \"?\")\n               (str \"is-\" (subs id 0 (dec (count id))))\n               id))\n    ;; create-server -> createServer\n    (set! id (reduce\n              (fn [result key]\n                (str result\n                     (if (and (not (empty? result))\n                              (not (empty? key)))\n                       (str (upper-case (get key 0)) (subs key 1))\n                       key)))\n              \"\"\n              (split id \"-\")))\n    id))\n\n(defn write-keyword-reference\n  [form]\n  (str \"\\\"\" (name form) \"\\\"\"))\n\n(defn write-keyword [form] (str \"\\\"\" \"\\uA789\" (name form) \"\\\"\"))\n\n(defn write-symbol [form]\n  (write (list 'symbol (namespace form) (name form))))\n\n(defn write-nil [form] \"void(0)\")\n\n(defn write-number [form] form)\n\n(defn write-boolean [form] (if (true? form) \"true\" \"false\"))\n\n(defn write-string\n  [form]\n  (set! form (replace form (RegExp \"\\\\\\\\\" \"g\") \"\\\\\\\\\"))\n  (set! form (replace form (RegExp \"\\n\" \"g\") \"\\\\n\"))\n  (set! form (replace form (RegExp \"\\r\" \"g\") \"\\\\r\"))\n  (set! form (replace form (RegExp \"\\t\" \"g\") \"\\\\t\"))\n  (set! form (replace form (RegExp \"\\\"\" \"g\") \"\\\\\\\"\"))\n  (str \"\\\"\" form \"\\\"\"))\n\n(defn write-template\n  \"Compiles given template\"\n  [& form]\n  (let [indent-pattern #\"\\n *$\"\n        line-break-patter (RegExp \"\\n\" \"g\")\n        get-indentation (fn [code] (or (re-find indent-pattern code) \"\\n\"))]\n    (loop [code \"\"\n           parts (split (first form) \"~{}\")\n           values (rest form)]\n      (if (> (count parts) 1)\n        (recur\n         (str\n          code\n          (first parts)\n          (replace (str \"\" (first values))\n                    line-break-patter\n                    (get-indentation (first parts))))\n         (rest parts)\n         (rest values))\n         (str code (first parts))))))\n\n\n(defn write-group\n  [& forms]\n  (join \", \" forms))\n\n(defn write-invoke\n  [callee & params]\n  (write-template \"~{}(~{})\" callee (apply write-group params)))\n\n(defn write-error\n  [message]\n  (fn [] (throw (Error message))))\n\n(def write-vector (write-error \"Vectors are not supported\"))\n(def write-dictionary (write-error \"Dictionaries are not supported\"))\n\n(defn- escape-pattern [pattern]\n  (set! pattern (join \"/\" (split pattern \"\\\\/\")))\n  (set! pattern (join \"\\\\/\" (split pattern \"/\")))\n  pattern)\n\n(defn write-re-pattern\n  [form]\n  (let [flags (str (if form.multiline \"m\" \"\")\n                   (if form.ignoreCase \"i\" \"\")\n                   (if form.sticky \"y\" \"\"))\n        pattern form.source]\n    (str \\/ (escape-pattern pattern) \\/ flags)))\n\n\n(defn compile-comment\n  [form]\n  (compile-template (list \"//~{}\\n\" (first form))))\n\n(defn write-def\n  \"Creates and interns or locates a global var with the name of symbol\n  and a namespace of the value of the current namespace (*ns*). If init\n  is supplied, it is evaluated, and the root binding of the var is set\n  to the resulting value. If init is not supplied, the root binding of\n  the var is unaffected. def always applies to the root binding, even if\n  the var is thread-bound at the point where def is called. def yields\n  the var itself (not its value).\"\n  [form]\n  (let [id (first form)\n        export? (and (:top (or (meta form) {}))\n                     (not (:private (or (meta id) {}))))\n        attribute (symbol (namespace id)\n                          (str \"-\" (name id)))]\n    (if export?\n      (compile-template (list \"var ~{};\\n~{}\"\n                               (compile (cons 'set! form))\n                               (compile `(set! (. exports ~attribute) ~id))))\n      (compile-template (list \"var ~{}\"\n                              (compile (cons 'set! form)))))))\n\n\n(defn write-instance?\n  \"Evaluates x and tests if it is an instance of the class\n  c. Returns true or false\"\n  [form]\n  (write-template \"~{} instanceof ~{}\"\n                  (write (second form))\n                  (write (first form))))\n(defn write\n  \"compiles given form\"\n  [form]\n  (cond\n   (nil? form) (write-nil form)\n   (symbol? form) (write-reference form)\n   (keyword? form) (write-keyword-reference form)\n   (string? form) (write-string form)\n   (number? form) (write-number form)\n   (boolean? form) (write-boolean form)\n   (re-pattern? form) (write-pattern form)\n   (vector? form) (write-vector form)\n   (dictionary? form) (write-dictionary)\n   (list? form) (apply write-invoke (map write (vec form)))\n   :else (write-error \"Unsupported form\")))\n"]}