hmmm
This commit is contained in:
@@ -19,10 +19,9 @@ import io.anuke.arc.util.io.*;
|
||||
import io.anuke.arc.util.serialization.*;
|
||||
import io.anuke.mindustry.*;
|
||||
import io.anuke.mindustry.core.GameState.*;
|
||||
import io.anuke.mindustry.core.Version;
|
||||
import io.anuke.mindustry.core.*;
|
||||
import io.anuke.mindustry.desktop.steam.*;
|
||||
import io.anuke.mindustry.game.EventType.*;
|
||||
import io.anuke.mindustry.mod.*;
|
||||
import io.anuke.mindustry.mod.Mods.*;
|
||||
import io.anuke.mindustry.net.*;
|
||||
import io.anuke.mindustry.net.Net.*;
|
||||
@@ -265,11 +264,6 @@ public class DesktopLauncher extends ClientLauncher{
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public Scripts createScripts(){
|
||||
return new GraalScripts();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Array<FileHandle> getWorkshopContent(Class<? extends Publishable> type){
|
||||
return !steam ? super.getWorkshopContent(type) : SVars.workshop.getWorkshopFiles(type);
|
||||
|
||||
@@ -1,54 +0,0 @@
|
||||
package io.anuke.mindustry.desktop;
|
||||
|
||||
import io.anuke.arc.*;
|
||||
import io.anuke.arc.files.*;
|
||||
import io.anuke.arc.util.*;
|
||||
import io.anuke.mindustry.mod.*;
|
||||
import io.anuke.mindustry.mod.Mods.*;
|
||||
import org.graalvm.polyglot.*;
|
||||
|
||||
import java.io.*;
|
||||
|
||||
public class GraalScripts extends Scripts{
|
||||
private static final Class[] denied = {FileHandle.class, InputStream.class, File.class, Scripts.class, Files.class, ClassAccess.class};
|
||||
private final Context context;
|
||||
private final String wrapper;
|
||||
private final Context.Builder builder;
|
||||
private Context console;
|
||||
|
||||
public GraalScripts(){
|
||||
Time.mark();
|
||||
builder = Context.newBuilder("js").allowHostClassLookup(ClassAccess.allowedClassNames::contains);
|
||||
|
||||
HostAccess.Builder hb = HostAccess.newBuilder();
|
||||
hb.allowPublicAccess(true);
|
||||
for(Class c : denied){
|
||||
hb.denyAccess(c);
|
||||
}
|
||||
builder.allowHostAccess(hb.build());
|
||||
builder.allowExperimentalOptions(true);
|
||||
|
||||
context = builder.build();
|
||||
wrapper = Core.files.internal("scripts/wrapper.js").readString();
|
||||
|
||||
run(Core.files.internal("scripts/global.js").readString());
|
||||
Log.info("Time to load script engine: {0}", Time.elapsed());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void run(LoadedMod mod, FileHandle file){
|
||||
run(wrapper.replace("$SCRIPT_NAME$", mod.name + "_" +file.nameWithoutExtension().replace("-", "_").replace(" ", "_")).replace("$CODE$", file.readString()));
|
||||
}
|
||||
|
||||
@Override
|
||||
public String runConsole(String text){
|
||||
if(console == null){
|
||||
console = builder.build();
|
||||
}
|
||||
return console.eval("js", text).toString();
|
||||
}
|
||||
|
||||
private void run(String script){
|
||||
context.eval("js", script);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user