Generate externs and typedefs
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -7,5 +7,6 @@
|
||||
/build/ol-all.js
|
||||
/build/proj4js-combined.js
|
||||
/build/require-all.js
|
||||
/build/src
|
||||
/examples/*.json
|
||||
/examples/*.combined.js
|
||||
|
||||
13
Makefile
13
Makefile
@@ -20,7 +20,7 @@ build: build/ol.css build/ol.js
|
||||
build/ol.css: build/ol.js
|
||||
touch $@
|
||||
|
||||
build/ol.js: $(PLOVR_JAR) $(SRC) base.json build/ol.json
|
||||
build/ol.js: $(PLOVR_JAR) $(SRC) base.json build/ol.json build/src/externs.js build/src/literals.js
|
||||
java -jar $(PLOVR_JAR) build build/ol.json >$@
|
||||
@echo $@ "uncompressed:" $$(wc -c <$@) bytes
|
||||
@echo $@ " compressed:" $$(gzip -9 -c <$@ | wc -c) bytes
|
||||
@@ -28,12 +28,20 @@ build/ol.js: $(PLOVR_JAR) $(SRC) base.json build/ol.json
|
||||
.PHONY: build-all
|
||||
build-all: build/ol-all.js
|
||||
|
||||
build/ol-all.js: $(PLOVR_JAR) $(SRC) base.json build/ol-all.json build/require-all.js
|
||||
build/ol-all.js: $(PLOVR_JAR) $(SRC) base.json build/ol-all.json build/require-all.js build/src/externs.js build/src/literals.js
|
||||
java -jar $(PLOVR_JAR) build build/ol-all.json >$@ || ( rm -f $@ ; false )
|
||||
|
||||
build/require-all.js: $(SRC)
|
||||
( echo "goog.require('goog.dom');" ; find src/ol -name \*.js | xargs grep -rh ^goog.provide | sort | uniq | sed -e 's/provide/require/g' ) >$@
|
||||
|
||||
build/src/externs.js: bin/generate-externs src/ol/literals.txt
|
||||
mkdir -p $(dir $@)
|
||||
bin/generate-externs --externs src/ol/literals.txt >$@
|
||||
|
||||
build/src/literals.js: bin/generate-externs src/ol/literals.txt
|
||||
mkdir -p $(dir $@)
|
||||
bin/generate-externs --typedef src/ol/literals.txt >$@
|
||||
|
||||
.PHONY: examples
|
||||
examples: $(subst .html,.json,$(EXAMPLES))
|
||||
|
||||
@@ -84,6 +92,7 @@ clean:
|
||||
rm -f build/ol.js
|
||||
rm -f build/ol-all.js
|
||||
rm -f build/require-all.js
|
||||
rm -f build/src/*
|
||||
rm -f examples/*.json
|
||||
rm -f examples/*.combined.js
|
||||
rm -rf build/apidoc
|
||||
|
||||
@@ -48,7 +48,10 @@
|
||||
|
||||
"mode": "ADVANCED",
|
||||
|
||||
"paths": "src",
|
||||
"paths": [
|
||||
"build/src",
|
||||
"src"
|
||||
],
|
||||
|
||||
"treat-warnings-as-errors": false
|
||||
|
||||
|
||||
101
bin/generate-externs
Executable file
101
bin/generate-externs
Executable file
@@ -0,0 +1,101 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
import fileinput
|
||||
from optparse import OptionParser
|
||||
import re
|
||||
import sys
|
||||
|
||||
|
||||
class Type(object):
|
||||
|
||||
def __init__(self, name, members=None):
|
||||
self.name = name
|
||||
self.namespace = '.'.join(self.name.split('.')[:-1]) or None
|
||||
self.members = members or {}
|
||||
|
||||
def extern(self):
|
||||
lines = []
|
||||
lines.append('/**\n')
|
||||
lines.append(' * @interface\n')
|
||||
lines.append(' */\n')
|
||||
lines.append('%s = function() {};\n' % (self.name,))
|
||||
for key in sorted(self.members.keys()):
|
||||
lines.append('\n')
|
||||
lines.append('\n')
|
||||
lines.append('/**\n')
|
||||
lines.append(' * @type {%s}\n' % (self.members[key],))
|
||||
lines.append(' */\n')
|
||||
lines.append('%s.prototype.%s;\n' % (self.name, key))
|
||||
return ''.join(lines)
|
||||
|
||||
def provide(self):
|
||||
return 'goog.provide(\'%s\');\n' % (self.name,)
|
||||
|
||||
def typedef(self):
|
||||
lines = []
|
||||
lines.append('/**\n')
|
||||
for i, key in enumerate(sorted(self.members.keys())):
|
||||
prefix = ' * @typedef {{' if i == 0 else ' * '
|
||||
suffix = '}}' if i == len(self.members) - 1 else ','
|
||||
type = self.members[key]
|
||||
if '|' in type:
|
||||
type = '(%s)' % (type,)
|
||||
lines.append('%s%s: %s%s\n' % (prefix, key, type, suffix))
|
||||
lines.append(' */\n')
|
||||
lines.append('%s;\n' % (self.name,))
|
||||
return ''.join(lines)
|
||||
|
||||
|
||||
def main(argv):
|
||||
|
||||
option_parser = OptionParser()
|
||||
option_parser.add_option('--externs', action='store_true')
|
||||
option_parser.add_option('--typedef', action='store_true')
|
||||
options, args = option_parser.parse_args(argv[1:])
|
||||
|
||||
types = []
|
||||
for arg in args:
|
||||
for line in open(arg):
|
||||
line = line.strip()
|
||||
if not line:
|
||||
continue
|
||||
m = re.match('@externtype\s*(?P<name>\S+)\Z', line)
|
||||
if m:
|
||||
name = m.group('name')
|
||||
if options.externs:
|
||||
name = re.sub('\Aol\.', 'olx.', name + 'Extern')
|
||||
if options.typedef:
|
||||
name = name + 'Literal'
|
||||
type = Type(name)
|
||||
types.append(type)
|
||||
continue
|
||||
m = re.match('(?P<key>\S+):\s+(?P<value>\S+)', line)
|
||||
if m:
|
||||
type.members[m.group('key')] = m.group('value')
|
||||
continue
|
||||
raise RuntimeError(line)
|
||||
|
||||
if options.externs:
|
||||
sys.stdout.write('/**\n')
|
||||
sys.stdout.write(' * @externs\n')
|
||||
sys.stdout.write(' */\n')
|
||||
namespaces = sorted(set(filter(None, (type.namespace for type in types))))
|
||||
for namespace in namespaces:
|
||||
sys.stdout.write('\n\n')
|
||||
sys.stdout.write('/**\n')
|
||||
sys.stdout.write(' * @type {Object}\n')
|
||||
sys.stdout.write(' */\n')
|
||||
sys.stdout.write('var %s;\n' % (namespace,))
|
||||
for type in types:
|
||||
sys.stdout.write('\n\n\n')
|
||||
sys.stdout.write(type.extern())
|
||||
|
||||
if options.typedef:
|
||||
sys.stdout.write(''.join(type.provide() for type in types))
|
||||
for type in types:
|
||||
sys.stdout.write('\n\n')
|
||||
sys.stdout.write(type.typedef())
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
sys.exit(main(sys.argv))
|
||||
@@ -13,8 +13,8 @@
|
||||
"css-output-file": "build/ol.css",
|
||||
|
||||
"externs": [
|
||||
"build/src/externs.js",
|
||||
"externs/bingmaps.js",
|
||||
"externs/ol.js",
|
||||
"externs/proj4js.js",
|
||||
"externs/tilejson.js"
|
||||
],
|
||||
|
||||
154
externs/ol.js
154
externs/ol.js
@@ -1,154 +0,0 @@
|
||||
/**
|
||||
* @externs
|
||||
*/
|
||||
|
||||
|
||||
/**
|
||||
* @type {Object}
|
||||
*/
|
||||
var olx;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @interface
|
||||
*/
|
||||
olx.MapOptionsExtern = function() {};
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.Coordinate|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.center;
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.Collection|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.controls;
|
||||
|
||||
|
||||
/**
|
||||
* @type {boolean|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.doubleClickZoom;
|
||||
|
||||
|
||||
/**
|
||||
* @type {boolean|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.dragPan;
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.Collection|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.interactions;
|
||||
|
||||
|
||||
/**
|
||||
* @type {boolean|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.keyboard;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.keyboardPanOffset;
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.Collection|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.layers;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.maxResolution;
|
||||
|
||||
|
||||
/**
|
||||
* @type {boolean|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.mouseWheelZoom;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.mouseWheelZoomDelta;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.numZoomLevels;
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.Projection|string|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.projection;
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.RendererHint|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.renderer;
|
||||
|
||||
|
||||
/**
|
||||
* @type {Array.<ol.RendererHint>|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.renderers;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.resolution;
|
||||
|
||||
|
||||
/**
|
||||
* @type {Array.<number>|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.resolutions;
|
||||
|
||||
|
||||
/**
|
||||
* @type {boolean|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.rotate;
|
||||
|
||||
|
||||
/**
|
||||
* @type {boolean|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.shiftDragZoom;
|
||||
|
||||
|
||||
/**
|
||||
* @type {ol.Projection|string|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.userProjection;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.zoom;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.zoomDelta;
|
||||
|
||||
|
||||
/**
|
||||
* @type {number|undefined}
|
||||
*/
|
||||
olx.MapOptionsExtern.prototype.zoomFactor;
|
||||
24
src/ol/literals.txt
Normal file
24
src/ol/literals.txt
Normal file
@@ -0,0 +1,24 @@
|
||||
@externtype ol.MapOptions
|
||||
center: ol.Coordinate|undefined
|
||||
controls: ol.Collection|undefined
|
||||
doubleClickZoom: boolean|undefined
|
||||
dragPan: boolean|undefined
|
||||
interactions: ol.Collection|undefined
|
||||
keyboard: boolean|undefined
|
||||
keyboardPanOffset: number|undefined
|
||||
layers: ol.Collection|undefined
|
||||
maxResolution: number|undefined
|
||||
mouseWheelZoom: boolean|undefined
|
||||
mouseWheelZoomDelta: number|undefined
|
||||
numZoomLevels: number|undefined
|
||||
projection: ol.Projection|string|undefined
|
||||
renderer: ol.RendererHint|undefined
|
||||
renderers: Array.<ol.RendererHint>|undefined
|
||||
resolution: number|undefined
|
||||
resolutions: Array.<number>|undefined
|
||||
rotate: boolean|undefined
|
||||
shiftDragZoom: boolean|undefined
|
||||
userProjection: ol.Projection|string|undefined
|
||||
zoom: number|undefined
|
||||
zoomDelta: number|undefined
|
||||
zoomFactor: number|undefined
|
||||
@@ -2,12 +2,12 @@
|
||||
// FIXME MapOptions should create a Zoom control
|
||||
|
||||
goog.provide('ol.MapOptions');
|
||||
goog.provide('ol.MapOptionsLiteral');
|
||||
goog.provide('ol.MapOptionsType');
|
||||
goog.provide('ol.RendererHint');
|
||||
|
||||
goog.require('ol.Collection');
|
||||
goog.require('ol.Constraints');
|
||||
goog.require('ol.MapOptionsLiteral');
|
||||
goog.require('ol.Projection');
|
||||
goog.require('ol.ResolutionConstraint');
|
||||
goog.require('ol.RotationConstraint');
|
||||
@@ -57,34 +57,6 @@ ol.DEFAULT_RENDERER_HINTS = [
|
||||
];
|
||||
|
||||
|
||||
/**
|
||||
* @typedef {{center: (ol.Coordinate|undefined),
|
||||
* controls: (ol.Collection|undefined),
|
||||
* doubleClickZoom: (boolean|undefined),
|
||||
* dragPan: (boolean|undefined),
|
||||
* interactions: (ol.Collection|undefined),
|
||||
* keyboard: (boolean|undefined),
|
||||
* keyboardPanOffset: (number|undefined),
|
||||
* layers: (ol.Collection|undefined),
|
||||
* maxResolution: (number|undefined),
|
||||
* mouseWheelZoom: (boolean|undefined),
|
||||
* mouseWheelZoomDelta: (number|undefined),
|
||||
* numZoomLevels: (number|undefined),
|
||||
* projection: (ol.Projection|string|undefined),
|
||||
* renderer: (ol.RendererHint|undefined),
|
||||
* renderers: (Array.<ol.RendererHint>|undefined),
|
||||
* resolution: (number|undefined),
|
||||
* resolutions: (Array.<number>|undefined),
|
||||
* rotate: (boolean|undefined),
|
||||
* shiftDragZoom: (boolean|undefined),
|
||||
* userProjection: (ol.Projection|string|undefined),
|
||||
* zoom: (number|undefined),
|
||||
* zoomDelta: (number|undefined),
|
||||
* zoomFactor: (number|undefined)}}
|
||||
*/
|
||||
ol.MapOptionsLiteral;
|
||||
|
||||
|
||||
/**
|
||||
* @typedef {{controls: ol.Collection,
|
||||
* constraints: ol.Constraints,
|
||||
|
||||
Reference in New Issue
Block a user