-
Notifications
You must be signed in to change notification settings - Fork 29
/
options.go
182 lines (160 loc) · 4.04 KB
/
options.go
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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
package libsass
import "context"
// FuncOpt enables configuration of compiler initialization
type FuncOpt func(*sass) error
// Option allows the modifying of internal compiler state
func (c *sass) Option(opts ...FuncOpt) error {
for _, opt := range opts {
err := opt(c)
if err != nil {
return err
}
}
return nil
}
// BasePath sets the internal path provided to handlers requiring
// a base path for http calls. This is useful for hosted solutions
// that need to provided absolute paths to assets.
func BasePath(basePath string) FuncOpt {
return func(c *sass) error {
c.httpPath = basePath
// FIXME: remove from context
c.ctx.HTTPPath = basePath
return nil
}
}
// BuildDir only used for spriting, how terrible!
func BuildDir(path string) FuncOpt {
return func(c *sass) error {
c.ctx.BuildDir = path
return nil
}
}
// CacheBust append timestamps to static assets to prevent caching
func CacheBust(t string) FuncOpt {
return func(c *sass) error {
if t == "ts" {
t = "timestamp"
}
c.cachebust = t
return nil
}
}
// Comments toggles whether comments should be included in the output
func Comments(b bool) FuncOpt {
return func(c *sass) error {
c.ctx.Comments = b
return nil
}
}
// FontDir specifies where to find fonts
func FontDir(path string) FuncOpt {
return func(c *sass) error {
c.ctx.FontDir = path
return nil
}
}
// HTTPPath prefixes all sprites and generated images with this uri.
// Enabling wellington to serve images when used in HTTP mode
func HTTPPath(u string) FuncOpt {
return func(c *sass) error {
c.httpPath = u
c.ctx.HTTPPath = u
return nil
}
}
// ImgBuildDir specifies the destination directory for images
func ImgBuildDir(path string) FuncOpt {
return func(c *sass) error {
c.ctx.GenImgDir = path
return nil
}
}
// ImgDir specifies where to locate images for spriting
func ImgDir(path string) FuncOpt {
return func(c *sass) error {
c.ctx.ImageDir = path
return nil
}
}
// ImportsOption specifies configuration for import resolution
func ImportsOption(imports *Imports) FuncOpt {
return func(c *sass) error {
c.ctx.Imports = imports
return nil
}
}
// IncludePaths adds additional directories to search for Sass files
func IncludePaths(includes []string) FuncOpt {
return func(c *sass) error {
c.includePaths = includes
c.ctx.IncludePaths = includes
return nil
}
}
// LineComments removes the line by line playby of the Sass compiler
func LineComments(b bool) FuncOpt {
return func(c *sass) error {
c.cmt = b
return nil
}
}
// OutputStyle controls the presentation of the CSS available
// option: nested, expanded, compact, compressed
func OutputStyle(style int) FuncOpt {
return func(c *sass) error {
c.ctx.OutputStyle = style
return nil
}
}
// Precision specifies the number of points beyond the decimal
// place is preserved during math calculations.
func Precision(prec int) FuncOpt {
return func(c *sass) error {
c.ctx.Precision = prec
return nil
}
}
// SourceMap behaves differently depending on compiler used. For
// compile, it will embed sourcemap into the source. For file
// compile, it will include a separate file with the source map.
func SourceMap(b bool, path, sourceMapRoot string) FuncOpt {
return func(c *sass) error {
c.ctx.includeMap = b
c.mappath = path
if len(sourceMapRoot) > 0 {
c.sourceMapRoot = sourceMapRoot
}
return nil
}
}
// Path specifies a file to read instead of using the provided
// io.Reader. This activates file compiling that includes line numbers
// in the resulting output.
func Path(path string) FuncOpt {
return func(c *sass) error {
c.srcFile = path
c.ctx.MainFile = path
return nil
}
}
// Payload gives access to sprite and image information for handlers
// to perform spriting functions.
func Payload(load context.Context) FuncOpt {
return func(c *sass) error {
c.ctx.Payload = load
return nil
}
}
// Syntax lists that available syntaxes for the compiler
type Syntax int
const (
SCSSSyntax Syntax = iota
SassSyntax
)
func WithSyntax(mode Syntax) FuncOpt {
return func(c *sass) error {
c.syntax = mode
return nil
}
}