aboutsummaryrefslogtreecommitdiff
path: root/tools/android/packaging
diff options
context:
space:
mode:
authorChris Browet <koying@semperpax.com>2014-06-15 13:38:24 +0200
committerChris Browet <koying@semperpax.com>2014-06-15 13:38:24 +0200
commit3c557edf2644eef160a6f2ec897c442788cd60db (patch)
tree3f8ed338bec3e3e8d74bc3daa65e295d55d24c6d /tools/android/packaging
parent8ea44f144f0600e07ed3973e29deaf9911eb5008 (diff)
parenta73c371c051f91ac2677d9af8706dbafdf9ebf18 (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.java76
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;
}
}