mirror of
https://github.com/marko-js/marko.git
synced 2025-12-08 19:26:05 +00:00
Fixes #78 Custom require extension for marko files
This commit is contained in:
parent
91ec007718
commit
391aa80a9a
@ -51,11 +51,22 @@ exports.enable = function() {
|
||||
if (!path) {
|
||||
throw new Error('Invalid path');
|
||||
}
|
||||
|
||||
var templatePath = path;
|
||||
|
||||
if (typeof templatePath !== 'string') {
|
||||
templatePath = path.path;
|
||||
}
|
||||
|
||||
if (typeof templatePath === 'string') {
|
||||
templatePath = templatePath.replace(/\.js$/, '');
|
||||
}
|
||||
|
||||
var template = oldLoad.apply(runtime, arguments);
|
||||
|
||||
// Store the current last modified with the template
|
||||
template.__hotReloadModifiedFlag = modifiedFlag;
|
||||
template.__hotReloadPath = path;
|
||||
template.__hotReloadPath = templatePath;
|
||||
|
||||
return template;
|
||||
};
|
||||
@ -74,6 +85,7 @@ exports.handleFileModified = function(path) {
|
||||
console.log('[marko/hot-reload] File modified: ' + path);
|
||||
|
||||
if (path.endsWith('.marko') || path.endsWith('.marko.html')) {
|
||||
delete require.cache[path];
|
||||
delete require.cache[path + '.js'];
|
||||
}
|
||||
|
||||
|
||||
51
node-require.js
Normal file
51
node-require.js
Normal file
@ -0,0 +1,51 @@
|
||||
var path = require('path');
|
||||
var resolveFrom = require('resolve-from');
|
||||
var fs = require('fs');
|
||||
var fsReadOptions = { encoding: 'utf8' };
|
||||
|
||||
function compile(templatePath, markoCompiler, compilerOptions) {
|
||||
|
||||
var targetDir = path.dirname(templatePath);
|
||||
|
||||
var targetFile = templatePath + '.js';
|
||||
var compiler = markoCompiler.createCompiler(templatePath, compilerOptions);
|
||||
var isUpToDate = compiler.checkUpToDate(targetFile);
|
||||
var compiledSrc;
|
||||
|
||||
if (isUpToDate) {
|
||||
compiledSrc = fs.readFileSync(targetFile, fsReadOptions);
|
||||
} else {
|
||||
var templateSrc = fs.readFileSync(templatePath, fsReadOptions);
|
||||
compiledSrc = compiler.compile(templateSrc);
|
||||
var filename = path.basename(targetFile);
|
||||
var tempFile = path.join(targetDir, '.' + process.pid + '.' + Date.now() + '.' + filename);
|
||||
fs.writeFileSync(tempFile, compiledSrc, fsReadOptions);
|
||||
fs.renameSync(tempFile, targetFile);
|
||||
}
|
||||
|
||||
return compiledSrc + '\nexports.path=__filename;\nmodule.exports = require("marko").load(exports);';
|
||||
}
|
||||
|
||||
exports.install = function(options) {
|
||||
options = options || {};
|
||||
|
||||
var compilerOptions = options.compilerOptions;
|
||||
|
||||
var extension = options.extension || '.marko';
|
||||
|
||||
if (extension.charAt(0) !== '.') {
|
||||
extension = '.' + extension;
|
||||
}
|
||||
|
||||
if (require.extensions[extension]) {
|
||||
return;
|
||||
}
|
||||
|
||||
require.extensions[extension] = function markoExtension(module, filename) {
|
||||
var dirname = path.dirname(filename);
|
||||
var markoCompilerModulePath = resolveFrom(dirname, 'marko/compiler');
|
||||
var markoCompiler = require(markoCompilerModulePath);
|
||||
var compiledSrc = compile(filename, markoCompiler, compilerOptions);
|
||||
module._compile(compiledSrc, filename + '.js');
|
||||
};
|
||||
};
|
||||
Loading…
x
Reference in New Issue
Block a user