]> git.cworth.org Git - apitrace/blobdiff - gui/main.cpp
qapitrace: Determine binary dir in run-time.
[apitrace] / gui / main.cpp
index dcfb6c2eea721e0e781f053d89844abca32de0fb..471dec7939c7eccd88c4d1c882a121ea2a587b08 100644 (file)
@@ -1,24 +1,82 @@
 #include "mainwindow.h"
 
-#include "trace_model.hpp"
+#include "apitrace.h"
+#include "apitracecall.h"
+
+#include "os_string.hpp"
+#include "os_process.hpp"
 
 #include <QApplication>
 #include <QMetaType>
 #include <QVariant>
+#include <QImage>
 
-Q_DECLARE_METATYPE(QList<Trace::Call*>);
+Q_DECLARE_METATYPE(QList<ApiTraceFrame*>);
+Q_DECLARE_METATYPE(QVector<ApiTraceCall*>);
+Q_DECLARE_METATYPE(Qt::CaseSensitivity);
+Q_DECLARE_METATYPE(ApiTrace::SearchResult);
+Q_DECLARE_METATYPE(ApiTrace::SearchRequest);
+Q_DECLARE_METATYPE(QList<QImage>);
+
+static void usage(void)
+{
+    qWarning("usage: qapitrace [TRACE] [CALLNO]\n");
+}
 
 int main(int argc, char **argv)
 {
+    QApplication::setGraphicsSystem("raster");
     QApplication app(argc, argv);
 
-    qRegisterMetaType<QList<Trace::Call*> >();
-    MainWindow window;
+    qRegisterMetaType<QList<ApiTraceFrame*> >();
+    qRegisterMetaType<QVector<ApiTraceCall*> >();
+    qRegisterMetaType<ApiTraceState>();
+    qRegisterMetaType<Qt::CaseSensitivity>();
+    qRegisterMetaType<ApiTrace::SearchResult>();
+    qRegisterMetaType<ApiTrace::SearchRequest>();
+    qRegisterMetaType<QList<QImage> >();
 
+#ifndef Q_OS_WIN
+    os::String currentProcess = os::getProcessName();
+    currentProcess.trimFilename();
+    QString path = qgetenv("PATH");
+    path = QLatin1String(currentProcess.str()) + QLatin1String(":") + path;
+    qputenv("PATH", path.toLatin1());
+#endif
+
+    QStringList args = app.arguments();
+
+    int i = 1;
+    while (i < args.count()) {
+        QString arg = args[i];
+        if (arg[0] != QLatin1Char('-')) {
+            break;
+        }
+        ++i;
+        if (arg == QLatin1String("--")) {
+            break;
+        } else if (arg == QLatin1String("-h") ||
+                   arg == QLatin1String("--help")) {
+            usage();
+            exit(0);
+        } else {
+            usage();
+            exit(1);
+        }
+    }
+
+    MainWindow window;
     window.show();
 
-    if (app.arguments().count() == 2)
-        window.loadTrace(app.arguments()[1]);
+    if (i < args.count()) {
+        QString fileName = args[i++];
+
+        int callNum = -1;
+        if (i < args.count()) {
+            callNum = args[i++].toInt();
+        }
+        window.loadTrace(fileName, callNum);
+    }
 
     app.exec();
 }