1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- 'use strict';
- Object.defineProperty(exports, '__esModule', {
- value: true,
- });
- exports.Source = void 0;
- exports.isSource = isSource;
- var _devAssert = require('../jsutils/devAssert.js');
- var _inspect = require('../jsutils/inspect.js');
- var _instanceOf = require('../jsutils/instanceOf.js');
- /**
- * 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.
- */
- class Source {
- constructor(
- body,
- name = 'GraphQL request',
- locationOffset = {
- line: 1,
- column: 1,
- },
- ) {
- typeof body === 'string' ||
- (0, _devAssert.devAssert)(
- false,
- `Body must be a string. Received: ${(0, _inspect.inspect)(body)}.`,
- );
- this.body = body;
- this.name = name;
- this.locationOffset = locationOffset;
- this.locationOffset.line > 0 ||
- (0, _devAssert.devAssert)(
- false,
- 'line in locationOffset is 1-indexed and must be positive.',
- );
- this.locationOffset.column > 0 ||
- (0, _devAssert.devAssert)(
- false,
- 'column in locationOffset is 1-indexed and must be positive.',
- );
- }
- get [Symbol.toStringTag]() {
- return 'Source';
- }
- }
- /**
- * Test if the given value is a Source object.
- *
- * @internal
- */
- exports.Source = Source;
- function isSource(source) {
- return (0, _instanceOf.instanceOf)(source, Source);
- }
|