diff --git a/framework/assets/js/storage.js b/framework/assets/js/storage.js index d438e084..bacf3f38 100755 --- a/framework/assets/js/storage.js +++ b/framework/assets/js/storage.js @@ -20,30 +20,13 @@ var DroidDB = function() { this.queryQueue = {}; }; -/** - * Callback from native code when result from a query is available. - * PRIVATE METHOD - * - * @param rawdata JSON string of the row data - * @param id Query id - */ -DroidDB.prototype.addResult = function(rawdata, id) { - try { - eval("var data = " + rawdata + ";"); - var query = this.queryQueue[id]; - query.resultSet.push(data); - } catch (e) { - console.log("DroidDB.addResult(): Error="+e); - } -}; - /** * Callback from native code when query is complete. * PRIVATE METHOD * * @param id Query id */ -DroidDB.prototype.completeQuery = function(id) { +DroidDB.prototype.completeQuery = function(id, data) { var query = this.queryQueue[id]; if (query) { try { @@ -59,8 +42,8 @@ DroidDB.prototype.completeQuery = function(id) { // Save query results var r = new DroidDB_Result(); - r.rows.resultSet = query.resultSet; - r.rows.length = query.resultSet.length; + r.rows.resultSet = data; + r.rows.length = data.length; try { if (typeof query.successCallback == 'function') { query.successCallback(query.tx, r); diff --git a/framework/src/com/phonegap/Storage.java b/framework/src/com/phonegap/Storage.java index 3cf798c5..de30afb2 100755 --- a/framework/src/com/phonegap/Storage.java +++ b/framework/src/com/phonegap/Storage.java @@ -160,24 +160,25 @@ public class Storage extends Plugin { */ public void processResults(Cursor cur, String tx_id) { + String result = "[]"; // If query result has rows + if (cur.moveToFirst()) { + JSONArray fullresult = new JSONArray(); String key = ""; String value = ""; int colCount = cur.getColumnCount(); // Build up JSON result object for each row do { - JSONObject result = new JSONObject(); + JSONObject row = new JSONObject(); try { for (int i = 0; i < colCount; ++i) { key = cur.getColumnName(i); - value = cur.getString(i).replace("\"", "\\\""); // must escape " with \" for JavaScript - result.put(key, value); + value = cur.getString(i); + row.put(key, value); } - - // Send row back to JavaScript - this.sendJavascript("droiddb.addResult('" + result.toString() + "','" + tx_id + "');"); + fullresult.put(row); } catch (JSONException e) { e.printStackTrace(); @@ -185,9 +186,11 @@ public class Storage extends Plugin { } while (cur.moveToNext()); + result = fullresult.toString(); } + // Let JavaScript know that there are no more rows - this.sendJavascript("droiddb.completeQuery('" + tx_id + "');"); + this.sendJavascript("droiddb.completeQuery('" + tx_id + "', "+result+");"); }