- /* from SM UBhistory, needs to be adapted
- // Open or create the urlbar history database.
- var file = Components.classes["@mozilla.org/file/directory_service;1"]
- .getService(Components.interfaces.nsIProperties)
- .get("ProfD", Components.interfaces.nsIFile);
- file.append("urlbarhistory.sqlite");
- var connection = Components.classes["@mozilla.org/storage/service;1"]
- .getService(Components.interfaces.mozIStorageService)
- .openDatabase(file);
- connection.beginTransaction();
- if (!connection.tableExists("urlbarhistory"))
- connection.createTable("urlbarhistory", "url TEXT, foo INTEGER, bar REAL");
- // NULL. The value is a NULL value.
- // INTEGER. The value is a signed integer, stored in 1, 2, 3, 4, 6, or 8 bytes depending on the magnitude of the value.
- // REAL. The value is a floating point value, stored as an 8-byte IEEE floating point number.
- // TEXT. The value is a text string, stored using the database encoding (UTF-8, UTF-16BE or UTF-16-LE).
-
- // Put the value as it was typed by the user in to urlbar history
- statement = connection.createStatement(
- "INSERT INTO urlbarhistory (url) VALUES (?1)");
- statement.bindStringParameter(0, aUrlToAdd);
- statement.execute();
- statement.finalize();
- */
+ // XXX: retrieve wanted bookmark name
+ var bmName = "mandelbrot bm test";
+
+ // Open or create the bookmarks database.
+ var file = Components.classes["@mozilla.org/file/directory_service;1"]
+ .getService(Components.interfaces.nsIProperties)
+ .get("ProfD", Components.interfaces.nsIFile);
+ file.append("mandelbookmarks.sqlite");
+ var connection = Components.classes["@mozilla.org/storage/service;1"]
+ .getService(Components.interfaces.mozIStorageService)
+ .openDatabase(file);
+ connection.beginTransaction();
+ if (!connection.tableExists("bookmarks"))
+ connection.createTable("bookmarks", "name TEXT, iteration_max INTEGER, Cr_min REAL, Cr_max REAL, Ci_min REAL, Ci_max REAL");
+ // NULL. The value is a NULL value.
+ // INTEGER. The value is a signed integer, stored in 1, 2, 3, 4, 6, or 8 bytes depending on the magnitude of the value.
+ // REAL. The value is a floating point value, stored as an 8-byte IEEE floating point number.
+ // TEXT. The value is a text string, stored using the database encoding (UTF-8, UTF-16BE or UTF-16-LE).
+
+ // Put value of the current image into the bookmarks table
+ var statement = connection.createStatement(
+ "INSERT INTO bookmarks (name,iteration_max,Cr_min,Cr_max,Ci_min,Ci_max) VALUES (?1,?2,?3,?4,?5,?6)");
+ statement.bindStringParameter(0, bmName);
+ statement.bindStringParameter(1, gPref.getIntPref("mandelbrot.iteration_max"));
+ statement.bindStringParameter(2, parseFloat(gPref.getCharPref("mandelbrot.last_image.Cr_min")));
+ statement.bindStringParameter(3, parseFloat(gPref.getCharPref("mandelbrot.last_image.Cr_max")));
+ statement.bindStringParameter(4, parseFloat(gPref.getCharPref("mandelbrot.last_image.Ci_min")));
+ statement.bindStringParameter(5, parseFloat(gPref.getCharPref("mandelbrot.last_image.Ci_max")));
+ statement.execute();
+ statement.finalize();
+ connection.commitTransaction();
+ connection.close();