马宇豪
2024-07-16 f591c27b57e2418c9495bc02ae8cfff84d35bc18
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
import {RawSourceMap} from 'source-map-js';
 
import {Options, StringOptions} from './options';
 
/**
 * The result of compiling Sass to CSS. Returned by [[compile]],
 * [[compileAsync]], [[compileString]], and [[compileStringAsync]].
 *
 * @category Compile
 */
export interface CompileResult {
  /**
   * The generated CSS.
   *
   * Note that this *never* includes a `sourceMapUrl` comment—it's up to the
   * caller to determine where to save the source map and how to link to it from
   * the stylesheet.
   */
  css: string;
 
  /**
   * The canonical URLs of all the stylesheets that were loaded during the
   * Sass compilation. The order of these URLs is not guaranteed.
   */
  loadedUrls: URL[];
 
  /**
   * The object representation of the source map that maps locations in the
   * generated CSS back to locations in the Sass source code.
   *
   * This typically uses absolute `file:` URLs to refer to Sass files, although
   * this can be controlled by having a custom [[Importer]] return
   * [[ImporterResult.sourceMapUrl]].
   *
   * This is set if and only if [[Options.sourceMap]] is `true`.
   */
  sourceMap?: RawSourceMap;
}
 
/**
 * Synchronously compiles the Sass file at `path` to CSS. If it succeeds it
 * returns a [[CompileResult]], and if it fails it throws an [[Exception]].
 *
 * This only allows synchronous [[Importer]]s and [[CustomFunction]]s.
 *
 * @example
 *
 * ```js
 * const sass = require('sass');
 *
 * const result = sass.compile("style.scss");
 * console.log(result.css);
 * ```
 *
 * @category Compile
 * @compatibility dart: "1.45.0", node: false
 */
export function compile(path: string, options?: Options<'sync'>): CompileResult;
 
/**
 * Asynchronously compiles the Sass file at `path` to CSS. Returns a promise
 * that resolves with a [[CompileResult]] if it succeeds and rejects with an
 * [[Exception]] if it fails.
 *
 * This only allows synchronous or asynchronous [[Importer]]s and
 * [[CustomFunction]]s.
 *
 * **Heads up!** When using Dart Sass, **[[compile]] is almost twice as fast as
 * [[compileAsync]]**, due to the overhead of making the entire evaluation
 * process asynchronous.
 *
 * @example
 *
 * ```js
 * const sass = require('sass');
 *
 * const result = await sass.compileAsync("style.scss");
 * console.log(result.css);
 * ```
 *
 * @category Compile
 * @compatibility dart: "1.45.0", node: false
 */
export function compileAsync(
  path: string,
  options?: Options<'async'>
): Promise<CompileResult>;
 
/**
 * Synchronously compiles a stylesheet whose contents is `source` to CSS. If it
 * succeeds it returns a [[CompileResult]], and if it fails it throws an
 * [[Exception]].
 *
 * This only allows synchronous [[Importer]]s and [[CustomFunction]]s.
 *
 * @example
 *
 * ```js
 * const sass = require('sass');
 *
 * const result = sass.compileString(`
 * h1 {
 *   font-size: 40px;
 *   code {
 *     font-face: Roboto Mono;
 *   }
 * }`);
 * console.log(result.css);
 * ```
 *
 * @category Compile
 * @compatibility dart: "1.45.0", node: false
 */
export function compileString(
  source: string,
  options?: StringOptions<'sync'>
): CompileResult;
 
/**
 * Asynchronously compiles a stylesheet whose contents is `source` to CSS.
 * Returns a promise that resolves with a [[CompileResult]] if it succeeds and
 * rejects with an [[Exception]] if it fails.
 *
 * This only allows synchronous or asynchronous [[Importer]]s and
 * [[CustomFunction]]s.
 *
 * **Heads up!** When using Dart Sass, **[[compile]] is almost twice as fast as
 * [[compileAsync]]**, due to the overhead of making the entire evaluation
 * process asynchronous.
 *
 * @example
 *
 * ```js
 * const sass = require('sass');
 *
 * const result = await sass.compileStringAsync(`
 * h1 {
 *   font-size: 40px;
 *   code {
 *     font-face: Roboto Mono;
 *   }
 * }`);
 * console.log(result.css);
 * ```
 *
 * @category Compile
 * @compatibility dart: "1.45.0", node: false
 */
export function compileStringAsync(
  source: string,
  options?: StringOptions<'async'>
): Promise<CompileResult>;