diff options
| author | Armand Philippot <git@armandphilippot.com> | 2021-12-30 19:47:21 +0100 |
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2021-12-30 19:47:21 +0100 |
| commit | a98b5ea6fe8e8cc98a55e0fd793e6e8660ea31c1 (patch) | |
| tree | 542810ab5aef99150db228bb54fd58303dcb31c7 /public/prism/prism-swift.js | |
| parent | ab355897a12b7bda1089a44de326d41455a0f7a3 (diff) | |
chore: add prismjs for syntax highlighting
Diffstat (limited to 'public/prism/prism-swift.js')
| -rw-r--r-- | public/prism/prism-swift.js | 154 |
1 files changed, 154 insertions, 0 deletions
diff --git a/public/prism/prism-swift.js b/public/prism/prism-swift.js new file mode 100644 index 0000000..d58d7b9 --- /dev/null +++ b/public/prism/prism-swift.js @@ -0,0 +1,154 @@ +Prism.languages.swift = { + comment: { + // Nested comments are supported up to 2 levels + pattern: + /(^|[^\\:])(?:\/\/.*|\/\*(?:[^/*]|\/(?!\*)|\*(?!\/)|\/\*(?:[^*]|\*(?!\/))*\*\/)*\*\/)/, + lookbehind: true, + greedy: true, + }, + 'string-literal': [ + // https://docs.swift.org/swift-book/LanguageGuide/StringsAndCharacters.html + { + pattern: RegExp( + /(^|[^"#])/.source + + '(?:' + + // single-line string + /"(?:\\(?:\((?:[^()]|\([^()]*\))*\)|\r\n|[^(])|[^\\\r\n"])*"/.source + + '|' + + // multi-line string + /"""(?:\\(?:\((?:[^()]|\([^()]*\))*\)|[^(])|[^\\"]|"(?!""))*"""/ + .source + + ')' + + /(?!["#])/.source + ), + lookbehind: true, + greedy: true, + inside: { + interpolation: { + pattern: /(\\\()(?:[^()]|\([^()]*\))*(?=\))/, + lookbehind: true, + inside: null, // see below + }, + 'interpolation-punctuation': { + pattern: /^\)|\\\($/, + alias: 'punctuation', + }, + punctuation: /\\(?=[\r\n])/, + string: /[\s\S]+/, + }, + }, + { + pattern: RegExp( + /(^|[^"#])(#+)/.source + + '(?:' + + // single-line string + /"(?:\\(?:#+\((?:[^()]|\([^()]*\))*\)|\r\n|[^#])|[^\\\r\n])*?"/ + .source + + '|' + + // multi-line string + /"""(?:\\(?:#+\((?:[^()]|\([^()]*\))*\)|[^#])|[^\\])*?"""/.source + + ')' + + '\\2' + ), + lookbehind: true, + greedy: true, + inside: { + interpolation: { + pattern: /(\\#+\()(?:[^()]|\([^()]*\))*(?=\))/, + lookbehind: true, + inside: null, // see below + }, + 'interpolation-punctuation': { + pattern: /^\)|\\#+\($/, + alias: 'punctuation', + }, + string: /[\s\S]+/, + }, + }, + ], + + directive: { + // directives with conditions + pattern: RegExp( + /#/.source + + '(?:' + + (/(?:elseif|if)\b/.source + + '(?:[ \t]*' + + // This regex is a little complex. It's equivalent to this: + // (?:![ \t]*)?(?:\b\w+\b(?:[ \t]*<round>)?|<round>)(?:[ \t]*(?:&&|\|\|))? + // where <round> is a general parentheses expression. + /(?:![ \t]*)?(?:\b\w+\b(?:[ \t]*\((?:[^()]|\([^()]*\))*\))?|\((?:[^()]|\([^()]*\))*\))(?:[ \t]*(?:&&|\|\|))?/ + .source + + ')+') + + '|' + + /(?:else|endif)\b/.source + + ')' + ), + alias: 'property', + inside: { + 'directive-name': /^#\w+/, + boolean: /\b(?:false|true)\b/, + number: /\b\d+(?:\.\d+)*\b/, + operator: /!|&&|\|\||[<>]=?/, + punctuation: /[(),]/, + }, + }, + literal: { + pattern: + /#(?:colorLiteral|column|dsohandle|file(?:ID|Literal|Path)?|function|imageLiteral|line)\b/, + alias: 'constant', + }, + 'other-directive': { + pattern: /#\w+\b/, + alias: 'property', + }, + + attribute: { + pattern: /@\w+/, + alias: 'atrule', + }, + + 'function-definition': { + pattern: /(\bfunc\s+)\w+/, + lookbehind: true, + alias: 'function', + }, + label: { + // https://docs.swift.org/swift-book/LanguageGuide/ControlFlow.html#ID141 + pattern: + /\b(break|continue)\s+\w+|\b[a-zA-Z_]\w*(?=\s*:\s*(?:for|repeat|while)\b)/, + lookbehind: true, + alias: 'important', + }, + + keyword: + /\b(?:Any|Protocol|Self|Type|actor|as|assignment|associatedtype|associativity|async|await|break|case|catch|class|continue|convenience|default|defer|deinit|didSet|do|dynamic|else|enum|extension|fallthrough|fileprivate|final|for|func|get|guard|higherThan|if|import|in|indirect|infix|init|inout|internal|is|isolated|lazy|left|let|lowerThan|mutating|none|nonisolated|nonmutating|open|operator|optional|override|postfix|precedencegroup|prefix|private|protocol|public|repeat|required|rethrows|return|right|safe|self|set|some|static|struct|subscript|super|switch|throw|throws|try|typealias|unowned|unsafe|var|weak|where|while|willSet)\b/, + boolean: /\b(?:false|true)\b/, + nil: { + pattern: /\bnil\b/, + alias: 'constant', + }, + + 'short-argument': /\$\d+\b/, + omit: { + pattern: /\b_\b/, + alias: 'keyword', + }, + number: + /\b(?:[\d_]+(?:\.[\de_]+)?|0x[a-f0-9_]+(?:\.[a-f0-9p_]+)?|0b[01_]+|0o[0-7_]+)\b/i, + + // A class name must start with an upper-case letter and be either 1 letter long or contain a lower-case letter. + 'class-name': /\b[A-Z](?:[A-Z_\d]*[a-z]\w*)?\b/, + function: /\b[a-z_]\w*(?=\s*\()/i, + constant: /\b(?:[A-Z_]{2,}|k[A-Z][A-Za-z_]+)\b/, + + // Operators are generic in Swift. Developers can even create new operators (e.g. +++). + // https://docs.swift.org/swift-book/ReferenceManual/zzSummaryOfTheGrammar.html#ID481 + // This regex only supports ASCII operators. + operator: /[-+*/%=!<>&|^~?]+|\.[.\-+*/%=!<>&|^~?]+/, + punctuation: /[{}[\]();,.:\\]/, +}; + +Prism.languages.swift['string-literal'].forEach(function (rule) { + rule.inside['interpolation'].inside = Prism.languages.swift; +}); |
