Adding Cupcake Storage

This commit is contained in:
Joe Bowser
2009-12-08 14:08:48 -08:00
parent f6e2e129b1
commit b0a69f5cc5
3 changed files with 160 additions and 3 deletions
+12 -3
View File
@@ -49,7 +49,6 @@ public class DroidGap extends Activity {
protected WebView appView;
private LinearLayout root;
private String uri;
private PhoneGap gap;
private GeoBroker geo;
private AccelListener accel;
@@ -58,7 +57,9 @@ public class DroidGap extends Activity {
private FileUtils fs;
private NetworkManager netMan;
private CompassListener mCompass;
private WebViewReflect eclairCheck;
private Storage cupcakeStorage;
/** Called when the activity is first created. */
@Override
@@ -89,7 +90,10 @@ public class DroidGap extends Activity {
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.ECLAIR)
appView.setWebChromeClient(new EclairClient(this));
else
{
appView.setWebChromeClient(new GapClient(this));
cupcakeStorage = new Storage(appView);
}
appView.setInitialScale(100);
appView.setVerticalScrollBarEnabled(false);
@@ -127,7 +131,7 @@ public class DroidGap extends Activity {
mContacts = new ContactManager(this, appView);
fs = new FileUtils(appView);
netMan = new NetworkManager(this, appView);
mCompass = new CompassListener(this, appView);
mCompass = new CompassListener(this, appView);
// This creates the new javascript interfaces for PhoneGap
appView.addJavascriptInterface(gap, "DroidGap");
@@ -138,6 +142,11 @@ public class DroidGap extends Activity {
appView.addJavascriptInterface(fs, "FileUtil");
appView.addJavascriptInterface(netMan, "NetworkManager");
appView.addJavascriptInterface(mCompass, "CompassHook");
if (android.os.Build.VERSION.SDK_INT <= android.os.Build.VERSION_CODES.DONUT)
{
cupcakeStorage = new Storage(appView);
appView.addJavascriptInterface(cupcakeStorage, "droidStorage");
}
}
+71
View File
@@ -0,0 +1,71 @@
package com.phonegap;
import android.database.Cursor;
import android.database.sqlite.*;
import android.util.Log;
import android.webkit.WebView;
public class Storage {
private static final String LOG_TAG = "SQLite Storage:";
SQLiteDatabase myDb;
String path;
String txid = "";
WebView appView;
Storage(WebView view)
{
Package pack = this.getClass().getPackage();
String appPackage = pack.getName();
path = "/data/data/" + appPackage + "/databases/";
appView = view;
}
public void openDatabase(String db, String version, String display_name, long size)
{
path += db + ".db";
myDb = SQLiteDatabase.openOrCreateDatabase(path, null);
}
public void executeSql(String query, String[] params, String tx_id)
{
if(txid.length() == 0)
{
try{
txid = tx_id;
Cursor myCursor = myDb.rawQuery(query, params);
processResults(myCursor);
}
catch (SQLiteException ex)
{
Log.d(LOG_TAG, ex.getMessage());
}
}
}
public void processResults(Cursor cur)
{
String key = "";
String value = "";
String resultString = "";
if (cur.moveToFirst()) {
int colCount = cur.getColumnCount();
do {
resultString = "{";
for(int i = 0; i < colCount; ++i)
{
key = cur.getColumnName(i);
value = cur.getString(i);
resultString += " \"" + key + "\" : \"" + value + "\"";
if (i != (colCount - 1))
resultString += ",";
}
resultString += "}";
appView.loadUrl("javascript:droiddb.addResult('" + resultString + "')");
} while (cur.moveToNext());
appView.loadUrl("javascript:droiddb.completeQuery()");
txid = "";
}
}
}