Oto zła hack, który działa tylko w V8. 140 bytes
wersja:
function x(a,b,c){function d(e,f){d=f}c=(b=Error)[a='prepareStackTrace'];b.captureStackTrace(b[a]=d,x);d.stack;b[a]=c;return d}
I mniej tajemnicze wersja
if ('captureStackTrace' in Error) {
void function(){
function prepare(e, callsites){
return callsites;
}
function stack(f){
var e = {};
var oldPrepare = Error.prepareStackTrace;
Error.prepareStackTrace = prepare;
Error.captureStackTrace(e, f || stack.caller);
e = e.stack;
Error.prepareStackTrace = oldPrepare;
return e;
}
function lastReceiver(){
return stack(lastReceiver)[2].receiver;
}
var CallSite = stack()[0].constructor;
var callsiteMethods = {};
Object.getOwnPropertyNames(CallSite.prototype).forEach(function(key){
if (/^is|^get/.test(key)) {
callsiteMethods[key.replace(/^is|^get/, '')] = CallSite.prototype[key];
}
callsiteMethods.location = CallSite.prototype.toString;
});
CallSite.prototype.resolve = function resolve(){
for (var k in callsiteMethods)
this[k] = callsiteMethods[k].call(this);
}
}();
}
można przekazać 'this' do funkcji, nie można? – gdoron
Myślę, że może chcesz zajrzeć tutaj, szczególnie w komentarzach http://stackoverflow.com/a/280396/575527 – Joseph
Obejście problemu polega na tym, aby twój kod był zgodny z trybem ścisłym. To jest pewien punkt trybu ścisłego; * To jest ścisłe *. W twoim przypadku oznaczałoby to udostępnienie osoby dzwoniącej w inny sposób, na przykład przekazanie jej po imieniu jako argumentu. –