text.mjs 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. // Skip text characters for text token, place those to pending buffer
  2. // and increment current pos
  3. // Rule to skip pure text
  4. // '{}$%@~+=:' reserved for extentions
  5. // !, ", #, $, %, &, ', (, ), *, +, ,, -, ., /, :, ;, <, =, >, ?, @, [, \, ], ^, _, `, {, |, }, or ~
  6. // !!!! Don't confuse with "Markdown ASCII Punctuation" chars
  7. // http://spec.commonmark.org/0.15/#ascii-punctuation-character
  8. function isTerminatorChar (ch) {
  9. switch (ch) {
  10. case 0x0A/* \n */:
  11. case 0x21/* ! */:
  12. case 0x23/* # */:
  13. case 0x24/* $ */:
  14. case 0x25/* % */:
  15. case 0x26/* & */:
  16. case 0x2A/* * */:
  17. case 0x2B/* + */:
  18. case 0x2D/* - */:
  19. case 0x3A/* : */:
  20. case 0x3C/* < */:
  21. case 0x3D/* = */:
  22. case 0x3E/* > */:
  23. case 0x40/* @ */:
  24. case 0x5B/* [ */:
  25. case 0x5C/* \ */:
  26. case 0x5D/* ] */:
  27. case 0x5E/* ^ */:
  28. case 0x5F/* _ */:
  29. case 0x60/* ` */:
  30. case 0x7B/* { */:
  31. case 0x7D/* } */:
  32. case 0x7E/* ~ */:
  33. return true
  34. default:
  35. return false
  36. }
  37. }
  38. export default function text (state, silent) {
  39. let pos = state.pos
  40. while (pos < state.posMax && !isTerminatorChar(state.src.charCodeAt(pos))) {
  41. pos++
  42. }
  43. if (pos === state.pos) { return false }
  44. if (!silent) { state.pending += state.src.slice(state.pos, pos) }
  45. state.pos = pos
  46. return true
  47. }
  48. // Alternative implementation, for memory.
  49. //
  50. // It costs 10% of performance, but allows extend terminators list, if place it
  51. // to `ParserInline` property. Probably, will switch to it sometime, such
  52. // flexibility required.
  53. /*
  54. var TERMINATOR_RE = /[\n!#$%&*+\-:<=>@[\\\]^_`{}~]/;
  55. module.exports = function text(state, silent) {
  56. var pos = state.pos,
  57. idx = state.src.slice(pos).search(TERMINATOR_RE);
  58. // first char is terminator -> empty text
  59. if (idx === 0) { return false; }
  60. // no terminator -> text till end of string
  61. if (idx < 0) {
  62. if (!silent) { state.pending += state.src.slice(pos); }
  63. state.pos = state.src.length;
  64. return true;
  65. }
  66. if (!silent) { state.pending += state.src.slice(pos, pos + idx); }
  67. state.pos += idx;
  68. return true;
  69. }; */