2023-01-16 22:26:34 +00:00
ace . define ( "ace/mode/alda_highlight_rules" , [ "require" , "exports" , "module" , "ace/lib/oop" , "ace/mode/text_highlight_rules" ] , function ( require , exports , module ) { /* This file was autogenerated from ../../src/alda.JSON-tmLanguage (uuid: ) */
"use strict" ;
var oop = require ( "../lib/oop" ) ;
var TextHighlightRules = require ( "./text_highlight_rules" ) . TextHighlightRules ;
var AldaHighlightRules = function ( ) {
this . $rules = {
pitch : [ {
2020-04-14 12:14:48 +00:00
token : "variable.parameter.operator.pitch.alda" ,
regex : /(?:[+\-]+|\=)/
} , {
token : "" ,
regex : "" ,
next : "timing"
} ] ,
2023-01-16 22:26:34 +00:00
timing : [ {
2020-04-14 12:14:48 +00:00
token : "string.quoted.operator.timing.alda" ,
regex : /\d+(?:s|ms)?/
} , {
token : "" ,
regex : "" ,
next : "start"
} ] ,
2023-01-16 22:26:34 +00:00
start : [ {
2020-04-14 12:14:48 +00:00
token : [
"constant.language.instrument.alda" ,
"constant.language.instrument.alda" ,
"meta.part.call.alda" ,
"storage.type.nickname.alda" ,
"meta.part.call.alda"
] ,
regex : /^([a-zA-Z]{2}[\w\-+\'()]*)((?:\s*\/\s*[a-zA-Z]{2}[\w\-+\'()]*)*)(?:(\s*)(\"[a-zA-Z]{2}[\w\-+\'()]*\"))?(\s*:)/
} , {
token : [
"text" ,
"entity.other.inherited-class.voice.alda" ,
"text"
] ,
regex : /^(\s*)(V\d+)(:)/
} , {
token : "comment.line.number-sign.alda" ,
regex : /#.*$/
} , {
token : "entity.name.function.pipe.measure.alda" ,
regex : /\|/
} , {
token : "comment.block.inline.alda" ,
regex : /\(comment\b/ ,
push : [ {
2023-01-16 22:26:34 +00:00
token : "comment.block.inline.alda" ,
regex : /\)/ ,
next : "pop"
} , {
defaultToken : "comment.block.inline.alda"
} ]
2020-04-14 12:14:48 +00:00
} , {
token : "entity.name.function.marker.alda" ,
regex : /%[a-zA-Z]{2}[\w\-+\'()]*/
} , {
token : "entity.name.function.at-marker.alda" ,
regex : /@[a-zA-Z]{2}[\w\-+\'()]*/
} , {
token : "keyword.operator.octave-change.alda" ,
regex : /\bo\d+\b/
} , {
token : "keyword.operator.octave-shift.alda" ,
regex : /[><]/
} , {
token : "keyword.operator.repeat.alda" ,
regex : /\*\s*\d+/
} , {
token : "string.quoted.operator.timing.alda" ,
regex : /[.]|r\d*(?:s|ms)?/
2023-01-16 22:26:34 +00:00
} , {
2020-04-14 12:14:48 +00:00
token : "text" ,
regex : /([cdefgab])/ ,
next : "pitch"
} , {
token : "string.quoted.operator.timing.alda" ,
regex : /~/ ,
next : "timing"
} , {
token : "punctuation.section.embedded.cram.alda" ,
regex : /\}/ ,
next : "timing"
} , {
token : "constant.numeric.subchord.alda" ,
regex : /\//
} , {
todo : {
token : "punctuation.section.embedded.cram.alda" ,
regex : /\{/ ,
push : [ {
2023-01-16 22:26:34 +00:00
token : "punctuation.section.embedded.cram.alda" ,
regex : /\}/ ,
next : "pop"
} , {
include : "$self"
} ]
2020-04-14 12:14:48 +00:00
}
} , {
todo : {
token : "keyword.control.sequence.alda" ,
regex : /\[/ ,
push : [ {
2023-01-16 22:26:34 +00:00
token : "keyword.control.sequence.alda" ,
regex : /\]/ ,
next : "pop"
} , {
include : "$self"
} ]
2020-04-14 12:14:48 +00:00
}
} , {
token : "meta.inline.clojure.alda" ,
regex : /\(/ ,
push : [ {
2023-01-16 22:26:34 +00:00
token : "meta.inline.clojure.alda" ,
regex : /\)/ ,
next : "pop"
} , {
include : "source.clojure"
} , {
defaultToken : "meta.inline.clojure.alda"
} ]
2020-04-14 12:14:48 +00:00
} ]
} ;
2023-01-16 22:26:34 +00:00
this . normalizeRules ( ) ;
} ;
AldaHighlightRules . metaData = {
scopeName : "source.alda" ,
fileTypes : [ "alda" ] ,
name : "Alda"
} ;
oop . inherits ( AldaHighlightRules , TextHighlightRules ) ;
exports . AldaHighlightRules = AldaHighlightRules ;
2020-04-14 12:14:48 +00:00
2023-01-16 22:26:34 +00:00
} ) ;
2020-04-14 12:14:48 +00:00
2023-01-16 22:26:34 +00:00
ace . define ( "ace/mode/folding/cstyle" , [ "require" , "exports" , "module" , "ace/lib/oop" , "ace/range" , "ace/mode/folding/fold_mode" ] , function ( require , exports , module ) { "use strict" ;
2020-04-14 12:14:48 +00:00
var oop = require ( "../../lib/oop" ) ;
var Range = require ( "../../range" ) . Range ;
var BaseFoldMode = require ( "./fold_mode" ) . FoldMode ;
2023-01-16 22:26:34 +00:00
var FoldMode = exports . FoldMode = function ( commentRegex ) {
2020-04-14 12:14:48 +00:00
if ( commentRegex ) {
2023-01-16 22:26:34 +00:00
this . foldingStartMarker = new RegExp ( this . foldingStartMarker . source . replace ( /\|[^|]*?$/ , "|" + commentRegex . start ) ) ;
this . foldingStopMarker = new RegExp ( this . foldingStopMarker . source . replace ( /\|[^|]*?$/ , "|" + commentRegex . end ) ) ;
2020-04-14 12:14:48 +00:00
}
} ;
oop . inherits ( FoldMode , BaseFoldMode ) ;
2023-01-16 22:26:34 +00:00
( function ( ) {
2020-04-14 12:14:48 +00:00
this . foldingStartMarker = /([\{\[\(])[^\}\]\)]*$|^\s*(\/\*)/ ;
this . foldingStopMarker = /^[^\[\{\(]*([\}\]\)])|^[\s\*]*(\*\/)/ ;
2023-01-16 22:26:34 +00:00
this . singleLineBlockCommentRe = /^\s*(\/\*).*\*\/\s*$/ ;
2020-04-14 12:14:48 +00:00
this . tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/ ;
this . startRegionRe = /^\s*(\/\*|\/\/)#?region\b/ ;
this . _getFoldWidgetBase = this . getFoldWidget ;
2023-01-16 22:26:34 +00:00
this . getFoldWidget = function ( session , foldStyle , row ) {
2020-04-14 12:14:48 +00:00
var line = session . getLine ( row ) ;
if ( this . singleLineBlockCommentRe . test ( line ) ) {
if ( ! this . startRegionRe . test ( line ) && ! this . tripleStarBlockCommentRe . test ( line ) )
return "" ;
}
var fw = this . _getFoldWidgetBase ( session , foldStyle , row ) ;
if ( ! fw && this . startRegionRe . test ( line ) )
return "start" ; // lineCommentRegionStart
return fw ;
} ;
2023-01-16 22:26:34 +00:00
this . getFoldWidgetRange = function ( session , foldStyle , row , forceMultiline ) {
2020-04-14 12:14:48 +00:00
var line = session . getLine ( row ) ;
if ( this . startRegionRe . test ( line ) )
return this . getCommentRegionBlock ( session , line , row ) ;
var match = line . match ( this . foldingStartMarker ) ;
if ( match ) {
var i = match . index ;
if ( match [ 1 ] )
return this . openingBracketBlock ( session , match [ 1 ] , row , i ) ;
var range = session . getCommentFoldRange ( row , i + match [ 0 ] . length , 1 ) ;
if ( range && ! range . isMultiLine ( ) ) {
if ( forceMultiline ) {
range = this . getSectionRange ( session , row ) ;
2023-01-16 22:26:34 +00:00
}
else if ( foldStyle != "all" )
2020-04-14 12:14:48 +00:00
range = null ;
}
return range ;
}
if ( foldStyle === "markbegin" )
return ;
var match = line . match ( this . foldingStopMarker ) ;
if ( match ) {
var i = match . index + match [ 0 ] . length ;
if ( match [ 1 ] )
return this . closingBracketBlock ( session , match [ 1 ] , row , i ) ;
return session . getCommentFoldRange ( row , i , - 1 ) ;
}
} ;
2023-01-16 22:26:34 +00:00
this . getSectionRange = function ( session , row ) {
2020-04-14 12:14:48 +00:00
var line = session . getLine ( row ) ;
var startIndent = line . search ( /\S/ ) ;
var startRow = row ;
var startColumn = line . length ;
row = row + 1 ;
var endRow = row ;
var maxRow = session . getLength ( ) ;
while ( ++ row < maxRow ) {
line = session . getLine ( row ) ;
var indent = line . search ( /\S/ ) ;
if ( indent === - 1 )
continue ;
2023-01-16 22:26:34 +00:00
if ( startIndent > indent )
2020-04-14 12:14:48 +00:00
break ;
var subRange = this . getFoldWidgetRange ( session , "all" , row ) ;
if ( subRange ) {
if ( subRange . start . row <= startRow ) {
break ;
2023-01-16 22:26:34 +00:00
}
else if ( subRange . isMultiLine ( ) ) {
2020-04-14 12:14:48 +00:00
row = subRange . end . row ;
2023-01-16 22:26:34 +00:00
}
else if ( startIndent == indent ) {
2020-04-14 12:14:48 +00:00
break ;
}
}
endRow = row ;
}
return new Range ( startRow , startColumn , endRow , session . getLine ( endRow ) . length ) ;
} ;
2023-01-16 22:26:34 +00:00
this . getCommentRegionBlock = function ( session , line , row ) {
2020-04-14 12:14:48 +00:00
var startColumn = line . search ( /\s*$/ ) ;
var maxRow = session . getLength ( ) ;
var startRow = row ;
var re = /^\s*(?:\/\*|\/\/|--)#?(end)?region\b/ ;
var depth = 1 ;
while ( ++ row < maxRow ) {
line = session . getLine ( row ) ;
var m = re . exec ( line ) ;
2023-01-16 22:26:34 +00:00
if ( ! m )
continue ;
if ( m [ 1 ] )
depth -- ;
else
depth ++ ;
if ( ! depth )
break ;
2020-04-14 12:14:48 +00:00
}
var endRow = row ;
if ( endRow > startRow ) {
return new Range ( startRow , startColumn , endRow , line . length ) ;
}
} ;
} ) . call ( FoldMode . prototype ) ;
} ) ;
2023-01-16 22:26:34 +00:00
ace . define ( "ace/mode/alda" , [ "require" , "exports" , "module" , "ace/lib/oop" , "ace/mode/text" , "ace/mode/alda_highlight_rules" , "ace/mode/folding/cstyle" ] , function ( require , exports , module ) { / *
THIS FILE WAS AUTOGENERATED BY mode . tmpl . js
* /
2020-04-14 12:14:48 +00:00
"use strict" ;
var oop = require ( "../lib/oop" ) ;
var TextMode = require ( "./text" ) . Mode ;
var AldaHighlightRules = require ( "./alda_highlight_rules" ) . AldaHighlightRules ;
var FoldMode = require ( "./folding/cstyle" ) . FoldMode ;
2023-01-16 22:26:34 +00:00
var Mode = function ( ) {
2020-04-14 12:14:48 +00:00
this . HighlightRules = AldaHighlightRules ;
this . foldingRules = new FoldMode ( ) ;
} ;
oop . inherits ( Mode , TextMode ) ;
2023-01-16 22:26:34 +00:00
( function ( ) {
2020-04-14 12:14:48 +00:00
this . $id = "ace/mode/alda" ;
} ) . call ( Mode . prototype ) ;
exports . Mode = Mode ;
2023-01-16 22:26:34 +00:00
2020-04-14 12:14:48 +00:00
} ) ; ( function ( ) {
ace . require ( [ "ace/mode/alda" ] , function ( m ) {
if ( typeof module == "object" && typeof exports == "object" && module ) {
module . exports = m ;
}
} ) ;
} ) ( ) ;