我在某地读过orion使用tern代码完成JavaScript但在运行服务器之后,创建一个js文件,然后创建另一个文件,另一个文件不知道第一个文件中的任何代码。
似乎完成仅适用于当前打开的文件中定义的符号。
有没有办法在orion中配置tern所以它会产生一些有用的完成而不是没有任何实际价值的工作演示?
答案 0 :(得分:1)
Orion在几周前(2015年4月中旬)才向Tern提出了内容协助提案。
https://bugs.eclipse.org/bugs/show_bug.cgi?id=432940
我们正致力于启用多文件支持。
答案 1 :(得分:0)
我已经使用.tern-config文件实现了一个hack来为特定项目加载文件。
它不适用于包含*的值,因为这需要更改服务器。
这只是一个简单的黑客攻击,很容易打破,但目前为我做的工作。
以下是我更改版本9 build S20150504-1254的代码的方法:
在org.eclipse.orion.client.javascript_1.0.0.v20150504-1644.jar
文件:/web/javascript/handlers/ternOccurrencesHandler.js
function sortProposals if语句检查file是否是当前打开的文件 只需检查它是否是以/ file /
开头的值取代:
if(_o === args.meta.location) {
使用:
if(/^\/file\//.test(_o)) {
查找函数computeProposals并在该函数之前添加以下代码:
function getFile(url){
return new Promise(function(resolve,reject){
var xhr = new XMLHttpRequest();
xhr.open('GET',url);
xhr.addEventListener("load", function(e){
//@todo: have to check something I dont think this should be called on a 404 but it is
console.log('ok, done:',xhr.responseURL);
if(xhr.status!==200){
reject('file not found:',xhr.responseURL);
return;
}
resolve(xhr.responseText);
}, false);
xhr.addEventListener("error", function(e){
console.log('an error:',e);
reject(e);
}, false);
xhr.send();
});
}
var loadFilesInTern = (function(){
var loadedConfigs = [];
var currentConfig = '';
function loadJsFileIntoTernServer(fileName,ternserver){
return getFile(fileName)
.then(function resolve(val){
ternserver.addFile(fileName,val);
},function reject(err){
console.log('an error:',fileName);
return true;
});
}
return function(location,ternserver){
var p = new Promise(function(resolve){resolve(true);});
rootPath = location.split('/').slice(0,4).join('/');
console.log('got rootpath, trying to get tern-config from:',rootPath+'/.tern-config');
return p
.then(function(){
if(!loadedConfigs[rootPath]){
return getFile(rootPath+'/.tern-config');
}else {
return loadedConfigs[rootPath];
}
})
.then(function(config){
loadedConfigs[rootPath]=config;
if(config===currentConfig){
return;
};
currentConfig = config;
var settings = JSON.parse(config);
var promises = [];
settings.loadEagerly.forEach(function(fileName){
promises.push(loadJsFileIntoTernServer(rootPath + '/' + fileName,ternserver));
});
return Promise.all(promises);
})
.then(null,function reject(e){
console.log('an error:',e);
return true;
});
p.resolve('start');
};
}());
在计算提案之前加载配置(第一次)
function computeProposals(ternserver, args, callback) {
if(ternserver) {
loadFilesInTern(args.meta.location,ternserver)
.then(function(){
console.log('ternserver is now:',ternserver);
ternserver.request({
//... rest of the computeProposals code
});//close the then
} else {//original code from computeProposals
callback({request: 'completions', proposals:[]});
}
您可以在项目目录中创建一个.tern-config并添加loadEagerly文件:
{
"libs": [
"browser",
"ecma5",
"jquery"
],
"loadEagerly": [
"goog/base.js",
"somefile.js",
"another file.js"
],
"plugins": {
"requirejs": {
"baseURL": "./",
"paths": {}
}
}
}
目前忽略了libs和插件,但是加载了其他文件(请注意,这是一个在某些情况下可能会中断的简单hack)