html5.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. function pug_attr(t, e, n, f) {
  2. return !1 !== e && null != e && (e || "class" !== t && "style" !== t) ? !0 === e ? " " + (f ? t : t + '="' + t + '"') : ("function" == typeof e.toJSON && (e = e.toJSON()),
  3. "string" == typeof e || (e = JSON.stringify(e), n || -1 === e.indexOf('"')) ? (n && (e = pug_escape(e)),
  4. " " + t + '="' + e + '"') : " " + t + "='" + e.replace(/'/g, "'") + "'") : "";
  5. }
  6. function pug_escape(e) {
  7. var a = "" + e, t = pug_match_html.exec(a);
  8. if (!t) return e;
  9. var r, c, n, s = "";
  10. for (r = t.index, c = 0; r < a.length; r++) {
  11. switch (a.charCodeAt(r)) {
  12. case 34:
  13. n = "&quot;";
  14. break;
  15. case 38:
  16. n = "&amp;";
  17. break;
  18. case 60:
  19. n = "&lt;";
  20. break;
  21. case 62:
  22. n = "&gt;";
  23. break;
  24. default:
  25. continue;
  26. }
  27. c !== r && (s += a.substring(c, r)), c = r + 1, s += n;
  28. }
  29. return c !== r ? s + a.substring(c, r) : s;
  30. }
  31. var pug_match_html = /["&<>]/;
  32. function template(locals) {
  33. var pug_html = "", pug_mixins = {}, pug_interp;
  34. pug_html = pug_html + "<!DOCTYPE html><input" + (' type="checkbox"' + pug_attr("checked", true, true, true)) + '><input type="checkbox" checked><input type="checkbox">';
  35. return pug_html;
  36. }