{
	"information_for_contributors": [
		"This file has been converted from https://github.com/jtbandes/swift-tmlanguage/blob/master/Swift.tmLanguage.json",
		"If you want to provide a fix or improvement, please create a pull request against the original repository.",
		"Once accepted there, we are happy to receive an update request."
	],
	"version": "https://github.com/jtbandes/swift-tmlanguage/commit/860eface4241cf9f2174d5fa690bd34389ac8d26",
	"name": "Swift",
	"scopeName": "source.swift",
	"comment": "See swift.tmbundle/grammar-test.swift for test cases.",
	"patterns": [
		{
			"include": "#root"
		}
	],
	"repository": {
		"async-throws": {
			"match": "\\b(?:(throws\\s+async|rethrows\\s+async)|(throws|rethrows)|(async))\\b",
			"captures": {
				"1": {
					"name": "invalid.illegal.await-must-precede-throws.swift"
				},
				"2": {
					"name": "storage.modifier.exception.swift"
				},
				"3": {
					"name": "storage.modifier.async.swift"
				}
			}
		},
		"attributes": {
			"patterns": [
				{
					"name": "meta.attribute.available.swift",
					"begin": "((@)available)(\\()",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "storage.modifier.attribute.swift"
						},
						"2": {
							"name": "punctuation.definition.attribute.swift"
						},
						"3": {
							"name": "punctuation.definition.arguments.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.arguments.end.swift"
						}
					},
					"patterns": [
						{
							"match": "\\b(swift|(?:iOS|macOS|OSX|watchOS|tvOS|visionOS|UIKitForMac)(?:ApplicationExtension)?)\\b(?:\\s+([0-9]+(?:\\.[0-9]+)*\\b))?",
							"captures": {
								"1": {
									"name": "keyword.other.platform.os.swift"
								},
								"2": {
									"name": "constant.numeric.swift"
								}
							}
						},
						{
							"begin": "\\b(introduced|deprecated|obsoleted)\\s*(:)\\s*",
							"end": "(?!\\G)",
							"beginCaptures": {
								"1": {
									"name": "keyword.other.swift"
								},
								"2": {
									"name": "punctuation.separator.key-value.swift"
								}
							},
							"patterns": [
								{
									"name": "constant.numeric.swift",
									"match": "\\b[0-9]+(?:\\.[0-9]+)*\\b"
								}
							]
						},
						{
							"begin": "\\b(message|renamed)\\s*(:)\\s*(?=\")",
							"end": "(?!\\G)",
							"beginCaptures": {
								"1": {
									"name": "keyword.other.swift"
								},
								"2": {
									"name": "punctuation.separator.key-value.swift"
								}
							},
							"patterns": [
								{
									"include": "#literals"
								}
							]
						},
						{
							"match": "(?:(\\*)|\\b(deprecated|unavailable|noasync)\\b)\\s*(.*?)(?=[,)])",
							"captures": {
								"1": {
									"name": "keyword.other.platform.all.swift"
								},
								"2": {
									"name": "keyword.other.swift"
								},
								"3": {
									"name": "invalid.illegal.character-not-allowed-here.swift"
								}
							}
						}
					]
				},
				{
					"name": "meta.attribute.objc.swift",
					"begin": "((@)objc)(\\()",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "storage.modifier.attribute.swift"
						},
						"2": {
							"name": "punctuation.definition.attribute.swift"
						},
						"3": {
							"name": "punctuation.definition.arguments.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.arguments.end.swift"
						}
					},
					"patterns": [
						{
							"name": "entity.name.function.swift",
							"match": "\\w*(?::(?:\\w*:)*(\\w*))?",
							"captures": {
								"1": {
									"name": "invalid.illegal.missing-colon-after-selector-piece.swift"
								}
							}
						}
					]
				},
				{
					"comment": "any other attribute",
					"name": "meta.attribute.swift",
					"begin": "(@)(?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>)",
					"end": "(?!\\G\\()",
					"beginCaptures": {
						"0": {
							"name": "storage.modifier.attribute.swift"
						},
						"1": {
							"name": "punctuation.definition.attribute.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						}
					},
					"patterns": [
						{
							"name": "meta.arguments.attribute.swift",
							"begin": "\\(",
							"end": "\\)",
							"beginCaptures": {
								"0": {
									"name": "punctuation.definition.arguments.begin.swift"
								}
							},
							"endCaptures": {
								"0": {
									"name": "punctuation.definition.arguments.end.swift"
								}
							},
							"patterns": [
								{
									"include": "#expressions"
								}
							]
						}
					]
				}
			]
		},
		"builtin-functions": {
			"patterns": [
				{
					"comment": "Member functions in the standard library in Swift 3 which may be used with trailing closures and no parentheses",
					"name": "support.function.swift",
					"match": "(?<=\\.)(?:s(?:ort(?:ed)?|plit)|contains|index|partition|f(?:i(?:lter|rst)|orEach|latMap)|with(?:MutableCharacters|CString|U(?:nsafe(?:Mutable(?:BufferPointer|Pointer(?:s|To(?:Header|Elements)))|BufferPointer)|TF8Buffer))|m(?:in|a(?:p|x)))(?=\\s*[({])\\b"
				},
				{
					"comment": "Member functions in the standard library in Swift 3",
					"name": "support.function.swift",
					"match": "(?<=\\.)(?:s(?:ymmetricDifference|t(?:oreBytes|arts|ride)|ortInPlace|u(?:ccessor|ffix|btract(?:ing|InPlace|WithOverflow)?)|quareRoot|amePosition)|h(?:oldsUnique(?:Reference|OrPinnedReference)|as(?:Suffix|Prefix))|ne(?:gate(?:d)?|xt)|c(?:o(?:untByEnumerating|py(?:Bytes)?)|lamp(?:ed)?|reate)|t(?:o(?:IntMax|Opaque|UIntMax)|ake(?:RetainedValue|UnretainedValue)|r(?:uncatingRemainder|a(?:nscodedLength|ilSurrogate)))|i(?:s(?:MutableAndUniquelyReferenced(?:OrPinned)?|S(?:trictSu(?:perset(?:Of)?|bset(?:Of)?)|u(?:perset(?:Of)?|bset(?:Of)?))|Continuation|T(?:otallyOrdered|railSurrogate)|Disjoint(?:With)?|Unique(?:Reference|lyReferenced(?:OrPinned)?)|Equal|Le(?:ss(?:ThanOrEqualTo)?|adSurrogate))|n(?:sert(?:ContentsOf)?|tersect(?:ion|InPlace)?|itialize(?:Memory|From)?|dex(?:Of|ForKey)))|o(?:verlaps|bjectAt)|d(?:i(?:stance(?:To)?|vide(?:d|WithOverflow)?)|e(?:s(?:cendant|troy)|code(?:CString)?|initialize|alloc(?:ate(?:Capacity)?)?)|rop(?:First|Last))|u(?:n(?:ion(?:InPlace)?|derestimateCount|wrappedOrError)|p(?:date(?:Value)?|percased))|join(?:ed|WithSeparator)|p(?:op(?:First|Last)|ass(?:Retained|Unretained)|re(?:decessor|fix))|e(?:scape(?:d)?|n(?:code|umerate(?:d)?)|lementsEqual|xclusiveOr(?:InPlace)?)|f(?:orm(?:Remainder|S(?:ymmetricDifference|quareRoot)|TruncatingRemainder|In(?:tersection|dex)|Union)|latten|rom(?:CString(?:RepairingIllFormedUTF8)?|Opaque))|w(?:i(?:thMemoryRebound|dth)|rite(?:To)?)|l(?:o(?:wercased|ad)|e(?:adSurrogate|xicographical(?:Compare|lyPrecedes)))|a(?:ss(?:ign(?:BackwardFrom|From)?|umingMemoryBound)|d(?:d(?:ing(?:Product)?|Product|WithOverflow)?|vanced(?:By)?)|utorelease|ppend(?:ContentsOf)?|lloc(?:ate)?|bs)|r(?:ound(?:ed)?|e(?:serveCapacity|tain|duce|place(?:Range|Subrange)?|verse(?:d)?|quest(?:NativeBuffer|UniqueMutableBackingBuffer)|lease|m(?:ove(?:Range|Subrange|Value(?:ForKey)?|First|Last|A(?:tIndex|ll))?|ainder(?:WithOverflow)?)))|ge(?:nerate|t(?:Objects|Element))|m(?:in(?:imum(?:Magnitude)?|Element)|ove(?:Initialize(?:Memory|BackwardFrom|From)?|Assign(?:From)?)?|ultipl(?:y(?:WithOverflow)?|ied)|easure|a(?:ke(?:Iterator|Description)|x(?:imum(?:Magnitude)?|Element)))|bindMemory)(?=\\s*\\()"
				},
				{
					"comment": "Member functions in the standard library in Swift 2 only",
					"name": "support.function.swift",
					"match": "(?<=\\.)(?:s(?:uperclassMirror|amePositionIn|tartsWith)|nextObject|c(?:haracterAtIndex|o(?:untByEnumeratingWithState|pyWithZone)|ustom(?:Mirror|PlaygroundQuickLook))|is(?:EmptyInput|ASCII)|object(?:Enumerator|ForKey|AtIndex)|join|put|keyEnumerator|withUnsafeMutablePointerToValue|length|getMirror|m(?:oveInitializeAssignFrom|ember))(?=\\s*\\()"
				}
			]
		},
		"builtin-global-functions": {
			"patterns": [
				{
					"begin": "\\b(type)(\\()\\s*(of)(:)",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "support.function.dynamic-type.swift"
						},
						"2": {
							"name": "punctuation.definition.arguments.begin.swift"
						},
						"3": {
							"name": "support.variable.parameter.swift"
						},
						"4": {
							"name": "punctuation.separator.argument-label.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.arguments.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#expressions"
						}
					]
				},
				{
					"comment": "Global functions available in Swift 3 which may be used with trailing closures and no parentheses",
					"name": "support.function.swift",
					"match": "\\b(?:anyGenerator|autoreleasepool)(?=\\s*[({])\\b"
				},
				{
					"comment": "Global functions available in Swift 3",
					"name": "support.function.swift",
					"match": "\\b(?:s(?:tride(?:of(?:Value)?)?|izeof(?:Value)?|equence|wap)|numericCast|transcode|is(?:UniquelyReferenced(?:NonObjC)?|KnownUniquelyReferenced)|zip|d(?:ump|ebugPrint)|unsafe(?:BitCast|Downcast|Unwrap|Address(?:Of)?)|pr(?:int|econdition(?:Failure)?)|fatalError|with(?:Unsafe(?:MutablePointer|Pointer)|ExtendedLifetime|VaList)|a(?:ssert(?:ionFailure)?|lignof(?:Value)?|bs)|re(?:peatElement|adLine)|getVaList|m(?:in|ax))(?=\\s*\\()"
				},
				{
					"comment": "Global functions available in Swift 2 only",
					"name": "support.function.swift",
					"match": "\\b(?:s(?:ort|uffix|pli(?:ce|t))|insert|overlaps|d(?:istance|rop(?:First|Last))|join|prefix|extend|withUnsafe(?:MutablePointers|Pointers)|lazy|advance|re(?:flect|move(?:Range|Last|A(?:tIndex|ll))))(?=\\s*\\()"
				}
			]
		},
		"builtin-properties": {
			"patterns": [
				{
					"comment": "The simpler (?<=\\bProcess\\.|\\bCommandLine\\.) breaks VS Code / Atom, see https://github.com/textmate/swift.tmbundle/issues/29",
					"name": "support.variable.swift",
					"match": "(?<=^Process\\.|\\WProcess\\.|^CommandLine\\.|\\WCommandLine\\.)(arguments|argc|unsafeArgv)"
				},
				{
					"comment": "Properties in the standard library in Swift 3",
					"name": "support.variable.swift",
					"match": "(?<=\\.)(?:s(?:t(?:artIndex|ri(?:ngValue|de))|i(?:ze|gn(?:BitIndex|ificand(?:Bit(?:Count|Pattern)|Width)?|alingNaN)?)|u(?:perclassMirror|mmary|bscriptBaseAddress))|h(?:eader|as(?:hValue|PointerRepresentation))|n(?:ulTerminatedUTF8|ext(?:Down|Up)|a(?:n|tiveOwner))|c(?:haracters|ount(?:TrailingZeros)?|ustom(?:Mirror|PlaygroundQuickLook)|apacity)|i(?:s(?:S(?:ign(?:Minus|aling(?:NaN)?)|ubnormal)|N(?:ormal|aN)|Canonical|Infinite|Zero|Empty|Finite|ASCII)|n(?:dices|finity)|dentity)|owner|de(?:scription|bugDescription)|u(?:n(?:safelyUnwrapped|icodeScalar(?:s)?|derestimatedCount)|tf(?:16|8(?:Start|C(?:String|odeUnitCount))?)|intValue|ppercaseString|lp(?:OfOne)?)|p(?:i|ointee)|e(?:ndIndex|lements|xponent(?:Bit(?:Count|Pattern))?)|value(?:s)?|keys|quietNaN|f(?:irst(?:ElementAddress(?:IfContiguous)?)?|loatingPointClass)|l(?:ittleEndian|owercaseString|eastNo(?:nzeroMagnitude|rmalMagnitude)|a(?:st|zy))|a(?:l(?:ignment|l(?:ocatedElementCount|Zeros))|rray(?:PropertyIsNativeTypeChecked)?)|ra(?:dix|wValue)|greatestFiniteMagnitude|m(?:in|emory|ax)|b(?:yteS(?:ize|wapped)|i(?:nade|tPattern|gEndian)|uffer|ase(?:Address)?))\\b"
				},
				{
					"comment": "Properties in the standard library in Swift 2 only",
					"name": "support.variable.swift",
					"match": "(?<=\\.)(?:boolValue|disposition|end|objectIdentifier|quickLookObject|start|valueType)\\b"
				},
				{
					"comment": "Enum cases in the standard library - note that there is some overlap between these and the properties",
					"name": "support.variable.swift",
					"match": "(?<=\\.)(?:s(?:calarValue|i(?:ze|gnalingNaN)|o(?:und|me)|uppressed|prite|et)|n(?:one|egative(?:Subnormal|Normal|Infinity|Zero))|c(?:ol(?:or|lection)|ustomized)|t(?:o(?:NearestOr(?:Even|AwayFromZero)|wardZero)|uple|ext)|i(?:nt|mage)|optional|d(?:ictionary|o(?:uble|wn))|u(?:Int|p|rl)|p(?:o(?:sitive(?:Subnormal|Normal|Infinity|Zero)|int)|lus)|e(?:rror|mptyInput)|view|quietNaN|float|a(?:ttributedString|wayFromZero)|r(?:ectangle|ange)|generated|minus|b(?:ool|ezierPath))\\b"
				}
			]
		},
		"builtin-types": {
			"comment": "Types provided in the standard library",
			"patterns": [
				{
					"include": "#builtin-types-builtin-class-type"
				},
				{
					"include": "#builtin-types-builtin-enum-type"
				},
				{
					"include": "#builtin-types-builtin-protocol-type"
				},
				{
					"include": "#builtin-types-builtin-struct-type"
				},
				{
					"include": "#builtin-types-builtin-typealias"
				},
				{
					"name": "support.type.any.swift",
					"match": "\\bAny\\b"
				}
			]
		},
		"builtin-types-builtin-class-type": {
			"comment": "Builtin class types",
			"name": "support.class.swift",
			"match": "\\b(Managed(Buffer|ProtoBuffer)|NonObjectiveCBase|AnyGenerator)\\b"
		},
		"builtin-types-builtin-enum-type": {
			"patterns": [
				{
					"comment": "CommandLine is an enum, but it acts like a constant",
					"name": "support.constant.swift",
					"match": "\\b(?:CommandLine|Process(?=\\.))\\b"
				},
				{
					"comment": "The return type of a function that never returns",
					"name": "support.constant.never.swift",
					"match": "\\bNever\\b"
				},
				{
					"comment": "Enum types in the standard library in Swift 3",
					"name": "support.type.swift",
					"match": "\\b(?:ImplicitlyUnwrappedOptional|Representation|MemoryLayout|FloatingPointClassification|SetIndexRepresentation|SetIteratorRepresentation|FloatingPointRoundingRule|UnicodeDecodingResult|Optional|DictionaryIndexRepresentation|AncestorRepresentation|DisplayStyle|PlaygroundQuickLook|Never|FloatingPointSign|Bit|DictionaryIteratorRepresentation)\\b"
				},
				{
					"comment": "Enum types in the standard library in Swift 2 only",
					"name": "support.type.swift",
					"match": "\\b(?:MirrorDisposition|QuickLookObject)\\b"
				}
			]
		},
		"builtin-types-builtin-protocol-type": {
			"patterns": [
				{
					"comment": "Protocols in the standard library in Swift 3",
					"name": "support.type.swift",
					"match": "\\b(?:Ra(?:n(?:domAccess(?:Collection|Indexable)|geReplaceable(?:Collection|Indexable))|wRepresentable)|M(?:irrorPath|utable(?:Collection|Indexable))|Bi(?:naryFloatingPoint|twiseOperations|directional(?:Collection|Indexable))|S(?:tr(?:ideable|eamable)|igned(?:Number|Integer)|e(?:tAlgebra|quence))|Hashable|C(?:o(?:llection|mparable)|ustom(?:Reflectable|StringConvertible|DebugStringConvertible|PlaygroundQuickLookable|LeafReflectable)|VarArg)|TextOutputStream|I(?:n(?:teger(?:Arithmetic)?|dexable(?:Base)?)|teratorProtocol)|OptionSet|Un(?:signedInteger|icodeCodec)|E(?:quatable|rror|xpressibleBy(?:BooleanLiteral|String(?:Interpolation|Literal)|NilLiteral|IntegerLiteral|DictionaryLiteral|UnicodeScalarLiteral|ExtendedGraphemeClusterLiteral|FloatLiteral|ArrayLiteral))|FloatingPoint|L(?:osslessStringConvertible|azy(?:SequenceProtocol|CollectionProtocol))|A(?:nyObject|bsoluteValuable))\\b"
				},
				{
					"comment": "Protocols in the standard library in Swift 2 only",
					"name": "support.type.swift",
					"match": "\\b(?:Ran(?:domAccessIndexType|geReplaceableCollectionType)|GeneratorType|M(?:irror(?:Type|PathType)|utable(?:Sliceable|CollectionType))|B(?:i(?:twiseOperationsType|directionalIndexType)|oolean(?:Type|LiteralConvertible))|S(?:tring(?:InterpolationConvertible|LiteralConvertible)|i(?:nkType|gned(?:NumberType|IntegerType))|e(?:tAlgebraType|quenceType)|liceable)|NilLiteralConvertible|C(?:ollectionType|VarArgType)|Inte(?:rvalType|ger(?:Type|LiteralConvertible|ArithmeticType))|O(?:utputStreamType|ptionSetType)|DictionaryLiteralConvertible|Un(?:signedIntegerType|icode(?:ScalarLiteralConvertible|CodecType))|E(?:rrorType|xten(?:sibleCollectionType|dedGraphemeClusterLiteralConvertible))|F(?:orwardIndexType|loat(?:ingPointType|LiteralConvertible))|A(?:nyCollectionType|rrayLiteralConvertible))\\b"
				}
			]
		},
		"builtin-types-builtin-struct-type": {
			"patterns": [
				{
					"comment": "Structs in the standard library in Swift 3",
					"name": "support.type.swift",
					"match": "\\b(?:R(?:e(?:peat(?:ed)?|versed(?:RandomAccess(?:Collection|Index)|Collection|Index))|an(?:domAccessSlice|ge(?:Replaceable(?:RandomAccessSlice|BidirectionalSlice|Slice)|Generator)?))|Generator(?:Sequence|OfOne)|M(?:irror|utable(?:Ran(?:domAccessSlice|geReplaceable(?:RandomAccessSlice|BidirectionalSlice|Slice))|BidirectionalSlice|Slice)|anagedBufferPointer)|B(?:idirectionalSlice|ool)|S(?:t(?:aticString|ri(?:ng|deT(?:hrough(?:Generator|Iterator)?|o(?:Generator|Iterator)?)))|et(?:I(?:ndex|terator))?|lice)|HalfOpenInterval|C(?:haracter(?:View)?|o(?:ntiguousArray|untable(?:Range|ClosedRange)|llectionOfOne)|OpaquePointer|losed(?:Range(?:I(?:ndex|terator))?|Interval)|VaListPointer)|I(?:n(?:t(?:16|8|32|64)?|d(?:ices|ex(?:ing(?:Generator|Iterator))?))|terator(?:Sequence|OverOne)?)|Zip2(?:Sequence|Iterator)|O(?:paquePointer|bjectIdentifier)|D(?:ictionary(?:I(?:ndex|terator)|Literal)?|ouble|efault(?:RandomAccessIndices|BidirectionalIndices|Indices))|U(?:n(?:safe(?:RawPointer|Mutable(?:RawPointer|BufferPointer|Pointer)|BufferPointer(?:Generator|Iterator)?|Pointer)|icodeScalar(?:View)?|foldSequence|managed)|TF(?:16(?:View)?|8(?:View)?|32)|Int(?:16|8|32|64)?)|Join(?:Generator|ed(?:Sequence|Iterator))|PermutationGenerator|E(?:numerate(?:Generator|Sequence|d(?:Sequence|Iterator))|mpty(?:Generator|Collection|Iterator))|Fl(?:oat(?:80)?|atten(?:Generator|BidirectionalCollection(?:Index)?|Sequence|Collection(?:Index)?|Iterator))|L(?:egacyChildren|azy(?:RandomAccessCollection|Map(?:RandomAccessCollection|Generator|BidirectionalCollection|Sequence|Collection|Iterator)|BidirectionalCollection|Sequence|Collection|Filter(?:Generator|BidirectionalCollection|Sequence|Collection|I(?:ndex|terator))))|A(?:ny(?:RandomAccessCollection|Generator|BidirectionalCollection|Sequence|Hashable|Collection|I(?:ndex|terator))|utoreleasingUnsafeMutablePointer|rray(?:Slice)?))\\b"
				},
				{
					"comment": "Structs in the standard library in Swift 2 only",
					"name": "support.type.swift",
					"match": "\\b(?:R(?:everse(?:RandomAccess(?:Collection|Index)|Collection|Index)|awByte)|Map(?:Generator|Sequence|Collection)|S(?:inkOf|etGenerator)|Zip2Generator|DictionaryGenerator|Filter(?:Generator|Sequence|Collection(?:Index)?)|LazyForwardCollection|Any(?:RandomAccessIndex|BidirectionalIndex|Forward(?:Collection|Index)))\\b"
				}
			]
		},
		"builtin-types-builtin-typealias": {
			"patterns": [
				{
					"comment": "Typealiases in the standard library in Swift 3",
					"name": "support.type.swift",
					"match": "\\b(?:Raw(?:Significand|Exponent|Value)|B(?:ooleanLiteralType|uffer|ase)|S(?:t(?:orage|r(?:i(?:ngLiteralType|de)|eam(?:1|2)))|ubSequence)|NativeBuffer|C(?:hild(?:ren)?|Bool|S(?:hort|ignedChar)|odeUnit|Char(?:16|32)?|Int|Double|Unsigned(?:Short|Char|Int|Long(?:Long)?)|Float|WideChar|Long(?:Long)?)|I(?:n(?:t(?:Max|egerLiteralType)|d(?:ices|ex(?:Distance)?))|terator)|Distance|U(?:n(?:icodeScalar(?:Type|Index|View|LiteralType)|foldFirstSequence)|TF(?:16(?:Index|View)|8Index)|IntMax)|E(?:lement(?:s)?|x(?:tendedGraphemeCluster(?:Type|LiteralType)|ponent))|V(?:oid|alue)|Key|Float(?:32|LiteralType|64)|AnyClass)\\b"
				},
				{
					"comment": "Typealiases in the standard library in Swift 2 only",
					"name": "support.type.swift",
					"match": "\\b(?:Generator|PlaygroundQuickLook|UWord|Word)\\b"
				}
			]
		},
		"code-block": {
			"begin": "\\{",
			"end": "\\}",
			"beginCaptures": {
				"0": {
					"name": "punctuation.section.scope.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.section.scope.end.swift"
				}
			},
			"patterns": [
				{
					"include": "$self"
				}
			]
		},
		"comments": {
			"patterns": [
				{
					"name": "comment.line.number-sign.swift",
					"match": "\\A^(#!).*$\\n?",
					"captures": {
						"1": {
							"name": "punctuation.definition.comment.swift"
						}
					}
				},
				{
					"name": "comment.block.documentation.swift",
					"begin": "/\\*\\*(?!/)",
					"end": "\\*/",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.comment.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.comment.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#comments-nested"
						}
					]
				},
				{
					"name": "comment.block.documentation.playground.swift",
					"begin": "/\\*:",
					"end": "\\*/",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.comment.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.comment.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#comments-nested"
						}
					]
				},
				{
					"name": "comment.block.swift",
					"begin": "/\\*",
					"end": "\\*/",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.comment.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.comment.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#comments-nested"
						}
					]
				},
				{
					"name": "invalid.illegal.unexpected-end-of-block-comment.swift",
					"match": "\\*/"
				},
				{
					"begin": "(^[ \\t]+)?(?=//)",
					"end": "(?!\\G)",
					"beginCaptures": {
						"1": {
							"name": "punctuation.whitespace.comment.leading.swift"
						}
					},
					"patterns": [
						{
							"name": "comment.line.triple-slash.documentation.swift",
							"begin": "///",
							"end": "$",
							"beginCaptures": {
								"0": {
									"name": "punctuation.definition.comment.swift"
								}
							}
						},
						{
							"name": "comment.line.double-slash.documentation.swift",
							"begin": "//:",
							"end": "$",
							"beginCaptures": {
								"0": {
									"name": "punctuation.definition.comment.swift"
								}
							}
						},
						{
							"name": "comment.line.double-slash.swift",
							"begin": "//",
							"end": "$",
							"beginCaptures": {
								"0": {
									"name": "punctuation.definition.comment.swift"
								}
							}
						}
					]
				}
			]
		},
		"comments-nested": {
			"begin": "/\\*",
			"end": "\\*/",
			"patterns": [
				{
					"include": "#comments-nested"
				}
			]
		},
		"compiler-control": {
			"patterns": [
				{
					"contentName": "comment.block.preprocessor.swift",
					"begin": "^\\s*(#)(if|elseif)\\s+(false)\\b.*?(?=$|//|/\\*)",
					"end": "(?=^\\s*(#(elseif|else|endif)\\b))",
					"beginCaptures": {
						"0": {
							"name": "meta.preprocessor.conditional.swift"
						},
						"1": {
							"name": "punctuation.definition.preprocessor.swift"
						},
						"2": {
							"name": "keyword.control.import.preprocessor.conditional.swift"
						},
						"3": {
							"name": "constant.language.boolean.swift"
						}
					}
				},
				{
					"name": "meta.preprocessor.conditional.swift",
					"captures": {
						"1": {
							"name": "punctuation.definition.preprocessor.swift"
						},
						"2": {
							"name": "keyword.control.import.preprocessor.conditional.swift"
						}
					},
					"begin": "^\\s*(#)(if|elseif)\\s+",
					"end": "(?=\\s*(?://|/\\*))|$",
					"patterns": [
						{
							"name": "keyword.operator.logical.swift",
							"match": "(&&|\\|\\|)"
						},
						{
							"name": "constant.language.boolean.swift",
							"match": "\\b(true|false)\\b"
						},
						{
							"match": "\\b(arch)\\s*(\\()\\s*(?:(arm|arm64|powerpc64|powerpc64le|i386|x86_64|s390x)|\\w+)\\s*(\\))",
							"captures": {
								"1": {
									"name": "keyword.other.condition.swift"
								},
								"2": {
									"name": "punctuation.definition.parameters.begin.swift"
								},
								"3": {
									"name": "support.constant.platform.architecture.swift"
								},
								"4": {
									"name": "punctuation.definition.parameters.end.swift"
								}
							}
						},
						{
							"match": "\\b(os)\\s*(\\()\\s*(?:(macOS|OSX|iOS|tvOS|watchOS|visionOS|Android|Linux|FreeBSD|Windows|PS4)|\\w+)\\s*(\\))",
							"captures": {
								"1": {
									"name": "keyword.other.condition.swift"
								},
								"2": {
									"name": "punctuation.definition.parameters.begin.swift"
								},
								"3": {
									"name": "support.constant.platform.os.swift"
								},
								"4": {
									"name": "punctuation.definition.parameters.end.swift"
								}
							}
						},
						{
							"match": "\\b(canImport)\\s*(\\()([\\p{L}_][\\p{L}_\\p{N}\\p{M}]*)(\\))",
							"captures": {
								"1": {
									"name": "keyword.other.condition.swift"
								},
								"2": {
									"name": "punctuation.definition.parameters.begin.swift"
								},
								"3": {
									"name": "entity.name.type.module.swift"
								},
								"4": {
									"name": "punctuation.definition.parameters.end.swift"
								}
							}
						},
						{
							"begin": "\\b(targetEnvironment)\\s*(\\()",
							"end": "(\\))|$",
							"beginCaptures": {
								"1": {
									"name": "keyword.other.condition.swift"
								},
								"2": {
									"name": "punctuation.definition.parameters.begin.swift"
								}
							},
							"endCaptures": {
								"1": {
									"name": "punctuation.definition.parameters.end.swift"
								}
							},
							"patterns": [
								{
									"name": "support.constant.platform.environment.swift",
									"match": "\\b(simulator|UIKitForMac)\\b"
								}
							]
						},
						{
							"begin": "\\b(swift|compiler)\\s*(\\()",
							"end": "(\\))|$",
							"beginCaptures": {
								"1": {
									"name": "keyword.other.condition.swift"
								},
								"2": {
									"name": "punctuation.definition.parameters.begin.swift"
								}
							},
							"endCaptures": {
								"1": {
									"name": "punctuation.definition.parameters.end.swift"
								}
							},
							"patterns": [
								{
									"name": "keyword.operator.comparison.swift",
									"match": ">=|<"
								},
								{
									"name": "constant.numeric.swift",
									"match": "\\b[0-9]+(?:\\.[0-9]+)*\\b"
								}
							]
						}
					]
				},
				{
					"name": "meta.preprocessor.conditional.swift",
					"match": "^\\s*(#)(else|endif)(.*?)(?=$|//|/\\*)",
					"captures": {
						"1": {
							"name": "punctuation.definition.preprocessor.swift"
						},
						"2": {
							"name": "keyword.control.import.preprocessor.conditional.swift"
						},
						"3": {
							"patterns": [
								{
									"name": "invalid.illegal.character-not-allowed-here.swift",
									"match": "\\S+"
								}
							]
						}
					}
				},
				{
					"name": "meta.preprocessor.sourcelocation.swift",
					"match": "^\\s*(#)(sourceLocation)((\\()([^)]*)(\\)))(.*?)(?=$|//|/\\*)",
					"captures": {
						"1": {
							"name": "punctuation.definition.preprocessor.swift"
						},
						"2": {
							"name": "keyword.control.import.preprocessor.sourcelocation.swift"
						},
						"4": {
							"name": "punctuation.definition.parameters.begin.swift"
						},
						"5": {
							"patterns": [
								{
									"begin": "(file)\\s*(:)\\s*(?=\")",
									"end": "(?!\\G)",
									"beginCaptures": {
										"1": {
											"name": "support.variable.parameter.swift"
										},
										"2": {
											"name": "punctuation.separator.key-value.swift"
										}
									},
									"patterns": [
										{
											"include": "#literals"
										}
									]
								},
								{
									"match": "(line)\\s*(:)\\s*([0-9]+)",
									"captures": {
										"1": {
											"name": "support.variable.parameter.swift"
										},
										"2": {
											"name": "punctuation.separator.key-value.swift"
										},
										"3": {
											"name": "constant.numeric.integer.swift"
										}
									}
								},
								{
									"name": "punctuation.separator.parameters.swift",
									"match": ","
								},
								{
									"name": "invalid.illegal.character-not-allowed-here.swift",
									"match": "\\S+"
								}
							]
						},
						"6": {
							"name": "punctuation.definition.parameters.begin.swift"
						},
						"7": {
							"patterns": [
								{
									"name": "invalid.illegal.character-not-allowed-here.swift",
									"match": "\\S+"
								}
							]
						}
					}
				}
			]
		},
		"conditionals": {
			"patterns": [
				{
					"begin": "(?<!\\.)\\b(if|guard|switch|for)\\b",
					"end": "(?=\\{)",
					"beginCaptures": {
						"1": {
							"patterns": [
								{
									"include": "#keywords"
								}
							]
						}
					},
					"patterns": [
						{
							"include": "#expressions-without-trailing-closures"
						}
					]
				},
				{
					"comment": "while can be the end of a repeat-while statement so doesn't necessarily have braces after it",
					"begin": "(?<!\\.)\\b(while)\\b",
					"end": "(?=\\{)|$",
					"beginCaptures": {
						"1": {
							"patterns": [
								{
									"include": "#keywords"
								}
							]
						}
					},
					"patterns": [
						{
							"include": "#expressions-without-trailing-closures"
						}
					]
				}
			]
		},
		"declarations": {
			"patterns": [
				{
					"include": "#declarations-function"
				},
				{
					"include": "#declarations-function-initializer"
				},
				{
					"include": "#declarations-function-subscript"
				},
				{
					"include": "#declarations-typed-variable-declaration"
				},
				{
					"include": "#declarations-import"
				},
				{
					"include": "#declarations-operator"
				},
				{
					"include": "#declarations-precedencegroup"
				},
				{
					"include": "#declarations-protocol"
				},
				{
					"include": "#declarations-type"
				},
				{
					"include": "#declarations-extension"
				},
				{
					"include": "#declarations-typealias"
				},
				{
					"include": "#declarations-macro"
				}
			]
		},
		"declarations-available-types": {
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#builtin-types"
				},
				{
					"include": "#attributes"
				},
				{
					"name": "storage.modifier.async.swift",
					"match": "\\basync\\b"
				},
				{
					"name": "storage.modifier.exception.swift",
					"match": "\\b(?:throws|rethrows)\\b"
				},
				{
					"name": "keyword.other.operator.type.opaque.swift",
					"match": "\\bsome\\b"
				},
				{
					"name": "keyword.other.operator.type.existential.swift",
					"match": "\\bany\\b"
				},
				{
					"name": "keyword.control.loop.swift",
					"match": "\\b(?:repeat|each)\\b"
				},
				{
					"name": "storage.modifier.swift",
					"match": "\\b(?:inout|isolated|borrowing|consuming)\\b"
				},
				{
					"name": "variable.language.swift",
					"match": "\\bSelf\\b"
				},
				{
					"match": "(?<![/=\\-+!*%<>&|\\^~.])(->)(?![/=\\-+!*%<>&|\\^~.])",
					"captures": {
						"1": {
							"name": "keyword.operator.type.function.swift"
						}
					}
				},
				{
					"comment": "Swift 3: A & B",
					"match": "(?<![/=\\-+!*%<>&|\\^~.])(&)(?![/=\\-+!*%<>&|\\^~.])",
					"captures": {
						"1": {
							"name": "keyword.operator.type.composition.swift"
						}
					}
				},
				{
					"name": "keyword.operator.type.optional.swift",
					"match": "[?!]"
				},
				{
					"name": "keyword.operator.function.variadic-parameter.swift",
					"match": "\\.\\.\\."
				},
				{
					"comment": "Swift 2: protocol<A, B>",
					"name": "keyword.other.type.composition.swift",
					"match": "\\bprotocol\\b"
				},
				{
					"name": "keyword.other.type.metatype.swift",
					"match": "(?<=\\.)(?:Protocol|Type)\\b"
				},
				{
					"include": "#declarations-available-types-tuple-type"
				},
				{
					"include": "#declarations-available-types-collection-type"
				},
				{
					"include": "#declarations-generic-argument-clause"
				}
			]
		},
		"declarations-available-types-collection-type": {
			"comment": "array and dictionary types [Value] and [Key: Value]",
			"begin": "\\[",
			"end": "\\]|(?=[>){}])",
			"beginCaptures": {
				"0": {
					"name": "punctuation.section.collection-type.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.section.collection-type.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-available-types"
				},
				{
					"begin": ":",
					"end": "(?=\\]|[>){}])",
					"beginCaptures": {
						"0": {
							"name": "punctuation.separator.key-value.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.extra-colon-in-dictionary-type.swift",
							"match": ":"
						},
						{
							"include": "#declarations-available-types"
						}
					]
				}
			]
		},
		"declarations-available-types-tuple-type": {
			"begin": "\\(",
			"end": "\\)|(?=[>\\]{}])",
			"beginCaptures": {
				"0": {
					"name": "punctuation.section.tuple-type.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.section.tuple-type.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-available-types"
				}
			]
		},
		"declarations-extension": {
			"name": "meta.definition.type.$1.swift",
			"begin": "\\b(extension)\\s+((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
			"end": "(?<=\\})",
			"beginCaptures": {
				"1": {
					"name": "storage.type.$1.swift"
				},
				"2": {
					"name": "entity.name.type.swift",
					"patterns": [
						{
							"include": "#declarations-available-types"
						}
					]
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"comment": "SE-0143: Conditional Conformances",
					"include": "#declarations-generic-where-clause"
				},
				{
					"include": "#declarations-inheritance-clause"
				},
				{
					"name": "meta.definition.type.body.swift",
					"begin": "\\{",
					"end": "\\}",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.type.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.type.end.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-function": {
			"name": "meta.definition.function.swift",
			"begin": "(?x)\n\\b\n(func)\n\\s+\n(\n  (?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>)\n  | (?:\n    (\n      (?<oph>                # operator-head\n        [/=\\-+!*%<>&|^~?]\n        | [\\x{00A1}-\\x{00A7}]\n        | [\\x{00A9}\\x{00AB}]\n        | [\\x{00AC}\\x{00AE}]\n        | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n        | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n        | [\\x{2030}-\\x{203E}]\n        | [\\x{2041}-\\x{2053}]\n        | [\\x{2055}-\\x{205E}]\n        | [\\x{2190}-\\x{23FF}]\n        | [\\x{2500}-\\x{2775}]\n        | [\\x{2794}-\\x{2BFF}]\n        | [\\x{2E00}-\\x{2E7F}]\n        | [\\x{3001}-\\x{3003}]\n        | [\\x{3008}-\\x{3030}]\n      )\n      (\n        \\g<oph>\n        | (?<opc>                # operator-character\n          [\\x{0300}-\\x{036F}]\n          | [\\x{1DC0}-\\x{1DFF}]\n          | [\\x{20D0}-\\x{20FF}]\n          | [\\x{FE00}-\\x{FE0F}]\n          | [\\x{FE20}-\\x{FE2F}]\n          | [\\x{E0100}-\\x{E01EF}]\n        )\n      )*\n    )\n    | ( \\. ( \\g<oph> | \\g<opc> | \\. )+ )      # Dot operators\n  )\n)\n\\s*\n(?=\\(|<)",
			"end": "(?<=\\})|$(?# functions in protocol declarations or generated interfaces have no body)",
			"beginCaptures": {
				"1": {
					"name": "storage.type.function.swift"
				},
				"2": {
					"name": "entity.name.function.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"include": "#declarations-parameter-clause"
				},
				{
					"include": "#declarations-function-result"
				},
				{
					"include": "#async-throws"
				},
				{
					"comment": "Swift 3: generic constraints after the parameters and return type",
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "meta.definition.function.body.swift",
					"begin": "(\\{)",
					"end": "(\\})",
					"beginCaptures": {
						"1": {
							"name": "punctuation.section.function.begin.swift"
						}
					},
					"endCaptures": {
						"1": {
							"name": "punctuation.section.function.end.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-function-initializer": {
			"name": "meta.definition.function.initializer.swift",
			"begin": "(?<!\\.)\\b(init[?!]*(?# only one is valid, but we want the in⇥ snippet to produce something that looks good))\\s*(?=\\(|<)",
			"end": "(?<=\\})|$",
			"beginCaptures": {
				"1": {
					"name": "storage.type.function.swift",
					"patterns": [
						{
							"name": "invalid.illegal.character-not-allowed-here.swift",
							"match": "(?<=[?!])[?!]+"
						}
					]
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"include": "#declarations-parameter-clause"
				},
				{
					"include": "#async-throws"
				},
				{
					"comment": "Swift 3: generic constraints after the parameters and return type",
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "meta.definition.function.body.swift",
					"begin": "(\\{)",
					"end": "(\\})",
					"beginCaptures": {
						"1": {
							"name": "punctuation.section.function.begin.swift"
						}
					},
					"endCaptures": {
						"1": {
							"name": "punctuation.section.function.end.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-function-result": {
			"name": "meta.function-result.swift",
			"begin": "(?<![/=\\-+!*%<>&|\\^~.])(->)(?![/=\\-+!*%<>&|\\^~.])\\s*",
			"end": "(?!\\G)(?=\\{|\\bwhere\\b|;|=)|$",
			"beginCaptures": {
				"1": {
					"name": "keyword.operator.function-result.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-available-types"
				}
			]
		},
		"declarations-function-subscript": {
			"name": "meta.definition.function.subscript.swift",
			"begin": "(?<!\\.)\\b(subscript)\\s*(?=\\(|<)",
			"end": "(?<=\\})|$",
			"beginCaptures": {
				"1": {
					"name": "storage.type.function.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"include": "#declarations-parameter-clause"
				},
				{
					"include": "#declarations-function-result"
				},
				{
					"include": "#async-throws"
				},
				{
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "meta.definition.function.body.swift",
					"begin": "(\\{)",
					"end": "(\\})",
					"beginCaptures": {
						"1": {
							"name": "punctuation.section.function.begin.swift"
						}
					},
					"endCaptures": {
						"1": {
							"name": "punctuation.section.function.end.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-generic-argument-clause": {
			"name": "meta.generic-argument-clause.swift",
			"begin": "<",
			"end": ">|(?=[)\\]{}])",
			"beginCaptures": {
				"0": {
					"name": "punctuation.separator.generic-argument-clause.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.separator.generic-argument-clause.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-available-types"
				}
			]
		},
		"declarations-generic-parameter-clause": {
			"name": "meta.generic-parameter-clause.swift",
			"begin": "<",
			"end": ">|(?=[^\\w\\d:<>\\s,=&`])(?# characters besides these are never valid in a generic param list -- even if it's not really a valid clause, we should stop trying to parse it if we see one of them.)",
			"beginCaptures": {
				"0": {
					"name": "punctuation.separator.generic-parameter-clause.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.separator.generic-parameter-clause.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"comment": "Swift 2: constraints inside the generic param list",
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "keyword.control.loop.swift",
					"match": "\\beach\\b"
				},
				{
					"match": "\\b((?!\\d)\\w[\\w\\d]*)\\b",
					"captures": {
						"1": {
							"name": "variable.language.generic-parameter.swift"
						}
					}
				},
				{
					"name": "punctuation.separator.generic-parameters.swift",
					"match": ","
				},
				{
					"name": "meta.generic-parameter-constraint.swift",
					"begin": "(:)\\s*",
					"end": "(?=[,>]|(?!\\G)\\bwhere\\b)",
					"beginCaptures": {
						"1": {
							"name": "punctuation.separator.generic-parameter-constraint.swift"
						}
					},
					"patterns": [
						{
							"name": "entity.other.inherited-class.swift",
							"begin": "\\G",
							"end": "(?=[,>]|(?!\\G)\\bwhere\\b)",
							"patterns": [
								{
									"include": "#declarations-type-identifier"
								},
								{
									"include": "#declarations-type-operators"
								}
							]
						}
					]
				}
			]
		},
		"declarations-generic-where-clause": {
			"name": "meta.generic-where-clause.swift",
			"begin": "\\b(where)\\b\\s*",
			"end": "(?!\\G)$|(?=[>{};\\n]|//|/\\*)",
			"beginCaptures": {
				"1": {
					"name": "keyword.other.generic-constraint-introducer.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-where-clause-requirement-list"
				}
			]
		},
		"declarations-generic-where-clause-requirement-list": {
			"begin": "\\G|,\\s*",
			"end": "(?=[,>{};\\n]|//|/\\*)",
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#constraint"
				},
				{
					"include": "#declarations-available-types"
				},
				{
					"name": "meta.generic-where-clause.same-type-requirement.swift",
					"begin": "(?<![/=\\-+!*%<>&|\\^~.])(==)(?![/=\\-+!*%<>&|\\^~.])",
					"end": "(?=\\s*[,>{};\\n]|//|/\\*)",
					"beginCaptures": {
						"1": {
							"name": "keyword.operator.generic-constraint.same-type.swift"
						}
					},
					"patterns": [
						{
							"include": "#declarations-available-types"
						}
					]
				},
				{
					"name": "meta.generic-where-clause.conformance-requirement.swift",
					"begin": "(?<![/=\\-+!*%<>&|\\^~.])(:)(?![/=\\-+!*%<>&|\\^~.])",
					"end": "(?=\\s*[,>{};\\n]|//|/\\*)",
					"beginCaptures": {
						"1": {
							"name": "keyword.operator.generic-constraint.conforms-to.swift"
						}
					},
					"patterns": [
						{
							"contentName": "entity.other.inherited-class.swift",
							"begin": "\\G\\s*",
							"end": "(?=\\s*[,>{};\\n]|//|/\\*)",
							"patterns": [
								{
									"include": "#declarations-available-types"
								}
							]
						}
					]
				}
			]
		},
		"declarations-import": {
			"name": "meta.import.swift",
			"begin": "(?<!\\.)\\b(import)\\s+",
			"end": "(;)|$\\n?|(?=//|/\\*)",
			"beginCaptures": {
				"1": {
					"name": "keyword.control.import.swift"
				}
			},
			"endCaptures": {
				"1": {
					"name": "punctuation.terminator.statement.swift"
				}
			},
			"patterns": [
				{
					"begin": "\\G(?!;|$|//|/\\*)(?:(typealias|struct|class|actor|enum|protocol|var|func)\\s+)?",
					"end": "(?=;|$|//|/\\*)",
					"beginCaptures": {
						"1": {
							"name": "storage.modifier.swift"
						}
					},
					"patterns": [
						{
							"name": "entity.name.type.swift",
							"match": "(?x)\n(?<=\\G|\\.)\n(?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>)",
							"captures": {
								"1": {
									"name": "punctuation.definition.identifier.swift"
								},
								"2": {
									"name": "punctuation.definition.identifier.swift"
								}
							}
						},
						{
							"name": "entity.name.type.swift",
							"match": "(?x)\n(?<=\\G|\\.)\n\\$[0-9]+"
						},
						{
							"name": "entity.name.type.swift",
							"match": "(?x)\n(?<=\\G|\\.)\n(?:\n  (\n    (?<oph>                # operator-head\n      [/=\\-+!*%<>&|^~?]\n      | [\\x{00A1}-\\x{00A7}]\n      | [\\x{00A9}\\x{00AB}]\n      | [\\x{00AC}\\x{00AE}]\n      | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n      | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n      | [\\x{2030}-\\x{203E}]\n      | [\\x{2041}-\\x{2053}]\n      | [\\x{2055}-\\x{205E}]\n      | [\\x{2190}-\\x{23FF}]\n      | [\\x{2500}-\\x{2775}]\n      | [\\x{2794}-\\x{2BFF}]\n      | [\\x{2E00}-\\x{2E7F}]\n      | [\\x{3001}-\\x{3003}]\n      | [\\x{3008}-\\x{3030}]\n    )\n    (\n      \\g<oph>\n      | (?<opc>                # operator-character\n        [\\x{0300}-\\x{036F}]\n        | [\\x{1DC0}-\\x{1DFF}]\n        | [\\x{20D0}-\\x{20FF}]\n        | [\\x{FE00}-\\x{FE0F}]\n        | [\\x{FE20}-\\x{FE2F}]\n        | [\\x{E0100}-\\x{E01EF}]\n      )\n    )*\n  )\n  | ( \\. ( \\g<oph> | \\g<opc> | \\. )+ )      # Dot operators\n)\n(?=\\.|;|$|//|/\\*|\\s)",
							"captures": {
								"1": {
									"patterns": [
										{
											"name": "invalid.illegal.dot-not-allowed-here.swift",
											"match": "\\."
										}
									]
								}
							}
						},
						{
							"name": "punctuation.separator.import.swift",
							"match": "\\."
						},
						{
							"name": "invalid.illegal.character-not-allowed-here.swift",
							"begin": "(?!\\s*(;|$|//|/\\*))",
							"end": "(?=\\s*(;|$|//|/\\*))"
						}
					]
				}
			]
		},
		"declarations-inheritance-clause": {
			"name": "meta.inheritance-clause.swift",
			"begin": "(:)(?=\\s*\\{)|(:)\\s*",
			"end": "(?!\\G)$|(?=[={}]|(?!\\G)\\bwhere\\b)",
			"beginCaptures": {
				"1": {
					"name": "invalid.illegal.empty-inheritance-clause.swift"
				},
				"2": {
					"name": "punctuation.separator.inheritance-clause.swift"
				}
			},
			"patterns": [
				{
					"begin": "\\bclass\\b",
					"end": "(?=[={}]|(?!\\G)\\bwhere\\b)",
					"beginCaptures": {
						"0": {
							"name": "storage.type.class.swift"
						}
					},
					"patterns": [
						{
							"include": "#comments"
						},
						{
							"include": "#declarations-inheritance-clause-more-types"
						}
					]
				},
				{
					"begin": "\\G",
					"end": "(?!\\G)$|(?=[={}]|(?!\\G)\\bwhere\\b)",
					"patterns": [
						{
							"include": "#comments"
						},
						{
							"include": "#declarations-inheritance-clause-inherited-type"
						},
						{
							"include": "#declarations-inheritance-clause-more-types"
						},
						{
							"include": "#declarations-type-operators"
						}
					]
				}
			]
		},
		"declarations-inheritance-clause-inherited-type": {
			"name": "entity.other.inherited-class.swift",
			"begin": "(?=[`\\p{L}_])",
			"end": "(?!\\G)",
			"patterns": [
				{
					"include": "#declarations-type-identifier"
				}
			]
		},
		"declarations-inheritance-clause-more-types": {
			"name": "meta.inheritance-list.more-types",
			"begin": ",\\s*",
			"end": "(?!\\G)(?!//|/\\*)|(?=[,={}]|(?!\\G)\\bwhere\\b)",
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-inheritance-clause-inherited-type"
				},
				{
					"include": "#declarations-inheritance-clause-more-types"
				},
				{
					"include": "#declarations-type-operators"
				}
			]
		},
		"declarations-macro": {
			"name": "meta.definition.macro.swift",
			"begin": "(?x)\n\\b\n(macro)\n\\s+\n((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\n\\s*\n(?=\\(|<|=)",
			"end": "$|(?=;|//|/\\*|\\}|=)",
			"beginCaptures": {
				"1": {
					"name": "storage.type.function.swift"
				},
				"2": {
					"name": "entity.name.function.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"include": "#declarations-parameter-clause"
				},
				{
					"include": "#declarations-function-result"
				},
				{
					"include": "#async-throws"
				},
				{
					"comment": "Swift 3: generic constraints after the parameters and return type",
					"include": "#declarations-generic-where-clause"
				}
			]
		},
		"declarations-operator": {
			"name": "meta.definition.operator.swift",
			"begin": "(?x)\n(?:\n  \\b(prefix|infix|postfix)\n  \\s+\n)?\n\\b\n(operator)\n\\s+\n(\n  (\n    (?<oph>                  # operator-head\n      [/=\\-+!*%<>&|^~?]\n      | [\\x{00A1}-\\x{00A7}]\n      | [\\x{00A9}\\x{00AB}]\n      | [\\x{00AC}\\x{00AE}]\n      | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n      | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n      | [\\x{2030}-\\x{203E}]\n      | [\\x{2041}-\\x{2053}]\n      | [\\x{2055}-\\x{205E}]\n      | [\\x{2190}-\\x{23FF}]\n      | [\\x{2500}-\\x{2775}]\n      | [\\x{2794}-\\x{2BFF}]\n      | [\\x{2E00}-\\x{2E7F}]\n      | [\\x{3001}-\\x{3003}]\n      | [\\x{3008}-\\x{3030}]\n    )\n    (\n      \\g<oph>\n      | \\.                  # Invalid dot\n      | (?<opc>                # operator-character\n        [\\x{0300}-\\x{036F}]\n        | [\\x{1DC0}-\\x{1DFF}]\n        | [\\x{20D0}-\\x{20FF}]\n        | [\\x{FE00}-\\x{FE0F}]\n        | [\\x{FE20}-\\x{FE2F}]\n        | [\\x{E0100}-\\x{E01EF}]\n      )\n    )*+\n  )\n  | ( \\. ( \\g<oph> | \\g<opc> | \\. )++ )      # Dot operators\n)\n\\s*",
			"end": "(;)|$\\n?|(?=//|/\\*)",
			"beginCaptures": {
				"1": {
					"name": "storage.modifier.swift"
				},
				"2": {
					"name": "storage.type.function.operator.swift"
				},
				"3": {
					"name": "entity.name.function.operator.swift"
				},
				"4": {
					"comment": "workaround for https://github.com/microsoft/vscode-textmate/issues/140#issuecomment-1793610346",
					"name": "entity.name.function.operator.swift",
					"patterns": [
						{
							"name": "invalid.illegal.dot-not-allowed-here.swift",
							"match": "\\."
						}
					]
				}
			},
			"endCaptures": {
				"1": {
					"name": "punctuation.terminator.statement.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-operator-swift2"
				},
				{
					"include": "#declarations-operator-swift3"
				},
				{
					"name": "invalid.illegal.character-not-allowed-here.swift",
					"match": "((?!$|;|//|/\\*)\\S)+"
				}
			]
		},
		"declarations-operator-swift2": {
			"begin": "\\G(\\{)",
			"end": "(\\})",
			"beginCaptures": {
				"1": {
					"name": "punctuation.definition.operator.begin.swift"
				}
			},
			"endCaptures": {
				"1": {
					"name": "punctuation.definition.operator.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"match": "\\b(associativity)\\s+(left|right)\\b",
					"captures": {
						"1": {
							"name": "storage.modifier.swift"
						},
						"2": {
							"name": "keyword.other.operator.associativity.swift"
						}
					}
				},
				{
					"match": "\\b(precedence)\\s+([0-9]+)\\b",
					"captures": {
						"1": {
							"name": "storage.modifier.swift"
						},
						"2": {
							"name": "constant.numeric.integer.swift"
						}
					}
				},
				{
					"match": "\\b(assignment)\\b",
					"captures": {
						"1": {
							"name": "storage.modifier.swift"
						}
					}
				}
			]
		},
		"declarations-operator-swift3": {
			"match": "\\G(:)\\s*((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
			"captures": {
				"2": {
					"name": "entity.other.inherited-class.swift",
					"patterns": [
						{
							"include": "#declarations-types-precedencegroup"
						}
					]
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			}
		},
		"declarations-parameter-clause": {
			"name": "meta.parameter-clause.swift",
			"begin": "(\\()",
			"end": "(\\))(?:\\s*(async)\\b)?",
			"beginCaptures": {
				"1": {
					"name": "punctuation.definition.parameters.begin.swift"
				}
			},
			"endCaptures": {
				"1": {
					"name": "punctuation.definition.parameters.end.swift"
				},
				"2": {
					"name": "storage.modifier.async.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-parameter-list"
				}
			]
		},
		"declarations-parameter-list": {
			"patterns": [
				{
					"comment": "External parameter labels are considered part of the function name",
					"match": "((?<q1>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q1>))\\s+((?<q2>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q2>))(?=\\s*:)",
					"captures": {
						"1": {
							"name": "entity.name.function.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						},
						"4": {
							"name": "variable.parameter.function.swift"
						},
						"5": {
							"name": "punctuation.definition.identifier.swift"
						},
						"6": {
							"name": "punctuation.definition.identifier.swift"
						}
					}
				},
				{
					"comment": "If no external label is given, the name is both the external label and the internal variable name",
					"match": "(((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>)))(?=\\s*:)",
					"captures": {
						"1": {
							"name": "variable.parameter.function.swift"
						},
						"2": {
							"name": "entity.name.function.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						},
						"4": {
							"name": "punctuation.definition.identifier.swift"
						}
					}
				},
				{
					"begin": ":\\s*(?!\\s)",
					"end": "(?=[,)])",
					"patterns": [
						{
							"include": "#declarations-available-types"
						},
						{
							"name": "invalid.illegal.extra-colon-in-parameter-list.swift",
							"match": ":"
						},
						{
							"comment": "a parameter's default value",
							"begin": "=",
							"end": "(?=[,)])",
							"beginCaptures": {
								"0": {
									"name": "keyword.operator.assignment.swift"
								}
							},
							"patterns": [
								{
									"include": "#expressions"
								}
							]
						}
					]
				}
			]
		},
		"declarations-precedencegroup": {
			"name": "meta.definition.precedencegroup.swift",
			"begin": "\\b(precedencegroup)\\s+((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*(?=\\{)",
			"end": "(?!\\G)",
			"beginCaptures": {
				"1": {
					"name": "storage.type.precedencegroup.swift"
				},
				"2": {
					"name": "entity.name.type.precedencegroup.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"begin": "\\{",
					"end": "\\}",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.precedencegroup.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.precedencegroup.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#comments"
						},
						{
							"match": "\\b(higherThan|lowerThan)\\s*:\\s*((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
							"captures": {
								"1": {
									"name": "storage.modifier.swift"
								},
								"2": {
									"name": "entity.other.inherited-class.swift",
									"patterns": [
										{
											"include": "#declarations-types-precedencegroup"
										}
									]
								},
								"3": {
									"name": "punctuation.definition.identifier.swift"
								},
								"4": {
									"name": "punctuation.definition.identifier.swift"
								}
							}
						},
						{
							"match": "\\b(associativity)\\b(?:\\s*:\\s*(right|left|none)\\b)?",
							"captures": {
								"1": {
									"name": "storage.modifier.swift"
								},
								"2": {
									"name": "keyword.other.operator.associativity.swift"
								}
							}
						},
						{
							"match": "\\b(assignment)\\b(?:\\s*:\\s*(true|false)\\b)?",
							"captures": {
								"1": {
									"name": "storage.modifier.swift"
								},
								"2": {
									"name": "constant.language.boolean.swift"
								}
							}
						}
					]
				}
			]
		},
		"declarations-protocol": {
			"name": "meta.definition.type.protocol.swift",
			"begin": "\\b(protocol)\\s+((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
			"end": "(?<=\\})",
			"beginCaptures": {
				"1": {
					"name": "storage.type.$1.swift"
				},
				"2": {
					"name": "entity.name.type.$1.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-inheritance-clause"
				},
				{
					"comment": "SE-0142: Permit where clauses to constrain associated types",
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "meta.definition.type.body.swift",
					"begin": "\\{",
					"end": "\\}",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.type.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.type.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#declarations-protocol-protocol-method"
						},
						{
							"include": "#declarations-protocol-protocol-initializer"
						},
						{
							"include": "#declarations-protocol-associated-type"
						},
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-protocol-associated-type": {
			"name": "meta.definition.associatedtype.swift",
			"begin": "\\b(associatedtype)\\s+((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*",
			"end": "(?!\\G)$|(?=[;}]|$)",
			"beginCaptures": {
				"1": {
					"name": "keyword.other.declaration-specifier.swift"
				},
				"2": {
					"name": "variable.language.associatedtype.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-inheritance-clause"
				},
				{
					"comment": "SE-0142: Permit where clauses to constrain associated types",
					"include": "#declarations-generic-where-clause"
				},
				{
					"include": "#declarations-typealias-assignment"
				}
			]
		},
		"declarations-protocol-protocol-initializer": {
			"name": "meta.definition.function.initializer.swift",
			"begin": "(?<!\\.)\\b(init[?!]*(?# only one is valid, but we want the in⇥ snippet to produce something that looks good))\\s*(?=\\(|<)",
			"end": "$|(?=;|//|/\\*|\\})",
			"beginCaptures": {
				"1": {
					"name": "storage.type.function.swift",
					"patterns": [
						{
							"name": "invalid.illegal.character-not-allowed-here.swift",
							"match": "(?<=[?!])[?!]+"
						}
					]
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"include": "#declarations-parameter-clause"
				},
				{
					"include": "#async-throws"
				},
				{
					"comment": "Swift 3: generic constraints after the parameters and return type",
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "invalid.illegal.function-body-not-allowed-in-protocol.swift",
					"begin": "\\{",
					"end": "\\}",
					"beginCaptures": {
						"0": {
							"name": "punctuation.section.function.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.section.function.end.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-protocol-protocol-method": {
			"name": "meta.definition.function.swift",
			"begin": "(?x)\n\\b\n(func)\n\\s+\n(\n  (?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>)\n    | (?:\n      (\n        (?<oph>                # operator-head\n          [/=\\-+!*%<>&|^~?]\n          | [\\x{00A1}-\\x{00A7}]\n          | [\\x{00A9}\\x{00AB}]\n          | [\\x{00AC}\\x{00AE}]\n          | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n          | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n          | [\\x{2030}-\\x{203E}]\n          | [\\x{2041}-\\x{2053}]\n          | [\\x{2055}-\\x{205E}]\n          | [\\x{2190}-\\x{23FF}]\n          | [\\x{2500}-\\x{2775}]\n          | [\\x{2794}-\\x{2BFF}]\n          | [\\x{2E00}-\\x{2E7F}]\n          | [\\x{3001}-\\x{3003}]\n          | [\\x{3008}-\\x{3030}]\n        )\n        (\n          \\g<oph>\n          | (?<opc>                # operator-character\n            [\\x{0300}-\\x{036F}]\n            | [\\x{1DC0}-\\x{1DFF}]\n            | [\\x{20D0}-\\x{20FF}]\n            | [\\x{FE00}-\\x{FE0F}]\n            | [\\x{FE20}-\\x{FE2F}]\n            | [\\x{E0100}-\\x{E01EF}]\n          )\n        )*\n      )\n      | ( \\. ( \\g<oph> | \\g<opc> | \\. )+ )      # Dot operators\n    )\n  )\n\\s*\n(?=\\(|<)",
			"end": "$|(?=;|//|/\\*|\\})",
			"beginCaptures": {
				"1": {
					"name": "storage.type.function.swift"
				},
				"2": {
					"name": "entity.name.function.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"include": "#declarations-parameter-clause"
				},
				{
					"include": "#declarations-function-result"
				},
				{
					"include": "#async-throws"
				},
				{
					"comment": "Swift 3: generic constraints after the parameters and return type",
					"include": "#declarations-generic-where-clause"
				},
				{
					"name": "invalid.illegal.function-body-not-allowed-in-protocol.swift",
					"begin": "\\{",
					"end": "\\}",
					"beginCaptures": {
						"0": {
							"name": "punctuation.section.function.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.section.function.end.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-type": {
			"patterns": [
				{
					"name": "meta.definition.type.$1.swift",
					"begin": "\\b(class(?!\\s+(?:func|var|let)\\b)|struct|actor)\\b\\s*((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
					"end": "(?<=\\})",
					"beginCaptures": {
						"1": {
							"name": "storage.type.$1.swift"
						},
						"2": {
							"name": "entity.name.type.$1.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						},
						"4": {
							"name": "punctuation.definition.identifier.swift"
						}
					},
					"patterns": [
						{
							"include": "#comments"
						},
						{
							"include": "#declarations-generic-parameter-clause"
						},
						{
							"comment": "Swift 3: generic constraints after the generic param list",
							"include": "#declarations-generic-where-clause"
						},
						{
							"include": "#declarations-inheritance-clause"
						},
						{
							"name": "meta.definition.type.body.swift",
							"begin": "\\{",
							"end": "\\}",
							"beginCaptures": {
								"0": {
									"name": "punctuation.definition.type.begin.swift"
								}
							},
							"endCaptures": {
								"0": {
									"name": "punctuation.definition.type.end.swift"
								}
							},
							"patterns": [
								{
									"include": "$self"
								}
							]
						}
					]
				},
				{
					"include": "#declarations-type-enum"
				}
			]
		},
		"declarations-type-enum": {
			"name": "meta.definition.type.$1.swift",
			"begin": "\\b(enum)\\s+((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
			"end": "(?<=\\})",
			"beginCaptures": {
				"1": {
					"name": "storage.type.$1.swift"
				},
				"2": {
					"name": "entity.name.type.$1.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-generic-parameter-clause"
				},
				{
					"comment": "Swift 3: generic constraints after the generic param list",
					"include": "#declarations-generic-where-clause"
				},
				{
					"include": "#declarations-inheritance-clause"
				},
				{
					"name": "meta.definition.type.body.swift",
					"begin": "\\{",
					"end": "\\}",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.type.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.type.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#declarations-type-enum-enum-case-clause"
						},
						{
							"include": "$self"
						}
					]
				}
			]
		},
		"declarations-type-enum-associated-values": {
			"begin": "\\G\\(",
			"end": "\\)",
			"beginCaptures": {
				"0": {
					"name": "punctuation.definition.parameters.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.definition.parameters.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"begin": "(?x)\n(?:(_)|((?<q1>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*\\k<q1>))\n\\s+\n(((?<q2>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*\\k<q2>))\n\\s*(:)",
					"end": "(?=[,)\\]])",
					"beginCaptures": {
						"1": {
							"name": "entity.name.function.swift"
						},
						"2": {
							"name": "invalid.illegal.distinct-labels-not-allowed.swift"
						},
						"5": {
							"name": "variable.parameter.function.swift"
						},
						"7": {
							"name": "punctuation.separator.argument-label.swift"
						}
					},
					"patterns": [
						{
							"include": "#declarations-available-types"
						}
					]
				},
				{
					"begin": "(((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*\\k<q>))\\s*(:)",
					"end": "(?=[,)\\]])",
					"beginCaptures": {
						"1": {
							"name": "entity.name.function.swift"
						},
						"2": {
							"name": "variable.parameter.function.swift"
						},
						"4": {
							"name": "punctuation.separator.argument-label.swift"
						}
					},
					"patterns": [
						{
							"include": "#declarations-available-types"
						}
					]
				},
				{
					"comment": "an element without a label (i.e. anything else)",
					"begin": "(?![,)\\]])(?=\\S)",
					"end": "(?=[,)\\]])",
					"patterns": [
						{
							"include": "#declarations-available-types"
						},
						{
							"name": "invalid.illegal.extra-colon-in-parameter-list.swift",
							"match": ":"
						}
					]
				}
			]
		},
		"declarations-type-enum-enum-case": {
			"begin": "(?x)((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*",
			"end": "(?<=\\))|(?![=(])",
			"beginCaptures": {
				"1": {
					"name": "variable.other.enummember.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-type-enum-associated-values"
				},
				{
					"include": "#declarations-type-enum-raw-value-assignment"
				}
			]
		},
		"declarations-type-enum-enum-case-clause": {
			"begin": "\\b(case)\\b\\s*",
			"end": "(?=[;}])|(?!\\G)(?!//|/\\*)(?=[^\\s,])",
			"beginCaptures": {
				"1": {
					"name": "storage.type.enum.case.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-type-enum-enum-case"
				},
				{
					"include": "#declarations-type-enum-more-cases"
				}
			]
		},
		"declarations-type-enum-more-cases": {
			"name": "meta.enum-case.more-cases",
			"begin": ",\\s*",
			"end": "(?!\\G)(?!//|/\\*)(?=[;}]|[^\\s,])",
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#declarations-type-enum-enum-case"
				},
				{
					"include": "#declarations-type-enum-more-cases"
				}
			]
		},
		"declarations-type-enum-raw-value-assignment": {
			"begin": "(=)\\s*",
			"end": "(?!\\G)",
			"beginCaptures": {
				"1": {
					"name": "keyword.operator.assignment.swift"
				}
			},
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#literals"
				}
			]
		},
		"declarations-type-identifier": {
			"begin": "((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*",
			"end": "(?!<)",
			"beginCaptures": {
				"1": {
					"name": "meta.type-name.swift",
					"patterns": [
						{
							"include": "#builtin-types"
						}
					]
				},
				"2": {
					"name": "punctuation.definition.identifier.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"begin": "(?=<)",
					"end": "(?!\\G)",
					"patterns": [
						{
							"include": "#declarations-generic-argument-clause"
						}
					]
				}
			]
		},
		"declarations-type-operators": {
			"patterns": [
				{
					"comment": "Swift 3: A & B",
					"match": "(?<![/=\\-+!*%<>&|\\^~.])(&)(?![/=\\-+!*%<>&|\\^~.])",
					"captures": {
						"1": {
							"name": "keyword.operator.type.composition.swift"
						}
					}
				},
				{
					"comment": "SE-0390: Noncopyable structs and enums",
					"match": "(?<![/=\\-+!*%<>&|\\^~.])(~)(?![/=\\-+!*%<>&|\\^~.])",
					"captures": {
						"1": {
							"name": "keyword.operator.type.requirement-suppression.swift"
						}
					}
				}
			]
		},
		"declarations-typealias": {
			"name": "meta.definition.typealias.swift",
			"begin": "\\b(typealias)\\s+((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*",
			"end": "(?!\\G)$|(?=;|//|/\\*|$)",
			"beginCaptures": {
				"1": {
					"name": "keyword.other.declaration-specifier.swift"
				},
				"2": {
					"name": "entity.name.type.typealias.swift"
				},
				"3": {
					"name": "punctuation.definition.identifier.swift"
				},
				"4": {
					"name": "punctuation.definition.identifier.swift"
				}
			},
			"patterns": [
				{
					"begin": "\\G(?=<)",
					"end": "(?!\\G)",
					"patterns": [
						{
							"include": "#declarations-generic-parameter-clause"
						}
					]
				},
				{
					"include": "#declarations-typealias-assignment"
				}
			]
		},
		"declarations-typealias-assignment": {
			"begin": "(=)\\s*",
			"end": "(?!\\G)$|(?=;|//|/\\*|$)",
			"beginCaptures": {
				"1": {
					"name": "keyword.operator.assignment.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-available-types"
				}
			]
		},
		"declarations-typed-variable-declaration": {
			"begin": "(?x)\n\\b(?:(async)\\s+)?(let|var)\\b\\s+\n(?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>)\\s*\n:",
			"end": "(?=$|[={])",
			"beginCaptures": {
				"1": {
					"name": "storage.modifier.async.swift"
				},
				"2": {
					"name": "keyword.other.declaration-specifier.swift"
				}
			},
			"patterns": [
				{
					"include": "#declarations-available-types"
				}
			]
		},
		"declarations-types-precedencegroup": {
			"patterns": [
				{
					"comment": "Precedence groups in the standard library",
					"name": "support.type.swift",
					"match": "\\b(?:BitwiseShift|Assignment|RangeFormation|Casting|Addition|NilCoalescing|Comparison|LogicalConjunction|LogicalDisjunction|Default|Ternary|Multiplication|FunctionArrow)Precedence\\b"
				}
			]
		},
		"expressions": {
			"comment": "trailing closures need to be parsed before other member references",
			"patterns": [
				{
					"include": "#expressions-without-trailing-closures-or-member-references"
				},
				{
					"include": "#expressions-trailing-closure"
				},
				{
					"include": "#member-reference"
				}
			]
		},
		"expressions-trailing-closure": {
			"patterns": [
				{
					"comment": "foo { body } -- a call with a trailing closure and no argument clause",
					"name": "meta.function-call.trailing-closure-only.swift",
					"match": "(#?(?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))(?=\\s*\\{)",
					"captures": {
						"1": {
							"name": "support.function.any-method.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						}
					}
				},
				{
					"comment": "foo: { body } -- labeled-trailing-closure (SE-0279)",
					"match": "((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*(:)(?=\\s*\\{)",
					"captures": {
						"1": {
							"name": "support.function.any-method.trailing-closure-label.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						},
						"4": {
							"name": "punctuation.separator.argument-label.swift"
						}
					}
				}
			]
		},
		"expressions-without-trailing-closures": {
			"patterns": [
				{
					"include": "#expressions-without-trailing-closures-or-member-references"
				},
				{
					"include": "#member-references"
				}
			]
		},
		"expressions-without-trailing-closures-or-member-references": {
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"include": "#code-block"
				},
				{
					"include": "#attributes"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-closure-parameter"
				},
				{
					"include": "#literals"
				},
				{
					"include": "#operators"
				},
				{
					"include": "#builtin-types"
				},
				{
					"include": "#builtin-functions"
				},
				{
					"include": "#builtin-global-functions"
				},
				{
					"include": "#builtin-properties"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-compound-name"
				},
				{
					"include": "#conditionals"
				},
				{
					"include": "#keywords"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-availability-condition"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-function-or-macro-call-expression"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-macro-expansion"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-subscript-expression"
				},
				{
					"include": "#expressions-without-trailing-closures-or-member-references-parenthesized-expression"
				},
				{
					"name": "support.variable.discard-value.swift",
					"match": "\\b_\\b"
				}
			]
		},
		"expressions-without-trailing-closures-or-member-references-availability-condition": {
			"begin": "\\B(#(?:un)?available)(\\()",
			"end": "\\)",
			"beginCaptures": {
				"1": {
					"name": "support.function.availability-condition.swift"
				},
				"2": {
					"name": "punctuation.definition.arguments.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.definition.arguments.end.swift"
				}
			},
			"patterns": [
				{
					"match": "\\s*\\b((?:iOS|macOS|OSX|watchOS|tvOS|visionOS|UIKitForMac)(?:ApplicationExtension)?)\\b(?:\\s+([0-9]+(?:\\.[0-9]+)*\\b))",
					"captures": {
						"1": {
							"name": "keyword.other.platform.os.swift"
						},
						"2": {
							"name": "constant.numeric.swift"
						}
					}
				},
				{
					"match": "(\\*)\\s*(.*?)(?=[,)])",
					"captures": {
						"1": {
							"name": "keyword.other.platform.all.swift"
						},
						"2": {
							"name": "invalid.illegal.character-not-allowed-here.swift"
						}
					}
				},
				{
					"name": "invalid.illegal.character-not-allowed-here.swift",
					"match": "[^\\s,)]+"
				}
			]
		},
		"expressions-without-trailing-closures-or-member-references-closure-parameter": {
			"name": "variable.language.closure-parameter.swift",
			"match": "\\$[0-9]+"
		},
		"expressions-without-trailing-closures-or-member-references-compound-name": {
			"comment": "a reference to a function with disambiguating argument labels, such as foo(_:), foo(bar:), etc.",
			"match": "(?x)\n((?<q1>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q1>))           # function name\n\\(\n  (\n    (\n      ((?<q2>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q2>))   # argument label\n      :                        # colon\n    )+\n  )\n\\)",
			"captures": {
				"1": {
					"name": "entity.name.function.compound-name.swift"
				},
				"2": {
					"name": "punctuation.definition.entity.swift"
				},
				"3": {
					"name": "punctuation.definition.entity.swift"
				},
				"4": {
					"patterns": [
						{
							"name": "entity.name.function.compound-name.swift",
							"match": "(?<q>`?)(?!_:)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>):",
							"captures": {
								"1": {
									"name": "punctuation.definition.entity.swift"
								},
								"2": {
									"name": "punctuation.definition.entity.swift"
								}
							}
						}
					]
				}
			}
		},
		"expressions-without-trailing-closures-or-member-references-expression-element-list": {
			"patterns": [
				{
					"include": "#comments"
				},
				{
					"comment": "an element with a label",
					"begin": "((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*(:)",
					"end": "(?=[,)\\]])",
					"beginCaptures": {
						"1": {
							"name": "support.function.any-method.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						},
						"4": {
							"name": "punctuation.separator.argument-label.swift"
						}
					},
					"patterns": [
						{
							"include": "#expressions"
						}
					]
				},
				{
					"comment": "an element without a label (i.e. anything else)",
					"begin": "(?![,)\\]])(?=\\S)",
					"end": "(?=[,)\\]])",
					"patterns": [
						{
							"include": "#expressions"
						}
					]
				}
			]
		},
		"expressions-without-trailing-closures-or-member-references-function-or-macro-call-expression": {
			"patterns": [
				{
					"comment": "foo(args) -- a call whose callee is a highlightable name",
					"name": "meta.function-call.swift",
					"begin": "(#?(?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))\\s*(\\()",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "support.function.any-method.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						},
						"4": {
							"name": "punctuation.definition.arguments.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.arguments.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#expressions-without-trailing-closures-or-member-references-expression-element-list"
						}
					]
				},
				{
					"comment": "[Int](args) -- a call whose callee is a more complicated expression",
					"name": "meta.function-call.swift",
					"begin": "(?<=[`\\])}>\\p{L}_\\p{N}\\p{M}])\\s*(\\()",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "punctuation.definition.arguments.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.arguments.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#expressions-without-trailing-closures-or-member-references-expression-element-list"
						}
					]
				}
			]
		},
		"expressions-without-trailing-closures-or-member-references-macro-expansion": {
			"name": "support.function.any-method.swift",
			"match": "(#(?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))"
		},
		"expressions-without-trailing-closures-or-member-references-parenthesized-expression": {
			"comment": "correctly matching closure expressions is too hard (depends on trailing \"in\") so we just tack on some basics to the end of parenthesized-expression",
			"begin": "\\(",
			"end": "(\\))\\s*((?:\\b(?:async|throws|rethrows)\\s)*)",
			"beginCaptures": {
				"0": {
					"name": "punctuation.section.tuple.begin.swift"
				}
			},
			"endCaptures": {
				"1": {
					"name": "punctuation.section.tuple.end.swift"
				},
				"2": {
					"patterns": [
						{
							"name": "invalid.illegal.rethrows-only-allowed-on-function-declarations.swift",
							"match": "\\brethrows\\b"
						},
						{
							"include": "#async-throws"
						}
					]
				}
			},
			"patterns": [
				{
					"include": "#expressions-without-trailing-closures-or-member-references-expression-element-list"
				}
			]
		},
		"expressions-without-trailing-closures-or-member-references-subscript-expression": {
			"name": "meta.subscript-expression.swift",
			"begin": "(?<=[`\\p{L}_\\p{N}\\p{M}])\\s*(\\[)",
			"end": "\\]",
			"beginCaptures": {
				"1": {
					"name": "punctuation.definition.arguments.begin.swift"
				}
			},
			"endCaptures": {
				"0": {
					"name": "punctuation.definition.arguments.end.swift"
				}
			},
			"patterns": [
				{
					"include": "#expressions-without-trailing-closures-or-member-references-expression-element-list"
				}
			]
		},
		"keywords": {
			"patterns": [
				{
					"name": "keyword.control.branch.swift",
					"match": "(?<!\\.)\\b(?:if|else|guard|where|switch|case|default|fallthrough)\\b"
				},
				{
					"name": "keyword.control.transfer.swift",
					"match": "(?<!\\.)\\b(?:continue|break|fallthrough|return)\\b"
				},
				{
					"name": "keyword.control.loop.swift",
					"match": "(?<!\\.)\\b(?:while|for|in|each)\\b"
				},
				{
					"name": "keyword.other.operator.type.existential.swift",
					"match": "\\bany\\b(?=\\s*`?[\\p{L}_])"
				},
				{
					"comment": "extra scopes for repeat-while snippet",
					"match": "(?<!\\.)\\b(repeat)\\b(\\s*)",
					"captures": {
						"1": {
							"name": "keyword.control.loop.swift"
						},
						"2": {
							"name": "punctuation.whitespace.trailing.repeat.swift"
						}
					}
				},
				{
					"name": "keyword.control.defer.swift",
					"match": "(?<!\\.)\\bdefer\\b"
				},
				{
					"match": "(?<!\\.)\\b(?:(await\\s+try)|(await))\\b",
					"captures": {
						"1": {
							"name": "invalid.illegal.try-must-precede-await.swift"
						},
						"2": {
							"name": "keyword.control.await.swift"
						}
					}
				},
				{
					"name": "keyword.control.exception.swift",
					"match": "(?<!\\.)\\b(?:catch|throw|try)\\b|\\btry[?!]\\B"
				},
				{
					"name": "storage.modifier.exception.swift",
					"match": "(?<!\\.)\\b(?:throws|rethrows)\\b"
				},
				{
					"comment": "extra scopes for do-catch snippet",
					"match": "(?<!\\.)\\b(do)\\b(\\s*)",
					"captures": {
						"1": {
							"name": "keyword.control.exception.swift"
						},
						"2": {
							"name": "punctuation.whitespace.trailing.do.swift"
						}
					}
				},
				{
					"match": "(?<!\\.)\\b(?:(async)\\s+)?(let|var)\\b",
					"captures": {
						"1": {
							"name": "storage.modifier.async.swift"
						},
						"2": {
							"name": "keyword.other.declaration-specifier.swift"
						}
					}
				},
				{
					"name": "keyword.other.declaration-specifier.swift",
					"match": "(?<!\\.)\\b(?:associatedtype|operator|typealias)\\b"
				},
				{
					"name": "storage.type.$1.swift",
					"match": "(?<!\\.)\\b(class|enum|extension|precedencegroup|protocol|struct|actor)\\b(?=\\s*`?[\\p{L}_])"
				},
				{
					"name": "storage.modifier.swift",
					"match": "(?<!\\.)\\b(?:inout|static|final|lazy|mutating|nonmutating|optional|indirect|required|override|dynamic|convenience|infix|prefix|postfix|distributed|nonisolated|borrowing|consuming)\\b"
				},
				{
					"name": "storage.type.function.swift",
					"match": "\\binit[?!]|\\binit\\b|(?<!\\.)\\b(?:func|deinit|subscript|didSet|get|set|willSet)\\b"
				},
				{
					"name": "keyword.other.declaration-specifier.accessibility.swift",
					"match": "(?<!\\.)\\b(?:fileprivate|private|internal|public|open|package)\\b"
				},
				{
					"comment": "matches weak, unowned, unowned(safe), unowned(unsafe)",
					"name": "keyword.other.capture-specifier.swift",
					"match": "(?<!\\.)\\bunowned\\((?:safe|unsafe)\\)|(?<!\\.)\\b(?:weak|unowned)\\b"
				},
				{
					"match": "(?<=\\.)(?:(dynamicType|self)|(Protocol|Type))\\b",
					"captures": {
						"1": {
							"name": "keyword.other.type.swift"
						},
						"2": {
							"name": "keyword.other.type.metatype.swift"
						}
					}
				},
				{
					"name": "variable.language.swift",
					"match": "(?<!\\.)\\b(?:super|self|Self)\\b"
				},
				{
					"name": "support.variable.swift",
					"match": "\\B(?:#file|#filePath|#fileID|#line|#column|#function|#dsohandle)\\b|\\b(?:__FILE__|__LINE__|__COLUMN__|__FUNCTION__|__DSO_HANDLE__)\\b"
				},
				{
					"name": "keyword.control.import.swift",
					"match": "(?<!\\.)\\bimport\\b"
				},
				{
					"comment": "SE-0366: \"consume behaves as a contextual keyword. In order to avoid interfering with existing code that calls functions named consume, the operand to consume must begin with another identifier, and must consist of an identifier or postfix expression\"",
					"name": "keyword.control.consume.swift",
					"match": "(?<!\\.)\\bconsume(?=\\s+`?[\\p{L}_])"
				},
				{
					"comment": "SE-0377: \"copy is a contextual keyword, parsed as an operator if it is immediately followed by an identifier on the same line, like the consume x operator before it\"",
					"name": "keyword.control.copy.swift",
					"match": "(?<!\\.)\\bcopy(?=\\s+`?[\\p{L}_])"
				}
			]
		},
		"literals": {
			"patterns": [
				{
					"include": "#literals-boolean"
				},
				{
					"include": "#literals-numeric"
				},
				{
					"include": "#literals-string"
				},
				{
					"name": "constant.language.nil.swift",
					"match": "\\bnil\\b"
				},
				{
					"comment": "object \"literals\" used in playgrounds",
					"name": "support.function.object-literal.swift",
					"match": "\\B#(colorLiteral|imageLiteral|fileLiteral)\\b"
				},
				{
					"name": "support.function.builtin-macro.swift",
					"match": "\\B#externalMacro\\b"
				},
				{
					"name": "support.function.key-path.swift",
					"match": "\\B#keyPath\\b"
				},
				{
					"begin": "\\B(#selector)(\\()(?:\\s*(getter|setter)\\s*(:))?",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "support.function.selector-reference.swift"
						},
						"2": {
							"name": "punctuation.definition.arguments.begin.swift"
						},
						"3": {
							"name": "support.variable.parameter.swift"
						},
						"4": {
							"name": "punctuation.separator.argument-label.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.arguments.end.swift"
						}
					},
					"patterns": [
						{
							"include": "#expressions"
						}
					]
				},
				{
					"include": "#literals-regular-expression-literal"
				}
			]
		},
		"literals-boolean": {
			"name": "constant.language.boolean.swift",
			"match": "\\b(true|false)\\b"
		},
		"literals-numeric": {
			"patterns": [
				{
					"comment": "0.1, -4_2.5, 6.022e23, 10E-5",
					"name": "constant.numeric.float.decimal.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)[0-9][0-9_]*(?=\\.[0-9]|[eE])(?:\\.[0-9][0-9_]*)?(?:[eE][-+]?[0-9][0-9_]*)?\\b(?!\\.[0-9])"
				},
				{
					"comment": "-0x1.ap2_3, 0x31p-4",
					"name": "constant.numeric.float.hexadecimal.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)(0x[0-9a-fA-F][0-9a-fA-F_]*)(?:\\.[0-9a-fA-F][0-9a-fA-F_]*)?[pP][-+]?[0-9][0-9_]*\\b(?!\\.[0-9])"
				},
				{
					"comment": "0x1p, 0x1p_2, 0x1.5pa, 0x1.1p+1f, 0x1pz",
					"name": "invalid.illegal.numeric.float.invalid-exponent.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)(0x[0-9a-fA-F][0-9a-fA-F_]*)(?:\\.[0-9a-fA-F][0-9a-fA-F_]*)?(?:[pP][-+]?\\w*)\\b(?!\\.[0-9])"
				},
				{
					"comment": "0x1.5w (note that 0x1.f may be a valid expression)",
					"name": "invalid.illegal.numeric.float.missing-exponent.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)(0x[0-9a-fA-F][0-9a-fA-F_]*)\\.[0-9][\\w.]*"
				},
				{
					"comment": "-.5, .2f (note that 1.-.5 may be a valid expression)",
					"name": "invalid.illegal.numeric.float.missing-leading-zero.swift",
					"match": "(?<=\\s|^)\\-?\\.[0-9][\\w.]*"
				},
				{
					"comment": "0b_0_1, 0x_1p+3q",
					"name": "invalid.illegal.numeric.leading-underscore.swift",
					"match": "(\\B\\-|\\b)0[box]_[0-9a-fA-F_]*(?:[pPeE][+-]?\\w+)?[\\w.]+"
				},
				{
					"comment": "tuple positional member: not really a numeric literal, but not invalid",
					"match": "(?<=[\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)[0-9]+\\b"
				},
				{
					"comment": "0b010, 0b1_0",
					"name": "constant.numeric.integer.binary.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)0b[01][01_]*\\b(?!\\.[0-9])"
				},
				{
					"comment": "0o1, 0o7_3",
					"name": "constant.numeric.integer.octal.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)0o[0-7][0-7_]*\\b(?!\\.[0-9])"
				},
				{
					"comment": "02, 3_456",
					"name": "constant.numeric.integer.decimal.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)[0-9][0-9_]*\\b(?!\\.[0-9])"
				},
				{
					"comment": "0x4, 0xF_7",
					"name": "constant.numeric.integer.hexadecimal.swift",
					"match": "(\\B\\-|\\b)(?<![\\[\\](){}\\p{L}_\\p{N}\\p{M}]\\.)0x[0-9a-fA-F][0-9a-fA-F_]*\\b(?!\\.[0-9])"
				},
				{
					"name": "invalid.illegal.numeric.other.swift",
					"match": "(\\B\\-|\\b)[0-9][\\w.]*"
				}
			]
		},
		"literals-regular-expression-literal": {
			"comment": "SE-0354 & SE-0355",
			"patterns": [
				{
					"name": "string.regexp.block.swift",
					"begin": "(#+)/\\n",
					"end": "/\\1",
					"patterns": [
						{
							"include": "#literals-regular-expression-literal-regex-guts"
						},
						{
							"include": "#literals-regular-expression-literal-line-comment"
						}
					]
				},
				{
					"comment": "Single-line regular expression literals must be matched all in one go\n in order to avoid ambiguities with operators, and to adhere to certain\n parsing rules in SE-0354/SE-0355, such as:\n - A regex literal will not be parsed if it contains an unbalanced ).\n - A regex may end with a space only if it began with an escaped space",
					"name": "string.regexp.line.swift",
					"match": "(?x)\n(((\\#+)?)/)     # (1) for captures, (2) for matching end, (3) for conditionals\n(?(3)|(?!/))   # is not a comment\n(?(3)|(?!\\s))  # does not start with a space or tab\n(\\\\\\s)? # (4) may start with an escaped space or tab\n(?<guts>\n  (?>   # no backtracking, avoids issues with negative lookbehind at end\n    (?:\n      \\\\Q\n        (?:(?!\\\\E)(?!/\\2).)*+\n        (?:\\\\E\n          # A quoted sequence may not have a closing E, in which case it extends to the end of the regex\n          | (?(3)|(?<!\\s))(?=/\\2)\n        )\n      | \\\\.\n      | \\(\\?\\#[^)]*\\)\n      | \\(\\?\n          # we only support a fixed maximum number of braces because otherwise we can't balance the number of open and close braces\n          \\{(?<g1>\\{)?+(?<g2>\\{)?+(?<g3>\\{)?+(?<g4>\\{)?+(?<g5>\\{)?+\n          .+?\n          \\}(?(<g1>)\\})(?(<g2>)\\})(?(<g3>)\\})(?(<g4>)\\})(?(<g5>)\\})\n          (?:\\[(?!\\d)\\w+\\])?\n          [X<>]?\n        \\)\n      | (?<class>\\[ (?:\\\\. | [^\\[\\]] | \\g<class>)+ \\])\n      | \\(\\g<guts>?+\\)\n      | (?:(?!/\\2)[^()\\[\\\\])+  # any character (until end)\n    )+\n  )\n)?+\n# may end with a space only if it is an extended literal or contains only a single escaped space\n(?(3)|(?(5)(?<!\\s)))\n(/\\2)     # (12)\n| \\#+/.+(\\n)",
					"captures": {
						"0": {
							"patterns": [
								{
									"include": "#literals-regular-expression-literal-regex-guts"
								}
							]
						},
						"1": {
							"name": "punctuation.definition.string.begin.regexp.swift"
						},
						"12": {
							"name": "punctuation.definition.string.end.regexp.swift"
						},
						"13": {
							"name": "invalid.illegal.returns-not-allowed.regexp"
						}
					}
				}
			]
		},
		"literals-regular-expression-literal-backreference-or-subpattern": {
			"comment": "These patterns are separated to work around issues like https://github.com/microsoft/vscode-textmate/issues/164",
			"patterns": [
				{
					"comment": "'\\g{' NamedOrNumberRef '}'",
					"match": "(?x)(\\\\g\\{) (?: ((?!\\d)\\w+) (?:([+-])(\\d+))? | ([+-]?\\d+) (?:([+-])(\\d+))? ) (\\})",
					"captures": {
						"1": {
							"name": "constant.character.escape.backslash.regexp"
						},
						"2": {
							"name": "variable.other.group-name.regexp"
						},
						"3": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"4": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"5": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"6": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"7": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"8": {
							"name": "constant.character.escape.backslash.regexp"
						}
					}
				},
				{
					"comment": "'\\g' NumberRef",
					"match": "(?x)(\\\\g) ([+-]?\\d+) (?:([+-])(\\d+))?",
					"captures": {
						"1": {
							"name": "constant.character.escape.backslash.regexp"
						},
						"2": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"3": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"4": {
							"name": "constant.numeric.integer.decimal.regexp"
						}
					}
				},
				{
					"comment": "'\\k<' NamedOrNumberRef '>'\n \"\\k'\" NamedOrNumberRef \"'\"\n '\\g<' NamedOrNumberRef '>'\n \"\\g'\" NamedOrNumberRef \"'\"",
					"match": "(?x)(\\\\[gk](<)|\\\\[gk]') (?: ((?!\\d)\\w+) (?:([+-])(\\d+))? | ([+-]?\\d+) (?:([+-])(\\d+))? ) ((?(2)>|'))",
					"captures": {
						"1": {
							"name": "constant.character.escape.backslash.regexp"
						},
						"3": {
							"name": "variable.other.group-name.regexp"
						},
						"4": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"5": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"6": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"7": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"8": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"9": {
							"name": "constant.character.escape.backslash.regexp"
						}
					}
				},
				{
					"comment": "'\\k{' NamedRef '}'",
					"match": "(?x)(\\\\k\\{) ((?!\\d)\\w+) (?:([+-])(\\d+))? (\\})",
					"captures": {
						"1": {
							"name": "constant.character.escape.backslash.regexp"
						},
						"2": {
							"name": "variable.other.group-name.regexp"
						},
						"3": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"4": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"5": {
							"name": "constant.character.escape.backslash.regexp"
						}
					}
				},
				{
					"name": "keyword.other.back-reference.regexp",
					"match": "\\\\[1-9][0-9]+"
				},
				{
					"comment": "'(?P=' NamedRef ')'",
					"match": "(?x)(\\(\\?(?:P[=>]|&)) ((?!\\d)\\w+) (?:([+-])(\\d+))? (\\))",
					"captures": {
						"1": {
							"name": "keyword.other.back-reference.regexp"
						},
						"2": {
							"name": "variable.other.group-name.regexp"
						},
						"3": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"4": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"5": {
							"name": "keyword.other.back-reference.regexp"
						}
					}
				},
				{
					"name": "keyword.other.back-reference.regexp",
					"match": "\\(\\?R\\)"
				},
				{
					"comment": "'(?' NumberRef ')'",
					"match": "(?x)(\\(\\?) ([+-]?\\d+) (?:([+-])(\\d+))? (\\))",
					"captures": {
						"1": {
							"name": "keyword.other.back-reference.regexp"
						},
						"2": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"3": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"4": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"5": {
							"name": "keyword.other.back-reference.regexp"
						}
					}
				}
			]
		},
		"literals-regular-expression-literal-backtracking-directive-or-global-matching-option": {
			"match": "(?x)\n(\\(\\*)\n(?:\n  (ACCEPT|FAIL|F|MARK(?=:)|(?=:)|COMMIT|PRUNE|SKIP|THEN)\n    (?:(:)([^)]+))?\n  | (?:(LIMIT_(?:DEPTH|HEAP|MATCH))(=)(\\d+))\n  | (\n      CRLF | CR | ANYCRLF | ANY | LF | NUL\n      | BSR_ANYCRLF | BSR_UNICODE\n      | NOTEMPTY_ATSTART | NOTEMPTY\n      | NO_AUTO_POSSESS | NO_DOTSTAR_ANCHOR\n      | NO_JIT | NO_START_OPT | UTF | UCP\n    )\n)\n(\\))",
			"captures": {
				"1": {
					"name": "keyword.control.directive.regexp"
				},
				"2": {
					"name": "keyword.control.directive.regexp"
				},
				"3": {
					"name": "keyword.control.directive.regexp"
				},
				"4": {
					"name": "variable.language.tag.regexp"
				},
				"5": {
					"name": "keyword.control.directive.regexp"
				},
				"6": {
					"name": "keyword.operator.assignment.regexp"
				},
				"7": {
					"name": "constant.numeric.integer.decimal.regexp"
				},
				"8": {
					"name": "keyword.control.directive.regexp"
				},
				"9": {
					"name": "keyword.control.directive.regexp"
				}
			}
		},
		"literals-regular-expression-literal-callout": {
			"name": "meta.callout.regexp",
			"match": "(?x)\n# PCRECallout\n(\\()(?<keyw>\\?C)\n  (?:\n    (?<num>\\d+)\n    | `(?<name>(?:[^`]|``)*)`\n    | '(?<name>(?:[^']|'')*)'\n    | \"(?<name>(?:[^\"]|\"\")*)\"\n    | \\^(?<name>(?:[^\\^]|\\^\\^)*)\\^\n    | %(?<name>(?:[^%]|%%)*)%\n    | \\#(?<name>(?:[^#]|\\#\\#)*)\\#\n    | \\$(?<name>(?:[^$]|\\$\\$)*)\\$\n    | \\{(?<name>(?:[^}]|\\}\\})*)\\}\n  )?\n(\\))\n# NamedCallout\n| (\\()(?<keyw>\\*)\n    (?<name>(?!\\d)\\w+)\n    (?:\\[(?<tag>(?!\\d)\\w+)\\])?\n    (?:\\{ [^,}]+ (?:,[^,}]+)* \\})?\n  (\\))\n# InterpolatedCallout\n| (\\()(?<keyw>\\?)\n    # we only support a fixed maximum number of braces because otherwise we can't balance the number of open and close braces\n    (\\{(?<g1>\\{)?+(?<g2>\\{)?+(?<g3>\\{)?+(?<g4>\\{)?+(?<g5>\\{)?+) .+? \\}(?(<g1>)\\})(?(<g2>)\\})(?(<g3>)\\})(?(<g4>)\\})(?(<g5>)\\})\n    (?:\\[(?<tag>(?!\\d)\\w+)\\])?\n    (?<keyw>[X<>]?)\n  (\\))",
			"captures": {
				"1": {
					"name": "punctuation.definition.group.regexp"
				},
				"2": {
					"name": "keyword.control.callout.regexp"
				},
				"3": {
					"name": "constant.numeric.integer.decimal.regexp"
				},
				"4": {
					"name": "entity.name.function.callout.regexp"
				},
				"5": {
					"name": "entity.name.function.callout.regexp"
				},
				"6": {
					"name": "entity.name.function.callout.regexp"
				},
				"7": {
					"name": "entity.name.function.callout.regexp"
				},
				"8": {
					"name": "entity.name.function.callout.regexp"
				},
				"9": {
					"name": "entity.name.function.callout.regexp"
				},
				"10": {
					"name": "entity.name.function.callout.regexp"
				},
				"11": {
					"name": "entity.name.function.callout.regexp"
				},
				"12": {
					"name": "punctuation.definition.group.regexp"
				},
				"13": {
					"name": "punctuation.definition.group.regexp"
				},
				"14": {
					"name": "keyword.control.callout.regexp"
				},
				"15": {
					"name": "entity.name.function.callout.regexp"
				},
				"16": {
					"name": "variable.language.tag-name.regexp"
				},
				"17": {
					"name": "punctuation.definition.group.regexp"
				},
				"18": {
					"name": "punctuation.definition.group.regexp"
				},
				"19": {
					"name": "keyword.control.callout.regexp"
				},
				"26": {
					"name": "variable.language.tag-name.regexp"
				},
				"27": {
					"name": "keyword.control.callout.regexp"
				},
				"28": {
					"name": "punctuation.definition.group.regexp"
				}
			}
		},
		"literals-regular-expression-literal-character-properties": {
			"name": "constant.other.character-class.set.regexp",
			"match": "(?x)\n\\\\[pP]\\{ ([\\s\\w-]+(?:=[\\s\\w-]+)?) \\}\n| (\\[:) ([\\s\\w-]+(?:=[\\s\\w-]+)?) (:\\])",
			"captures": {
				"1": {
					"name": "support.variable.character-property.regexp"
				},
				"2": {
					"name": "punctuation.definition.character-class.regexp"
				},
				"3": {
					"name": "support.variable.character-property.regexp"
				},
				"4": {
					"name": "punctuation.definition.character-class.regexp"
				}
			}
		},
		"literals-regular-expression-literal-custom-char-class": {
			"patterns": [
				{
					"name": "constant.other.character-class.set.regexp",
					"begin": "(\\[)(\\^)?",
					"end": "\\]",
					"beginCaptures": {
						"1": {
							"name": "punctuation.definition.character-class.regexp"
						},
						"2": {
							"name": "keyword.operator.negation.regexp"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.character-class.regexp"
						}
					},
					"patterns": [
						{
							"include": "#literals-regular-expression-literal-custom-char-class-members"
						}
					]
				}
			]
		},
		"literals-regular-expression-literal-custom-char-class-members": {
			"comment": "TODO: should also include atoms?",
			"patterns": [
				{
					"comment": "\\b inside a character class represents a backspace",
					"name": "constant.character.escape.backslash.regexp",
					"match": "\\\\b"
				},
				{
					"include": "#literals-regular-expression-literal-custom-char-class"
				},
				{
					"include": "#literals-regular-expression-literal-quote"
				},
				{
					"include": "#literals-regular-expression-literal-set-operators"
				},
				{
					"include": "#literals-regular-expression-literal-unicode-scalars"
				},
				{
					"include": "#literals-regular-expression-literal-character-properties"
				}
			]
		},
		"literals-regular-expression-literal-group-option-toggle": {
			"comment": "A matching option sequence may be part of an \"isolated group\" which has an implicit scope that wraps the remaining elements of the current group",
			"name": "keyword.other.option-toggle.regexp",
			"match": "(?x)\n\\(\\?\n(?:\n  \\^(?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})*\n  | (?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})+\n  | (?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})* - (?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})*\n)\n\\)"
		},
		"literals-regular-expression-literal-group-or-conditional": {
			"patterns": [
				{
					"name": "meta.group.absent.regexp",
					"begin": "(\\()(\\?~)",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "punctuation.definition.group.regexp"
						},
						"2": {
							"name": "keyword.control.conditional.absent.regexp"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.group.regexp"
						}
					},
					"patterns": [
						{
							"include": "#literals-regular-expression-literal-regex-guts"
						}
					]
				},
				{
					"name": "meta.group.conditional.regexp",
					"begin": "(?x)\n# KnownConditionalStart\n(\\() (?<cond>\\?\\()\n  (?:\n    (?<NumberRef> (?<num>[+-]?\\d+)(?:(?<op>[+-])(?<num>\\d+))? )\n    | (?<cond>R) \\g<NumberRef>?\n    | (?<cond>R&) (?<NamedRef> (?<name>(?!\\d)\\w+) (?:(?<op>[+-])(?<num>\\d+))? )\n    | (?<cond><) (?:\\g<NamedRef>|\\g<NumberRef>) (?<cond>>)\n    | (?<cond>') (?:\\g<NamedRef>|\\g<NumberRef>) (?<cond>')\n    | (?<cond>DEFINE)\n    | (?<cond>VERSION)(?<compar>>?=)(?<num>\\d+\\.\\d+)\n  )\n(?<cond>\\))\n| (\\()(?<cond>\\?)(?=\\()",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "punctuation.definition.group.regexp"
						},
						"2": {
							"name": "keyword.control.conditional.regexp"
						},
						"4": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"5": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"6": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"7": {
							"name": "keyword.control.conditional.regexp"
						},
						"8": {
							"name": "keyword.control.conditional.regexp"
						},
						"10": {
							"name": "variable.other.group-name.regexp"
						},
						"11": {
							"name": "keyword.operator.recursion-level.regexp"
						},
						"12": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"13": {
							"name": "keyword.control.conditional.regexp"
						},
						"14": {
							"name": "keyword.control.conditional.regexp"
						},
						"15": {
							"name": "keyword.control.conditional.regexp"
						},
						"16": {
							"name": "keyword.control.conditional.regexp"
						},
						"17": {
							"name": "keyword.control.conditional.regexp"
						},
						"18": {
							"name": "keyword.control.conditional.regexp"
						},
						"19": {
							"name": "keyword.operator.comparison.regexp"
						},
						"20": {
							"name": "constant.numeric.integer.decimal.regexp"
						},
						"21": {
							"name": "keyword.control.conditional.regexp"
						},
						"22": {
							"name": "punctuation.definition.group.regexp"
						},
						"23": {
							"name": "keyword.control.conditional.regexp"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.group.regexp"
						}
					},
					"patterns": [
						{
							"include": "#literals-regular-expression-literal-regex-guts"
						}
					]
				},
				{
					"name": "meta.group.regexp",
					"begin": "(?x)\n(\\()\n(\n  # BasicGroupKind\n  (\\?)\n  (?:\n    ([:|>=!*] | <[=!*])\n    # named groups\n    | P?< (?:((?!\\d)\\w+) (-))? ((?!\\d)\\w+) >\n    | ' (?:((?!\\d)\\w+) (-))? ((?!\\d)\\w+) '\n    # matching options\n    | (?:\n      \\^(?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})*\n      | (?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})+\n      | (?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})* - (?:[iJmnsUxwDPSW]|xx|y\\{[gw]\\})*\n    ):  # case without : is handled by group-option-toggle\n  )\n  # PCRE2GroupKind\n  | \\*(\n    atomic\n    |pla|positive_lookahead\n    |nla|negative_lookahead\n    |plb|positive_lookbehind\n    |nlb|negative_lookbehind\n    |napla|non_atomic_positive_lookahead\n    |naplb|non_atomic_positive_lookbehind\n    |sr|script_run\n    |asr|atomic_script_run\n  ):\n)?+",
					"end": "\\)",
					"beginCaptures": {
						"1": {
							"name": "punctuation.definition.group.regexp"
						},
						"2": {
							"name": "keyword.other.group-options.regexp"
						},
						"3": {
							"name": "punctuation.definition.group.regexp"
						},
						"4": {
							"name": "punctuation.definition.group.regexp"
						},
						"5": {
							"name": "variable.other.group-name.regexp"
						},
						"6": {
							"name": "keyword.operator.balancing-group.regexp"
						},
						"7": {
							"name": "variable.other.group-name.regexp"
						},
						"8": {
							"name": "variable.other.group-name.regexp"
						},
						"9": {
							"name": "keyword.operator.balancing-group.regexp"
						},
						"10": {
							"name": "variable.other.group-name.regexp"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.group.regexp"
						}
					},
					"patterns": [
						{
							"include": "#literals-regular-expression-literal-regex-guts"
						}
					]
				}
			]
		},
		"literals-regular-expression-literal-line-comment": {
			"name": "comment.line.regexp",
			"match": "(\\#).*$",
			"captures": {
				"1": {
					"name": "punctuation.definition.comment.regexp"
				}
			}
		},
		"literals-regular-expression-literal-quote": {
			"name": "string.quoted.other.regexp.swift",
			"begin": "\\\\Q",
			"end": "\\\\E|(\\n)",
			"beginCaptures": {
				"0": {
					"name": "constant.character.escape.backslash.regexp"
				}
			},
			"endCaptures": {
				"0": {
					"name": "constant.character.escape.backslash.regexp"
				},
				"1": {
					"name": "invalid.illegal.returns-not-allowed.regexp"
				}
			}
		},
		"literals-regular-expression-literal-regex-guts": {
			"patterns": [
				{
					"include": "#literals-regular-expression-literal-quote"
				},
				{
					"name": "comment.block.regexp",
					"begin": "\\(\\?\\#",
					"end": "\\)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.comment.begin.regexp"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.comment.end.regexp"
						}
					}
				},
				{
					"name": "meta.embedded.expression.regexp",
					"begin": "<\\{",
					"end": "\\}>",
					"beginCaptures": {
						"0": {
							"name": "punctuation.section.embedded.begin.regexp"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.section.embedded.end.regexp"
						}
					}
				},
				{
					"include": "#literals-regular-expression-literal-unicode-scalars"
				},
				{
					"include": "#literals-regular-expression-literal-character-properties"
				},
				{
					"name": "keyword.control.anchor.regexp",
					"match": "[$^]|\\\\[AbBGyYzZ]|\\\\K"
				},
				{
					"include": "#literals-regular-expression-literal-backtracking-directive-or-global-matching-option"
				},
				{
					"include": "#literals-regular-expression-literal-callout"
				},
				{
					"include": "#literals-regular-expression-literal-backreference-or-subpattern"
				},
				{
					"name": "constant.character.character-class.regexp",
					"match": "\\.|\\\\[CdDhHNORsSvVwWX]"
				},
				{
					"name": "constant.character.entity.control-character.regexp",
					"match": "\\\\c."
				},
				{
					"name": "constant.character.escape.backslash.regexp",
					"match": "\\\\[^c]"
				},
				{
					"name": "keyword.operator.or.regexp",
					"match": "\\|"
				},
				{
					"name": "keyword.operator.quantifier.regexp",
					"match": "[*+?]"
				},
				{
					"name": "keyword.operator.quantifier.regexp",
					"match": "\\{\\s*\\d+\\s*(?:,\\s*\\d*\\s*)?\\}|\\{\\s*,\\s*\\d+\\s*\\}"
				},
				{
					"include": "#literals-regular-expression-literal-custom-char-class"
				},
				{
					"include": "#literals-regular-expression-literal-group-option-toggle"
				},
				{
					"include": "#literals-regular-expression-literal-group-or-conditional"
				}
			]
		},
		"literals-regular-expression-literal-set-operators": {
			"patterns": [
				{
					"name": "keyword.operator.intersection.regexp.swift",
					"match": "&&"
				},
				{
					"name": "keyword.operator.subtraction.regexp.swift",
					"match": "--"
				},
				{
					"name": "keyword.operator.symmetric-difference.regexp.swift",
					"match": "\\~\\~"
				}
			]
		},
		"literals-regular-expression-literal-unicode-scalars": {
			"name": "constant.character.numeric.regexp",
			"match": "(?x)\n\\\\u\\{\\s*(?:[0-9a-fA-F]+\\s*)+\\}\n| \\\\u[0-9a-fA-F]{4}\n| \\\\x\\{[0-9a-fA-F]+\\}\n| \\\\x[0-9a-fA-F]{0,2}\n| \\\\U[0-9a-fA-F]{8}\n| \\\\o\\{[0-7]+\\}\n| \\\\0[0-7]{0,3}\n| \\\\N\\{(?:U\\+[0-9a-fA-F]{1,8} | [\\s\\w-]+)\\}"
		},
		"literals-string": {
			"patterns": [
				{
					"comment": "SE-0168: Multi-Line String Literals",
					"name": "string.quoted.double.block.swift",
					"begin": "\"\"\"",
					"end": "\"\"\"(#*)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.string.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.string.end.swift"
						},
						"1": {
							"name": "invalid.illegal.extra-closing-delimiter.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.content-after-opening-delimiter.swift",
							"match": "\\G.+(?=\"\"\")|\\G.+"
						},
						{
							"name": "constant.character.escape.newline.swift",
							"match": "\\\\\\s*\\n"
						},
						{
							"include": "#literals-string-string-guts"
						},
						{
							"comment": "Allow \\(\"\"\"...\"\"\") to appear inside a block string",
							"name": "invalid.illegal.content-before-closing-delimiter.swift",
							"match": "\\S((?!\\\\\\().)*(?=\"\"\")"
						}
					]
				},
				{
					"name": "string.quoted.double.block.raw.swift",
					"begin": "#\"\"\"",
					"end": "\"\"\"#(#*)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.string.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.string.end.swift"
						},
						"1": {
							"name": "invalid.illegal.extra-closing-delimiter.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.content-after-opening-delimiter.swift",
							"match": "\\G.+(?=\"\"\")|\\G.+"
						},
						{
							"name": "constant.character.escape.newline.swift",
							"match": "\\\\#\\s*\\n"
						},
						{
							"include": "#literals-string-raw-string-guts"
						},
						{
							"comment": "Allow \\(\"\"\"...\"\"\") to appear inside a block string",
							"name": "invalid.illegal.content-before-closing-delimiter.swift",
							"match": "\\S((?!\\\\#\\().)*(?=\"\"\")"
						}
					]
				},
				{
					"name": "string.quoted.double.block.raw.swift",
					"begin": "(##+)\"\"\"",
					"end": "\"\"\"\\1(#*)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.string.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.string.end.swift"
						},
						"1": {
							"name": "invalid.illegal.extra-closing-delimiter.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.content-after-opening-delimiter.swift",
							"match": "\\G.+(?=\"\"\")|\\G.+"
						}
					]
				},
				{
					"name": "string.quoted.double.single-line.swift",
					"begin": "\"",
					"end": "\"(#*)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.string.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.string.end.swift"
						},
						"1": {
							"name": "invalid.illegal.extra-closing-delimiter.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.returns-not-allowed.swift",
							"match": "\\r|\\n"
						},
						{
							"include": "#literals-string-string-guts"
						}
					]
				},
				{
					"comment": "SE-0168: raw string literals (more than one #, grammar limitations prevent us from supporting escapes)",
					"name": "string.quoted.double.single-line.raw.swift",
					"begin": "(##+)\"",
					"end": "\"\\1(#*)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.string.begin.raw.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.string.end.raw.swift"
						},
						"1": {
							"name": "invalid.illegal.extra-closing-delimiter.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.returns-not-allowed.swift",
							"match": "\\r|\\n"
						}
					]
				},
				{
					"comment": "SE-0168: raw string literals (one #, escapes supported)",
					"name": "string.quoted.double.single-line.raw.swift",
					"begin": "#\"",
					"end": "\"#(#*)",
					"beginCaptures": {
						"0": {
							"name": "punctuation.definition.string.begin.raw.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.definition.string.end.raw.swift"
						},
						"1": {
							"name": "invalid.illegal.extra-closing-delimiter.swift"
						}
					},
					"patterns": [
						{
							"name": "invalid.illegal.returns-not-allowed.swift",
							"match": "\\r|\\n"
						},
						{
							"include": "#literals-string-raw-string-guts"
						}
					]
				}
			]
		},
		"literals-string-raw-string-guts": {
			"comment": "the same as #string-guts but with # in escapes",
			"patterns": [
				{
					"name": "constant.character.escape.swift",
					"match": "\\\\#[0\\\\tnr\"']"
				},
				{
					"name": "constant.character.escape.unicode.swift",
					"match": "\\\\#u\\{[0-9a-fA-F]{1,8}\\}"
				},
				{
					"contentName": "source.swift",
					"name": "meta.embedded.line.swift",
					"begin": "\\\\#\\(",
					"end": "(\\))",
					"beginCaptures": {
						"0": {
							"name": "punctuation.section.embedded.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.section.embedded.end.swift"
						},
						"1": {
							"name": "source.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						},
						{
							"comment": "Nested parens",
							"begin": "\\(",
							"end": "\\)"
						}
					]
				},
				{
					"name": "invalid.illegal.escape-not-recognized",
					"match": "\\\\#."
				}
			]
		},
		"literals-string-string-guts": {
			"patterns": [
				{
					"name": "constant.character.escape.swift",
					"match": "\\\\[0\\\\tnr\"']"
				},
				{
					"name": "constant.character.escape.unicode.swift",
					"match": "\\\\u\\{[0-9a-fA-F]{1,8}\\}"
				},
				{
					"contentName": "source.swift",
					"name": "meta.embedded.line.swift",
					"begin": "\\\\\\(",
					"end": "(\\))",
					"beginCaptures": {
						"0": {
							"name": "punctuation.section.embedded.begin.swift"
						}
					},
					"endCaptures": {
						"0": {
							"name": "punctuation.section.embedded.end.swift"
						},
						"1": {
							"name": "source.swift"
						}
					},
					"patterns": [
						{
							"include": "$self"
						},
						{
							"comment": "Nested parens",
							"begin": "\\(",
							"end": "\\)"
						}
					]
				},
				{
					"name": "invalid.illegal.escape-not-recognized",
					"match": "\\\\."
				}
			]
		},
		"member-reference": {
			"patterns": [
				{
					"match": "(?<=\\.)((?<q>`?)[\\p{L}_][\\p{L}_\\p{N}\\p{M}]*(\\k<q>))",
					"captures": {
						"1": {
							"name": "variable.other.swift"
						},
						"2": {
							"name": "punctuation.definition.identifier.swift"
						},
						"3": {
							"name": "punctuation.definition.identifier.swift"
						}
					}
				}
			]
		},
		"operators": {
			"patterns": [
				{
					"comment": "Type casting",
					"name": "keyword.operator.type-casting.swift",
					"match": "\\b(is\\b|as([!?]\\B|\\b))"
				},
				{
					"comment": "This rule helps us speed up the matching.",
					"begin": "(?x)\n(?=\n  (?<oph>                # operator-head\n    [/=\\-+!*%<>&|^~?]\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  )\n  | \\.\n  (\n    \\g<oph>              # operator-head\n    | \\.\n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)",
					"end": "(?!\\G)",
					"patterns": [
						{
							"comment": "Prefix unary operator",
							"match": "(?x)\n\\G                    # Matching from the beginning ensures\n                    # that we start with operator-head\n(?<=^|[\\s(\\[{,;:])\n(\n  (?!(//|/\\*|\\*/))\n  (\n    [/=\\-+!*%<>&|^~?]        # operator-head\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  \n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)++\n(?![\\s)\\]},;:]|\\z)",
							"captures": {
								"0": {
									"patterns": [
										{
											"name": "keyword.operator.increment-or-decrement.swift",
											"match": "\\G(\\+\\+|\\-\\-)$"
										},
										{
											"name": "keyword.operator.arithmetic.unary.swift",
											"match": "\\G(\\+|\\-)$"
										},
										{
											"name": "keyword.operator.logical.not.swift",
											"match": "\\G!$"
										},
										{
											"name": "keyword.operator.bitwise.not.swift",
											"match": "\\G~$"
										},
										{
											"name": "keyword.operator.custom.prefix.swift",
											"match": ".+"
										}
									]
								}
							}
						},
						{
							"comment": "Postfix unary operator",
							"match": "(?x)\n\\G                    # Matching from the beginning ensures\n                    # that we start with operator-head\n(?<!^|[\\s(\\[{,;:])\n(\n  (?!(//|/\\*|\\*/))\n  (\n    [/=\\-+!*%<>&|^~?]        # operator-head\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  \n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)++\n(?=[\\s)\\]},;:]|\\z)",
							"captures": {
								"0": {
									"patterns": [
										{
											"name": "keyword.operator.increment-or-decrement.swift",
											"match": "\\G(\\+\\+|\\-\\-)$"
										},
										{
											"name": "keyword.operator.increment-or-decrement.swift",
											"match": "\\G!$"
										},
										{
											"name": "keyword.operator.custom.postfix.swift",
											"match": ".+"
										}
									]
								}
							}
						},
						{
							"comment": "Infix operator",
							"match": "(?x)\n\\G                    # Matching from the beginning ensures\n                    # that we start with operator-head\n(\n  (?!(//|/\\*|\\*/))\n  (\n    [/=\\-+!*%<>&|^~?]        # operator-head\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  \n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)++",
							"captures": {
								"0": {
									"patterns": [
										{
											"name": "keyword.operator.assignment.swift",
											"match": "\\G=$"
										},
										{
											"name": "keyword.operator.assignment.compound.swift",
											"match": "\\G(\\+|\\-|\\*|/|%|<<|>>|&|\\^|\\||&&|\\|\\|)=$"
										},
										{
											"name": "keyword.operator.arithmetic.swift",
											"match": "\\G(\\+|\\-|\\*|/)$"
										},
										{
											"name": "keyword.operator.arithmetic.overflow.swift",
											"match": "\\G&(\\+|\\-|\\*)$"
										},
										{
											"name": "keyword.operator.arithmetic.remainder.swift",
											"match": "\\G%$"
										},
										{
											"name": "keyword.operator.comparison.swift",
											"match": "\\G(==|!=|>|<|>=|<=|~=)$"
										},
										{
											"name": "keyword.operator.coalescing.swift",
											"match": "\\G\\?\\?$"
										},
										{
											"name": "keyword.operator.logical.swift",
											"match": "\\G(&&|\\|\\|)$"
										},
										{
											"name": "keyword.operator.bitwise.swift",
											"match": "\\G(&|\\||\\^|<<|>>)$"
										},
										{
											"name": "keyword.operator.bitwise.swift",
											"match": "\\G(===|!==)$"
										},
										{
											"name": "keyword.operator.ternary.swift",
											"match": "\\G\\?$"
										},
										{
											"name": "keyword.operator.custom.infix.swift",
											"match": ".+"
										}
									]
								}
							}
						},
						{
							"comment": "Dot prefix unary operator",
							"match": "(?x)\n\\G                    # Matching from the beginning ensures\n                    # that we start with operator-head\n(?<=^|[\\s(\\[{,;:])\n\\.                    # dot\n(\n  (?!(//|/\\*|\\*/))\n  (\n    \\.                # dot\n    | [/=\\-+!*%<>&|^~?]        # operator-head\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  \n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)++\n(?![\\s)\\]},;:]|\\z)",
							"captures": {
								"0": {
									"patterns": [
										{
											"name": "keyword.operator.custom.prefix.dot.swift",
											"match": ".+"
										}
									]
								}
							}
						},
						{
							"comment": "Dot postfix unary operator",
							"match": "(?x)\n\\G                    # Matching from the beginning ensures\n                    # that we start with operator-head\n(?<!^|[\\s(\\[{,;:])\n\\.                    # dot\n(\n  (?!(//|/\\*|\\*/))\n  (\n    \\.                # dot\n    | [/=\\-+!*%<>&|^~?]        # operator-head\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  \n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)++\n(?=[\\s)\\]},;:]|\\z)",
							"captures": {
								"0": {
									"patterns": [
										{
											"name": "keyword.operator.custom.postfix.dot.swift",
											"match": ".+"
										}
									]
								}
							}
						},
						{
							"comment": "Dot infix operator",
							"match": "(?x)\n\\G                    # Matching from the beginning ensures\n                    # that we start with operator-head\n\\.                    # dot\n(\n  (?!(//|/\\*|\\*/))\n  (\n    \\.                # dot\n    | [/=\\-+!*%<>&|^~?]        # operator-head\n    | [\\x{00A1}-\\x{00A7}]\n    | [\\x{00A9}\\x{00AB}]\n    | [\\x{00AC}\\x{00AE}]\n    | [\\x{00B0}-\\x{00B1}\\x{00B6}\\x{00BB}\\x{00BF}\\x{00D7}\\x{00F7}]\n    | [\\x{2016}-\\x{2017}\\x{2020}-\\x{2027}]\n    | [\\x{2030}-\\x{203E}]\n    | [\\x{2041}-\\x{2053}]\n    | [\\x{2055}-\\x{205E}]\n    | [\\x{2190}-\\x{23FF}]\n    | [\\x{2500}-\\x{2775}]\n    | [\\x{2794}-\\x{2BFF}]\n    | [\\x{2E00}-\\x{2E7F}]\n    | [\\x{3001}-\\x{3003}]\n    | [\\x{3008}-\\x{3030}]\n  \n    | [\\x{0300}-\\x{036F}]        # operator-character\n    | [\\x{1DC0}-\\x{1DFF}]\n    | [\\x{20D0}-\\x{20FF}]\n    | [\\x{FE00}-\\x{FE0F}]\n    | [\\x{FE20}-\\x{FE2F}]\n    | [\\x{E0100}-\\x{E01EF}]\n  )\n)++",
							"captures": {
								"0": {
									"patterns": [
										{
											"name": "keyword.operator.range.swift",
											"match": "\\G\\.\\.[.<]$"
										},
										{
											"name": "keyword.operator.custom.infix.dot.swift",
											"match": ".+"
										}
									]
								}
							}
						}
					]
				},
				{
					"name": "keyword.operator.ternary.swift",
					"match": ":"
				}
			]
		},
		"root": {
			"patterns": [
				{
					"include": "#compiler-control"
				},
				{
					"include": "#declarations"
				},
				{
					"include": "#expressions"
				}
			]
		}
	}
}