2022-06-08 10:36:39 +00:00
|
|
|
|
import { RangePosition } from './css-syntax-error.js'
|
|
|
|
|
import Node from './node.js'
|
|
|
|
|
|
2023-08-17 09:47:40 +00:00
|
|
|
|
declare namespace Warning {
|
|
|
|
|
export interface WarningOptions {
|
|
|
|
|
/**
|
|
|
|
|
* End position, exclusive, in CSS node string that caused the warning.
|
|
|
|
|
*/
|
|
|
|
|
end?: RangePosition
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* End index, exclusive, in CSS node string that caused the warning.
|
|
|
|
|
*/
|
|
|
|
|
endIndex?: number
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Start index, inclusive, in CSS node string that caused the warning.
|
|
|
|
|
*/
|
|
|
|
|
index?: number
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* CSS node that caused the warning.
|
|
|
|
|
*/
|
|
|
|
|
node?: Node
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Name of the plugin that created this warning. `Result#warn` fills
|
|
|
|
|
* this property automatically.
|
|
|
|
|
*/
|
|
|
|
|
plugin?: string
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Start position, inclusive, in CSS node string that caused the warning.
|
|
|
|
|
*/
|
|
|
|
|
start?: RangePosition
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Word in CSS source that caused the warning.
|
|
|
|
|
*/
|
|
|
|
|
word?: string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-use-before-define
|
|
|
|
|
export { Warning_ as default }
|
2022-06-08 10:36:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Represents a plugin’s warning. It can be created using `Node#warn`.
|
|
|
|
|
*
|
|
|
|
|
* ```js
|
|
|
|
|
* if (decl.important) {
|
|
|
|
|
* decl.warn(result, 'Avoid !important', { word: '!important' })
|
|
|
|
|
* }
|
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
declare class Warning_ {
|
2022-06-08 10:36:39 +00:00
|
|
|
|
/**
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* Column for inclusive start position in the input file with this warning’s source.
|
2022-06-08 10:36:39 +00:00
|
|
|
|
*
|
|
|
|
|
* ```js
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* warning.column //=> 6
|
2022-06-08 10:36:39 +00:00
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
column: number
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* Column for exclusive end position in the input file with this warning’s source.
|
2022-06-08 10:36:39 +00:00
|
|
|
|
*
|
|
|
|
|
* ```js
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* warning.endColumn //=> 4
|
2022-06-08 10:36:39 +00:00
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
endColumn?: number
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* Line for exclusive end position in the input file with this warning’s source.
|
2022-06-08 10:36:39 +00:00
|
|
|
|
*
|
|
|
|
|
* ```js
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* warning.endLine //=> 6
|
2022-06-08 10:36:39 +00:00
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
endLine?: number
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Line for inclusive start position in the input file with this warning’s source.
|
|
|
|
|
*
|
|
|
|
|
* ```js
|
|
|
|
|
* warning.line //=> 5
|
|
|
|
|
* ```
|
|
|
|
|
*/
|
|
|
|
|
line: number
|
|
|
|
|
|
|
|
|
|
/**
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* Contains the CSS node that caused the warning.
|
2022-06-08 10:36:39 +00:00
|
|
|
|
*
|
|
|
|
|
* ```js
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* warning.node.toString() //=> 'color: white !important'
|
2022-06-08 10:36:39 +00:00
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
node: Node
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* The name of the plugin that created this warning.
|
|
|
|
|
* When you call `Node#warn` it will fill this property automatically.
|
2022-06-08 10:36:39 +00:00
|
|
|
|
*
|
|
|
|
|
* ```js
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* warning.plugin //=> 'postcss-important'
|
2022-06-08 10:36:39 +00:00
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
plugin: string
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* The warning message.
|
2022-06-08 10:36:39 +00:00
|
|
|
|
*
|
|
|
|
|
* ```js
|
2023-08-17 09:47:40 +00:00
|
|
|
|
* warning.text //=> 'Try to avoid !important'
|
2022-06-08 10:36:39 +00:00
|
|
|
|
* ```
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
text: string
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Type to filter warnings from `Result#messages`.
|
|
|
|
|
* Always equal to `"warning"`.
|
|
|
|
|
*/
|
|
|
|
|
type: 'warning'
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param text Warning message.
|
|
|
|
|
* @param opts Warning options.
|
|
|
|
|
*/
|
2023-08-17 09:47:40 +00:00
|
|
|
|
constructor(text: string, opts?: Warning.WarningOptions)
|
2022-06-08 10:36:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns a warning position and message.
|
|
|
|
|
*
|
|
|
|
|
* ```js
|
|
|
|
|
* warning.toString() //=> 'postcss-lint:a.css:10:14: Avoid !important'
|
|
|
|
|
* ```
|
|
|
|
|
*
|
|
|
|
|
* @return Warning position and message.
|
|
|
|
|
*/
|
|
|
|
|
toString(): string
|
|
|
|
|
}
|
2023-08-17 09:47:40 +00:00
|
|
|
|
|
|
|
|
|
declare class Warning extends Warning_ {}
|
|
|
|
|
|
|
|
|
|
export = Warning
|