diff options
author | Chris Browet <koying@semperpax.com> | 2014-06-15 13:38:24 +0200 |
---|---|---|
committer | Chris Browet <koying@semperpax.com> | 2014-06-15 13:38:24 +0200 |
commit | 3c557edf2644eef160a6f2ec897c442788cd60db (patch) | |
tree | 3f8ed338bec3e3e8d74bc3daa65e295d55d24c6d /tools/android/packaging | |
parent | 8ea44f144f0600e07ed3973e29deaf9911eb5008 (diff) | |
parent | a73c371c051f91ac2677d9af8706dbafdf9ebf18 (diff) |
Merge pull request #4076 from koying/adddroidhome
ADD: [droid] backdoor to define XBMC_HOME and HOME on android
Diffstat (limited to 'tools/android/packaging')
-rw-r--r-- | tools/android/packaging/xbmc/src/org/xbmc/xbmc/Splash.java | 76 |
1 files changed, 57 insertions, 19 deletions
diff --git a/tools/android/packaging/xbmc/src/org/xbmc/xbmc/Splash.java b/tools/android/packaging/xbmc/src/org/xbmc/xbmc/Splash.java index 8ecc127540..bdfadf0330 100644 --- a/tools/android/packaging/xbmc/src/org/xbmc/xbmc/Splash.java +++ b/tools/android/packaging/xbmc/src/org/xbmc/xbmc/Splash.java @@ -3,16 +3,19 @@ package org.xbmc.xbmc; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileNotFoundException; +import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; -import java.util.Enumeration; +import java.lang.System; +import java.util.Iterator; import java.util.List; import java.util.regex.Matcher; import java.util.regex.Pattern; import java.util.zip.ZipEntry; import java.util.zip.ZipFile; import java.util.Properties; +import java.util.Enumeration; import android.os.AsyncTask; import android.os.Build; @@ -49,10 +52,10 @@ public class Splash extends Activity { private State mState = State.Uninitialized; public AlertDialog myAlertDialog; - private String sPackagePath; - private String sApkDir; - private File fPackagePath; - private File fApkDir; + private String sPackagePath = ""; + private String sXbmcHome = ""; + private File fPackagePath = null; + private File fXbmcHome = null; public void showErrorDialog(Context context, String title, String message) { if (myAlertDialog != null && myAlertDialog.isShowing()) @@ -98,15 +101,15 @@ public class Splash extends Activity { @Override protected Integer doInBackground(Void... param) { - if (fApkDir.exists()) { + if (fXbmcHome.exists()) { // Remove existing files - Log.d(TAG, "Removing existing " + fApkDir.toString()); - DeleteRecursive(fApkDir); + Log.d(TAG, "Removing existing " + fXbmcHome.toString()); + DeleteRecursive(fXbmcHome); } - fApkDir.mkdirs(); + fXbmcHome.mkdirs(); // Log.d(TAG, "apk: " + sPackagePath); - // Log.d(TAG, "output: " + sApkDir); + // Log.d(TAG, "output: " + sXbmcHome); ZipFile zip; byte[] buf = new byte[4096]; @@ -130,7 +133,7 @@ public class Splash extends Activity { if (e.getName().startsWith("assets/python2.6")) continue; - String sFullPath = sApkDir + "/" + e.getName(); + String sFullPath = sXbmcHome + "/" + e.getName(); File fFullPath = new File(sFullPath); if (e.isDirectory()) { // Log.d(TAG, "creating dir: " + sFullPath); @@ -156,7 +159,7 @@ public class Splash extends Activity { zip.close(); - fApkDir.setLastModified(fPackagePath.lastModified()); + fXbmcHome.setLastModified(fPackagePath.lastModified()); } catch (FileNotFoundException e1) { e1.printStackTrace(); @@ -205,6 +208,45 @@ public class Splash extends Activity { } } + private void SetupEnvironment() { + File fProp = new File("/sdcard/xbmc_env.properties"); + if (fProp.exists()) { + try { + Properties sysProp = new Properties(System.getProperties()); + FileInputStream xbmcenvprop = new FileInputStream(fProp); + sysProp.load(xbmcenvprop); + System.setProperties(sysProp); + + sXbmcHome = System.getProperty("xbmc.home", ""); + fXbmcHome = new File(sXbmcHome); + fXbmcHome.mkdir(); + if (!fXbmcHome.exists()) + sXbmcHome = ""; + + String sXbmcdata = System.getProperty("xbmc.data", ""); + if (!sXbmcdata.isEmpty()) { + File fXbmcData = new File(sXbmcdata); + fXbmcData.mkdir(); + if (!fXbmcData.exists()) + sXbmcdata = ""; + } + + } catch (NotFoundException e) { + Log.e(TAG, "Cannot find xbmc_env properties file"); + } catch (IOException e) { + Log.e(TAG, "Failed to open xbmc_env properties file"); + } + } + if (sXbmcHome.isEmpty()) { + File fCacheDir = getCacheDir(); + sXbmcHome = fCacheDir.getAbsolutePath() + "/apk"; + } + + sPackagePath = getPackageResourcePath(); + fPackagePath = new File(sPackagePath); + fXbmcHome = new File(sXbmcHome); + } + private boolean ParseCpuFeature() { ProcessBuilder cmd; @@ -319,14 +361,10 @@ public class Splash extends Activity { } if (mState != State.InError) { - sPackagePath = getPackageResourcePath(); - fPackagePath = new File(sPackagePath); - File fCacheDir = getCacheDir(); - sApkDir = fCacheDir.getAbsolutePath() + "/apk"; - fApkDir = new File(sApkDir); + SetupEnvironment(); - if (fApkDir.exists() - && fApkDir.lastModified() >= fPackagePath.lastModified()) { + if (fXbmcHome.exists() + && fXbmcHome.lastModified() >= fPackagePath.lastModified()) { mState = State.StartingXBMC; } } |