fileTypes:

firstLineMatch: -[*]-( Mode:)? C -[*]- foldingStartMarker: “(?x)n\

\t\t /\\*\\*(?!\\*)\n\
\t\t|^(?![^{]*?//|[^{]*?/\\*(?!.*?\\*/.*?\\{)).*?\\{\\s*($|//|/\\*(?!.*?\\*/.*\\S))\n\
\t"

foldingStopMarker: (?<!*)**/|^s*} keyEquivalent: ^~C name: C patterns:

repository:

access: 
  match: \.[a-zA-Z_][a-zA-Z_0-9]*\b(?!\s*\()
  name: variable.other.dot-access.c
block: 
  begin: \{
  end: \}
  name: meta.block.c
  patterns: 
  - include: "#block_innards"
block_innards: 
  patterns: 
  - include: "#preprocessor-rule-enabled-block"
  - include: "#preprocessor-rule-disabled-block"
  - include: "#preprocessor-rule-other-block"
  - include: "#sizeof"
  - include: "#access"
  - captures: 
      "1": 
        name: punctuation.whitespace.support.function.leading.c
      "2": 
        name: support.function.C99.c
    match: (\s*)\b(hypot(f|l)?|s(scanf|ystem|nprintf|ca(nf|lb(n(f|l)?|ln(f|l)?))|i(n(h(f|l)?|f|l)?|gn(al|bit))|tr(s(tr|pn)|nc(py|at|mp)|c(spn|hr|oll|py|at|mp)|to(imax|d|u(l(l)?|max)|k|f|l(d|l)?)|error|pbrk|ftime|len|rchr|xfrm)|printf|et(jmp|vbuf|locale|buf)|qrt(f|l)?|w(scanf|printf)|rand)|n(e(arbyint(f|l)?|xt(toward(f|l)?|after(f|l)?))|an(f|l)?)|c(s(in(h(f|l)?|f|l)?|qrt(f|l)?)|cos(h(f)?|f|l)?|imag(f|l)?|t(ime|an(h(f|l)?|f|l)?)|o(s(h(f|l)?|f|l)?|nj(f|l)?|pysign(f|l)?)|p(ow(f|l)?|roj(f|l)?)|e(il(f|l)?|xp(f|l)?)|l(o(ck|g(f|l)?)|earerr)|a(sin(h(f|l)?|f|l)?|cos(h(f|l)?|f|l)?|tan(h(f|l)?|f|l)?|lloc|rg(f|l)?|bs(f|l)?)|real(f|l)?|brt(f|l)?)|t(ime|o(upper|lower)|an(h(f|l)?|f|l)?|runc(f|l)?|gamma(f|l)?|mp(nam|file))|i(s(space|n(ormal|an)|cntrl|inf|digit|u(nordered|pper)|p(unct|rint)|finite|w(space|c(ntrl|type)|digit|upper|p(unct|rint)|lower|al(num|pha)|graph|xdigit|blank)|l(ower|ess(equal|greater)?)|al(num|pha)|gr(eater(equal)?|aph)|xdigit|blank)|logb(f|l)?|max(div|abs))|di(v|fftime)|_Exit|unget(c|wc)|p(ow(f|l)?|ut(s|c(har)?|wc(har)?)|error|rintf)|e(rf(c(f|l)?|f|l)?|x(it|p(2(f|l)?|f|l|m1(f|l)?)?))|v(s(scanf|nprintf|canf|printf|w(scanf|printf))|printf|f(scanf|printf|w(scanf|printf))|w(scanf|printf)|a_(start|copy|end|arg))|qsort|f(s(canf|e(tpos|ek))|close|tell|open|dim(f|l)?|p(classify|ut(s|c|w(s|c))|rintf)|e(holdexcept|set(e(nv|xceptflag)|round)|clearexcept|testexcept|of|updateenv|r(aiseexcept|ror)|get(e(nv|xceptflag)|round))|flush|w(scanf|ide|printf|rite)|loor(f|l)?|abs(f|l)?|get(s|c|pos|w(s|c))|re(open|e|ad|xp(f|l)?)|m(in(f|l)?|od(f|l)?|a(f|l|x(f|l)?)?))|l(d(iv|exp(f|l)?)|o(ngjmp|cal(time|econv)|g(1(p(f|l)?|0(f|l)?)|2(f|l)?|f|l|b(f|l)?)?)|abs|l(div|abs|r(int(f|l)?|ound(f|l)?))|r(int(f|l)?|ound(f|l)?)|gamma(f|l)?)|w(scanf|c(s(s(tr|pn)|nc(py|at|mp)|c(spn|hr|oll|py|at|mp)|to(imax|d|u(l(l)?|max)|k|f|l(d|l)?|mbs)|pbrk|ftime|len|r(chr|tombs)|xfrm)|to(b|mb)|rtomb)|printf|mem(set|c(hr|py|mp)|move))|a(s(sert|ctime|in(h(f|l)?|f|l)?)|cos(h(f|l)?|f|l)?|t(o(i|f|l(l)?)|exit|an(h(f|l)?|2(f|l)?|f|l)?)|b(s|ort))|g(et(s|c(har)?|env|wc(har)?)|mtime)|r(int(f|l)?|ound(f|l)?|e(name|alloc|wind|m(ove|quo(f|l)?|ainder(f|l)?))|a(nd|ise))|b(search|towc)|m(odf(f|l)?|em(set|c(hr|py|mp)|move)|ktime|alloc|b(s(init|towcs|rtowcs)|towc|len|r(towc|len))))\b
  - captures: 
      "1": 
        name: punctuation.whitespace.function-call.leading.c
      "2": 
        name: support.function.any-method.c
      "3": 
        name: punctuation.definition.parameters.c
    match: |-
      (?x) (?: (?= \s )  (?:(?<=else|new|return) | (?<!\w)) (\s+))?
                              (\b 
                                      (?!(while|for|do|if|else|switch|catch|enumerate|return|r?iterate)\s*\()(?:(?!NS)[A-Za-z_][A-Za-z0-9_]*+\b | :: )++                  # actual name
                              )
                               \s*(\()
    name: meta.function-call.c
  - captures: 
      "1": 
        name: variable.other.c
      "2": 
        name: punctuation.definition.parameters.c
    match: |-
      (?x)
                                      (?x)
                              (?:  
                                   (?: (?= \s )           (?<!else|new|return) (?<=\w)\s+      #  or word + space before name
                                   )
                              )
                              (
                                      (?: [A-Za-z_][A-Za-z0-9_]*+ | :: )++    |              # actual name
                                      (?: (?<=operator) (?: [-*&<>=+!]+ | \(\) | \[\] ) )?  # if it is a C++ operator
                              )
                               \s*(\()
    name: meta.initialization.c
  - include: "#block"
  - include: $base
comments: 
  patterns: 
  - captures: 
      "1": 
        name: meta.toc-list.banner.block.c
    match: ^/\* =(\s*.*?)\s*= \*/$\n?
    name: comment.block.c
  - begin: /\*
    captures: 
      "0": 
        name: punctuation.definition.comment.c
    end: \*/
    name: comment.block.c
  - match: \*/.*\n
    name: invalid.illegal.stray-comment-end.c
  - captures: 
      "1": 
        name: meta.toc-list.banner.line.c
    match: ^// =(\s*.*?)\s*=\s*$\n?
    name: comment.line.banner.c++
  - begin: //
    beginCaptures: 
      "0": 
        name: punctuation.definition.comment.c
    end: $\n?
    name: comment.line.double-slash.c++
    patterns: 
    - match: (?>\\\s*\n)
      name: punctuation.separator.continuation.c++
disabled: 
  begin: ^\s*#\s*if(n?def)?\b.*$
  comment: eat nested preprocessor if(def)s
  end: ^\s*#\s*endif\b.*$
  patterns: 
  - include: "#disabled"
  - include: "#pragma-mark"
parens: 
  begin: \(
  end: \)
  name: meta.parens.c
  patterns: 
  - include: $base
pragma-mark: 
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.pragma.c
    "3": 
      name: meta.toc-list.pragma-mark.c
  match: ^\s*(#\s*(pragma\s+mark)\s+(.*))
  name: meta.section
preprocessor-rule-disabled: 
  begin: ^\s*(#(if)\s+(0)\b).*
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.if.c
    "3": 
      name: constant.numeric.preprocessor.c
  end: ^\s*(#\s*(endif)\b)
  patterns: 
  - begin: ^\s*(#\s*(else)\b)
    captures: 
      "1": 
        name: meta.preprocessor.c
      "2": 
        name: keyword.control.import.else.c
    end: (?=^\s*#\s*endif\b.*$)
    patterns: 
    - include: $base
  - begin: ""
    end: (?=^\s*#\s*(else|endif)\b.*$)
    name: comment.block.preprocessor.if-branch
    patterns: 
    - include: "#disabled"
    - include: "#pragma-mark"
preprocessor-rule-disabled-block: 
  begin: ^\s*(#(if)\s+(0)\b).*
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.if.c
    "3": 
      name: constant.numeric.preprocessor.c
  end: ^\s*(#\s*(endif)\b)
  patterns: 
  - begin: ^\s*(#\s*(else)\b)
    captures: 
      "1": 
        name: meta.preprocessor.c
      "2": 
        name: keyword.control.import.else.c
    end: (?=^\s*#\s*endif\b.*$)
    patterns: 
    - include: "#block_innards"
  - begin: ""
    end: (?=^\s*#\s*(else|endif)\b.*$)
    name: comment.block.preprocessor.if-branch.in-block
    patterns: 
    - include: "#disabled"
    - include: "#pragma-mark"
preprocessor-rule-enabled: 
  begin: ^\s*(#(if)\s+(0*1)\b)
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.if.c
    "3": 
      name: constant.numeric.preprocessor.c
  end: ^\s*(#\s*(endif)\b)
  patterns: 
  - begin: ^\s*(#\s*(else)\b).*
    captures: 
      "1": 
        name: meta.preprocessor.c
      "2": 
        name: keyword.control.import.else.c
    contentName: comment.block.preprocessor.else-branch
    end: (?=^\s*#\s*endif\b.*$)
    patterns: 
    - include: "#disabled"
    - include: "#pragma-mark"
  - begin: ""
    end: (?=^\s*#\s*(else|endif)\b.*$)
    patterns: 
    - include: $base
preprocessor-rule-enabled-block: 
  begin: ^\s*(#(if)\s+(0*1)\b)
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.if.c
    "3": 
      name: constant.numeric.preprocessor.c
  end: ^\s*(#\s*(endif)\b)
  patterns: 
  - begin: ^\s*(#\s*(else)\b).*
    captures: 
      "1": 
        name: meta.preprocessor.c
      "2": 
        name: keyword.control.import.else.c
    contentName: comment.block.preprocessor.else-branch.in-block
    end: (?=^\s*#\s*endif\b.*$)
    patterns: 
    - include: "#disabled"
    - include: "#pragma-mark"
  - begin: ""
    end: (?=^\s*#\s*(else|endif)\b.*$)
    patterns: 
    - include: "#block_innards"
preprocessor-rule-other: 
  begin: ^\s*(#\s*(if(n?def)?)\b.*?(?:(?=(?://|/\*))|$))
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.c
  end: ^\s*(#\s*(endif)\b).*$
  patterns: 
  - include: $base
preprocessor-rule-other-block: 
  begin: ^\s*(#\s*(if(n?def)?)\b.*?(?:(?=(?://|/\*))|$))
  captures: 
    "1": 
      name: meta.preprocessor.c
    "2": 
      name: keyword.control.import.c
  end: ^\s*(#\s*(endif)\b).*$
  patterns: 
  - include: "#block_innards"
sizeof: 
  match: \b(sizeof)\b
  name: keyword.operator.sizeof.c
string_escaped_char: 
  patterns: 
  - match: \\(\\|[abefnprtv&apos;"?]|[0-3]\d{,2}|[4-7]\d?|x[a-fA-F0-9]{,2})
    name: constant.character.escape.c
  - match: \\.
    name: invalid.illegal.unknown-escape.c
string_placeholder: 
  patterns: 
  - match: "(?x)%\n    \t\t\t\t\t\t(\\d+\\$)?                             # field (argument #)\n    \t\t\t\t\t\t[#0\\- +&apos;]*                           # flags\n    \t\t\t\t\t\t[,;:_]?                              # separator character (AltiVec)\n    \t\t\t\t\t\t((-?\\d+)|\\*(-?\\d+\\$)?)?              # minimum field width\n    \t\t\t\t\t\t(\\.((-?\\d+)|\\*(-?\\d+\\$)?)?)?         # precision\n    \t\t\t\t\t\t(hh|h|ll|l|j|t|z|q|L|vh|vl|v|hv|hl)? # length modifier\n    \t\t\t\t\t\t[diouxXDOUeEfFgGaACcSspn%]           # conversion type\n    \t\t\t\t\t"
    name: constant.other.placeholder.c
  - match: "%"
    name: invalid.illegal.placeholder.c

scopeName: source.c uuid: 25066DC2-6B1D-11D9-9D5B-000D93589AF6