You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
65 lines
1.7 KiB
65 lines
1.7 KiB
'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); |
|
}
|
|
|