2023-01-16 22:26:34 +00:00
ace . define ( "ace/mode/turtle_highlight_rules" , [ "require" , "exports" , "module" , "ace/lib/oop" , "ace/mode/text_highlight_rules" ] , function ( require , exports , module ) { /* This file was autogenerated from turtle.tmLanguage (uuid: ) */
2017-02-05 20:05:00 +00:00
"use strict" ;
var oop = require ( "../lib/oop" ) ;
var TextHighlightRules = require ( "./text_highlight_rules" ) . TextHighlightRules ;
2023-01-16 22:26:34 +00:00
var TurtleHighlightRules = function ( ) {
2017-02-05 20:05:00 +00:00
this . $rules = {
start : [ {
2023-01-16 22:26:34 +00:00
include : "#comments"
} , {
include : "#strings"
} , {
include : "#base-prefix-declarations"
} , {
include : "#string-language-suffixes"
} , {
include : "#string-datatype-suffixes"
} , {
include : "#relative-urls"
} , {
include : "#xml-schema-types"
} , {
include : "#rdf-schema-types"
} , {
include : "#owl-types"
} , {
include : "#qnames"
} , {
include : "#punctuation-operators"
} ] ,
2017-02-05 20:05:00 +00:00
"#base-prefix-declarations" : [ {
2023-01-16 22:26:34 +00:00
token : "keyword.other.prefix.turtle" ,
regex : /@(?:base|prefix)/
} ] ,
2017-02-05 20:05:00 +00:00
"#comments" : [ {
2023-01-16 22:26:34 +00:00
token : [
"punctuation.definition.comment.turtle" ,
"comment.line.hash.turtle"
] ,
regex : /(#)(.*$)/
} ] ,
2017-02-05 20:05:00 +00:00
"#owl-types" : [ {
2023-01-16 22:26:34 +00:00
token : "support.type.datatype.owl.turtle" ,
regex : /owl:[a-zA-Z]+/
} ] ,
2017-02-05 20:05:00 +00:00
"#punctuation-operators" : [ {
2023-01-16 22:26:34 +00:00
token : "keyword.operator.punctuation.turtle" ,
regex : /;|,|\.|\(|\)|\[|\]/
} ] ,
2017-02-05 20:05:00 +00:00
"#qnames" : [ {
2023-01-16 22:26:34 +00:00
token : "entity.name.other.qname.turtle" ,
regex : /(?:[a-zA-Z][-_a-zA-Z0-9]*)?:(?:[_a-zA-Z][-_a-zA-Z0-9]*)?/
} ] ,
2017-02-05 20:05:00 +00:00
"#rdf-schema-types" : [ {
2023-01-16 22:26:34 +00:00
token : "support.type.datatype.rdf.schema.turtle" ,
regex : /rdfs?:[a-zA-Z]+|(?:^|\s)a(?:\s|$)/
} ] ,
2017-02-05 20:05:00 +00:00
"#relative-urls" : [ {
token : "string.quoted.other.relative.url.turtle" ,
2023-01-16 22:26:34 +00:00
regex : /</ ,
push : [ {
token : "string.quoted.other.relative.url.turtle" ,
regex : />/ ,
next : "pop"
} , {
defaultToken : "string.quoted.other.relative.url.turtle"
} ]
} ] ,
2017-02-05 20:05:00 +00:00
"#string-datatype-suffixes" : [ {
2023-01-16 22:26:34 +00:00
token : "keyword.operator.datatype.suffix.turtle" ,
regex : /\^\^/
} ] ,
2017-02-05 20:05:00 +00:00
"#string-language-suffixes" : [ {
2023-01-16 22:26:34 +00:00
token : [
"keyword.operator.language.suffix.turtle" ,
"constant.language.suffix.turtle"
] ,
regex : /(?!")(@)([a-z]+(?:\-[a-z0-9]+)*)/
} ] ,
2017-02-05 20:05:00 +00:00
"#strings" : [ {
token : "string.quoted.triple.turtle" ,
regex : /"""/ ,
2023-01-16 22:26:34 +00:00
push : [ {
token : "string.quoted.triple.turtle" ,
regex : /"""/ ,
next : "pop"
} , {
defaultToken : "string.quoted.triple.turtle"
} ]
2017-02-05 20:05:00 +00:00
} , {
token : "string.quoted.double.turtle" ,
regex : /"/ ,
2023-01-16 22:26:34 +00:00
push : [ {
token : "string.quoted.double.turtle" ,
regex : /"/ ,
next : "pop"
} , {
token : "invalid.string.newline" ,
regex : /$/
} , {
token : "constant.character.escape.turtle" ,
regex : /\\./
} , {
defaultToken : "string.quoted.double.turtle"
} ]
} ] ,
2017-02-05 20:05:00 +00:00
"#xml-schema-types" : [ {
2023-01-16 22:26:34 +00:00
token : "support.type.datatype.xml.schema.turtle" ,
regex : /xsd?:[a-z][a-zA-Z]+/
} ]
2020-04-14 12:14:48 +00:00
} ;
2017-02-05 20:05:00 +00:00
this . normalizeRules ( ) ;
} ;
TurtleHighlightRules . metaData = {
fileTypes : [ "ttl" , "nt" ] ,
name : "Turtle" ,
scopeName : "source.turtle"
2020-04-14 12:14:48 +00:00
} ;
2017-02-05 20:05:00 +00:00
oop . inherits ( TurtleHighlightRules , TextHighlightRules ) ;
exports . TurtleHighlightRules = TurtleHighlightRules ;
2023-01-16 22:26:34 +00:00
} ) ;
2017-02-05 20:05:00 +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" ;
2017-02-05 20:05:00 +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 ) {
2017-02-05 20:05:00 +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 ) ) ;
2017-02-05 20:05:00 +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*$/ ;
2017-02-05 20:05:00 +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 ) {
2017-02-05 20:05:00 +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 ) {
2017-02-05 20:05:00 +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" )
2017-02-05 20:05:00 +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 ) {
2017-02-05 20:05:00 +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 )
2017-02-05 20:05:00 +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 ( ) ) {
2017-02-05 20:05:00 +00:00
row = subRange . end . row ;
2023-01-16 22:26:34 +00:00
}
else if ( startIndent == indent ) {
2017-02-05 20:05:00 +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 ) {
2017-02-05 20:05:00 +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 ;
2017-02-05 20:05:00 +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/turtle" , [ "require" , "exports" , "module" , "ace/lib/oop" , "ace/mode/text" , "ace/mode/turtle_highlight_rules" , "ace/mode/folding/cstyle" ] , function ( require , exports , module ) { / *
THIS FILE WAS AUTOGENERATED BY mode . tmpl . js
* /
2017-02-05 20:05:00 +00:00
"use strict" ;
var oop = require ( "../lib/oop" ) ;
var TextMode = require ( "./text" ) . Mode ;
var TurtleHighlightRules = require ( "./turtle_highlight_rules" ) . TurtleHighlightRules ;
var FoldMode = require ( "./folding/cstyle" ) . FoldMode ;
2023-01-16 22:26:34 +00:00
var Mode = function ( ) {
2017-02-05 20:05:00 +00:00
this . HighlightRules = TurtleHighlightRules ;
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/turtle" ;
2017-02-05 20:05:00 +00:00
} ) . 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/turtle" ] , function ( m ) {
if ( typeof module == "object" && typeof exports == "object" && module ) {
module . exports = m ;
}
} ) ;
} ) ( ) ;