graphql
Version:
A Query Language and Runtime which can target any service.
53 lines (52 loc) • 1.88 kB
text/typescript
/** @category Source */
interface Location {
line: number;
column: number;
}
/**
* A representation of source input to GraphQL. The `name` and `locationOffset` parameters are
* optional, but they are useful for clients who store GraphQL documents in source files.
* For example, if the GraphQL input starts at line 40 in a file named `Foo.graphql`, it might
* be useful for `name` to be `"Foo.graphql"` and location to be `{ line: 40, column: 1 }`.
* The `line` and `column` properties in `locationOffset` are 1-indexed.
*/
export declare class Source {
/** The GraphQL source text. */
body: string;
/** Name used in diagnostics for this source, such as a file path or request name. */
name: string;
/** One-indexed line and column where this source begins. */
locationOffset: Location;
/**
* Creates a Source instance.
* @param body - The GraphQL source text.
* @param name - Name used in diagnostics for this source.
* @param locationOffset - One-indexed line and column where this source begins.
* @example
* ```ts
* import { Source } from 'graphql/language';
*
* const source = new Source('type Query { greeting: String }', 'schema.graphql', {
* line: 10,
* column: 1,
* });
*
* source.body; // => 'type Query { greeting: String }'
* source.name; // => 'schema.graphql'
* source.locationOffset; // => { line: 10, column: 1 }
* ```
*/
constructor(body: string, name?: string, locationOffset?: Location);
/**
* Returns the value used by `Object.prototype.toString`.
* @returns The built-in string tag for this object.
*/
get [Symbol.toStringTag](): string;
}
/**
* Test if the given value is a Source object.
*
* @internal
*/
export declare function isSource(source: unknown): source is Source;
export {};