mirror of
https://github.com/juce-framework/JUCE.git
synced 2026-01-10 23:44:24 +00:00
Projucer: add feature download & install live-build engine (including checks for supported OS versions)
This commit is contained in:
parent
42b8156cf6
commit
a0350e4ee6
13 changed files with 411 additions and 97 deletions
|
|
@ -61,6 +61,7 @@ OBJECTS := \
|
|||
$(JUCE_OBJDIR)/jucer_AutoUpdater_ca658dc2.o \
|
||||
$(JUCE_OBJDIR)/jucer_CommandLine_f35de107.o \
|
||||
$(JUCE_OBJDIR)/jucer_DocumentEditorComponent_695dff1d.o \
|
||||
$(JUCE_OBJDIR)/jucer_DownloadCompileEngineThread_8a38703f.o \
|
||||
$(JUCE_OBJDIR)/jucer_GlobalPreferences_b0f1bd3d.o \
|
||||
$(JUCE_OBJDIR)/jucer_Main_f8488f5b.o \
|
||||
$(JUCE_OBJDIR)/jucer_MainWindow_1e163aeb.o \
|
||||
|
|
@ -154,6 +155,11 @@ $(JUCE_OBJDIR)/jucer_DocumentEditorComponent_695dff1d.o: ../../Source/Applicatio
|
|||
@echo "Compiling jucer_DocumentEditorComponent.cpp"
|
||||
@$(CXX) $(JUCE_CXXFLAGS) -o "$@" -c "$<"
|
||||
|
||||
$(JUCE_OBJDIR)/jucer_DownloadCompileEngineThread_8a38703f.o: ../../Source/Application/jucer_DownloadCompileEngineThread.cpp
|
||||
-@mkdir -p $(JUCE_OBJDIR)
|
||||
@echo "Compiling jucer_DownloadCompileEngineThread.cpp"
|
||||
@$(CXX) $(JUCE_CXXFLAGS) -o "$@" -c "$<"
|
||||
|
||||
$(JUCE_OBJDIR)/jucer_GlobalPreferences_b0f1bd3d.o: ../../Source/Application/jucer_GlobalPreferences.cpp
|
||||
-@mkdir -p $(JUCE_OBJDIR)
|
||||
@echo "Compiling jucer_GlobalPreferences.cpp"
|
||||
|
|
|
|||
|
|
@ -28,6 +28,7 @@
|
|||
6DD9DA1677A6CF789CDAB478 = {isa = PBXBuildFile; fileRef = 0D4D508C638BC74943B9976D; };
|
||||
954A036F5DDB375DB23FFB3E = {isa = PBXBuildFile; fileRef = 0400CB0E056A1D840304D2DE; };
|
||||
3EB3D569250C4BA4CA9AF578 = {isa = PBXBuildFile; fileRef = C7608A3967D9AB9481848F2B; };
|
||||
636D21BF846031A6A1A7476A = {isa = PBXBuildFile; fileRef = 11EB44786085029106099D01; };
|
||||
3C3B0ED6C43FDA3AF76DEE2E = {isa = PBXBuildFile; fileRef = 84DE44680C9D37CDDCD127FF; };
|
||||
95B44E6C74B1DED31DBE37EB = {isa = PBXBuildFile; fileRef = 8C52A3DDA62A746AA7A68535; };
|
||||
AA9D0B8E23F3D87A23DE9F8A = {isa = PBXBuildFile; fileRef = 9069981E414A631B036CC9AC; };
|
||||
|
|
@ -151,6 +152,7 @@
|
|||
11BB370E0CBA3B3548B1DDC7 = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = pngtrans.c; path = "../../../../modules/juce_graphics/image_formats/pnglib/pngtrans.c"; sourceTree = "SOURCE_ROOT"; };
|
||||
11C55B714FE5D7CAFC35A0C7 = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = "juce_ImageEffectFilter.h"; path = "../../../../modules/juce_graphics/effects/juce_ImageEffectFilter.h"; sourceTree = "SOURCE_ROOT"; };
|
||||
11DC04468BC6023671017EBF = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = "jucer_NewFileWizard.h"; path = "../../Source/Wizards/jucer_NewFileWizard.h"; sourceTree = "SOURCE_ROOT"; };
|
||||
11EB44786085029106099D01 = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = "jucer_DownloadCompileEngineThread.cpp"; path = "../../Source/Application/jucer_DownloadCompileEngineThread.cpp"; sourceTree = "SOURCE_ROOT"; };
|
||||
1241F3A1FCDF100CD75D5E78 = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = "juce_win32_DragAndDrop.cpp"; path = "../../../../modules/juce_gui_basics/native/juce_win32_DragAndDrop.cpp"; sourceTree = "SOURCE_ROOT"; };
|
||||
125CD8A5E5B57840F5154ACD = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = "juce_Viewport.cpp"; path = "../../../../modules/juce_gui_basics/layout/juce_Viewport.cpp"; sourceTree = "SOURCE_ROOT"; };
|
||||
1268E54178897254E9A8B94C = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = "juce_TextLayout.cpp"; path = "../../../../modules/juce_graphics/fonts/juce_TextLayout.cpp"; sourceTree = "SOURCE_ROOT"; };
|
||||
|
|
@ -829,6 +831,7 @@
|
|||
B67F3F40C568E6A0A85B13D9 = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = jcphuff.c; path = "../../../../modules/juce_graphics/image_formats/jpglib/jcphuff.c"; sourceTree = "SOURCE_ROOT"; };
|
||||
B6C40E843F7E8E7C4768B99E = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = "juce_GZIPDecompressorInputStream.cpp"; path = "../../../../modules/juce_core/zip/juce_GZIPDecompressorInputStream.cpp"; sourceTree = "SOURCE_ROOT"; };
|
||||
B6D03F8491E288FD4BC31445 = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = "juce_ColourSelector.h"; path = "../../../../modules/juce_gui_extra/misc/juce_ColourSelector.h"; sourceTree = "SOURCE_ROOT"; };
|
||||
B7307A82D9EB1EDBA91EE43D = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = "jucer_DownloadCompileEngineThread.h"; path = "../../Source/Application/jucer_DownloadCompileEngineThread.h"; sourceTree = "SOURCE_ROOT"; };
|
||||
B741170E45D74F30B7D5CDDF = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = "jucer_ComponentNameProperty.h"; path = "../../Source/ComponentEditor/components/jucer_ComponentNameProperty.h"; sourceTree = "SOURCE_ROOT"; };
|
||||
B743DC50150100FFA2DE76AD = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; name = "juce_mac_Strings.mm"; path = "../../../../modules/juce_core/native/juce_mac_Strings.mm"; sourceTree = "SOURCE_ROOT"; };
|
||||
B79595279502C1A11A4E8C36 = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = "juce_Point.h"; path = "../../../../modules/juce_graphics/geometry/juce_Point.h"; sourceTree = "SOURCE_ROOT"; };
|
||||
|
|
@ -1142,6 +1145,8 @@
|
|||
6E6140969908E7619F858740,
|
||||
C7608A3967D9AB9481848F2B,
|
||||
E65A820D34BF39478B7C5925,
|
||||
11EB44786085029106099D01,
|
||||
B7307A82D9EB1EDBA91EE43D,
|
||||
6AEF2E6130619AE550A5FCA7,
|
||||
D526C38D581425949BA0E4AC,
|
||||
84DE44680C9D37CDDCD127FF,
|
||||
|
|
@ -2461,6 +2466,7 @@
|
|||
6DD9DA1677A6CF789CDAB478,
|
||||
954A036F5DDB375DB23FFB3E,
|
||||
3EB3D569250C4BA4CA9AF578,
|
||||
636D21BF846031A6A1A7476A,
|
||||
3C3B0ED6C43FDA3AF76DEE2E,
|
||||
95B44E6C74B1DED31DBE37EB,
|
||||
AA9D0B8E23F3D87A23DE9F8A,
|
||||
|
|
|
|||
|
|
@ -135,6 +135,7 @@
|
|||
<ClCompile Include="..\..\Source\Application\jucer_AutoUpdater.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_CommandLine.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_DocumentEditorComponent.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_GlobalPreferences.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_Main.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_MainWindow.cpp"/>
|
||||
|
|
@ -1326,6 +1327,7 @@
|
|||
<ClInclude Include="..\..\Source\Application\jucer_CommandLine.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_CommonHeaders.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_DocumentEditorComponent.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_EulaDialogue.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_FilePreviewComponent.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_GlobalPreferences.h"/>
|
||||
|
|
|
|||
|
|
@ -277,6 +277,9 @@
|
|||
<ClCompile Include="..\..\Source\Application\jucer_DocumentEditorComponent.cpp">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.cpp">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_GlobalPreferences.cpp">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClCompile>
|
||||
|
|
@ -1665,6 +1668,9 @@
|
|||
<ClInclude Include="..\..\Source\Application\jucer_DocumentEditorComponent.h">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.h">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_EulaDialogue.h">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClInclude>
|
||||
|
|
|
|||
|
|
@ -135,6 +135,7 @@
|
|||
<ClCompile Include="..\..\Source\Application\jucer_AutoUpdater.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_CommandLine.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_DocumentEditorComponent.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_GlobalPreferences.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_Main.cpp"/>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_MainWindow.cpp"/>
|
||||
|
|
@ -1326,6 +1327,7 @@
|
|||
<ClInclude Include="..\..\Source\Application\jucer_CommandLine.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_CommonHeaders.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_DocumentEditorComponent.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_EulaDialogue.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_FilePreviewComponent.h"/>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_GlobalPreferences.h"/>
|
||||
|
|
|
|||
|
|
@ -277,6 +277,9 @@
|
|||
<ClCompile Include="..\..\Source\Application\jucer_DocumentEditorComponent.cpp">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.cpp">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="..\..\Source\Application\jucer_GlobalPreferences.cpp">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClCompile>
|
||||
|
|
@ -1665,6 +1668,9 @@
|
|||
<ClInclude Include="..\..\Source\Application\jucer_DocumentEditorComponent.h">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_DownloadCompileEngineThread.h">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\Source\Application\jucer_EulaDialogue.h">
|
||||
<Filter>Projucer\Application</Filter>
|
||||
</ClInclude>
|
||||
|
|
|
|||
|
|
@ -112,6 +112,10 @@
|
|||
resource="0" file="Source/Application/jucer_DocumentEditorComponent.cpp"/>
|
||||
<FILE id="prPBQg" name="jucer_DocumentEditorComponent.h" compile="0"
|
||||
resource="0" file="Source/Application/jucer_DocumentEditorComponent.h"/>
|
||||
<FILE id="TkXpt2" name="jucer_DownloadCompileEngineThread.cpp" compile="1"
|
||||
resource="0" file="Source/Application/jucer_DownloadCompileEngineThread.cpp"/>
|
||||
<FILE id="J37kAi" name="jucer_DownloadCompileEngineThread.h" compile="0"
|
||||
resource="0" file="Source/Application/jucer_DownloadCompileEngineThread.h"/>
|
||||
<FILE id="Sm7ufE" name="jucer_EulaDialogue.h" compile="0" resource="0"
|
||||
file="Source/Application/jucer_EulaDialogue.h"/>
|
||||
<FILE id="eo4r70" name="jucer_FilePreviewComponent.h" compile="0" resource="0"
|
||||
|
|
|
|||
|
|
@ -0,0 +1,156 @@
|
|||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2015 - ROLI Ltd.
|
||||
|
||||
Permission is granted to use this software under the terms of either:
|
||||
a) the GPL v2 (or any later version)
|
||||
b) the Affero GPL v3
|
||||
|
||||
Details of these licenses can be found at: www.gnu.org/licenses
|
||||
|
||||
JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
||||
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||
|
||||
------------------------------------------------------------------------------
|
||||
|
||||
To release a closed-source product which uses JUCE, commercial licenses are
|
||||
available: visit www.juce.com for more information.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
#include "../jucer_Headers.h"
|
||||
#include "jucer_DownloadCompileEngineThread.h"
|
||||
#include "../LiveBuildEngine/projucer_CompileEngineDLL.h"
|
||||
|
||||
bool DownloadCompileEngineThread::downloadAndInstall()
|
||||
{
|
||||
DownloadCompileEngineThread d;
|
||||
|
||||
if (d.runThread())
|
||||
{
|
||||
if (d.result.failed())
|
||||
return withError (d.result.getErrorMessage());
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
if (d.cancelledByUser)
|
||||
return false;
|
||||
|
||||
return withError (d.result.getErrorMessage());
|
||||
}
|
||||
|
||||
DownloadCompileEngineThread::DownloadCompileEngineThread()
|
||||
: ThreadWithProgressWindow ("Downloading live-build engine", true, true),
|
||||
result (Result::ok()), cancelledByUser (false)
|
||||
{
|
||||
}
|
||||
|
||||
void DownloadCompileEngineThread::threadComplete (bool userPressedCancel)
|
||||
{
|
||||
cancelledByUser = userPressedCancel;
|
||||
}
|
||||
|
||||
void DownloadCompileEngineThread::run()
|
||||
{
|
||||
setProgress (-1.0);
|
||||
setStatusMessage ("Downloading...");
|
||||
|
||||
MemoryBlock zipData;
|
||||
result = download (zipData);
|
||||
|
||||
if (result.failed())
|
||||
return;
|
||||
|
||||
setStatusMessage ("Installing...");
|
||||
|
||||
File installFolder = getInstallFolder();
|
||||
if (! installFolder.createDirectory())
|
||||
{
|
||||
result = Result::fail ("Install error: cannot create target directory");
|
||||
return;
|
||||
}
|
||||
|
||||
result = install (zipData, installFolder);
|
||||
}
|
||||
|
||||
Result DownloadCompileEngineThread::download (MemoryBlock& dest)
|
||||
{
|
||||
int statusCode = 302;
|
||||
const int timeoutMs = 10000;
|
||||
StringPairArray responseHeaders;
|
||||
|
||||
URL url = getDownloadUrl();
|
||||
ScopedPointer<InputStream> in = url.createInputStream (false, nullptr, nullptr,
|
||||
String(), timeoutMs, &responseHeaders,
|
||||
&statusCode, 0);
|
||||
|
||||
if (in == nullptr || statusCode != 200)
|
||||
return Result::fail ("Download error: cannot establish connection");
|
||||
|
||||
MemoryOutputStream mo (dest, true);
|
||||
|
||||
int64 size = in->getTotalLength();
|
||||
int64 bytesReceived = -1;
|
||||
String msg("Downloading... (123)");
|
||||
|
||||
for (int64 pos = 0; pos < size; pos += bytesReceived)
|
||||
{
|
||||
setStatusMessage (msg.replace ("123", File::descriptionOfSizeInBytes (pos)));
|
||||
|
||||
if (threadShouldExit())
|
||||
return Result::fail ("Download error: operation interrupted");
|
||||
|
||||
bytesReceived = mo.writeFromInputStream (*in, 8192);
|
||||
|
||||
if (bytesReceived == 0)
|
||||
return Result::fail ("Download error: lost connection");
|
||||
}
|
||||
|
||||
return Result::ok();
|
||||
}
|
||||
|
||||
Result DownloadCompileEngineThread::install (const MemoryBlock& data, File& targetFolder)
|
||||
{
|
||||
MemoryInputStream input (data, false);
|
||||
ZipFile zip (input);
|
||||
|
||||
if (zip.getNumEntries() == 0)
|
||||
return Result::fail ("Install error: downloaded file is corrupt");
|
||||
|
||||
if (threadShouldExit())
|
||||
return Result::fail ("Install error: operation interrupted");
|
||||
|
||||
return zip.uncompressTo (targetFolder);
|
||||
}
|
||||
|
||||
URL DownloadCompileEngineThread::getDownloadUrl()
|
||||
{
|
||||
String urlStub ("http://assets.roli.com/juce/JUCECompileEngine_");
|
||||
|
||||
#if JUCE_MAC
|
||||
urlStub << "osx_";
|
||||
#elif JUCE_WINDOWS
|
||||
urlStub << "windows_";
|
||||
#else
|
||||
jassertfalse
|
||||
#endif
|
||||
|
||||
return urlStub + ProjectInfo::versionString + ".zip";
|
||||
}
|
||||
|
||||
File DownloadCompileEngineThread::getInstallFolder()
|
||||
{
|
||||
return CompileEngineDLL::getVersionedUserAppSupportFolder();
|
||||
}
|
||||
|
||||
bool DownloadCompileEngineThread::withError(const String& msg)
|
||||
{
|
||||
AlertWindow::showMessageBox (AlertWindow::WarningIcon,
|
||||
"Download and install", msg);
|
||||
return false;
|
||||
}
|
||||
|
|
@ -0,0 +1,57 @@
|
|||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2015 - ROLI Ltd.
|
||||
|
||||
Permission is granted to use this software under the terms of either:
|
||||
a) the GPL v2 (or any later version)
|
||||
b) the Affero GPL v3
|
||||
|
||||
Details of these licenses can be found at: www.gnu.org/licenses
|
||||
|
||||
JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
||||
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||
|
||||
------------------------------------------------------------------------------
|
||||
|
||||
To release a closed-source product which uses JUCE, commercial licenses are
|
||||
available: visit www.juce.com for more information.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
#ifndef JUCER_DOWNLOADCOMPILEENGINETHREAD_H_INCLUDED
|
||||
#define JUCER_DOWNLOADCOMPILEENGINETHREAD_H_INCLUDED
|
||||
|
||||
#include "jucer_Application.h"
|
||||
|
||||
|
||||
//==============================================================================
|
||||
class DownloadCompileEngineThread : public ThreadWithProgressWindow
|
||||
{
|
||||
public:
|
||||
static bool downloadAndInstall();
|
||||
|
||||
protected:
|
||||
void run() override;
|
||||
void threadComplete (bool userPressedCancel) override;
|
||||
|
||||
private:
|
||||
DownloadCompileEngineThread();
|
||||
|
||||
Result download (MemoryBlock& dest);
|
||||
Result install (const MemoryBlock& data, File& targetFolder);
|
||||
|
||||
static URL getDownloadUrl();
|
||||
static File getInstallFolder();
|
||||
static bool withError(const String& msg);
|
||||
|
||||
Result result;
|
||||
bool cancelledByUser;
|
||||
|
||||
JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (DownloadCompileEngineThread)
|
||||
};
|
||||
|
||||
#endif // JUCER_DOWNLOADCOMPILEENGINETHREAD_H_INCLUDED
|
||||
|
|
@ -101,6 +101,12 @@ struct ProjucerLicenses : private DeletedAtShutdown
|
|||
return isDLLPresent() && dll.projucer_hasLiveCodingLicence();
|
||||
}
|
||||
|
||||
bool retryLoadDll()
|
||||
{
|
||||
dll.tryLoadDll();
|
||||
return dll.isLoaded();
|
||||
}
|
||||
|
||||
private:
|
||||
CompileEngineDLL dll;
|
||||
LoginCallback* userCallback = nullptr;
|
||||
|
|
|
|||
|
|
@ -29,14 +29,7 @@ struct CompileEngineDLL
|
|||
{
|
||||
CompileEngineDLL()
|
||||
{
|
||||
File f = findDLLFile();
|
||||
|
||||
if (f != File() && dll.open (f.getLinkedTarget().getFullPathName()))
|
||||
{
|
||||
#define INIT_LIVE_DLL_FN(name, returnType, params) name = (name##_type) dll.getFunction (#name);
|
||||
LIVE_DLL_FUNCTIONS (INIT_LIVE_DLL_FN);
|
||||
#undef INIT_LIVE_DLL_FN
|
||||
}
|
||||
tryLoadDll();
|
||||
}
|
||||
|
||||
~CompileEngineDLL()
|
||||
|
|
@ -44,6 +37,22 @@ struct CompileEngineDLL
|
|||
shutdown();
|
||||
}
|
||||
|
||||
void tryLoadDll()
|
||||
{
|
||||
// never load the dynamic lib multiple times
|
||||
if (! isLoaded())
|
||||
{
|
||||
File f = findDLLFile();
|
||||
|
||||
if (f != File() && dll.open (f.getLinkedTarget().getFullPathName()))
|
||||
{
|
||||
#define INIT_LIVE_DLL_FN(name, returnType, params) name = (name##_type) dll.getFunction (#name);
|
||||
LIVE_DLL_FUNCTIONS (INIT_LIVE_DLL_FN);
|
||||
#undef INIT_LIVE_DLL_FN
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void initialise (CrashCallbackFunction crashFn, QuitCallbackFunction quitFn, bool setupSignals)
|
||||
{
|
||||
if (isLoaded())
|
||||
|
|
@ -87,80 +96,15 @@ struct CompileEngineDLL
|
|||
#endif
|
||||
}
|
||||
|
||||
static bool isDLLFile (const File& f)
|
||||
static File getVersionedUserAppSupportFolder()
|
||||
{
|
||||
return f.getFileName().equalsIgnoreCase (getDLLName()) && f.exists();
|
||||
}
|
||||
|
||||
static File findDLLFile()
|
||||
{
|
||||
File appFile = File::getSpecialLocation (File::currentApplicationFile);
|
||||
File userAppData (File::getSpecialLocation (File::userApplicationDataDirectory));
|
||||
|
||||
#if JUCE_MAC
|
||||
// Look in the app bundle..
|
||||
for (DirectoryIterator i (appFile, true, "*", File::findFilesAndDirectories); i.next();)
|
||||
if (isDLLFile (i.getFile()))
|
||||
return i.getFile();
|
||||
|
||||
{
|
||||
// Try in Application Support..
|
||||
File f = File ("~/Library/Application Support/Projucer").getChildFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
|
||||
f = File ("/Library/Application Support/Projucer").getChildFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
}
|
||||
|
||||
#elif JUCE_WINDOWS
|
||||
{
|
||||
// Look in the application folder
|
||||
File f = appFile.getParentDirectory().getChildFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
}
|
||||
#elif JUCE_LINUX
|
||||
// TODO?
|
||||
#else
|
||||
#error
|
||||
userAppData = userAppData.getChildFile ("Application Support");
|
||||
#endif
|
||||
|
||||
{
|
||||
// Look for a DLL in extras/Projucer/Builds
|
||||
File f = appFile.getParentDirectory();
|
||||
|
||||
for (int i = 5; --i >= 0;)
|
||||
{
|
||||
if (f.getFileName().equalsIgnoreCase ("Builds")
|
||||
&& f.getParentDirectory().getFileName().equalsIgnoreCase ("Projucer"))
|
||||
{
|
||||
f = f.getSiblingFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
f = f.getParentDirectory();
|
||||
}
|
||||
}
|
||||
|
||||
// See if there's one in the same folder as the app...
|
||||
File f = appFile.getSiblingFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
|
||||
// Look in some common folders as a last resort..
|
||||
f = File::getSpecialLocation (File::userHomeDirectory).getChildFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
|
||||
f = File::getSpecialLocation (File::userDocumentsDirectory).getChildFile (getDLLName());
|
||||
if (isDLLFile (f))
|
||||
return f;
|
||||
|
||||
return File();
|
||||
return userAppData.getChildFile (String ("Projucer-") + ProjectInfo::versionString);
|
||||
}
|
||||
|
||||
private:
|
||||
|
|
@ -168,6 +112,61 @@ private:
|
|||
|
||||
enum { requiredVersion = 1 };
|
||||
|
||||
static File findDLLFile()
|
||||
{
|
||||
File dllFile;
|
||||
|
||||
if (tryFindDLLFileInAppFolder(dllFile))
|
||||
return dllFile;
|
||||
|
||||
#if JUCE_MAC
|
||||
if (tryFindDLLFileInAppBundle(dllFile))
|
||||
return dllFile;
|
||||
#endif
|
||||
|
||||
if (tryFindDLLFileInAppConfigFolder(dllFile))
|
||||
return dllFile;
|
||||
|
||||
return File();
|
||||
}
|
||||
|
||||
#if JUCE_MAC
|
||||
static bool tryFindDLLFileInAppBundle(File &outFile)
|
||||
{
|
||||
File currentExecFile (File::getSpecialLocation (File::currentExecutableFile));
|
||||
return tryFindDLLFileInFolder (currentExecFile.getParentDirectory(), outFile);
|
||||
}
|
||||
#endif
|
||||
|
||||
static bool tryFindDLLFileInAppFolder(File &outFile)
|
||||
{
|
||||
File currentAppFile (File::getSpecialLocation (File::currentApplicationFile));
|
||||
return tryFindDLLFileInFolder (currentAppFile.getParentDirectory(), outFile);
|
||||
}
|
||||
|
||||
static bool tryFindDLLFileInAppConfigFolder(File &outFile)
|
||||
{
|
||||
File userAppDataFolder (getVersionedUserAppSupportFolder());
|
||||
return tryFindDLLFileInFolder (userAppDataFolder, outFile);
|
||||
}
|
||||
|
||||
static bool tryFindDLLFileInFolder(File folder, File& outFile)
|
||||
{
|
||||
File file = folder.getChildFile (getDLLName());
|
||||
if (isDLLFile (file))
|
||||
{
|
||||
outFile = file;
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
static bool isDLLFile (const File& f)
|
||||
{
|
||||
return f.getFileName().equalsIgnoreCase (getDLLName()) && f.exists();
|
||||
}
|
||||
|
||||
static void setPropertyCallback (const char* key, const char* value)
|
||||
{
|
||||
if (String (key).isNotEmpty())
|
||||
|
|
|
|||
|
|
@ -27,6 +27,7 @@
|
|||
#include "jucer_Module.h"
|
||||
#include "../Application/jucer_MainWindow.h"
|
||||
#include "../Application/jucer_Application.h"
|
||||
#include "../Application/jucer_DownloadCompileEngineThread.h"
|
||||
#include "../Code Editor/jucer_SourceCodeEditor.h"
|
||||
#include "../Utility/jucer_FilePathPropertyComponent.h"
|
||||
#include "jucer_TreeItemTypes.h"
|
||||
|
|
@ -330,6 +331,7 @@ void ProjectContentComponent::rebuildProjectTabs()
|
|||
resized();
|
||||
}
|
||||
|
||||
|
||||
//==============================================================================
|
||||
struct BuildTabComponent : public ConcertinaPanel
|
||||
{
|
||||
|
|
@ -355,7 +357,8 @@ struct ProjucerDisabledComp : public Component,
|
|||
private Button::Listener
|
||||
{
|
||||
ProjucerDisabledComp (String message, bool loggedIn, bool showSubscribeButton,
|
||||
bool showSignInButton, bool showSwitchAccountButton)
|
||||
bool showSignInButton, bool showSwitchAccountButton,
|
||||
bool showDownloadButton)
|
||||
: isLoggedIn (loggedIn)
|
||||
{
|
||||
infoLabel.setColour (Label::textColourId, findColour (mainBackgroundColourId).contrasting (0.7f));
|
||||
|
|
@ -383,6 +386,13 @@ struct ProjucerDisabledComp : public Component,
|
|||
addAndMakeVisible (*switchAccountButton);
|
||||
switchAccountButton->addListener (this);
|
||||
}
|
||||
|
||||
if (showDownloadButton)
|
||||
{
|
||||
downloadButton = new TextButton (String ("Download live-build engine"));
|
||||
addAndMakeVisible (*downloadButton);
|
||||
downloadButton->addListener (this);
|
||||
}
|
||||
}
|
||||
|
||||
void resized() override
|
||||
|
|
@ -417,6 +427,13 @@ struct ProjucerDisabledComp : public Component,
|
|||
{
|
||||
switchAccountButton->setSize (buttonWidth, buttonHeight);
|
||||
switchAccountButton->setCentrePosition (buttonCenterX, buttonCenterY);
|
||||
buttonCenterY += itemDistance + buttonHeight;
|
||||
}
|
||||
|
||||
if (downloadButton.get() != nullptr)
|
||||
{
|
||||
downloadButton->setSize (buttonWidth, buttonHeight);
|
||||
downloadButton->setCentrePosition (buttonCenterX, buttonCenterY);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -434,6 +451,26 @@ struct ProjucerDisabledComp : public Component,
|
|||
{
|
||||
ProjucerApplication::getApp().showLoginForm();
|
||||
}
|
||||
else if (btn == downloadButton.get())
|
||||
{
|
||||
if (DownloadCompileEngineThread::downloadAndInstall())
|
||||
{
|
||||
if (! ProjucerLicenses::getInstance()->retryLoadDll())
|
||||
{
|
||||
AlertWindow::showMessageBox(AlertWindow::WarningIcon,
|
||||
"Download and install",
|
||||
"Loading the live-build engine failed");
|
||||
return;
|
||||
}
|
||||
|
||||
// async!
|
||||
ProjucerApplication::getApp().showLoginForm();
|
||||
|
||||
// if sign in successful project tabs update, otherwise they were not
|
||||
auto parent = findParentComponentOfClass<ProjectContentComponent>();
|
||||
parent->rebuildProjectTabs();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
bool isLoggedIn;
|
||||
|
|
@ -443,6 +480,7 @@ private:
|
|||
ScopedPointer<TextButton> subscribeButton;
|
||||
ScopedPointer<TextButton> signInButton;
|
||||
ScopedPointer<TextButton> switchAccountButton;
|
||||
ScopedPointer<TextButton> downloadButton;
|
||||
};
|
||||
|
||||
struct EnableBuildComp : public Component
|
||||
|
|
@ -476,11 +514,6 @@ struct EnableBuildComp : public Component
|
|||
//==============================================================================
|
||||
Component* ProjectContentComponent::createBuildTab (CompileEngineChildProcess* child)
|
||||
{
|
||||
#if JUCE_LINUX
|
||||
ignoreUnused (child);
|
||||
return new ProjucerDisabledComp ("Linux support is still under development - "
|
||||
"please check for updates at www.juce.com!", false, false, false, false);
|
||||
#else
|
||||
if (child != nullptr)
|
||||
{
|
||||
child->crashHandler = [this] (const String& m) { this->handleCrash (m); };
|
||||
|
|
@ -489,31 +522,61 @@ Component* ProjectContentComponent::createBuildTab (CompileEngineChildProcess* c
|
|||
}
|
||||
|
||||
jassert (project != nullptr);
|
||||
|
||||
const auto osType = SystemStats::getOperatingSystemType();
|
||||
const bool isMac = (osType & SystemStats::MacOSX) != 0;
|
||||
const bool isWin = (osType & SystemStats::Windows) != 0;
|
||||
const bool isLinux = (osType & SystemStats::Linux) != 0;
|
||||
|
||||
if (! isMac && ! isWin && ! isLinux)
|
||||
return createDisabledBuildTabInfoOnly (
|
||||
"Live-build features are not supported on your system.\n\n"
|
||||
"Please check supported platforms at www.juce.com!");
|
||||
|
||||
if (isLinux)
|
||||
return createDisabledBuildTabInfoOnly (
|
||||
"Live-build features for Linux are under development.\n\n"
|
||||
"Please check for updates at www.juce.com!");
|
||||
|
||||
if (isMac)
|
||||
if (osType < SystemStats::MacOSX_10_9)
|
||||
return createDisabledBuildTabInfoOnly (
|
||||
"Live-build features are available only on MacOSX 10.9 or higher.");
|
||||
|
||||
if (isWin)
|
||||
if (! SystemStats::isOperatingSystem64Bit() || osType < SystemStats::Windows8_0)
|
||||
return createDisabledBuildTabInfoOnly (
|
||||
"Live-build features are available only on 64-Bit Windows 8 or higher.");
|
||||
|
||||
const auto& unlockStatus = *ProjucerLicenses::getInstance();
|
||||
|
||||
if (unlockStatus.hasLiveCodingLicence())
|
||||
{
|
||||
jassert (unlockStatus.isLoggedIn());
|
||||
jassert (unlockStatus.isDLLPresent());
|
||||
return new EnableBuildComp();
|
||||
}
|
||||
if (! unlockStatus.hasLiveCodingLicence())
|
||||
return createDisabledBuildTabSubscribe(unlockStatus.isLoggedIn(),
|
||||
unlockStatus.isDLLPresent());
|
||||
|
||||
return createDisabledBuildTab(unlockStatus.isLoggedIn(),
|
||||
unlockStatus.isDLLPresent());
|
||||
#endif
|
||||
jassert (unlockStatus.isLoggedIn());
|
||||
jassert (unlockStatus.isDLLPresent());
|
||||
return new EnableBuildComp();
|
||||
};
|
||||
|
||||
//==============================================================================
|
||||
Component* ProjectContentComponent::createDisabledBuildTab(bool loggedIn, bool dllPresent) {
|
||||
Component* ProjectContentComponent::createDisabledBuildTabSubscribe(bool loggedIn, bool dllPresent)
|
||||
{
|
||||
bool showSubscribeButton = true;
|
||||
bool showSignInButton = dllPresent && ! loggedIn;
|
||||
bool showSwitchAccountButton = dllPresent && loggedIn;
|
||||
bool showDownloadButton = ! dllPresent;
|
||||
|
||||
return new ProjucerDisabledComp (
|
||||
"Subscribe to JUCE Pro or Indie to use the Projucer's live-build features:",
|
||||
loggedIn, showSubscribeButton, showSignInButton, showSwitchAccountButton);
|
||||
loggedIn, showSubscribeButton, showSignInButton, showSwitchAccountButton, showDownloadButton);
|
||||
}
|
||||
|
||||
Component* ProjectContentComponent::createDisabledBuildTabInfoOnly(const char* message)
|
||||
{
|
||||
return new ProjucerDisabledComp (message, false, false, false, false, false);
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
BuildTabComponent* findBuildTab (const TabbedComponent& tabs)
|
||||
{
|
||||
return dynamic_cast<BuildTabComponent*> (tabs.getTabContentComponent (2));
|
||||
|
|
@ -1527,7 +1590,7 @@ void ProjectContentComponent::handleMissingSystemHeaders()
|
|||
createProjectTabs();
|
||||
|
||||
bool isLoggedIn = ProjucerLicenses::getInstance()->isLoggedIn();
|
||||
ProjucerDisabledComp* buildTab = new ProjucerDisabledComp (tabMessage, isLoggedIn, false, false, false);
|
||||
ProjucerDisabledComp* buildTab = new ProjucerDisabledComp (tabMessage, isLoggedIn, false, false, false, false);
|
||||
|
||||
treeViewTabs.addTab ("Build", Colours::transparentBlack, buildTab, true);
|
||||
showBuildTab();
|
||||
|
|
|
|||
|
|
@ -154,7 +154,8 @@ private:
|
|||
void timerCallback() override;
|
||||
|
||||
Component* createBuildTab (CompileEngineChildProcess*);
|
||||
Component* createDisabledBuildTab (bool loggedIn, bool dllPresent);
|
||||
Component* createDisabledBuildTabSubscribe (bool loggedIn, bool dllPresent);
|
||||
Component* createDisabledBuildTabInfoOnly (const char* messsage);
|
||||
|
||||
bool isContinuousRebuildEnabled() { return getAppSettings().getGlobalProperties().getBoolValue ("continuousRebuild", true); }
|
||||
void setContinuousRebuildEnabled (bool b) { getAppSettings().getGlobalProperties().setValue ("continuousRebuild", b); }
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue