Clean up ChunkedUpdateDrawingAreaProxy
[WebKit-https.git] / Tools / QtTestBrowser / main.cpp
1 /*
2  * Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies)
3  * Copyright (C) 2009 Girish Ramakrishnan <girish@forwardbias.in>
4  * Copyright (C) 2006 George Staikos <staikos@kde.org>
5  * Copyright (C) 2006 Dirk Mueller <mueller@kde.org>
6  * Copyright (C) 2006 Zack Rusin <zack@kde.org>
7  * Copyright (C) 2006 Simon Hausmann <hausmann@kde.org>
8  *
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions and the following disclaimer.
16  * 2. Redistributions in binary form must reproduce the above copyright
17  *    notice, this list of conditions and the following disclaimer in the
18  *    documentation and/or other materials provided with the distribution.
19  *
20  * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
21  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE COMPUTER, INC. OR
24  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
28  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32
33 #include "launcherwindow.h"
34 #include "urlloader.h"
35
36 WindowOptions windowOptions;
37
38 int launcherMain(const QApplication& app)
39 {
40 #ifndef NDEBUG
41     int retVal = app.exec();
42     DumpRenderTreeSupportQt::garbageCollectorCollect();
43     QWebSettings::clearMemoryCaches();
44     return retVal;
45 #else
46     return app.exec();
47 #endif
48 }
49
50 class LauncherApplication : public QApplication {
51     Q_OBJECT
52
53 public:
54     LauncherApplication(int& argc, char** argv);
55     QStringList urls() const { return m_urls; }
56     bool isRobotized() const { return m_isRobotized; }
57     int robotTimeout() const { return m_robotTimeoutSeconds; }
58     int robotExtraTime() const { return m_robotExtraTimeSeconds; }
59
60 private:
61     void handleUserOptions();
62     void applyDefaultSettings();
63
64 private:
65     bool m_isRobotized;
66     int m_robotTimeoutSeconds;
67     int m_robotExtraTimeSeconds;
68     QStringList m_urls;
69 };
70
71 void LauncherApplication::applyDefaultSettings()
72 {
73     QWebSettings::setMaximumPagesInCache(4);
74
75     QWebSettings::setObjectCacheCapacities((16*1024*1024) / 8, (16*1024*1024) / 8, 16*1024*1024);
76
77     QWebSettings::globalSettings()->setAttribute(QWebSettings::PluginsEnabled, true);
78     QWebSettings::globalSettings()->setAttribute(QWebSettings::DeveloperExtrasEnabled, true);
79     QWebSettings::enablePersistentStorage();
80 }
81
82 LauncherApplication::LauncherApplication(int& argc, char** argv)
83     : QApplication(argc, argv, QApplication::GuiServer)
84     , m_isRobotized(false)
85     , m_robotTimeoutSeconds(0)
86     , m_robotExtraTimeSeconds(0)
87 {
88     // To allow QWebInspector's configuration persistence
89     setOrganizationName("Nokia");
90     setApplicationName("QtTestBrowser");
91     setApplicationVersion("0.1");
92
93     applyDefaultSettings();
94
95     handleUserOptions();
96 }
97
98 static void requiresGraphicsView(const QString& option)
99 {
100     if (windowOptions.useGraphicsView)
101         return;
102     appQuit(1, QString("%1 only works in combination with the -graphicsbased option").arg(option));
103 }
104
105 void LauncherApplication::handleUserOptions()
106 {
107     QStringList args = arguments();
108     QFileInfo program(args.at(0));
109     QString programName("QtTestBrowser");
110     if (program.exists())
111         programName = program.baseName();
112
113     QList<QString> updateModes(enumToKeys(QGraphicsView::staticMetaObject,
114             "ViewportUpdateMode", "ViewportUpdate"));
115
116     if (args.contains("-help")) {
117         qDebug() << "Usage:" << programName.toLatin1().data()
118              << "[-graphicsbased]"
119              << "[-no-compositing]"
120              << QString("[-viewport-update-mode %1]").arg(formatKeys(updateModes)).toLatin1().data()
121              << "[-cache-webview]"
122              << "[-show-fps]"
123              << "[-r list]"
124              << "[-robot-timeout seconds]"
125              << "[-robot-extra-time seconds]"
126              << "[-inspector-url location]"
127              << "[-tiled-backing-store]"
128              << "[-resizes-to-contents]"
129              << "URLs";
130         appQuit(0);
131     }
132
133     const bool defaultForAnimations = args.contains("-default-animations");
134     if (args.contains("-graphicsbased") || defaultForAnimations)
135         windowOptions.useGraphicsView = true;
136
137     if (args.contains("-no-compositing")) {
138         requiresGraphicsView("-no-compositing");
139         windowOptions.useCompositing = false;
140     }
141
142     if (args.contains("-show-fps")) {
143         requiresGraphicsView("-show-fps");
144         windowOptions.showFrameRate = true;
145     }
146
147     if (args.contains("-cache-webview") || defaultForAnimations) {
148         requiresGraphicsView("-cache-webview");
149         windowOptions.cacheWebView = true;
150     }
151
152     if (args.contains("-tiled-backing-store")) {
153         requiresGraphicsView("-tiled-backing-store");
154         windowOptions.useTiledBackingStore = true;
155     }
156
157     if (args.contains("-resizes-to-contents")) {
158         requiresGraphicsView("-resizes-to-contents");
159         windowOptions.resizesToContents = true;
160     }
161
162     if (defaultForAnimations)
163         windowOptions.viewportUpdateMode = QGraphicsView::BoundingRectViewportUpdate;
164
165     QString arg1("-viewport-update-mode");
166     int modeIndex = args.indexOf(arg1);
167     if (modeIndex != -1) {
168         requiresGraphicsView(arg1);
169
170         QString mode = takeOptionValue(&args, modeIndex);
171         if (mode.isEmpty())
172             appQuit(1, QString("%1 needs a value of one of [%2]").arg(arg1).arg(formatKeys(updateModes)));
173         int idx = updateModes.indexOf(mode);
174         if (idx == -1)
175             appQuit(1, QString("%1 value has to be one of [%2]").arg(arg1).arg(formatKeys(updateModes)));
176
177         windowOptions.viewportUpdateMode = static_cast<QGraphicsView::ViewportUpdateMode>(idx);
178     }
179 #ifdef QT_CONFIGURED_WITH_OPENGL
180     if (args.contains("-gl-viewport") || defaultForAnimations) {
181         requiresGraphicsView("-gl-viewport");
182         windowOptions.useQGLWidgetViewport = true;
183     }
184 #endif
185
186     QString inspectorUrlArg("-inspector-url");
187     int inspectorUrlIndex = args.indexOf(inspectorUrlArg);
188     if (inspectorUrlIndex != -1)
189        windowOptions.inspectorUrl = takeOptionValue(&args, inspectorUrlIndex);
190
191     QString remoteInspectorPortArg("-remote-inspector-port");
192     int remoteInspectorPortIndex = args.indexOf(remoteInspectorPortArg);
193     if (remoteInspectorPortIndex != -1)
194         windowOptions.remoteInspectorPort = takeOptionValue(&args, remoteInspectorPortIndex).toInt();
195
196     int robotIndex = args.indexOf("-r");
197     if (robotIndex != -1) {
198         QString listFile = takeOptionValue(&args, robotIndex);
199         if (listFile.isEmpty())
200             appQuit(1, "-r needs a list file to start in robotized mode");
201         if (!QFile::exists(listFile))
202             appQuit(1, "The list file supplied to -r does not exist.");
203
204         m_isRobotized = true;
205         m_urls = QStringList(listFile);
206     } else {
207         int lastArg = args.lastIndexOf(QRegExp("^-.*"));
208         m_urls = (lastArg != -1) ? args.mid(++lastArg) : args.mid(1);
209     }
210
211     int robotTimeoutIndex = args.indexOf("-robot-timeout");
212     if (robotTimeoutIndex != -1)
213         m_robotTimeoutSeconds = takeOptionValue(&args, robotTimeoutIndex).toInt();
214
215     int robotExtraTimeIndex = args.indexOf("-robot-extra-time");
216     if (robotExtraTimeIndex != -1)
217         m_robotExtraTimeSeconds = takeOptionValue(&args, robotExtraTimeIndex).toInt();
218 }
219
220
221 int main(int argc, char **argv)
222 {
223     LauncherApplication app(argc, argv);
224
225     if (app.isRobotized()) {
226         LauncherWindow* window = new LauncherWindow();
227         UrlLoader loader(window->page()->mainFrame(), app.urls().at(0), app.robotTimeout(), app.robotExtraTime());
228         loader.loadNext();
229         window->show();
230         return launcherMain(app);
231     }
232
233     QStringList urls = app.urls();
234
235     if (urls.isEmpty()) {
236         QString defaultIndexFile = QString("%1/%2").arg(QDir::homePath()).arg(QLatin1String("index.html"));
237         if (QFile(defaultIndexFile).exists())
238             urls.append(QString("file://") + defaultIndexFile);
239         else
240             urls.append("");
241     }
242
243     LauncherWindow* window = 0;
244     foreach (QString url, urls) {
245         LauncherWindow* newWindow;
246         if (!window)
247             newWindow = window = new LauncherWindow(&windowOptions);
248         else
249             newWindow = window->newWindow();
250
251         newWindow->load(url);
252     }
253
254     window->show();
255     return launcherMain(app);
256 }
257
258 #include "main.moc"