123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- module.exports = // We try to support full Ada2012
- //
- // We highlight all appearances of types, keywords, literals (string, char, number, bool)
- // and titles (user defined function/procedure/package)
- // CSS classes are set accordingly
- //
- // Languages causing problems for language detection:
- // xml (broken by Foo : Bar type), elm (broken by Foo : Bar type), vbscript-html (broken by body keyword)
- // sql (ada default.txt has a lot of sql keywords)
- function(hljs) {
- // Regular expression for Ada numeric literals.
- // stolen form the VHDL highlighter
- // Decimal literal:
- var INTEGER_RE = '\\d(_|\\d)*';
- var EXPONENT_RE = '[eE][-+]?' + INTEGER_RE;
- var DECIMAL_LITERAL_RE = INTEGER_RE + '(\\.' + INTEGER_RE + ')?' + '(' + EXPONENT_RE + ')?';
- // Based literal:
- var BASED_INTEGER_RE = '\\w+';
- var BASED_LITERAL_RE = INTEGER_RE + '#' + BASED_INTEGER_RE + '(\\.' + BASED_INTEGER_RE + ')?' + '#' + '(' + EXPONENT_RE + ')?';
- var NUMBER_RE = '\\b(' + BASED_LITERAL_RE + '|' + DECIMAL_LITERAL_RE + ')';
- // Identifier regex
- var ID_REGEX = '[A-Za-z](_?[A-Za-z0-9.])*';
- // bad chars, only allowed in literals
- var BAD_CHARS = '[]{}%#\'\"'
- // Ada doesn't have block comments, only line comments
- var COMMENTS = hljs.COMMENT('--', '$');
- // variable declarations of the form
- // Foo : Bar := Baz;
- // where only Bar will be highlighted
- var VAR_DECLS = {
- // TODO: These spaces are not required by the Ada syntax
- // however, I have yet to see handwritten Ada code where
- // someone does not put spaces around :
- begin: '\\s+:\\s+', end: '\\s*(:=|;|\\)|=>|$)',
- // endsWithParent: true,
- // returnBegin: true,
- illegal: BAD_CHARS,
- contains: [
- {
- // workaround to avoid highlighting
- // named loops and declare blocks
- beginKeywords: 'loop for declare others',
- endsParent: true,
- },
- {
- // properly highlight all modifiers
- className: 'keyword',
- beginKeywords: 'not null constant access function procedure in out aliased exception'
- },
- {
- className: 'type',
- begin: ID_REGEX,
- endsParent: true,
- relevance: 0,
- }
- ]
- };
- return {
- case_insensitive: true,
- keywords: {
- keyword:
- 'abort else new return abs elsif not reverse abstract end ' +
- 'accept entry select access exception of separate aliased exit or some ' +
- 'all others subtype and for out synchronized array function overriding ' +
- 'at tagged generic package task begin goto pragma terminate ' +
- 'body private then if procedure type case in protected constant interface ' +
- 'is raise use declare range delay limited record when delta loop rem while ' +
- 'digits renames with do mod requeue xor',
- literal:
- 'True False',
- },
- contains: [
- COMMENTS,
- // strings "foobar"
- {
- className: 'string',
- begin: /"/, end: /"/,
- contains: [{begin: /""/, relevance: 0}]
- },
- // characters ''
- {
- // character literals always contain one char
- className: 'string',
- begin: /'.'/
- },
- {
- // number literals
- className: 'number',
- begin: NUMBER_RE,
- relevance: 0
- },
- {
- // Attributes
- className: 'symbol',
- begin: "'" + ID_REGEX,
- },
- {
- // package definition, maybe inside generic
- className: 'title',
- begin: '(\\bwith\\s+)?(\\bprivate\\s+)?\\bpackage\\s+(\\bbody\\s+)?', end: '(is|$)',
- keywords: 'package body',
- excludeBegin: true,
- excludeEnd: true,
- illegal: BAD_CHARS
- },
- {
- // function/procedure declaration/definition
- // maybe inside generic
- begin: '(\\b(with|overriding)\\s+)?\\b(function|procedure)\\s+', end: '(\\bis|\\bwith|\\brenames|\\)\\s*;)',
- keywords: 'overriding function procedure with is renames return',
- // we need to re-match the 'function' keyword, so that
- // the title mode below matches only exactly once
- returnBegin: true,
- contains:
- [
- COMMENTS,
- {
- // name of the function/procedure
- className: 'title',
- begin: '(\\bwith\\s+)?\\b(function|procedure)\\s+',
- end: '(\\(|\\s+|$)',
- excludeBegin: true,
- excludeEnd: true,
- illegal: BAD_CHARS
- },
- // 'self'
- // // parameter types
- VAR_DECLS,
- {
- // return type
- className: 'type',
- begin: '\\breturn\\s+', end: '(\\s+|;|$)',
- keywords: 'return',
- excludeBegin: true,
- excludeEnd: true,
- // we are done with functions
- endsParent: true,
- illegal: BAD_CHARS
- },
- ]
- },
- {
- // new type declarations
- // maybe inside generic
- className: 'type',
- begin: '\\b(sub)?type\\s+', end: '\\s+',
- keywords: 'type',
- excludeBegin: true,
- illegal: BAD_CHARS
- },
- // see comment above the definition
- VAR_DECLS,
- // no markup
- // relevance boosters for small snippets
- // {begin: '\\s*=>\\s*'},
- // {begin: '\\s*:=\\s*'},
- // {begin: '\\s+:=\\s+'},
- ]
- };
- };
|