This repository has been archived by the owner on Feb 26, 2024. It is now read-only.
/
serve.js
79 lines (71 loc) · 1.93 KB
/
serve.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
var path = require('path');
var url = require('url');
var closure = require('closure-util');
var nomnom = require('nomnom');
var log = closure.log;
/**
* Create a debug server for ol and Closure Library sources.
* @param {function(Error, closure.Server)} callback Callback.
* @param {boolean} loadTests whether the tests should be loaded
*/
var createServer = exports.createServer = function(callback, loadTests) {
var lib = [
'src/**/*.js'
];
if (loadTests) {
lib.push('test/**/*.test.js');
}
var manager = new closure.Manager({
closure: true, // use the bundled Closure Library
lib: lib,
ignoreRequires: 'ol'
});
manager.on('error', function(e) {
log.error('ol3-google-maps', e.message);
});
manager.on('ready', function() {
server = new closure.Server({
manager: manager,
loader: '/@loader'
});
callback(null, server);
});
};
/**
* If running this module directly start the server.
*/
if (require.main === module) {
var options = nomnom.options({
port: {
abbr: 'p',
'default': 4000,
help: 'Port for incoming connections',
metavar: 'PORT'
},
loglevel: {
abbr: 'l',
choices: ['silly', 'verbose', 'info', 'warn', 'error'],
'default': 'info',
help: 'Log level',
metavar: 'LEVEL'
}
}).parse();
/** @type {string} */
log.level = options.loglevel;
log.info('ol3-google-maps', 'Parsing dependencies...');
createServer(function(err, server) {
if (err) {
log.error('ol3-google-maps', 'Parsing failed');
log.error('ol3-google-maps', err.message);
process.exit(1);
}
server.listen(options.port, function() {
log.info('ol3-google-maps', 'Listening on http://localhost:' +
options.port + '/ (Ctrl+C to stop)');
});
server.on('error', function(err) {
log.error('ol3-google-maps', 'Server failed to start: ' + err.message);
process.exit(1);
});
});
}