Update to 8.0
This commit is contained in:
@@ -4,7 +4,7 @@ Description: Erlang is a general-purpose functional language, with strict evalua
|
||||
Author: Nikolay Zakharov <nikolay.desh@gmail.com>, Dmitry Kovega <arhibot@gmail.com>
|
||||
*/
|
||||
|
||||
hljs.LANGUAGES['erlang'] = function(hljs) {
|
||||
function(hljs) {
|
||||
var BASIC_ATOM_RE = '[a-z\'][a-zA-Z0-9_\']*';
|
||||
var FUNCTION_NAME_RE = '(' + BASIC_ATOM_RE + ':' + BASIC_ATOM_RE + '|' + BASIC_ATOM_RE + ')';
|
||||
var ERLANG_RESERVED = {
|
||||
@@ -17,8 +17,7 @@ hljs.LANGUAGES['erlang'] = function(hljs) {
|
||||
|
||||
var COMMENT = {
|
||||
className: 'comment',
|
||||
begin: '%', end: '$',
|
||||
relevance: 0
|
||||
begin: '%', end: '$'
|
||||
};
|
||||
var NUMBER = {
|
||||
className: 'number',
|
||||
@@ -62,8 +61,7 @@ hljs.LANGUAGES['erlang'] = function(hljs) {
|
||||
relevance: 0
|
||||
};
|
||||
var RECORD_ACCESS = {
|
||||
begin: '#', end: '}',
|
||||
illegal: '.',
|
||||
begin: '#' + hljs.UNDERSCORE_IDENT_RE,
|
||||
relevance: 0,
|
||||
returnBegin: true,
|
||||
contains: [
|
||||
@@ -73,7 +71,7 @@ hljs.LANGUAGES['erlang'] = function(hljs) {
|
||||
relevance: 0
|
||||
},
|
||||
{
|
||||
begin: '{', endsWithParent: true,
|
||||
begin: '{', end: '}',
|
||||
relevance: 0
|
||||
// "contains" defined later
|
||||
}
|
||||
@@ -81,8 +79,8 @@ hljs.LANGUAGES['erlang'] = function(hljs) {
|
||||
};
|
||||
|
||||
var BLOCK_STATEMENTS = {
|
||||
keywords: ERLANG_RESERVED,
|
||||
begin: '(fun|receive|if|try|case)', end: 'end'
|
||||
beginKeywords: 'fun receive if try case', end: 'end',
|
||||
keywords: ERLANG_RESERVED
|
||||
};
|
||||
BLOCK_STATEMENTS.contains = [
|
||||
COMMENT,
|
||||
@@ -118,47 +116,45 @@ hljs.LANGUAGES['erlang'] = function(hljs) {
|
||||
contains: BASIC_MODES
|
||||
};
|
||||
return {
|
||||
defaultMode: {
|
||||
keywords: ERLANG_RESERVED,
|
||||
illegal: '(</|\\*=|\\+=|-=|/=|/\\*|\\*/|\\(\\*|\\*\\))',
|
||||
contains: [
|
||||
{
|
||||
className: 'function',
|
||||
begin: '^' + BASIC_ATOM_RE + '\\s*\\(', end: '->',
|
||||
returnBegin: true,
|
||||
illegal: '\\(|#|//|/\\*|\\\\|:',
|
||||
contains: [
|
||||
PARAMS,
|
||||
{
|
||||
className: 'title', begin: BASIC_ATOM_RE
|
||||
}
|
||||
],
|
||||
starts: {
|
||||
end: ';|\\.',
|
||||
keywords: ERLANG_RESERVED,
|
||||
contains: BASIC_MODES
|
||||
}
|
||||
},
|
||||
COMMENT,
|
||||
{
|
||||
className: 'pp',
|
||||
begin: '^-', end: '\\.',
|
||||
relevance: 0,
|
||||
excludeEnd: true,
|
||||
returnBegin: true,
|
||||
lexems: '-' + hljs.IDENT_RE,
|
||||
keywords:
|
||||
'-module -record -undef -export -ifdef -ifndef -author -copyright -doc -vsn ' +
|
||||
'-import -include -include_lib -compile -define -else -endif -file -behaviour ' +
|
||||
'-behavior',
|
||||
contains: [PARAMS]
|
||||
},
|
||||
NUMBER,
|
||||
hljs.QUOTE_STRING_MODE,
|
||||
RECORD_ACCESS,
|
||||
VAR1, VAR2,
|
||||
TUPLE
|
||||
]
|
||||
}
|
||||
aliases: ['erl'],
|
||||
keywords: ERLANG_RESERVED,
|
||||
illegal: '(</|\\*=|\\+=|-=|/\\*|\\*/|\\(\\*|\\*\\))',
|
||||
contains: [
|
||||
{
|
||||
className: 'function',
|
||||
begin: '^' + BASIC_ATOM_RE + '\\s*\\(', end: '->',
|
||||
returnBegin: true,
|
||||
illegal: '\\(|#|//|/\\*|\\\\|:|;',
|
||||
contains: [
|
||||
PARAMS,
|
||||
hljs.inherit(hljs.TITLE_MODE, {begin: BASIC_ATOM_RE})
|
||||
],
|
||||
starts: {
|
||||
end: ';|\\.',
|
||||
keywords: ERLANG_RESERVED,
|
||||
contains: BASIC_MODES
|
||||
}
|
||||
},
|
||||
COMMENT,
|
||||
{
|
||||
className: 'pp',
|
||||
begin: '^-', end: '\\.',
|
||||
relevance: 0,
|
||||
excludeEnd: true,
|
||||
returnBegin: true,
|
||||
lexemes: '-' + hljs.IDENT_RE,
|
||||
keywords:
|
||||
'-module -record -undef -export -ifdef -ifndef -author -copyright -doc -vsn ' +
|
||||
'-import -include -include_lib -compile -define -else -endif -file -behaviour ' +
|
||||
'-behavior -spec',
|
||||
contains: [PARAMS]
|
||||
},
|
||||
NUMBER,
|
||||
hljs.QUOTE_STRING_MODE,
|
||||
RECORD_ACCESS,
|
||||
VAR1, VAR2,
|
||||
TUPLE,
|
||||
{begin: /\.$/} // relevance booster
|
||||
]
|
||||
};
|
||||
}(hljs);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user