Opinionated defines
This commit is contained in:
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "ol",
|
"name": "ol",
|
||||||
"version": "3.21.0-beta.8",
|
"version": "3.21.0-beta.10",
|
||||||
"description": "OpenLayers",
|
"description": "OpenLayers",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"module": "index.js",
|
"module": "index.js",
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# `ol`
|
# `ol`
|
||||||
|
|
||||||
[OpenLayers](https://openlayers.org/) for CommonJS module loaders.
|
[OpenLayers](https://openlayers.org/) for module loaders.
|
||||||
|
|
||||||
**Note: This is still a work in progress. Not yet ready for production.**
|
**Note: This is still a work in progress. Not yet ready for production.**
|
||||||
|
|
||||||
@@ -18,7 +18,7 @@ import View from 'ol/View';
|
|||||||
import TileLayer from 'ol/layer/Tile';
|
import TileLayer from 'ol/layer/Tile';
|
||||||
import OSM from 'ol/source/OSM';
|
import OSM from 'ol/source/OSM';
|
||||||
|
|
||||||
var map = new OLMap({
|
var map = new Map({
|
||||||
target: 'map',
|
target: 'map',
|
||||||
layers: [
|
layers: [
|
||||||
new TileLayer({
|
new TileLayer({
|
||||||
|
|||||||
@@ -1,5 +1,9 @@
|
|||||||
const pkg = require('../package.json');
|
const pkg = require('../package.json');
|
||||||
const defineLookup = require('../build/defines.json');
|
|
||||||
|
const defines = {
|
||||||
|
'ol.DEBUG': false,
|
||||||
|
'ol.ENABLE_WEBGL': false
|
||||||
|
};
|
||||||
|
|
||||||
function rename(name) {
|
function rename(name) {
|
||||||
const parts = name.split('.');
|
const parts = name.split('.');
|
||||||
@@ -69,26 +73,6 @@ function getGoogExpressionStatement(identifier) {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
const defineStatement = {
|
|
||||||
type: 'ExpressionStatement',
|
|
||||||
expression: {
|
|
||||||
type: 'AssignmentExpression',
|
|
||||||
left: {
|
|
||||||
type: 'MemberExpression',
|
|
||||||
object: {
|
|
||||||
type: 'Identifier',
|
|
||||||
name: 'ol'
|
|
||||||
},
|
|
||||||
property: {
|
|
||||||
type: 'Identifier'
|
|
||||||
}
|
|
||||||
},
|
|
||||||
right: {
|
|
||||||
type: 'Literal'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const defineMemberExpression = {
|
const defineMemberExpression = {
|
||||||
type: 'MemberExpression',
|
type: 'MemberExpression',
|
||||||
object: {
|
object: {
|
||||||
@@ -131,37 +115,16 @@ module.exports = function(info, api) {
|
|||||||
|
|
||||||
const replacements = {};
|
const replacements = {};
|
||||||
|
|
||||||
// replace assignments defines (e.g. ol.FOO = true -> window.OL_FOO = true)
|
// replace all uses of defines
|
||||||
root.find(j.ExpressionStatement, defineStatement)
|
|
||||||
.filter(path => {
|
|
||||||
const expression = path.value.expression;
|
|
||||||
const defineName = `${expression.left.object.name}.${expression.left.property.name}`;
|
|
||||||
return defineName in defineLookup;
|
|
||||||
})
|
|
||||||
.replaceWith(path => {
|
|
||||||
const expression = path.value.expression;
|
|
||||||
const defineName = `${expression.left.object.name}.${expression.left.property.name}`;
|
|
||||||
const comments = path.value.comments;
|
|
||||||
const statement = j.expressionStatement(
|
|
||||||
j.assignmentExpression('=',
|
|
||||||
j.memberExpression(j.identifier('window'), j.identifier(renameDefine(defineName))),
|
|
||||||
j.literal(expression.right.value)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
statement.comments = comments;
|
|
||||||
return statement;
|
|
||||||
});
|
|
||||||
|
|
||||||
// replace all uses of defines with renamed define
|
|
||||||
root.find(j.MemberExpression, defineMemberExpression)
|
root.find(j.MemberExpression, defineMemberExpression)
|
||||||
.filter(path => {
|
.filter(path => {
|
||||||
const node = path.value;
|
const node = path.value;
|
||||||
const defineName = `${node.object.name}.${node.property.name}`;
|
const name = `${node.object.name}.${node.property.name}`;
|
||||||
return defineName in defineLookup;
|
return (name in defines) && path.parentPath.value.type !== 'AssignmentExpression';
|
||||||
})
|
})
|
||||||
.replaceWith(path => {
|
.replaceWith(path => {
|
||||||
const defineName = `${path.value.object.name}.${path.value.property.name}`;
|
const name = `${path.value.object.name}.${path.value.property.name}`;
|
||||||
return j.memberExpression(j.identifier('window'), j.identifier(renameDefine(defineName)));
|
return j.literal(defines[name]);
|
||||||
});
|
});
|
||||||
|
|
||||||
// replace goog.provide()
|
// replace goog.provide()
|
||||||
|
|||||||
Reference in New Issue
Block a user