1
0
mirror of https://github.com/thangisme/notes.git synced 2025-01-22 23:26:32 -05:00
notes/node_modules/stylelint/lib/getPostcssResult.js

98 lines
2.9 KiB
JavaScript
Raw Normal View History

2017-03-09 13:16:08 -05:00
/* @flow */
"use strict"
const fs = require("fs")
const lessSyntax = require("postcss-less")
const path = require("path")
const postcss = require("postcss")
const scssSyntax = require("postcss-scss")
const sugarssSyntax = require("sugarss")
const postcssProcessor = postcss()
module.exports = function (stylelint/*: stylelint$internalApi*/)/*: Promise<?Object>*/ {
const options/*: {
code?: string,
codeFilename?: string,
filePath?: string,
codeProcessors?: Array<Function>,
syntax?: stylelint$syntaxes,
customSyntax?: string
}*/ = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}
const cached = stylelint._postcssResultCache.get(options.filePath)
if (cached) return Promise.resolve(cached)
let getCode
if (options.code !== undefined) {
getCode = Promise.resolve(options.code)
} else if (options.filePath) {
getCode = readFile(options.filePath)
}
if (!getCode) {
throw new Error("code or filePath required")
}
return getCode.then(code => {
const customSyntax = stylelint._options.customSyntax
let syntax = stylelint._options.syntax
if (customSyntax) {
try {
syntax = require(customSyntax)
} catch (e) {
throw new Error(`Cannot resolve custom syntax module ${customSyntax}`)
}
} else {
const fileExtension = path.extname(options.filePath || "")
if (syntax === "scss" || !syntax && fileExtension === ".scss") {
syntax = scssSyntax
} else if (syntax === "less" || !syntax && fileExtension === ".less") {
syntax = lessSyntax
} else if (syntax === "sugarss" || !syntax && fileExtension === ".sss") {
syntax = sugarssSyntax
} else if (syntax) {
throw new Error("You must use a valid syntax option, either: scss, less or sugarss")
}
}
const postcssOptions = {}
postcssOptions.from = options.filePath
/*
* PostCSS allows for syntaxes that only contain a parser, however,
* it then expects the syntax to be set as the `parser` option rather than `syntax.
*/
if (syntax && !syntax.stringify) {
postcssOptions.parser = syntax
} else {
postcssOptions.syntax = syntax
}
const source = options.code ? options.codeFilename : options.filePath
let preProcessedCode = code
if (options.codeProcessors) {
options.codeProcessors.forEach(codeProcessor => {
preProcessedCode = codeProcessor(preProcessedCode, source)
})
}
return postcssProcessor.process(preProcessedCode, postcssOptions)
}).then(postcssResult => {
stylelint._postcssResultCache.set(options.filePath, postcssResult)
return postcssResult
})
}
function readFile(filePath/*: string*/)/*: Promise<string>*/ {
return new Promise((resolve, reject) => {
fs.readFile(filePath, "utf8", (err, content) => {
if (err) {
return reject(err)
}
resolve(content)
})
})
}