Skip to content

Commit

Permalink
add sublime-syntax.json (SchemaStore#3010)
Browse files Browse the repository at this point in the history
Co-authored-by: Keith Hall <[email protected]>
Co-authored-by: Edwin Kofler <[email protected]>
  • Loading branch information
3 people authored and jmatias committed Oct 26, 2023
1 parent 592d905 commit 5dce7c8
Show file tree
Hide file tree
Showing 3 changed files with 424 additions and 0 deletions.
6 changes: 6 additions & 0 deletions src/api/json/catalog.json
Original file line number Diff line number Diff line change
Expand Up @@ -5277,6 +5277,12 @@
"1.0": "https://json-schema.api.strmprivacy.io/latest/strmprivacy.api.entities.v1.DataContract.json"
}
},
{
"description": "Sublime Text/Merge syntax highlighting definition",
"fileMatch": ["*.sublime-syntax"],
"name": "Sublime Syntax",
"url": "https://json.schemastore.org/sublime-syntax.json"
},
{
"name": "Keycloak REST API",
"description": "REST API Keycloak Admin",
Expand Down
247 changes: 247 additions & 0 deletions src/schemas/json/sublime-syntax.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,247 @@
{
"$comment": "https://www.sublimetext.com/docs/syntax.html",
"$id": "https://json.schemastore.org/sublime-syntax.json",
"$schema": "http://json-schema.org/draft-07/schema#",
"definitions": {
"push": {
"anyOf": [
{
"type": "string"
},
{
"type": "array",
"items": {
"type": "string"
},
"minItems": 1
},
{
"$ref": "#/definitions/patterns"
}
]
},
"meta-pattern": {
"description": "Meta patterns must be listed first in the context, before any match or include patterns.\nhttps://www.sublimetext.com/docs/syntax.html#meta-patterns",
"type": "object",
"properties": {
"meta_scope": {
"description": "This assigns the given scope to all text within this context, including the patterns that push the context onto the stack and pop it off.",
"type": "string"
},
"meta_content_scope": {
"description": "This assigns the given scope to all text within this context, including the patterns that push the context onto the stack and pop it off. But does not apply to the text that triggers the context (e.g., in the above string example, the content scope would not get applied to the quote characters).",
"type": "string"
},
"meta_include_prototype": {
"description": "Used to stop the current context from automatically including the prototype context.",
"type": "boolean"
},
"clear_scopes": {
"description": "This setting allows removing scope names from the current stack. It can be an integer, or the value true to remove all scope names. It is applied before meta_scope and meta_content_scope. This is typically only used when one syntax is embedding another.",
"type": "boolean"
},
"meta_prepend": {
"description": "A boolean, controlling context name conflict resolution during inheritance. If this is specified, the rules in this context will be inserted before any existing rules from a context with the same name in an ancestor syntax definition.",
"type": "boolean"
},
"meta_append": {
"description": "A boolean, controlling context name conflict resolution during inheritance. If this is specified, the rules in this context will be inserted after to any existing rules from a context with the same name in an ancestor syntax definition.",
"type": "boolean"
}
}
},
"match-pattern": {
"description": "The following keys control behavior that is exclusive, and only one can be specified per match pattern: push pop set embed branch fail\nhttps://www.sublimetext.com/docs/syntax.html#match-patterns",
"type": "object",
"properties": {
"match": {
"description": "The regex used to match against the text. YAML allows many strings to be written without quotes, which can help make the regex clearer, but it's important to understand when you need to quote the regex. If your regex includes the characters #, :, -, {, [ or > then you likely need to quote it. Regexes are only ever run against a single line of text at a time.",
"type": "string"
},
"scope": {
"description": "The scope assigned to the matched text.",
"pattern": "^[_a-zA-Z][a-zA-Z0-9._ -]*$",
"type": "string"
},
"captures": {
"description": "A mapping of numbers to scope, assigning scopes to captured portions of the match regex.",
"type": "object",
"patternProperties": {
"^\\d+$": {
"type": "string"
}
},
"minProperties": 1
},
"push": {
"description": "The contexts to push onto the stack. This may be either a single context name, a list of context names, or an inline, anonymous context.",
"$ref": "#/definitions/push"
},
"pop": {
"description": "Pops contexts off the stack. The value true will pop a single context. An integer greater than zero will pop the corresponding number of contexts. The pop key can be combined with push, set, embed and branch. When combined, the specified number of contexts will be popped off of the stack before the other action is performed. For push, embed and branch actions, the pop treats the match as if it were a lookahead, which means the match will not receive the meta_scope of the contexts that are popped.",
"type": "boolean"
},
"set": {
"description": "Accepts the same arguments as push, but will first pop this context off, and then push the given context(s) onto the stack. Any match will receive the meta_scope of the context being popped and the context being pushed.",
"$ref": "#/definitions/push"
},
"embed": {
"description": "Accepts the name of a single context to push into. While similar to push, it pops out of any number of nested contexts as soon as the escape pattern is found. This makes it an ideal tool for embedding one syntax within another.",
"type": "object",
"properties": {
"escape": {
"description": "This key is required if embed is used, and is a regex used to exit from the embedded context. Any backreferences in this pattern will refer to capture groups in the match regex.",
"type": "string"
},
"embed_scope": {
"description": "A scope assigned to all text matched after the match and before the escape. Similar in concept to meta_content_scope.",
"type": "string"
},
"escape_captures": {
"description": "A mapping of capture groups to scope names, for the escape pattern. Use capture group 0 to apply a scope to the entire escape match.",
"type": "object",
"patternProperties": {
"^\\d+$": {
"type": "string"
}
},
"minProperties": 1
},
"branch": {
"description": "Accepts the names of two or more contexts, which are attempted in order. If a fail action is encountered, the highlighting of the file will be restarted at the character where the branch occurred, and the next context will be attempted.",
"type": "object",
"properties": {
"branch_point": {
"description": "This is the unique identifier for the branch and is specified when a match uses the fail action.",
"type": "string"
}
}
},
"fail": {
"description": "Accepts the name of a branch_point to rewind to and retry the next context of. If a fail action specifies a branch_point that was never pushed on the stack, or has already been popped off of the stack, it will have no effect.",
"type": "string"
}
}
}
},
"required": ["match"]
},
"include-pattern": {
"description": "Frequently it’s convenient to include the contents of one context within another. For example, you may define several different contexts for parsing the C language, and almost all of them can include comments. Rather than copying the relevant match patterns into each of these contexts, you can include them.\nhttps://www.sublimetext.com/docs/syntax.html#include-patterns",
"type": "object",
"properties": {
"include": {
"type": "string"
},
"apply_prototype": {
"type": "boolean"
}
},
"required": ["include"]
},
"prototype-pattern": {
"description": "With elements such as comments, it’s so common to include them that it’s simpler to make them included automatically in every context, and just list the exceptions instead. You can do this by creating a context named prototype, it will be included automatically at the top of every other context, unless the context contains the meta_include_prototype key.\nhttps://www.sublimetext.com/docs/syntax.html#prototype-context",
"type": "object",
"properties": {
"meta_include_prototype": {
"type": "boolean"
}
},
"required": ["meta_include_prototype"]
},
"pattern": {
"anyOf": [
{
"$ref": "#/definitions/meta-pattern"
},
{
"$ref": "#/definitions/match-pattern"
},
{
"$ref": "#/definitions/include-pattern"
},
{
"$ref": "#/definitions/prototype-pattern"
}
]
},
"patterns": {
"type": "array",
"items": {
"$ref": "#/definitions/pattern"
},
"minItems": 1,
"uniqueItems": true
}
},
"description": "JSON schema for *.sublime-syntax yaml",
"properties": {
"name": {
"description": "This defines the name shown for the syntax in the menu. It’s optional, and will be derived from the file name if not used.",
"type": "string"
},
"file_extensions": {
"description": "A list of strings, defining file extensions this syntax should be used for. Extensions listed here will be shown in file dialog dropdowns on some operating systems. If a file does not have a basename, e.g. .gitignore, the entirety of the filename including the leading . should be specified.",
"type": "array",
"items": {
"type": "string"
},
"minItems": 1,
"uniqueItems": true
},
"hidden_file_extensions": {
"description": "A list of strings, also defining file extensions this syntax should be used for. These extensions are not listed in file dialogs.",
"type": "array",
"items": {
"type": "string"
},
"minItems": 1,
"uniqueItems": true
},
"first_line_match": {
"description": "When a file is opened without a recognized extension, the first line of the file contents will be tested against this regex, to see if the syntax should be applied.",
"type": "string"
},
"scope": {
"description": "The default scope assigned to all text in the file",
"pattern": "^[_a-zA-Z][a-zA-Z0-9._ -]*$",
"type": "string"
},
"version": {
"default": 2,
"type": "integer",
"enum": [1, 2]
},
"extends": {
"description": "A string of a base syntax this syntax should inherit from. The base syntax must be specified using its package path, e.g. Packages/JavaScript/JavaScript.sublime-syntax. See Inheritance for an overview of syntax inheritance.",
"type": "string"
},
"hidden": {
"description": "Hidden syntax definitions won’t be shown in the menu, but can still be assigned by plugins, or included by other syntax definitions.",
"type": "boolean"
},
"contexts": {
"description": "https://www.sublimetext.com/docs/syntax.html#contexts",
"type": "object",
"patternProperties": {
"^[_a-zA-Z][a-zA-Z0-9_-]*$": {
"$ref": "#/definitions/patterns"
}
},
"minProperties": 1
},
"variables": {
"description": "Variables must be defined at the top level of the .sublime-syntax file, and are referenced within regxes via {{varname}}. Variables may themselves include other variables. Note that any text that doesn’t match {{[A-Za-z0-9_]+}} won’t be considered as a variable, so regexes can still include literal {{ characters, for example.\nhttps://www.sublimetext.com/docs/syntax.html#variables",
"type": "object",
"patternProperties": {
"^[_a-zA-Z][a-zA-Z0-9_]*$": {
"type": "string"
}
},
"minProperties": 1
}
},
"required": ["scope", "contexts"],
"title": "sublime-syntax",
"type": "object"
}
Loading

0 comments on commit 5dce7c8

Please sign in to comment.