Spaces:
Running
Running
; | |
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); | |
} | |