From 103819844246df2d30599afdf7d45b607be7420d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=81=AA=E8=81=AA?= <178666380@qq.com> Date: Sun, 23 Jul 2017 06:48:28 +0800 Subject: [PATCH] =?UTF-8?q?=E5=8D=87=E7=BA=A7=E4=BE=9D=E8=B5=96=E7=89=88?= =?UTF-8?q?=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- build.gradle | 6 +- .../server/MinecraftServer.java.patch | 75 ++--- src/main/java/jline/AnsiWindowsTerminal.java | 91 ------ .../jline/internal/TerminalLineSettings.java | 227 -------------- .../fusesource/hawtjni/runtime/Library.java | 286 ------------------ 5 files changed, 42 insertions(+), 643 deletions(-) delete mode 100644 src/main/java/jline/AnsiWindowsTerminal.java delete mode 100644 src/main/java/jline/internal/TerminalLineSettings.java delete mode 100644 src/main/java/org/fusesource/hawtjni/runtime/Library.java diff --git a/build.gradle b/build.gradle index 2e83be5..6ee7983 100644 --- a/build.gradle +++ b/build.gradle @@ -131,16 +131,16 @@ dependencies { libraries 'org.scala-lang:scala-xml_2.11:1.0.2' libraries 'net.sf.jopt-simple:jopt-simple:4.7' libraries 'lzma:lzma:0.0.1' - libraries 'org.yaml:snakeyaml:1.9' + libraries 'org.yaml:snakeyaml:1.15' libraries 'commons-lang:commons-lang:2.6' libraries 'org.avaje:ebean:2.7.3' - libraries 'jline:jline:2.6' + libraries 'jline:jline:2.12.1' libraries 'net.md-5:SpecialSource:1.7.3' libraries 'net.sourceforge.argo:argo:2.25' libraries 'org.fusesource.jansi:jansi:1.8' libraries 'com.googlecode.json-simple:json-simple:1.1' libraries 'org.xerial:sqlite-jdbc:3.7.2' - libraries 'mysql:mysql-connector-java:5.1.14' + libraries 'mysql:mysql-connector-java:5.1.42' libraries 'javax.persistence:persistence-api:1.0.2' libraries 'net.minecraft:server:1.7.10' libraries 'pw.prok:KImagine:0.2.0@jar' diff --git a/patches/net/minecraft/server/MinecraftServer.java.patch b/patches/net/minecraft/server/MinecraftServer.java.patch index de0c3ba..a4fe2c4 100644 --- a/patches/net/minecraft/server/MinecraftServer.java.patch +++ b/patches/net/minecraft/server/MinecraftServer.java.patch @@ -22,7 +22,7 @@ import java.awt.GraphicsEnvironment; import java.awt.image.BufferedImage; import java.io.File; -@@ -33,10 +17,45 @@ +@@ -33,10 +17,46 @@ import java.util.Random; import java.util.UUID; import java.util.concurrent.Callable; @@ -42,6 +42,7 @@ +import org.bukkit.craftbukkit.util.Waitable; +import org.bukkit.event.server.RemoteServerCommandEvent; +import org.bukkit.event.world.WorldSaveEvent; ++import org.fusesource.jansi.AnsiConsole; + +import com.google.common.base.Charsets; +import com.mojang.authlib.GameProfile; @@ -69,7 +70,7 @@ import net.minecraft.command.ServerCommandManager; import net.minecraft.crash.CrashReport; import net.minecraft.entity.player.EntityPlayer; -@@ -50,9 +69,11 @@ +@@ -50,9 +70,11 @@ import net.minecraft.profiler.PlayerUsageSnooper; import net.minecraft.profiler.Profiler; import net.minecraft.server.dedicated.DedicatedServer; @@ -81,7 +82,7 @@ import net.minecraft.util.ChatComponentText; import net.minecraft.util.ChunkCoordinates; import net.minecraft.util.IChatComponent; -@@ -63,19 +84,20 @@ +@@ -63,19 +85,20 @@ import net.minecraft.world.MinecraftException; import net.minecraft.world.World; import net.minecraft.world.WorldManager; @@ -107,7 +108,7 @@ import net.minecraftforge.common.DimensionManager; import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.event.world.WorldEvent; -@@ -85,13 +107,13 @@ +@@ -85,13 +108,13 @@ private static final Logger logger = LogManager.getLogger(); public static final File field_152367_a = new File("usercache.json"); private static MinecraftServer mcServer; @@ -124,7 +125,7 @@ private final ServerStatusResponse field_147147_p = new ServerStatusResponse(); private final Random field_147146_q = new Random(); @SideOnly(Side.SERVER) -@@ -135,8 +157,42 @@ +@@ -135,8 +158,42 @@ private long field_147142_T = 0L; private final GameProfileRepository field_152365_W; private final PlayerProfileCache field_152366_X; @@ -167,7 +168,7 @@ public MinecraftServer(File p_i45281_1_, Proxy p_i45281_2_) { this.field_152366_X = new PlayerProfileCache(this, field_152367_a); -@@ -149,10 +205,72 @@ +@@ -149,10 +206,72 @@ this.field_152364_T = new YggdrasilAuthenticationService(p_i45281_2_, UUID.randomUUID().toString()); this.field_147143_S = this.field_152364_T.createMinecraftSessionService(); this.field_152365_W = this.field_152364_T.createProfileRepository(); @@ -241,7 +242,7 @@ protected void convertMapIfNeeded(String p_71237_1_) { if (this.getActiveAnvilConverter().isOldMapFormat(p_71237_1_)) -@@ -172,6 +290,7 @@ +@@ -172,6 +291,7 @@ MinecraftServer.logger.info("Converting... " + p_73718_1_ + "%"); } } @@ -249,7 +250,7 @@ @SideOnly(Side.CLIENT) public void resetProgressAndMessage(String p_73721_1_) {} @SideOnly(Side.CLIENT) -@@ -195,10 +314,17 @@ +@@ -195,10 +315,17 @@ protected void loadAllWorlds(String p_71247_1_, String p_71247_2_, long p_71247_3_, WorldType p_71247_5_, String p_71247_6_) { @@ -269,7 +270,7 @@ WorldSettings worldsettings; if (worldinfo == null) -@@ -215,11 +341,79 @@ +@@ -215,11 +342,79 @@ { worldsettings.enableBonusChest(); } @@ -352,7 +353,7 @@ world.addWorldAccess(new WorldManager(this, world)); if (!this.isSinglePlayer()) -@@ -227,12 +421,14 @@ +@@ -227,12 +422,14 @@ world.getWorldInfo().setGameType(this.getGameType()); } @@ -370,7 +371,7 @@ } protected void initialWorldChunkLoad() -@@ -244,9 +440,12 @@ +@@ -244,9 +441,12 @@ int i = 0; this.setUserMessage("menu.generatingTerrain"); byte b0 = 0; @@ -383,7 +384,7 @@ long j = getSystemTimeMillis(); for (int k = -192; k <= 192 && this.isServerRunning(); k += 16) -@@ -265,7 +464,8 @@ +@@ -265,7 +465,8 @@ worldserver.theChunkProviderServer.loadChunk(chunkcoordinates.posX + k >> 4, chunkcoordinates.posZ + l >> 4); } } @@ -393,7 +394,7 @@ this.clearCurrentTask(); } -@@ -292,19 +492,17 @@ +@@ -292,19 +493,17 @@ { this.currentTask = null; this.percentDone = 0; @@ -418,7 +419,7 @@ if (worldserver != null) { -@@ -313,25 +511,41 @@ +@@ -313,25 +512,41 @@ logger.info("Saving chunks for level \'" + worldserver.getWorldInfo().getWorldName() + "\'/" + worldserver.provider.getDimensionName()); } @@ -465,7 +466,7 @@ if (this.func_147137_ag() != null) { this.func_147137_ag().terminateEndpoints(); -@@ -347,7 +561,14 @@ +@@ -347,7 +562,14 @@ if (this.worldServers != null) { logger.info("Saving worlds"); @@ -481,7 +482,7 @@ for (int i = 0; i < this.worldServers.length; ++i) { -@@ -380,6 +601,13 @@ +@@ -380,6 +602,13 @@ this.serverRunning = false; } @@ -495,7 +496,7 @@ public void run() { try -@@ -392,45 +620,41 @@ +@@ -392,45 +621,41 @@ this.field_147147_p.func_151315_a(new ChatComponentText(this.motd)); this.field_147147_p.func_151321_a(new ServerStatusResponse.MinecraftProtocolVersionIdentifier("1.7.10", 5)); this.func_147138_a(this.field_147147_p); @@ -562,7 +563,7 @@ FMLCommonHandler.instance().handleServerStopping(); FMLCommonHandler.instance().expectServerStopped(); // has to come before finalTick to avoid race conditions } -@@ -448,6 +672,14 @@ +@@ -448,6 +673,14 @@ catch (Throwable throwable1) { logger.error("Encountered an unexpected exception", throwable1); @@ -577,7 +578,7 @@ CrashReport crashreport = null; if (throwable1 instanceof ReportedException) -@@ -477,6 +709,7 @@ +@@ -477,6 +710,7 @@ { try { @@ -585,7 +586,7 @@ this.stopServer(); this.serverStopped = true; } -@@ -486,6 +719,16 @@ +@@ -486,6 +720,16 @@ } finally { @@ -602,7 +603,7 @@ FMLCommonHandler.instance().handleServerStopped(); this.serverStopped = true; this.systemExitNow(); -@@ -532,8 +775,11 @@ +@@ -532,8 +776,11 @@ public void tick() { @@ -614,7 +615,7 @@ ++this.tickCounter; if (this.startProfiling) -@@ -562,12 +808,21 @@ +@@ -562,12 +809,21 @@ this.field_147147_p.func_151318_b().func_151330_a(agameprofile); } @@ -638,7 +639,7 @@ } this.theProfiler.startSection("tallying"); -@@ -575,25 +830,57 @@ +@@ -575,25 +831,57 @@ this.theProfiler.endSection(); this.theProfiler.startSection("snooper"); @@ -698,7 +699,7 @@ int i; Integer[] ids = DimensionManager.getIDs(this.tickCounter % 200 == 0); -@@ -602,19 +889,21 @@ +@@ -602,19 +890,21 @@ int id = ids[x]; long j = System.nanoTime(); @@ -723,7 +724,7 @@ this.theProfiler.startSection("tick"); FMLCommonHandler.instance().onPreWorldTick(worldserver); -@@ -622,22 +911,46 @@ +@@ -622,22 +912,46 @@ try { @@ -772,7 +773,7 @@ worldserver.addWorldInfoToCrashReport(crashreport); throw new ReportedException(crashreport); } -@@ -645,10 +958,13 @@ +@@ -645,10 +959,13 @@ FMLCommonHandler.instance().onPostWorldTick(worldserver); this.theProfiler.endSection(); this.theProfiler.startSection("tracker"); @@ -787,7 +788,7 @@ worldTickTimes.get(id)[this.tickCounter % 100] = System.nanoTime() - j; } -@@ -656,15 +972,21 @@ +@@ -656,15 +973,21 @@ this.theProfiler.endStartSection("dim_unloading"); DimensionManager.unloadWorlds(worldTickTimes); this.theProfiler.endStartSection("connection"); @@ -809,7 +810,7 @@ this.theProfiler.endSection(); } -@@ -699,6 +1021,13 @@ +@@ -699,6 +1022,13 @@ public WorldServer worldServerForDimension(int p_71218_1_) { @@ -823,7 +824,7 @@ WorldServer ret = DimensionManager.getWorld(p_71218_1_); if (ret == null) { -@@ -784,13 +1113,14 @@ +@@ -784,13 +1114,14 @@ public List getPossibleCompletions(ICommandSender p_71248_1_, String p_71248_2_) { @@ -842,7 +843,7 @@ if (list != null) { -@@ -798,40 +1128,25 @@ +@@ -798,40 +1129,25 @@ while (iterator.hasNext()) { @@ -891,7 +892,7 @@ } public static MinecraftServer getServer() -@@ -1034,7 +1349,7 @@ +@@ -1034,7 +1350,7 @@ public boolean isServerInOnlineMode() { @@ -900,7 +901,7 @@ } public void setOnlineMode(boolean p_71229_1_) -@@ -1124,7 +1439,7 @@ +@@ -1124,7 +1440,7 @@ public NetworkSystem func_147137_ag() { @@ -909,7 +910,7 @@ } @SideOnly(Side.CLIENT) -@@ -1259,8 +1574,11 @@ +@@ -1259,8 +1575,11 @@ { Bootstrap.func_151354_b(); @@ -921,7 +922,7 @@ boolean flag = true; String s = null; String s1 = "."; -@@ -1356,16 +1674,34 @@ +@@ -1356,16 +1675,34 @@ { dedicatedserver.setGuiEnabled(); } @@ -962,7 +963,7 @@ } catch (Exception exception) { -@@ -1400,15 +1736,70 @@ +@@ -1400,15 +1737,70 @@ @SideOnly(Side.SERVER) public String getPlugins() { @@ -1038,7 +1039,7 @@ } @SideOnly(Side.SERVER) -@@ -1455,9 +1846,220 @@ +@@ -1455,9 +1847,222 @@ return this.serverStopped; } @@ -1178,6 +1179,8 @@ + if (!useJline) { + // This ensures the terminal literal will always match the jline implementation + System.setProperty(jline.TerminalFactory.JLINE_TERMINAL, jline.UnsupportedTerminal.class.getName()); ++ }else{ ++ AnsiConsole.systemInstall(); // install Windows JNI library + } + + diff --git a/src/main/java/jline/AnsiWindowsTerminal.java b/src/main/java/jline/AnsiWindowsTerminal.java deleted file mode 100644 index a638036..0000000 --- a/src/main/java/jline/AnsiWindowsTerminal.java +++ /dev/null @@ -1,91 +0,0 @@ -/* - * Copyright (C) 2009 the original author(s). - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - * - * MODIFICATIONS: methods to deal with wrapping the output stream. - */ - -package jline; - -import org.fusesource.jansi.AnsiConsole; -import org.fusesource.jansi.AnsiOutputStream; -import org.fusesource.jansi.WindowsAnsiOutputStream; - -import java.io.ByteArrayOutputStream; -import java.io.OutputStream; - -/** - * ANSI-supported {@link WindowsTerminal}. - * - * @since 2.0 - */ -public class AnsiWindowsTerminal - extends WindowsTerminal -{ - private final boolean ansiSupported = detectAnsiSupport(); - - @Override - public OutputStream wrapOutIfNeeded(OutputStream out) { - return wrapOutputStream(out); - } - - /** - * Returns an ansi output stream handler. We return whatever was - * passed if we determine we cannot handle ansi based on Kernel32 calls. - * - * @return an @{link AltWindowAnsiOutputStream} instance or the passed - * stream. - */ - private static OutputStream wrapOutputStream(final OutputStream stream) { - String os = System.getProperty("os.name"); - if( os.startsWith("Windows") ) { - // On windows we know the console does not interpret ANSI codes.. - try { - return new WindowsAnsiOutputStream(stream); - } catch (Throwable ignore) { - // this happens when JNA is not in the path.. or - // this happens when the stdout is being redirected to a file. - } - // Use the ANSIOutputStream to strip out the ANSI escape sequences. - return new AnsiOutputStream(stream); - } - return stream; - } - - private static boolean detectAnsiSupport() { - AnsiConsole.systemInstall(); // CraftBukkit - install Windows JNI library - OutputStream out = AnsiConsole.wrapOutputStream(new ByteArrayOutputStream()); - try { - out.close(); - } - catch (Exception e) { - // ignore; - } - return out instanceof WindowsAnsiOutputStream; - } - - public AnsiWindowsTerminal() throws Exception { - super(); - } - - @Override - public boolean isAnsiSupported() { - return ansiSupported; - } - - @Override - public boolean hasWeirdWrap() { - return false; - } -} diff --git a/src/main/java/jline/internal/TerminalLineSettings.java b/src/main/java/jline/internal/TerminalLineSettings.java deleted file mode 100644 index b4b2409..0000000 --- a/src/main/java/jline/internal/TerminalLineSettings.java +++ /dev/null @@ -1,227 +0,0 @@ -/* - * Copyright (c) 2002-2007, Marc Prud'hommeaux. All rights reserved. - * - * This software is distributable under the BSD license. See the terms of the - * BSD license in the documentation provided with this software. - */ - -package jline.internal; - -import java.io.ByteArrayOutputStream; -import java.io.Closeable; -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; -import java.text.MessageFormat; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -/** - * Provides access to terminal line settings via stty. - * - * @author Marc Prud'hommeaux - * @author Dale Kemp - * @author Jason Dillon - * @author Jean-Baptiste Onofré - * @since 2.0 - */ -public final class TerminalLineSettings -{ - public static final String JLINE_STTY = "jline.stty"; - - public static final String DEFAULT_STTY = "stty"; - - public static final String JLINE_SH = "jline.sh"; - - public static final String DEFAULT_SH = "sh"; - - private String sttyCommand; - - private String shCommand; - - private String config; - - private long configLastFetched; - - public TerminalLineSettings() throws IOException, InterruptedException { - sttyCommand = Configuration.getString(JLINE_STTY, DEFAULT_STTY); - shCommand = Configuration.getString(JLINE_SH, DEFAULT_SH); - config = get("-a"); - configLastFetched = System.currentTimeMillis(); - - Log.debug("Config: ", config); - - // sanity check - if (config.length() == 0) { - throw new IOException(MessageFormat.format("Unrecognized stty code: {0}", config)); - } - } - - public String getConfig() { - return config; - } - - public void restore() throws IOException, InterruptedException { - set("sane"); - } - - public String get(final String args) throws IOException, InterruptedException { - return stty(args); - } - - public void set(final String args) throws IOException, InterruptedException { - stty(args); - } - - /** - *

- * Get the value of a stty property, including the management of a cache. - *

- * - * @param name the stty property. - * @return the stty property value. - */ - public int getProperty(String name) { - assert name != null; - // CraftBukkit start - long currentTime = System.currentTimeMillis(); - - try { - // tty properties are cached so we don't have to worry too much about getting term widht/height - if (config == null || currentTime - configLastFetched > 1000) { - config = get("-a"); - } - } catch (Exception e) { - Log.debug("Failed to query stty ", name, "\n", e); - } - - // always update the last fetched time and try to parse the output - if (currentTime - configLastFetched > 1000) { - configLastFetched = currentTime; - } - - return this.getProperty(name, config); - // CraftBukkit end - } - - /** - *

- * Parses a stty output (provided by stty -a) and return the value of a given property. - *

- * - * @param name property name. - * @param stty string resulting of stty -a execution. - * @return value of the given property. - */ - protected static int getProperty(String name, String stty) { - // try the first kind of regex - Pattern pattern = Pattern.compile(name + "\\s+=\\s+([^;]*)[;\\n\\r]"); - Matcher matcher = pattern.matcher(stty); - if (!matcher.find()) { - // try a second kind of regex - pattern = Pattern.compile(name + "\\s+([^;]*)[;\\n\\r]"); - matcher = pattern.matcher(stty); - if (!matcher.find()) { - // try a second try of regex - pattern = Pattern.compile("(\\S*)\\s+" + name); - matcher = pattern.matcher(stty); - if (!matcher.find()) { - return -1; - } - } - } - return parseControlChar(matcher.group(1)); - } - - private static int parseControlChar(String str) { - // under - if ("".equals(str)) { - return -1; - } - // octal - if (str.charAt(0) == '0') { - return Integer.parseInt(str, 8); - } - // decimal - if (str.charAt(0) >= '1' && str.charAt(0) <= '9') { - return Integer.parseInt(str, 10); - } - // control char - if (str.charAt(0) == '^') { - if (str.charAt(1) == '?') { - return 127; - } else { - return str.charAt(1) - 64; - } - } else if (str.charAt(0) == 'M' && str.charAt(1) == '-') { - if (str.charAt(2) == '^') { - if (str.charAt(3) == '?') { - return 127 + 128; - } else { - return str.charAt(3) - 64 + 128; - } - } else { - return str.charAt(2) + 128; - } - } else { - return str.charAt(0); - } - } - - private String stty(final String args) throws IOException, InterruptedException { - assert args != null; - return exec(String.format("%s %s < /dev/tty", sttyCommand, args)); - } - - private String exec(final String cmd) throws IOException, InterruptedException { - assert cmd != null; - return exec(shCommand, "-c", cmd); - } - - private String exec(final String... cmd) throws IOException, InterruptedException { - assert cmd != null; - - ByteArrayOutputStream bout = new ByteArrayOutputStream(); - - Log.trace("Running: ", cmd); - - Process p = Runtime.getRuntime().exec(cmd); - - InputStream in = null; - InputStream err = null; - OutputStream out = null; - try { - int c; - in = p.getInputStream(); - while ((c = in.read()) != -1) { - bout.write(c); - } - err = p.getErrorStream(); - while ((c = err.read()) != -1) { - bout.write(c); - } - out = p.getOutputStream(); - p.waitFor(); - } - finally { - close(in, out, err); - } - - String result = bout.toString(); - - Log.trace("Result: ", result); - - return result; - } - - private static void close(final Closeable... closeables) { - for (Closeable c : closeables) { - try { - c.close(); - } - catch (Exception e) { - // Ignore - } - } - } -} \ No newline at end of file diff --git a/src/main/java/org/fusesource/hawtjni/runtime/Library.java b/src/main/java/org/fusesource/hawtjni/runtime/Library.java deleted file mode 100644 index e80ef32..0000000 --- a/src/main/java/org/fusesource/hawtjni/runtime/Library.java +++ /dev/null @@ -1,286 +0,0 @@ -package org.fusesource.hawtjni.runtime; - -import java.io.Closeable; -import java.io.File; -import java.io.FileOutputStream; -import java.io.InputStream; -import java.net.MalformedURLException; -import java.net.URL; -import java.util.ArrayList; -import java.util.regex.Pattern; - -public class Library{ - - static final String SLASH=System.getProperty("file.separator"); - private final String name; - private final String version; - private final ClassLoader classLoader; - private boolean loaded; - - public Library(String name){ - this(name,null,null); - } - - public Library(String name,Class clazz){ - this(name,version(clazz),clazz.getClassLoader()); - } - - public Library(String name,String version){ - this(name,version,null); - } - - public Library(String name,String version,ClassLoader classLoader){ - if(name==null){ - throw new IllegalArgumentException("name cannot be null"); - } - this.name=name; - this.version=version; - this.classLoader=classLoader; - } - - private static String version(Class clazz){ - try{ - return clazz.getPackage().getImplementationVersion(); - }catch(Throwable e){ - } - return null; - } - - public static String getOperatingSystem(){ - String name=System.getProperty("os.name").toLowerCase().trim(); - if(name.startsWith("linux")){ - return "linux"; - } - if(name.startsWith("mac os x")){ - return "osx"; - } - if(name.startsWith("win")){ - return "windows"; - } - return name.replaceAll("\\W+","_"); - } - - public static String getPlatform(){ - return getOperatingSystem()+getBitModel(); - } - - public static int getBitModel(){ - String prop=System.getProperty("sun.arch.data.model"); - if(prop==null){ - prop=System.getProperty("com.ibm.vm.bitmode"); - } - if(prop!=null){ - return Integer.parseInt(prop); - } - return -1; - } - - public synchronized void load(){ - if(this.loaded){ - return; - } - doLoad(); - this.loaded=true; - } - - private void doLoad(){ - String version=System.getProperty("library."+this.name+".version"); - if(version==null){ - version=this.version; - } - ArrayList errors=new ArrayList(); - - String customPath=System.getProperty("library."+this.name+".path"); - if(customPath!=null){ - if(version!=null){ - if(load(errors,file(new String[]{customPath,map(this.name+"-"+version)}))){ - return; - } - } - if(load(errors,file(new String[]{customPath,map(this.name)}))){ - return; - } - } - if((version!=null)&&(load(errors,this.name+getBitModel()+"-"+version))){ - return; - } - if((version!=null)&&(load(errors,this.name+"-"+version))){ - return; - } - if(load(errors,this.name)){ - return; - } - if(this.classLoader!=null){ - if(exractAndLoad(errors,version,customPath,getPlatformSpecifcResourcePath())){ - return; - } - if(exractAndLoad(errors,version,customPath,getOperatingSystemSpecifcResourcePath())){ - return; - } - if(exractAndLoad(errors,version,customPath,getResorucePath())){ - return; - } - } - throw new UnsatisfiedLinkError("Could not load library. Reasons: "+errors.toString()); - } - - public final String getOperatingSystemSpecifcResourcePath(){ - return getPlatformSpecifcResourcePath(getOperatingSystem()); - } - - public final String getPlatformSpecifcResourcePath(){ - return getPlatformSpecifcResourcePath(getPlatform()); - } - - public final String getPlatformSpecifcResourcePath(String platform){ - return "META-INF/native/"+platform+"/"+map(this.name); - } - - public final String getResorucePath(){ - return "META-INF/native/"+map(this.name); - } - - public final String getLibraryFileName(){ - return map(this.name); - } - - private boolean exractAndLoad(ArrayList errors,String version,String customPath,String resourcePath){ - URL resource=this.classLoader.getResource(resourcePath); - if(resource!=null){ - String libName=this.name+"-"+getBitModel(); - if(version!=null){ - libName=libName+"-"+version; - } - String[] libNameParts=map(libName).split("\\."); - String prefix=libNameParts[0]+"-"; - String suffix="."+libNameParts[1]; - if(customPath!=null){ - File target=extract(errors,resource,prefix,suffix,file(new String[]{customPath})); - if((target!=null)&& - (load(errors,target))){ - return true; - } - } - customPath=System.getProperty("java.io.tmpdir"); - File target=extract(errors,resource,prefix,suffix,file(new String[]{customPath})); - if((target!=null)&& - (load(errors,target))){ - return true; - } - } - return false; - } - - private File extract(ArrayList errors,URL source,String prefix,String suffix,File directory){ - File target=null; - try{ - FileOutputStream os=null; - InputStream is=null; - try{ - target=File.createTempFile(prefix,suffix,directory); - is=source.openStream(); - byte[] buffer; - if(is!=null){ - buffer=new byte[64]; - os=new FileOutputStream(target); - int read; - while((read=is.read(buffer))!=-1){ - os.write(buffer,0,read); - } - chmod("755",target); - } - target.deleteOnExit(); - }finally{ - close(os,is); - } - }catch(Throwable e){ - if(target!=null){ - target.delete(); - } - errors.add(e.getMessage()); - } - return target; - } - - private static void close(Closeable...pStreams){ - for(Closeable sStream : pStreams){ - if(sStream!=null){ - try{ - sStream.close(); - }catch(Exception ignore){ - } - } - } - } - - private File file(String...paths){ - File rc=null; - for(String path : paths){ - if(rc==null){ - rc=new File(path); - }else{ - rc=new File(rc,path); - } - } - return rc; - } - - private String map(String libName){ - libName=System.mapLibraryName(libName); - String ext=".dylib"; - if(libName.endsWith(ext)){ - libName=libName.substring(0,libName.length()-ext.length())+".jnilib"; - } - return libName; - } - - private boolean isStale(URL source,File target){ - if(source.getProtocol().equals("jar")){ - try{ - String[] parts=source.getFile().split(Pattern.quote("!")); - source=new URL(parts[0]); - }catch(MalformedURLException e){ - return false; - } - } - File sourceFile=null; - if(source.getProtocol().equals("file")){ - sourceFile=new File(source.getFile()); - } - if((sourceFile!=null)&&(sourceFile.exists())&& - (sourceFile.lastModified()>target.lastModified())){ - return true; - } - return false; - } - - private void chmod(String permision,File path){ - if(getPlatform().startsWith("windows")){ - return; - } - try{ - Runtime.getRuntime().exec(new String[]{"chmod",permision,path.getCanonicalPath()}).waitFor(); - }catch(Throwable e){ - } - } - - private boolean load(ArrayList errors,File lib){ - try{ - System.load(lib.getPath()); - return true; - }catch(UnsatisfiedLinkError e){ - errors.add(e.getMessage()); - } - return false; - } - - private boolean load(ArrayList errors,String lib){ - try{ - System.loadLibrary(lib); - return true; - }catch(UnsatisfiedLinkError e){ - errors.add(e.getMessage()); - } - return false; - } -}