mon-entreprise/source/scripts/dottednames.js

26 lines
926 B
JavaScript
Raw Normal View History

// It is currently not possible to automatically type yaml import with
// Typescript types, so we manually watch the yaml file containing the rules,
// convert it to json and persit it on the file system so that we can access the
// list of dotted names in the Typescript types.
//
// A fututre version of typescript may support "plugin" to type files such as
// yaml.
const fs = require('fs')
const path = require('path')
2020-02-04 17:35:21 +00:00
const { readRules } = require('./rules')
2020-04-05 21:27:31 +00:00
const sourceDirPath = path.resolve(__dirname, '../rules')
// Note: we can't put the output file in the fs.watched directory
const outPath = path.resolve(__dirname, '../types/dottednames.json')
function persistJsonFileFromYaml() {
2020-02-04 17:35:21 +00:00
const rules = readRules()
const jsonString = JSON.stringify(rules, null, 2)
fs.writeFileSync(outPath, jsonString)
}
persistJsonFileFromYaml()
2020-02-04 17:35:21 +00:00
exports.watchDottedNames = () =>
fs.watch(sourceDirPath, persistJsonFileFromYaml)