]> sigrok.org Git - pulseview.git/blame - main.cpp
Make get_raw_samples() use provided mem instead of allocating
[pulseview.git] / main.cpp
CommitLineData
d7bed479 1/*
b3f22de0 2 * This file is part of the PulseView project.
d7bed479
JH
3 *
4 * Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
efdec55a 17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
d7bed479
JH
18 */
19
269528f5 20#ifdef ENABLE_DECODE
aaabd61b 21#include <libsigrokdecode/libsigrokdecode.h> /* First, so we avoid a _POSIX_C_SOURCE warning. */
269528f5 22#endif
d52d8455 23
15a69e54 24#include <cstdint>
fe3a1c21 25#include <libsigrokcxx/libsigrokcxx.hpp>
664fca5c 26
f7951df4
JH
27#include <getopt.h>
28
664fca5c 29#include <QDebug>
0bd39c0c 30#include <QSettings>
075fb499 31
140181a4 32#ifdef ENABLE_SIGNALS
2acdb232 33#include "signalhandler.hpp"
140181a4
JH
34#endif
35
2acdb232
JH
36#include "pv/application.hpp"
37#include "pv/devicemanager.hpp"
38#include "pv/mainwindow.hpp"
9137928c 39#ifdef ANDROID
aff51746 40#include <libsigrokandroidutils/libsigrokandroidutils.h>
dddff2e7 41#include "android/assetreader.hpp"
2acdb232 42#include "android/loghandler.hpp"
9137928c 43#endif
d7bed479 44
075fb499
AG
45#include "config.h"
46
11a04e2a 47#ifdef _WIN32
11a04e2a 48#include <QtPlugin>
09f55d96
UH
49Q_IMPORT_PLUGIN(QWindowsIntegrationPlugin)
50Q_IMPORT_PLUGIN(QSvgPlugin)
11a04e2a
UH
51#endif
52
6f925ba9
UH
53using std::exception;
54using std::shared_ptr;
55using std::string;
56
d4384c6d
JH
57void usage()
58{
9fd5bb6e 59 fprintf(stdout,
d4384c6d 60 "Usage:\n"
41e2ade4 61 " %s [OPTIONS] [FILE]\n"
d4384c6d
JH
62 "\n"
63 "Help Options:\n"
d4384c6d 64 " -h, -?, --help Show help option\n"
aa90e86b
JH
65 "\n"
66 "Application Options:\n"
67 " -V, --version Show release version\n"
68 " -l, --loglevel Set libsigrok/libsigrokdecode loglevel\n"
58d8e4c6 69 " -d, --driver Specify the device driver to use\n"
e3c79b07
JH
70 " -i, --input-file Load input from file\n"
71 " -I, --input-format Input format\n"
156f06e9 72 " -c, --clean Don't restore previous sessions on startup\n"
41e2ade4 73 "\n", PV_BIN_NAME);
d4384c6d
JH
74}
75
d7bed479
JH
76int main(int argc, char *argv[])
77{
be03620e 78 int ret = 0;
6f925ba9 79 shared_ptr<sigrok::Context> context;
58d8e4c6 80 string open_file, open_file_format, driver;
156f06e9 81 bool restore_sessions = true;
f2242929 82
dac1bb97 83 Application a(argc, argv);
640e5565 84
9137928c 85#ifdef ANDROID
aff51746 86 srau_init_environment();
9137928c 87 pv::AndroidLogHandler::install_callbacks();
dddff2e7 88 pv::AndroidAssetReader asset_reader;
9137928c
MC
89#endif
90
f7951df4 91 // Parse arguments
15a69e54 92 while (true) {
f7951df4 93 static const struct option long_options[] = {
f74015db
UH
94 {"help", no_argument, nullptr, 'h'},
95 {"version", no_argument, nullptr, 'V'},
96 {"loglevel", required_argument, nullptr, 'l'},
58d8e4c6 97 {"driver", required_argument, nullptr, 'd'},
f74015db
UH
98 {"input-file", required_argument, nullptr, 'i'},
99 {"input-format", required_argument, nullptr, 'I'},
156f06e9 100 {"clean", no_argument, nullptr, 'c'},
f74015db 101 {nullptr, 0, nullptr, 0}
f7951df4
JH
102 };
103
815b3f26 104 const int c = getopt_long(argc, argv,
58d8e4c6 105 "l:Vhc?d:i:I:", long_options, nullptr);
f7951df4
JH
106 if (c == -1)
107 break;
108
109 switch (c) {
aa90e86b
JH
110 case 'h':
111 case '?':
112 usage();
113 return 0;
114
115 case 'V':
116 // Print version info
117 fprintf(stdout, "%s %s\n", PV_TITLE, PV_VERSION_STRING);
118 return 0;
119
9b5099b6
JH
120 case 'l':
121 {
122 const int loglevel = atoi(optarg);
e8d00928 123 context->set_log_level(sigrok::LogLevel::get(loglevel));
269528f5
JH
124
125#ifdef ENABLE_DECODE
9b5099b6 126 srd_log_loglevel_set(loglevel);
269528f5 127#endif
d52d8455 128
0bd39c0c
UH
129 if (loglevel >= 5) {
130 const QSettings settings;
131 qDebug() << "Settings:" << settings.fileName()
132 << "format" << settings.format();
133 }
9b5099b6
JH
134 break;
135 }
e3c79b07 136
58d8e4c6
GS
137 case 'd':
138 driver = optarg;
139 break;
140
e3c79b07
JH
141 case 'i':
142 open_file = optarg;
143 break;
144
145 case 'I':
146 open_file_format = optarg;
147 break;
156f06e9
SA
148
149 case 'c':
150 restore_sessions = false;
151 break;
f7951df4
JH
152 }
153 }
154
3e5bc268 155 if (argc - optind > 1) {
39ccf9c3 156 fprintf(stderr, "Only one file can be opened.\n");
1d478458 157 return 1;
e3c79b07 158 }
1d478458 159
c063290a
UH
160 if (argc - optind == 1)
161 open_file = argv[argc - 1];
162
6a6772b7 163 // Initialise libsigrok
e8d00928 164 context = sigrok::Context::create();
dddff2e7
DE
165#ifdef ANDROID
166 context->set_resource_reader(&asset_reader);
167#endif
d52d8455
JH
168 do {
169
269528f5 170#ifdef ENABLE_DECODE
d52d8455 171 // Initialise libsigrokdecode
4c60462b 172 if (srd_init(nullptr) != SRD_OK) {
d52d8455
JH
173 qDebug() << "ERROR: libsigrokdecode init failed.";
174 break;
175 }
be03620e
JH
176
177 // Load the protocol decoders
178 srd_decoder_load_all();
269528f5 179#endif
be03620e 180
107ca6d3
JH
181 try {
182 // Create the device manager, initialise the drivers
58d8e4c6 183 pv::DeviceManager device_manager(context, driver);
664fca5c 184
be03620e 185 // Initialise the main window
3ed18835 186 pv::MainWindow w(device_manager);
be03620e 187 w.show();
664fca5c 188
3ed18835
SA
189 if (restore_sessions)
190 w.restore_sessions();
191
192 if (!open_file.empty())
193 w.add_session_with_file(open_file, open_file_format);
194 else
195 w.add_default_session();
196
140181a4 197#ifdef ENABLE_SIGNALS
f3290553 198 if (SignalHandler::prepare_signals()) {
708605aa 199 SignalHandler *const handler =
7a255aa9 200 new SignalHandler(&w);
708605aa
JH
201 QObject::connect(handler,
202 SIGNAL(int_received()),
7a255aa9 203 &w, SLOT(close()));
708605aa
JH
204 QObject::connect(handler,
205 SIGNAL(term_received()),
7a255aa9 206 &w, SLOT(close()));
360ab9be 207 } else {
7a255aa9
JH
208 qWarning() <<
209 "Could not prepare signal handler.";
210 }
140181a4 211#endif
7a255aa9 212
be03620e
JH
213 // Run the application
214 ret = a.exec();
107ca6d3 215
6f925ba9 216 } catch (exception e) {
107ca6d3 217 qDebug() << e.what();
6fb67b27 218 }
6fb67b27 219
269528f5 220#ifdef ENABLE_DECODE
d52d8455 221 // Destroy libsigrokdecode
be03620e 222 srd_exit();
269528f5 223#endif
664fca5c 224
15a69e54 225 } while (false);
664fca5c 226
664fca5c 227 return ret;
d7bed479 228}