mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Merge mozilla-central to mozilla-inbound
This commit is contained in:
commit
870b8d7d2c
@ -66,6 +66,7 @@ endif
|
|||||||
|
|
||||||
JAVAC_FLAGS = \
|
JAVAC_FLAGS = \
|
||||||
-target $(JAVA_VERSION) \
|
-target $(JAVA_VERSION) \
|
||||||
|
-source $(JAVA_VERSION) \
|
||||||
-classpath $(JAVA_CLASSPATH) \
|
-classpath $(JAVA_CLASSPATH) \
|
||||||
-bootclasspath $(JAVA_BOOTCLASSPATH) \
|
-bootclasspath $(JAVA_BOOTCLASSPATH) \
|
||||||
-encoding ascii \
|
-encoding ascii \
|
||||||
|
@ -251,6 +251,7 @@ SHELL_WRAPPER1(nativeRun, jstring)
|
|||||||
SHELL_WRAPPER1(notifyGeckoOfEvent, jobject)
|
SHELL_WRAPPER1(notifyGeckoOfEvent, jobject)
|
||||||
SHELL_WRAPPER0(processNextNativeEvent)
|
SHELL_WRAPPER0(processNextNativeEvent)
|
||||||
SHELL_WRAPPER1(setSurfaceView, jobject)
|
SHELL_WRAPPER1(setSurfaceView, jobject)
|
||||||
|
SHELL_WRAPPER1(setSoftwareLayerClient, jobject)
|
||||||
SHELL_WRAPPER0(onResume)
|
SHELL_WRAPPER0(onResume)
|
||||||
SHELL_WRAPPER0(onLowMemory)
|
SHELL_WRAPPER0(onLowMemory)
|
||||||
SHELL_WRAPPER3(callObserver, jstring, jstring, jstring)
|
SHELL_WRAPPER3(callObserver, jstring, jstring, jstring)
|
||||||
@ -259,6 +260,7 @@ SHELL_WRAPPER1(onChangeNetworkLinkStatus, jstring)
|
|||||||
SHELL_WRAPPER1(reportJavaCrash, jstring)
|
SHELL_WRAPPER1(reportJavaCrash, jstring)
|
||||||
SHELL_WRAPPER0(executeNextRunnable)
|
SHELL_WRAPPER0(executeNextRunnable)
|
||||||
SHELL_WRAPPER1(cameraCallbackBridge, jbyteArray)
|
SHELL_WRAPPER1(cameraCallbackBridge, jbyteArray)
|
||||||
|
SHELL_WRAPPER1(notifyUriVisited, jstring)
|
||||||
SHELL_WRAPPER3(notifyBatteryChange, jdouble, jboolean, jdouble);
|
SHELL_WRAPPER3(notifyBatteryChange, jdouble, jboolean, jdouble);
|
||||||
|
|
||||||
static void * xul_handle = NULL;
|
static void * xul_handle = NULL;
|
||||||
@ -653,6 +655,7 @@ loadLibs(const char *apkName)
|
|||||||
GETFUNC(notifyGeckoOfEvent);
|
GETFUNC(notifyGeckoOfEvent);
|
||||||
GETFUNC(processNextNativeEvent);
|
GETFUNC(processNextNativeEvent);
|
||||||
GETFUNC(setSurfaceView);
|
GETFUNC(setSurfaceView);
|
||||||
|
GETFUNC(setSoftwareLayerClient);
|
||||||
GETFUNC(onResume);
|
GETFUNC(onResume);
|
||||||
GETFUNC(onLowMemory);
|
GETFUNC(onLowMemory);
|
||||||
GETFUNC(callObserver);
|
GETFUNC(callObserver);
|
||||||
@ -661,6 +664,7 @@ loadLibs(const char *apkName)
|
|||||||
GETFUNC(reportJavaCrash);
|
GETFUNC(reportJavaCrash);
|
||||||
GETFUNC(executeNextRunnable);
|
GETFUNC(executeNextRunnable);
|
||||||
GETFUNC(cameraCallbackBridge);
|
GETFUNC(cameraCallbackBridge);
|
||||||
|
GETFUNC(notifyUriVisited);
|
||||||
GETFUNC(notifyBatteryChange);
|
GETFUNC(notifyBatteryChange);
|
||||||
#undef GETFUNC
|
#undef GETFUNC
|
||||||
sStartupTimeline = (uint64_t *)__wrap_dlsym(xul_handle, "_ZN7mozilla15StartupTimeline16sStartupTimelineE");
|
sStartupTimeline = (uint64_t *)__wrap_dlsym(xul_handle, "_ZN7mozilla15StartupTimeline16sStartupTimelineE");
|
||||||
|
27
services/sync/tests/tps/restartless.xml
Normal file
27
services/sync/tests/tps/restartless.xml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<searchresults total_results="1">
|
||||||
|
<addon id="5617">
|
||||||
|
<name>Restartless Test XPI</name>
|
||||||
|
<type id="1">Extension</type>
|
||||||
|
<guid>restartless-xpi@tests.mozilla.org</guid>
|
||||||
|
<slug>restartless-xpi</slug>
|
||||||
|
<version>1.0</version>
|
||||||
|
|
||||||
|
<compatible_applications><application>
|
||||||
|
<name>Firefox</name>
|
||||||
|
<application_id>1</application_id>
|
||||||
|
<min_version>3.6</min_version>
|
||||||
|
<max_version>*</max_version>
|
||||||
|
<appID>{ec8030f7-c20a-464f-9b0e-13a3a9e97384}</appID>
|
||||||
|
</application></compatible_applications>
|
||||||
|
<all_compatible_os><os>ALL</os></all_compatible_os>
|
||||||
|
|
||||||
|
<install os="ALL" size="485">http://127.0.0.1:4567/restartless.xpi</install>
|
||||||
|
<created epoch="1252903662">
|
||||||
|
2009-09-14T04:47:42Z
|
||||||
|
</created>
|
||||||
|
<last_updated epoch="1315255329">
|
||||||
|
2011-09-05T20:42:09Z
|
||||||
|
</last_updated>
|
||||||
|
</addon>
|
||||||
|
</searchresults>
|
BIN
services/sync/tests/tps/restartless.xpi
Normal file
BIN
services/sync/tests/tps/restartless.xpi
Normal file
Binary file not shown.
@ -3,82 +3,89 @@ Cu.import("resource://services-sync/async.js");
|
|||||||
|
|
||||||
const SQLITE_CONSTRAINT_VIOLATION = 19; // http://www.sqlite.org/c3ref/c_abort.html
|
const SQLITE_CONSTRAINT_VIOLATION = 19; // http://www.sqlite.org/c3ref/c_abort.html
|
||||||
|
|
||||||
|
function querySpinningly(query, names) {
|
||||||
|
let q = Svc.Form.DBConnection.createStatement(query);
|
||||||
|
let r = Async.querySpinningly(q, names);
|
||||||
|
q.finalize();
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
function run_test() {
|
function run_test() {
|
||||||
initTestLogging("Trace");
|
initTestLogging("Trace");
|
||||||
|
|
||||||
_("Using the form service to test queries");
|
|
||||||
function c(query) Svc.Form.DBConnection.createStatement(query);
|
|
||||||
|
|
||||||
_("Make sure the call is async and allows other events to process");
|
_("Make sure the call is async and allows other events to process");
|
||||||
let isAsync = false;
|
let isAsync = false;
|
||||||
Utils.nextTick(function() { isAsync = true; });
|
Utils.nextTick(function() { isAsync = true; });
|
||||||
do_check_false(isAsync);
|
do_check_false(isAsync);
|
||||||
|
|
||||||
_("Empty out the formhistory table");
|
_("Empty out the formhistory table");
|
||||||
let r0 = Async.querySpinningly(c("DELETE FROM moz_formhistory"));
|
let r0 = querySpinningly("DELETE FROM moz_formhistory");
|
||||||
do_check_eq(r0, null);
|
do_check_eq(r0, null);
|
||||||
|
|
||||||
_("Make sure there's nothing there");
|
_("Make sure there's nothing there");
|
||||||
let r1 = Async.querySpinningly(c("SELECT 1 FROM moz_formhistory"));
|
let r1 = querySpinningly("SELECT 1 FROM moz_formhistory");
|
||||||
do_check_eq(r1, null);
|
do_check_eq(r1, null);
|
||||||
|
|
||||||
_("Insert a row");
|
_("Insert a row");
|
||||||
let r2 = Async.querySpinningly(c("INSERT INTO moz_formhistory (fieldname, value) VALUES ('foo', 'bar')"));
|
let r2 = querySpinningly("INSERT INTO moz_formhistory (fieldname, value) VALUES ('foo', 'bar')");
|
||||||
do_check_eq(r2, null);
|
do_check_eq(r2, null);
|
||||||
|
|
||||||
_("Request a known value for the one row");
|
_("Request a known value for the one row");
|
||||||
let r3 = Async.querySpinningly(c("SELECT 42 num FROM moz_formhistory"), ["num"]);
|
let r3 = querySpinningly("SELECT 42 num FROM moz_formhistory", ["num"]);
|
||||||
do_check_eq(r3.length, 1);
|
do_check_eq(r3.length, 1);
|
||||||
do_check_eq(r3[0].num, 42);
|
do_check_eq(r3[0].num, 42);
|
||||||
|
|
||||||
_("Get multiple columns");
|
_("Get multiple columns");
|
||||||
let r4 = Async.querySpinningly(c("SELECT fieldname, value FROM moz_formhistory"), ["fieldname", "value"]);
|
let r4 = querySpinningly("SELECT fieldname, value FROM moz_formhistory", ["fieldname", "value"]);
|
||||||
do_check_eq(r4.length, 1);
|
do_check_eq(r4.length, 1);
|
||||||
do_check_eq(r4[0].fieldname, "foo");
|
do_check_eq(r4[0].fieldname, "foo");
|
||||||
do_check_eq(r4[0].value, "bar");
|
do_check_eq(r4[0].value, "bar");
|
||||||
|
|
||||||
_("Get multiple columns with a different order");
|
_("Get multiple columns with a different order");
|
||||||
let r5 = Async.querySpinningly(c("SELECT fieldname, value FROM moz_formhistory"), ["value", "fieldname"]);
|
let r5 = querySpinningly("SELECT fieldname, value FROM moz_formhistory", ["value", "fieldname"]);
|
||||||
do_check_eq(r5.length, 1);
|
do_check_eq(r5.length, 1);
|
||||||
do_check_eq(r5[0].fieldname, "foo");
|
do_check_eq(r5[0].fieldname, "foo");
|
||||||
do_check_eq(r5[0].value, "bar");
|
do_check_eq(r5[0].value, "bar");
|
||||||
|
|
||||||
_("Add multiple entries (sqlite doesn't support multiple VALUES)");
|
_("Add multiple entries (sqlite doesn't support multiple VALUES)");
|
||||||
let r6 = Async.querySpinningly(c("INSERT INTO moz_formhistory (fieldname, value) SELECT 'foo', 'baz' UNION SELECT 'more', 'values'"));
|
let r6 = querySpinningly("INSERT INTO moz_formhistory (fieldname, value) SELECT 'foo', 'baz' UNION SELECT 'more', 'values'");
|
||||||
do_check_eq(r6, null);
|
do_check_eq(r6, null);
|
||||||
|
|
||||||
_("Get multiple rows");
|
_("Get multiple rows");
|
||||||
let r7 = Async.querySpinningly(c("SELECT fieldname, value FROM moz_formhistory WHERE fieldname = 'foo'"), ["fieldname", "value"]);
|
let r7 = querySpinningly("SELECT fieldname, value FROM moz_formhistory WHERE fieldname = 'foo'", ["fieldname", "value"]);
|
||||||
do_check_eq(r7.length, 2);
|
do_check_eq(r7.length, 2);
|
||||||
do_check_eq(r7[0].fieldname, "foo");
|
do_check_eq(r7[0].fieldname, "foo");
|
||||||
do_check_eq(r7[1].fieldname, "foo");
|
do_check_eq(r7[1].fieldname, "foo");
|
||||||
|
|
||||||
_("Make sure updates work");
|
_("Make sure updates work");
|
||||||
let r8 = Async.querySpinningly(c("UPDATE moz_formhistory SET value = 'updated' WHERE fieldname = 'more'"));
|
let r8 = querySpinningly("UPDATE moz_formhistory SET value = 'updated' WHERE fieldname = 'more'");
|
||||||
do_check_eq(r8, null);
|
do_check_eq(r8, null);
|
||||||
|
|
||||||
_("Get the updated");
|
_("Get the updated");
|
||||||
let r9 = Async.querySpinningly(c("SELECT value, fieldname FROM moz_formhistory WHERE fieldname = 'more'"), ["fieldname", "value"]);
|
let r9 = querySpinningly("SELECT value, fieldname FROM moz_formhistory WHERE fieldname = 'more'", ["fieldname", "value"]);
|
||||||
do_check_eq(r9.length, 1);
|
do_check_eq(r9.length, 1);
|
||||||
do_check_eq(r9[0].fieldname, "more");
|
do_check_eq(r9[0].fieldname, "more");
|
||||||
do_check_eq(r9[0].value, "updated");
|
do_check_eq(r9[0].value, "updated");
|
||||||
|
|
||||||
_("Grabbing fewer fields than queried is fine");
|
_("Grabbing fewer fields than queried is fine");
|
||||||
let r10 = Async.querySpinningly(c("SELECT value, fieldname FROM moz_formhistory"), ["fieldname"]);
|
let r10 = querySpinningly("SELECT value, fieldname FROM moz_formhistory", ["fieldname"]);
|
||||||
do_check_eq(r10.length, 3);
|
do_check_eq(r10.length, 3);
|
||||||
|
|
||||||
_("Generate an execution error");
|
_("Generate an execution error");
|
||||||
let r11, except, query = c("INSERT INTO moz_formhistory (fieldname, value) VALUES ('one', NULL)");
|
let query = "INSERT INTO moz_formhistory (fieldname, value) VALUES ('one', NULL)";
|
||||||
|
let stmt = Svc.Form.DBConnection.createStatement(query);
|
||||||
|
let r11, except; ;
|
||||||
try {
|
try {
|
||||||
r11 = Async.querySpinningly(query);
|
r11 = Async.querySpinningly(stmt);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
except = e;
|
except = e;
|
||||||
}
|
}
|
||||||
|
stmt.finalize()
|
||||||
do_check_true(!!except);
|
do_check_true(!!except);
|
||||||
do_check_eq(except.result, SQLITE_CONSTRAINT_VIOLATION);
|
do_check_eq(except.result, SQLITE_CONSTRAINT_VIOLATION);
|
||||||
|
|
||||||
_("Cleaning up");
|
_("Cleaning up");
|
||||||
Async.querySpinningly(c("DELETE FROM moz_formhistory"));
|
querySpinningly("DELETE FROM moz_formhistory");
|
||||||
|
|
||||||
_("Make sure the timeout got to run before this function ends");
|
_("Make sure the timeout got to run before this function ends");
|
||||||
do_check_true(isAsync);
|
do_check_true(isAsync);
|
||||||
|
@ -795,6 +795,22 @@ nsWindow::GetThebesSurface()
|
|||||||
return new gfxImageSurface(gfxIntSize(5,5), gfxImageSurface::ImageFormatRGB24);
|
return new gfxImageSurface(gfxIntSize(5,5), gfxImageSurface::ImageFormatRGB24);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class DrawToFileRunnable : public nsRunnable {
|
||||||
|
public:
|
||||||
|
DrawToFileRunnable(nsWindow* win, const nsAString &path) {
|
||||||
|
mPath = path;
|
||||||
|
mWindow = win;
|
||||||
|
}
|
||||||
|
NS_IMETHOD Run() {
|
||||||
|
mWindow->DrawToFile(mPath);
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
private:
|
||||||
|
nsString mPath;
|
||||||
|
nsRefPtr<nsWindow> mWindow;
|
||||||
|
};
|
||||||
|
|
||||||
bool
|
bool
|
||||||
nsWindow::DrawToFile(const nsAString &path)
|
nsWindow::DrawToFile(const nsAString &path)
|
||||||
{
|
{
|
||||||
@ -1008,7 +1024,11 @@ nsWindow::OnGlobalAndroidEvent(AndroidGeckoEvent *ae)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case AndroidGeckoEvent::SAVE_STATE:
|
case AndroidGeckoEvent::SAVE_STATE:
|
||||||
win->DrawToFile(ae->Characters());
|
{
|
||||||
|
nsCOMPtr<nsIThread> thread;
|
||||||
|
nsRefPtr<DrawToFileRunnable> runnable = new DrawToFileRunnable(win, ae->Characters());
|
||||||
|
NS_NewThread(getter_AddRefs(thread), runnable);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -176,12 +176,13 @@ public:
|
|||||||
static bool sAccessibilityEnabled;
|
static bool sAccessibilityEnabled;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
bool DrawToFile(const nsAString &path);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void BringToFront();
|
void BringToFront();
|
||||||
nsWindow *FindTopLevel();
|
nsWindow *FindTopLevel();
|
||||||
bool DrawTo(gfxASurface *targetSurface);
|
bool DrawTo(gfxASurface *targetSurface);
|
||||||
bool DrawTo(gfxASurface *targetSurface, const nsIntRect &aRect);
|
bool DrawTo(gfxASurface *targetSurface, const nsIntRect &aRect);
|
||||||
bool DrawToFile(const nsAString &path);
|
|
||||||
bool IsTopLevel();
|
bool IsTopLevel();
|
||||||
void OnIMEAddRange(mozilla::AndroidGeckoEvent *ae);
|
void OnIMEAddRange(mozilla::AndroidGeckoEvent *ae);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user