aboutsummaryrefslogtreecommitdiff
path: root/node_modules/es5-ext/string/raw
diff options
context:
space:
mode:
Diffstat (limited to 'node_modules/es5-ext/string/raw')
-rw-r--r--node_modules/es5-ext/string/raw/implement.js8
-rw-r--r--node_modules/es5-ext/string/raw/index.js5
-rw-r--r--node_modules/es5-ext/string/raw/is-implemented.js9
-rw-r--r--node_modules/es5-ext/string/raw/shim.js14
4 files changed, 36 insertions, 0 deletions
diff --git a/node_modules/es5-ext/string/raw/implement.js b/node_modules/es5-ext/string/raw/implement.js
new file mode 100644
index 000000000..0f17df3f1
--- /dev/null
+++ b/node_modules/es5-ext/string/raw/implement.js
@@ -0,0 +1,8 @@
+"use strict";
+
+if (!require("./is-implemented")()) {
+ Object.defineProperty(String, "raw", { value: require("./shim"),
+ configurable: true,
+enumerable: false,
+writable: true });
+}
diff --git a/node_modules/es5-ext/string/raw/index.js b/node_modules/es5-ext/string/raw/index.js
new file mode 100644
index 000000000..e818dd56d
--- /dev/null
+++ b/node_modules/es5-ext/string/raw/index.js
@@ -0,0 +1,5 @@
+"use strict";
+
+module.exports = require("./is-implemented")()
+ ? String.raw
+ : require("./shim");
diff --git a/node_modules/es5-ext/string/raw/is-implemented.js b/node_modules/es5-ext/string/raw/is-implemented.js
new file mode 100644
index 000000000..8758108c0
--- /dev/null
+++ b/node_modules/es5-ext/string/raw/is-implemented.js
@@ -0,0 +1,9 @@
+"use strict";
+
+module.exports = function () {
+ var raw = String.raw, test;
+ if (typeof raw !== "function") return false;
+ test = ["foo\nbar", "marko\n"];
+ test.raw = ["foo\\nbar", "marko\\n"];
+ return raw(test, "INSE\nRT") === "foo\\nbarINSE\nRTmarko\\n";
+};
diff --git a/node_modules/es5-ext/string/raw/shim.js b/node_modules/es5-ext/string/raw/shim.js
new file mode 100644
index 000000000..8c52bb552
--- /dev/null
+++ b/node_modules/es5-ext/string/raw/shim.js
@@ -0,0 +1,14 @@
+"use strict";
+
+var toPosInt = require("../../number/to-pos-integer")
+ , validValue = require("../../object/valid-value")
+ , reduce = Array.prototype.reduce;
+
+module.exports = function (callSite /*, …substitutions*/) {
+ var args, rawValue = Object(validValue(Object(validValue(callSite)).raw));
+ if (!toPosInt(rawValue.length)) return "";
+ args = arguments;
+ return reduce.call(rawValue, function (str1, str2, i) {
+ return str1 + String(args[i]) + str2;
+ });
+};