How to use the parser-ts.char.char function in parser-ts

To help you get started, we’ve selected a few parser-ts examples, based on popular ways it is used in public projects.

Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.

github gcanti / fp-ts-codegen / src / haskell.ts View on Github external
const identifierFirstLetter = P.sat(c => !isDigit(c) && !isPunctuation(c))

const identifierBody = P.sat(c => !isPunctuation(c))

/**
 * @since 0.4.0
 */
export const identifier: P.Parser = P.expected(
  S.fold([identifierFirstLetter, C.many(identifierBody)]),
  'an identifier'
)

const leftParens: P.Parser = S.fold([C.char('('), S.spaces])

const rightParens: P.Parser = S.fold([S.spaces, C.char(')')])

const withParens = <a>(parser: P.Parser): P.Parser =&gt; {
  return pipe(
    leftParens,
    P.apSecond(parser),
    P.apFirst(rightParens)
  )
}

const unparametrizedRef: P.Parser = pipe(
  identifier,
  P.map(name =&gt; M.ref(name))
)

/**
 * @since 0.4.0</a>
github gcanti / fp-ts-codegen / src / haskell.ts View on Github external
P.map(types =&gt; M.constructor(name, types.map(type =&gt; M.member(type))))
        )
      )
    )
  )
)

/**
 * @since 0.4.0
 */
export const constructor: P.Parser = pipe(
  recordConstructor,
  P.alt(() =&gt; positionalConstructor)
)

const equal = S.fold([S.spaces, C.char('='), S.spaces])

const unconstrainedParameterDeclaration: P.Parser = pipe(
  identifier,
  P.map(name =&gt; M.parameterDeclaration(name))
)

const constrainedParameterDeclaration: P.Parser = pipe(
  S.fold([C.char('('), S.spaces]),
  P.apSecond(
    pipe(
      pair,
      P.map(({ name, type }) =&gt; M.parameterDeclaration(name, some(type))),
      P.apFirst(S.fold([S.spaces, C.char(')')]))
    )
  )
)
github gcanti / fp-ts-codegen / src / haskell.ts View on Github external
export const ref: P.Parser = pipe(
  identifier,
  P.chain(name =&gt;
    pipe(
      S.spaces,
      P.apSecond(
        pipe(
          types,
          P.map(parameters =&gt; M.ref(name, parameters))
        )
      )
    )
  )
)

const comma = S.fold([S.spaces, C.char(','), S.spaces])

/**
 * @since 0.4.0
 */
export const tuple: P.Parser = P.expected(
  pipe(
    leftParens,
    P.chain(() =&gt;
      pipe(
        P.sepBy(comma, type),
        P.map(types =&gt; {
          switch (types.length) {
            case 0:
              return M.unit
            case 1:
              return types[0]
github gcanti / fp-ts-codegen / src / haskell.ts View on Github external
pair,
      P.map(({ name, type }) =&gt; M.parameterDeclaration(name, some(type))),
      P.apFirst(S.fold([S.spaces, C.char(')')]))
    )
  )
)

export const parameterDeclaration = P.expected(
  pipe(
    unconstrainedParameterDeclaration,
    P.alt(() =&gt; constrainedParameterDeclaration)
  ),
  'a parameter'
)

const pipeParser = S.fold([S.spaces, C.char('|'), S.spaces])

/**
 * @since 0.4.0
 */
export const data: P.Parser = P.expected(
  pipe(
    S.string('data'),
    P.chain(() =&gt;
      pipe(
        S.spaces,
        P.apSecond(
          pipe(
            identifier,
            P.chain(name =&gt;
              pipe(
                S.spaces,
github gcanti / fp-ts-codegen / src / haskell.ts View on Github external
)
)

const pair: P.Parser = pipe(
  identifier,
  P.chain(name =&gt;
    pipe(
      S.fold([S.spaces, S.string('::'), S.spaces]),
      P.apSecond(type),
      P.map(type =&gt; ({ name, type }))
    )
  )
)

const pairs: P.Parser&gt; = pipe(
  S.fold([C.char('{'), S.spaces]),
  P.apSecond(P.sepBy(comma, pair)),
  P.apFirst(S.fold([S.spaces, C.char('}')]))
)

const recordConstructor: P.Parser = pipe(
  identifier,
  P.chain(name =&gt;
    pipe(
      S.spaces,
      P.apSecond(
        pipe(
          pairs,
          P.map(pairs =&gt; M.constructor(name, pairs.map(({ name, type }) =&gt; M.member(type, some(name)))))
        )
      )
    )
github gcanti / fp-ts-codegen / src / haskell.ts View on Github external
const pair: P.Parser = pipe(
  identifier,
  P.chain(name =&gt;
    pipe(
      S.fold([S.spaces, S.string('::'), S.spaces]),
      P.apSecond(type),
      P.map(type =&gt; ({ name, type }))
    )
  )
)

const pairs: P.Parser&gt; = pipe(
  S.fold([C.char('{'), S.spaces]),
  P.apSecond(P.sepBy(comma, pair)),
  P.apFirst(S.fold([S.spaces, C.char('}')]))
)

const recordConstructor: P.Parser = pipe(
  identifier,
  P.chain(name =&gt;
    pipe(
      S.spaces,
      P.apSecond(
        pipe(
          pairs,
          P.map(pairs =&gt; M.constructor(name, pairs.map(({ name, type }) =&gt; M.member(type, some(name)))))
        )
      )
    )
  )
)