OSDN Git Service

Adapt for latest MUtils changes.
[x264-launcher/x264-launcher.git] / src / main.cpp
1 ///////////////////////////////////////////////////////////////////////////////
2 // Simple x264 Launcher
3 // Copyright (C) 2004-2016 LoRd_MuldeR <MuldeR2@GMX.de>
4 //
5 // This program is free software; you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation; either version 2 of the License, or
8 // (at your option) any later version.
9 //
10 // This program is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License along
16 // with this program; if not, write to the Free Software Foundation, Inc.,
17 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 //
19 // http://www.gnu.org/licenses/gpl-2.0.txt
20 ///////////////////////////////////////////////////////////////////////////////
21
22 //Internal
23 #include "global.h"
24 #include "win_main.h"
25 #include "cli.h"
26 #include "ipc.h"
27 #include "thread_ipc_send.h"
28
29 //MUtils
30 #include <MUtils/Startup.h>
31 #include <MUtils/OSSupport.h>
32 #include <MUtils/CPUFeatures.h>
33 #include <MUtils/IPCChannel.h>
34 #include <MUtils/Version.h>
35
36 //Qt includes
37 #include <QApplication>
38 #include <QDate>
39 #include <QPlastiqueStyle>
40
41 //Windows includes
42 #define NOMINMAX
43 #define WIN32_LEAN_AND_MEAN
44 #include <Windows.h>
45
46 ///////////////////////////////////////////////////////////////////////////////
47 // Helper functions
48 ///////////////////////////////////////////////////////////////////////////////
49
50 static void x264_print_logo(void)
51 {
52         //Print version info
53         qDebug("Simple x264 Launcher v%u.%02u.%u - use 64-Bit x264 with 32-Bit Avisynth", x264_version_major(), x264_version_minor(), x264_version_build());
54         qDebug("Copyright (c) 2004-%04d LoRd_MuldeR <mulder2@gmx.de>. Some rights reserved.", qMax(MUtils::Version::app_build_date().year(), MUtils::OS::current_date().year()));
55         qDebug("Built on %s at %s with %s for Win-%s.\n", MUTILS_UTF8(MUtils::Version::app_build_date().toString(Qt::ISODate)), MUTILS_UTF8(MUtils::Version::app_build_time().toString(Qt::ISODate)), MUtils::Version::compiler_version(), MUtils::Version::compiler_arch());
56
57         //print license info
58         qDebug("This program is free software: you can redistribute it and/or modify");
59         qDebug("it under the terms of the GNU General Public License <http://www.gnu.org/>.");
60         qDebug("Note that this program is distributed with ABSOLUTELY NO WARRANTY.\n");
61
62         //Print library version
63         qDebug("This application is powerd by MUtils library v%u.%02u (%s, %s).\n", MUtils::Version::lib_version_major(), MUtils::Version::lib_version_minor(), MUTILS_UTF8(MUtils::Version::lib_build_date().toString(Qt::ISODate)), MUTILS_UTF8(MUtils::Version::lib_build_time().toString(Qt::ISODate)));
64
65         //Print warning, if this is a "debug" build
66         if(MUTILS_DEBUG)
67         {
68                 qWarning("---------------------------------------------------------");
69                 qWarning("DEBUG BUILD: DO NOT RELEASE THIS BINARY TO THE PUBLIC !!!");
70                 qWarning("---------------------------------------------------------\n"); 
71         }
72 }
73
74 static int x264_initialize_ipc(MUtils::IPCChannel *const ipcChannel)
75 {
76                 int iResult = 0;
77
78         if((iResult = ipcChannel->initialize()) != MUtils::IPCChannel::RET_SUCCESS_MASTER)
79         {
80                 if(iResult == MUtils::IPCChannel::RET_SUCCESS_SLAVE)
81                 {
82                         qDebug("Simple x264 Launcher is already running, connecting to running instance...");
83                         QScopedPointer<IPCThread_Send> messageProducerThread(new IPCThread_Send(ipcChannel));
84                         messageProducerThread->start();
85                         if(!messageProducerThread->wait(30000))
86                         {
87                                 qWarning("MessageProducer thread has encountered timeout -> going to kill!");
88                                 messageProducerThread->terminate();
89                                 messageProducerThread->wait();
90                                 MUtils::OS::system_message_err(L"Simple x264 Launcher", L"Simple x264 Launcher is already running, but the running instance doesn't respond!");
91                                 return -1;
92                         }
93                         return 0;
94                 }
95                 else
96                 {
97                         qFatal("The IPC initialization has failed!");
98                         return -1;
99                 }
100         }
101
102         return 1;
103 }
104
105 ///////////////////////////////////////////////////////////////////////////////
106 // Main function
107 ///////////////////////////////////////////////////////////////////////////////
108
109 static int simple_x264_main(int &argc, char **argv)
110 {
111         int iResult = -1;
112
113         //Print logo
114         x264_print_logo();
115
116         //Get CLI arguments
117         const MUtils::OS::ArgumentMap &arguments = MUtils::OS::arguments();
118
119         //Enumerate CLI arguments
120         if(!arguments.isEmpty())
121         {
122                 qDebug("Command-Line Arguments:");
123                 foreach(const QString &key, arguments.uniqueKeys())
124                 {
125                         foreach(const QString &val, arguments.values(key))
126                         {
127                                 if(!val.isEmpty())
128                                 {
129                                         qDebug("--%s = \"%s\"", MUTILS_UTF8(key), MUTILS_UTF8(val));
130                                         continue;
131                                 }
132                                 qDebug("--%s", MUTILS_UTF8(key));
133                         }
134                 }
135                 qDebug(" ");
136         }
137
138         //Detect CPU capabilities
139         const MUtils::CPUFetaures::cpu_info_t cpuFeatures = MUtils::CPUFetaures::detect();
140         qDebug("   CPU vendor id  :  %s (Intel=%s)", cpuFeatures.idstr, MUTILS_BOOL2STR(cpuFeatures.vendor & MUtils::CPUFetaures::VENDOR_INTEL));
141         qDebug("CPU brand string  :  %s", cpuFeatures.brand);
142         qDebug("   CPU signature  :  Family=%d Model=%d Stepping=%d", cpuFeatures.family, cpuFeatures.model, cpuFeatures.stepping);
143         qDebug("CPU capabilities  :  CMOV=%s MMX=%s SSE=%s SSE2=%s SSE3=%s SSSE3=%s", MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_CMOV), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_MMX), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_SSE), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_SSE2), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_SSE3), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_SSSE3));
144         qDebug("CPU capabilities  :  SSE4.1=%s SSE4.2=%s AVX=%s EM64T/AMD64=%s", MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_SSE4), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_SSE42), MUTILS_BOOL2STR(cpuFeatures.features & MUtils::CPUFetaures::FLAG_AVX), MUTILS_BOOL2STR(cpuFeatures.x64));
145         qDebug(" Number of CPU's  :  %d\n", cpuFeatures.count);
146
147         //Initialize Qt
148         QScopedPointer<QApplication> application(MUtils::Startup::create_qt(argc, argv, QLatin1String("Simple x264 Launcher")));
149         if(application.isNull())
150         {
151                 return EXIT_FAILURE;
152         }
153
154         //Initialize application
155         application->setWindowIcon(QIcon(":/icons/movie.ico"));
156         application->setApplicationVersion(QString().sprintf("%d.%02d.%04d", x264_version_major(), x264_version_minor(), x264_version_build())); 
157
158         //Initialize the IPC handler class
159         QScopedPointer<MUtils::IPCChannel> ipcChannel(new MUtils::IPCChannel("simple-x264-launcher", x264_version_build(), "instance"));
160         if((iResult = x264_initialize_ipc(ipcChannel.data())) < 1)
161         {
162                 return (iResult == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
163         }
164
165         //Running in portable mode?
166         if(x264_is_portable())
167         {
168                 qDebug("Application is running in portable mode!\n");
169         }
170
171         //Set style
172         if(!arguments.contains(CLI_PARAM_NO_GUI_STYLE))
173         {
174                 qApp->setStyle(new QPlastiqueStyle());
175         }
176
177         //Create Main Window
178         QScopedPointer<MainWindow> mainWindow(new MainWindow(cpuFeatures, ipcChannel.data()));
179         mainWindow->show();
180
181         //Run application
182         int ret = qApp->exec();
183         
184         //Exit program
185         return ret;
186 }
187
188 ///////////////////////////////////////////////////////////////////////////////
189 // Applicaton entry point
190 ///////////////////////////////////////////////////////////////////////////////
191
192 int main(int argc, char* argv[])
193 {
194         return MUtils::Startup::startup(argc, argv, simple_x264_main, "Simple x264 Launcher", x264_is_prerelease());
195 }