group jison loader and transformer
This commit is contained in:
parent
d040883286
commit
9c48703fb1
|
@ -4,7 +4,7 @@ module.exports = {
|
||||||
testEnvironment: 'jsdom',
|
testEnvironment: 'jsdom',
|
||||||
transform: {
|
transform: {
|
||||||
'^.+\\.jsx?$': ['babel-jest', { rootMode: 'upward' }],
|
'^.+\\.jsx?$': ['babel-jest', { rootMode: 'upward' }],
|
||||||
'^.+\\.jison$': path.resolve(__dirname, './jisonTransformer.js'),
|
'^.+\\.jison$': [path.resolve(__dirname, './jison/transformer.js'), { 'token-stack': true }],
|
||||||
},
|
},
|
||||||
transformIgnorePatterns: ['/node_modules/(?!dagre-d3-renderer/lib).*\\.js'],
|
transformIgnorePatterns: ['/node_modules/(?!dagre-d3-renderer/lib).*\\.js'],
|
||||||
moduleNameMapper: {
|
moduleNameMapper: {
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
const { Generator } = require('jison');
|
||||||
|
const { validate } = require('schema-utils');
|
||||||
|
const schema = require('./parser-options-schema.json');
|
||||||
|
|
||||||
|
module.exports = function jisonLoader(source) {
|
||||||
|
const options = this.getOptions();
|
||||||
|
validate(schema, options, {
|
||||||
|
name: 'Jison Loader',
|
||||||
|
baseDataPath: 'options',
|
||||||
|
});
|
||||||
|
return new Generator(source, options).generate();
|
||||||
|
};
|
|
@ -0,0 +1,13 @@
|
||||||
|
{
|
||||||
|
"title": "Jison Parser options",
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"token-stack": {
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"debug": {
|
||||||
|
"type": "boolean"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false
|
||||||
|
}
|
|
@ -0,0 +1,7 @@
|
||||||
|
const { Generator } = require('jison');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
process(sourceText, sourcePath, options) {
|
||||||
|
return new Generator(sourceText, options.transformerConfig).generate();
|
||||||
|
},
|
||||||
|
};
|
|
@ -1,5 +0,0 @@
|
||||||
const { Generator } = require('jison');
|
|
||||||
|
|
||||||
module.exports = function jisonLoader(source) {
|
|
||||||
return new Generator(source, this.getOptions()).generate();
|
|
||||||
};
|
|
|
@ -1,9 +0,0 @@
|
||||||
const { Generator } = require('jison');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
process(source, filename, config, transformOptions) {
|
|
||||||
return new Generator(source, {
|
|
||||||
'token-stack': true,
|
|
||||||
}).generate();
|
|
||||||
},
|
|
||||||
};
|
|
|
@ -3,7 +3,7 @@ import path from 'path';
|
||||||
const jisonRule = {
|
const jisonRule = {
|
||||||
test: /\.jison$/,
|
test: /\.jison$/,
|
||||||
use: {
|
use: {
|
||||||
loader: path.resolve(__dirname, './jisonLoader'),
|
loader: path.resolve(__dirname, './jison/loader'),
|
||||||
options: {
|
options: {
|
||||||
'token-stack': true,
|
'token-stack': true,
|
||||||
},
|
},
|
||||||
|
|
|
@ -11,7 +11,7 @@ const jsRule = {
|
||||||
const jisonRule = {
|
const jisonRule = {
|
||||||
test: /\.jison$/,
|
test: /\.jison$/,
|
||||||
use: {
|
use: {
|
||||||
loader: path.resolve(__dirname, './jisonLoader'),
|
loader: path.resolve(__dirname, './jison/loader'),
|
||||||
options: {
|
options: {
|
||||||
'token-stack': true,
|
'token-stack': true,
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue