This app provides monitoring and information features for the common freifunk user and the technical stuff of a freifunk community.
Code base is taken from a TUM Practical Course project and added here to see if Freifunk Altdorf can use it.
https://www.freifunk-altdorf.de
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
142 lines
5.0 KiB
142 lines
5.0 KiB
'use strict'; |
|
|
|
var _crypto; |
|
|
|
function _load_crypto() { |
|
return _crypto = _interopRequireDefault(require('crypto')); |
|
} |
|
|
|
var _fs; |
|
|
|
function _load_fs() { |
|
return _fs = _interopRequireDefault(require('fs')); |
|
} |
|
|
|
var _path; |
|
|
|
function _load_path() { |
|
return _path = _interopRequireDefault(require('path')); |
|
} |
|
|
|
var _babelPresetJest; |
|
|
|
function _load_babelPresetJest() { |
|
return _babelPresetJest = _interopRequireDefault(require('babel-preset-jest')); |
|
} |
|
|
|
var _babelCore; |
|
|
|
function _load_babelCore() { |
|
return _babelCore = require('babel-core'); |
|
} |
|
|
|
var _babelPluginIstanbul; |
|
|
|
function _load_babelPluginIstanbul() { |
|
return _babelPluginIstanbul = _interopRequireDefault(require('babel-plugin-istanbul')); |
|
} |
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } |
|
|
|
/** |
|
* Copyright (c) 2014-present, Facebook, Inc. All rights reserved. |
|
* |
|
* This source code is licensed under the MIT license found in the |
|
* LICENSE file in the root directory of this source tree. |
|
* |
|
* |
|
*/ |
|
|
|
const BABELRC_FILENAME = '.babelrc'; |
|
const BABELRC_JS_FILENAME = '.babelrc.js'; |
|
const BABEL_CONFIG_KEY = 'babel'; |
|
const PACKAGE_JSON = 'package.json'; |
|
const THIS_FILE = (_fs || _load_fs()).default.readFileSync(__filename); |
|
|
|
const createTransformer = options => { |
|
const cache = Object.create(null); |
|
|
|
const getBabelRC = filename => { |
|
const paths = []; |
|
let directory = filename; |
|
while (directory !== (directory = (_path || _load_path()).default.dirname(directory))) { |
|
if (cache[directory]) { |
|
break; |
|
} |
|
|
|
paths.push(directory); |
|
const configFilePath = (_path || _load_path()).default.join(directory, BABELRC_FILENAME); |
|
if ((_fs || _load_fs()).default.existsSync(configFilePath)) { |
|
cache[directory] = (_fs || _load_fs()).default.readFileSync(configFilePath, 'utf8'); |
|
break; |
|
} |
|
const configJsFilePath = (_path || _load_path()).default.join(directory, BABELRC_JS_FILENAME); |
|
if ((_fs || _load_fs()).default.existsSync(configJsFilePath)) { |
|
// $FlowFixMe |
|
cache[directory] = JSON.stringify(require(configJsFilePath)); |
|
break; |
|
} |
|
const resolvedJsonFilePath = (_path || _load_path()).default.join(directory, PACKAGE_JSON); |
|
const packageJsonFilePath = resolvedJsonFilePath === PACKAGE_JSON ? (_path || _load_path()).default.resolve(directory, PACKAGE_JSON) : resolvedJsonFilePath; |
|
if ((_fs || _load_fs()).default.existsSync(packageJsonFilePath)) { |
|
// $FlowFixMe |
|
const packageJsonFileContents = require(packageJsonFilePath); |
|
if (packageJsonFileContents[BABEL_CONFIG_KEY]) { |
|
cache[directory] = JSON.stringify(packageJsonFileContents[BABEL_CONFIG_KEY]); |
|
break; |
|
} |
|
} |
|
} |
|
paths.forEach(directoryPath => cache[directoryPath] = cache[directory]); |
|
return cache[directory] || ''; |
|
}; |
|
|
|
options = Object.assign({}, options, { |
|
plugins: options && options.plugins || [], |
|
presets: (options && options.presets || []).concat([(_babelPresetJest || _load_babelPresetJest()).default]), |
|
sourceMaps: 'both' |
|
}); |
|
delete options.cacheDirectory; |
|
delete options.filename; |
|
|
|
return { |
|
canInstrument: true, |
|
getCacheKey(fileData, filename, configString, _ref) { |
|
let instrument = _ref.instrument, |
|
rootDir = _ref.rootDir; |
|
|
|
return (_crypto || _load_crypto()).default.createHash('md5').update(THIS_FILE).update('\0', 'utf8').update(fileData).update('\0', 'utf8').update((_path || _load_path()).default.relative(rootDir, filename)).update('\0', 'utf8').update(configString).update('\0', 'utf8').update(getBabelRC(filename)).update('\0', 'utf8').update(instrument ? 'instrument' : '').digest('hex'); |
|
}, |
|
process(src, filename, config, transformOptions) { |
|
const altExts = config.moduleFileExtensions.map(extension => '.' + extension); |
|
if ((_babelCore || _load_babelCore()).util && !(_babelCore || _load_babelCore()).util.canCompile(filename, altExts)) { |
|
return src; |
|
} |
|
|
|
const theseOptions = Object.assign({ filename }, options); |
|
if (transformOptions && transformOptions.instrument) { |
|
theseOptions.auxiliaryCommentBefore = ' istanbul ignore next '; |
|
// Copied from jest-runtime transform.js |
|
theseOptions.plugins = theseOptions.plugins.concat([[(_babelPluginIstanbul || _load_babelPluginIstanbul()).default, { |
|
// files outside `cwd` will not be instrumented |
|
cwd: config.rootDir, |
|
exclude: [] |
|
}]]); |
|
} |
|
|
|
// babel v7 might return null in the case when the file has been ignored. |
|
const transformResult = (0, (_babelCore || _load_babelCore()).transform)(src, theseOptions); |
|
|
|
if (!transformResult) { |
|
return src; |
|
} |
|
|
|
const shouldReturnCodeOnly = transformOptions == null || transformOptions.returnSourceString == null || transformOptions.returnSourceString === true; |
|
|
|
return shouldReturnCodeOnly ? transformResult.code : transformResult; |
|
} |
|
}; |
|
}; |
|
|
|
module.exports = createTransformer(); |
|
module.exports.createTransformer = createTransformer; |