mirror of https://github.com/procxx/kepka.git
Build scripts updated for Xcode projects from GYP, MacStore build tested.
This commit is contained in:
parent
dfcebcf9e2
commit
89cbf3a55a
|
@ -355,8 +355,13 @@ namespace {
|
||||||
|
|
||||||
// {fulltype} is in "{type}-{tag}-{tag}-{tag}" format
|
// {fulltype} is in "{type}-{tag}-{tag}-{tag}" format
|
||||||
// if we find "all" tag we return the restriction string
|
// if we find "all" tag we return the restriction string
|
||||||
QStringList typeTags = fullRestriction.mid(0, fullTypeEnd).split('-').mid(1);
|
auto typeTags = fullRestriction.mid(0, fullTypeEnd).split('-').mid(1);
|
||||||
if (typeTags.contains(qsl("all"))) {
|
#ifndef OS_MAC_STORE
|
||||||
|
auto restrictionApplies = typeTags.contains(qsl("all"));
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
auto restrictionApplies = typeTags.contains(qsl("all")) || typeTags.contains(qsl("ios"));
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
|
if (restrictionApplies) {
|
||||||
return fullRestriction.midRef(fullTypeEnd + 1).trimmed().toString();
|
return fullRestriction.midRef(fullTypeEnd + 1).trimmed().toString();
|
||||||
}
|
}
|
||||||
return QString();
|
return QString();
|
||||||
|
|
|
@ -92,7 +92,12 @@ Application::Application(int &argc, char **argv) : QApplication(argc, argv) {
|
||||||
QByteArray d(QFile::encodeName(QDir(cWorkingDir()).absolutePath()));
|
QByteArray d(QFile::encodeName(QDir(cWorkingDir()).absolutePath()));
|
||||||
char h[33] = { 0 };
|
char h[33] = { 0 };
|
||||||
hashMd5Hex(d.constData(), d.size(), h);
|
hashMd5Hex(d.constData(), d.size(), h);
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
_localServerName = psServerPrefix() + h + '-' + cGUIDStr();
|
_localServerName = psServerPrefix() + h + '-' + cGUIDStr();
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
h[4] = 0; // use only first 4 chars
|
||||||
|
_localServerName = psServerPrefix() + h;
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
|
|
||||||
connect(&_localSocket, SIGNAL(connected()), this, SLOT(socketConnected()));
|
connect(&_localSocket, SIGNAL(connected()), this, SLOT(socketConnected()));
|
||||||
connect(&_localSocket, SIGNAL(disconnected()), this, SLOT(socketDisconnected()));
|
connect(&_localSocket, SIGNAL(disconnected()), this, SLOT(socketDisconnected()));
|
||||||
|
|
|
@ -185,14 +185,22 @@ inline bool isServiceUser(uint64 id) {
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
inline const GUID &cGUID() {
|
inline const GUID &cGUID() {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
static const GUID gGuid = { 0x87a94ab0, 0xe370, 0x4cde, { 0x98, 0xd3, 0xac, 0xc1, 0x10, 0xc5, 0x96, 0x7d } };
|
static const GUID gGuid = { 0x87a94ab0, 0xe370, 0x4cde, { 0x98, 0xd3, 0xac, 0xc1, 0x10, 0xc5, 0x96, 0x7d } };
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
static const GUID gGuid = { 0xe51fb841, 0x8c0b, 0x4ef9, { 0x9e, 0x9e, 0x5a, 0x0, 0x78, 0x56, 0x76, 0x27 } };
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
|
|
||||||
return gGuid;
|
return gGuid;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
inline const char *cGUIDStr() {
|
inline const char *cGUIDStr() {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
static const char *gGuidStr = "{87A94AB0-E370-4cde-98D3-ACC110C5967D}";
|
static const char *gGuidStr = "{87A94AB0-E370-4cde-98D3-ACC110C5967D}";
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
static const char *gGuidStr = "{E51FB841-8C0B-4EF9-9E9E-5A0078567627}";
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
|
|
||||||
return gGuidStr;
|
return gGuidStr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,11 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
|
||||||
#include "pspecific_mac_p.h"
|
#include "pspecific_mac_p.h"
|
||||||
|
|
||||||
inline QString psServerPrefix() {
|
inline QString psServerPrefix() {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
return qsl("/tmp/");
|
return qsl("/tmp/");
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
return objc_documentsPath();
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
inline void psCheckLocalSocket(const QString &serverName) {
|
inline void psCheckLocalSocket(const QString &serverName) {
|
||||||
QFile address(serverName);
|
QFile address(serverName);
|
||||||
|
|
|
@ -79,6 +79,7 @@ void objc_deleteDir(const QString &dir);
|
||||||
|
|
||||||
double objc_appkitVersion();
|
double objc_appkitVersion();
|
||||||
|
|
||||||
|
QString objc_documentsPath();
|
||||||
QString objc_appDataPath();
|
QString objc_appDataPath();
|
||||||
QString objc_downloadPath();
|
QString objc_downloadPath();
|
||||||
QString objc_currentCountry();
|
QString objc_currentCountry();
|
||||||
|
@ -88,6 +89,7 @@ QByteArray objc_downloadPathBookmark(const QString &path);
|
||||||
QByteArray objc_pathBookmark(const QString &path);
|
QByteArray objc_pathBookmark(const QString &path);
|
||||||
void objc_downloadPathEnableAccess(const QByteArray &bookmark);
|
void objc_downloadPathEnableAccess(const QByteArray &bookmark);
|
||||||
|
|
||||||
|
class objc_FileBookmarkData;
|
||||||
class objc_FileBookmark {
|
class objc_FileBookmark {
|
||||||
public:
|
public:
|
||||||
objc_FileBookmark(const QByteArray &bookmark);
|
objc_FileBookmark(const QByteArray &bookmark);
|
||||||
|
@ -100,4 +102,7 @@ public:
|
||||||
|
|
||||||
~objc_FileBookmark();
|
~objc_FileBookmark();
|
||||||
|
|
||||||
|
private:
|
||||||
|
objc_FileBookmarkData *data = nullptr;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -22,6 +22,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
|
||||||
#include "mainwidget.h"
|
#include "mainwidget.h"
|
||||||
#include "application.h"
|
#include "application.h"
|
||||||
#include "playerwidget.h"
|
#include "playerwidget.h"
|
||||||
|
#include "localstorage.h"
|
||||||
|
|
||||||
#include "lang.h"
|
#include "lang.h"
|
||||||
|
|
||||||
|
@ -849,6 +850,9 @@ void objc_openFile(const QString &f, bool openwith) {
|
||||||
alwaysRect.origin.y = selectorFrame.origin.y - alwaysRect.size.height - st::macAlwaysThisAppTop;
|
alwaysRect.origin.y = selectorFrame.origin.y - alwaysRect.size.height - st::macAlwaysThisAppTop;
|
||||||
[button setFrame:alwaysRect];
|
[button setFrame:alwaysRect];
|
||||||
[button setAutoresizingMask:NSViewMinXMargin|NSViewMaxXMargin];
|
[button setAutoresizingMask:NSViewMinXMargin|NSViewMaxXMargin];
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
[button setHidden:YES];
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
NSTextField *goodLabel = [[NSTextField alloc] init];
|
NSTextField *goodLabel = [[NSTextField alloc] init];
|
||||||
[goodLabel setStringValue:QNSString(lng_mac_this_app_can_open(lt_file, objcString(name))).s()];
|
[goodLabel setStringValue:QNSString(lng_mac_this_app_can_open(lt_file, objcString(name))).s()];
|
||||||
[goodLabel setFont:[NSFont systemFontOfSize:[NSFont smallSystemFontSize]]];
|
[goodLabel setFont:[NSFont systemFontOfSize:[NSFont smallSystemFontSize]]];
|
||||||
|
@ -1012,7 +1016,12 @@ bool objc_execUpdater() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void objc_execTelegram(const QString &crashreport) {
|
void objc_execTelegram(const QString &crashreport) {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
_execUpdater(NO, crashreport);
|
_execUpdater(NO, crashreport);
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
NSDictionary *conf = [NSDictionary dictionaryWithObject:[NSArray array] forKey:NSWorkspaceLaunchConfigurationArguments];
|
||||||
|
[[NSWorkspace sharedWorkspace] launchApplicationAtURL:[NSURL fileURLWithPath:QNSString(cExeDir() + cExeName()).s()] options:NSWorkspaceLaunchAsync | NSWorkspaceLaunchNewInstance configuration:conf error:0];
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
void objc_activateProgram(WId winId) {
|
void objc_activateProgram(WId winId) {
|
||||||
|
@ -1050,6 +1059,14 @@ double objc_appkitVersion() {
|
||||||
return NSAppKitVersionNumber;
|
return NSAppKitVersionNumber;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString objc_documentsPath() {
|
||||||
|
NSURL *url = [[NSFileManager defaultManager] URLForDirectory:NSDocumentDirectory inDomain:NSUserDomainMask appropriateForURL:nil create:YES error:nil];
|
||||||
|
if (url) {
|
||||||
|
return QString::fromUtf8([[url path] fileSystemRepresentation]) + '/';
|
||||||
|
}
|
||||||
|
return QString();
|
||||||
|
}
|
||||||
|
|
||||||
QString objc_appDataPath() {
|
QString objc_appDataPath() {
|
||||||
NSURL *url = [[NSFileManager defaultManager] URLForDirectory:NSApplicationSupportDirectory inDomain:NSUserDomainMask appropriateForURL:nil create:YES error:nil];
|
NSURL *url = [[NSFileManager defaultManager] URLForDirectory:NSApplicationSupportDirectory inDomain:NSUserDomainMask appropriateForURL:nil create:YES error:nil];
|
||||||
if (url) {
|
if (url) {
|
||||||
|
@ -1086,37 +1103,152 @@ QString objc_convertFileUrl(const QString &url) {
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray objc_downloadPathBookmark(const QString &path) {
|
QByteArray objc_downloadPathBookmark(const QString &path) {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
return QByteArray();
|
return QByteArray();
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
NSURL *url = [NSURL fileURLWithPath:[NSString stringWithUTF8String:path.toUtf8().constData()] isDirectory:YES];
|
||||||
|
if (!url) return QByteArray();
|
||||||
|
|
||||||
|
NSError *error = nil;
|
||||||
|
NSData *data = [url bookmarkDataWithOptions:NSURLBookmarkCreationWithSecurityScope includingResourceValuesForKeys:nil relativeToURL:nil error:&error];
|
||||||
|
return data ? QByteArray::fromNSData(data) : QByteArray();
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray objc_pathBookmark(const QString &path) {
|
QByteArray objc_pathBookmark(const QString &path) {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
return QByteArray();
|
return QByteArray();
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
NSURL *url = [NSURL fileURLWithPath:[NSString stringWithUTF8String:path.toUtf8().constData()]];
|
||||||
|
if (!url) return QByteArray();
|
||||||
|
|
||||||
|
NSError *error = nil;
|
||||||
|
NSData *data = [url bookmarkDataWithOptions:(NSURLBookmarkCreationWithSecurityScope | NSURLBookmarkCreationSecurityScopeAllowOnlyReadAccess) includingResourceValuesForKeys:nil relativeToURL:nil error:&error];
|
||||||
|
return data ? QByteArray::fromNSData(data) : QByteArray();
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
void objc_downloadPathEnableAccess(const QByteArray &bookmark) {
|
void objc_downloadPathEnableAccess(const QByteArray &bookmark) {
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
if (bookmark.isEmpty()) return;
|
||||||
|
|
||||||
|
BOOL isStale = NO;
|
||||||
|
NSError *error = nil;
|
||||||
|
NSURL *url = [NSURL URLByResolvingBookmarkData:bookmark.toNSData() options:NSURLBookmarkResolutionWithSecurityScope relativeToURL:nil bookmarkDataIsStale:&isStale error:&error];
|
||||||
|
if (!url) return;
|
||||||
|
|
||||||
|
if ([url startAccessingSecurityScopedResource]) {
|
||||||
|
if (_downloadPathUrl) {
|
||||||
|
[_downloadPathUrl stopAccessingSecurityScopedResource];
|
||||||
|
}
|
||||||
|
_downloadPathUrl = url;
|
||||||
|
|
||||||
|
cSetDownloadPath(objcString([_downloadPathUrl path]) + '/');
|
||||||
|
if (isStale) {
|
||||||
|
NSData *data = [_downloadPathUrl bookmarkDataWithOptions:NSURLBookmarkCreationWithSecurityScope includingResourceValuesForKeys:nil relativeToURL:nil error:&error];
|
||||||
|
if (data) {
|
||||||
|
cSetDownloadPathBookmark(QByteArray::fromNSData(data));
|
||||||
|
Local::writeUserSettings();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
namespace {
|
||||||
|
QMutex _bookmarksMutex;
|
||||||
|
}
|
||||||
|
|
||||||
|
class objc_FileBookmarkData {
|
||||||
|
public:
|
||||||
|
~objc_FileBookmarkData() {
|
||||||
|
if (url) [url release];
|
||||||
|
}
|
||||||
|
NSURL *url = nil;
|
||||||
|
QString name;
|
||||||
|
QByteArray bookmark;
|
||||||
|
int counter = 0;
|
||||||
|
};
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
|
|
||||||
objc_FileBookmark::objc_FileBookmark(const QByteArray &bookmark) {
|
objc_FileBookmark::objc_FileBookmark(const QByteArray &bookmark) {
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
if (bookmark.isEmpty()) return;
|
||||||
|
|
||||||
|
BOOL isStale = NO;
|
||||||
|
NSError *error = nil;
|
||||||
|
NSURL *url = [NSURL URLByResolvingBookmarkData:bookmark.toNSData() options:NSURLBookmarkResolutionWithSecurityScope relativeToURL:nil bookmarkDataIsStale:&isStale error:&error];
|
||||||
|
if (!url) return;
|
||||||
|
|
||||||
|
if ([url startAccessingSecurityScopedResource]) {
|
||||||
|
data = new objc_FileBookmarkData();
|
||||||
|
data->url = [url retain];
|
||||||
|
data->name = objcString([url path]);
|
||||||
|
data->bookmark = bookmark;
|
||||||
|
[url stopAccessingSecurityScopedResource];
|
||||||
|
}
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
bool objc_FileBookmark::valid() const {
|
bool objc_FileBookmark::valid() const {
|
||||||
return true;
|
if (enable()) {
|
||||||
|
disable();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool objc_FileBookmark::enable() const {
|
bool objc_FileBookmark::enable() const {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
return true;
|
return true;
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
if (!data) return false;
|
||||||
|
|
||||||
|
QMutexLocker lock(&_bookmarksMutex);
|
||||||
|
if (data->counter > 0 || [data->url startAccessingSecurityScopedResource] == YES) {
|
||||||
|
++data->counter;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
void objc_FileBookmark::disable() const {
|
void objc_FileBookmark::disable() const {
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
if (!data) return;
|
||||||
|
|
||||||
|
QMutexLocker lock(&_bookmarksMutex);
|
||||||
|
if (data->counter > 0) {
|
||||||
|
--data->counter;
|
||||||
|
if (!data->counter) {
|
||||||
|
[data->url stopAccessingSecurityScopedResource];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString &objc_FileBookmark::name(const QString &original) const {
|
const QString &objc_FileBookmark::name(const QString &original) const {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
return original;
|
return original;
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
return (data && !data->name.isEmpty()) ? data->name : original;
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray objc_FileBookmark::bookmark() const {
|
QByteArray objc_FileBookmark::bookmark() const {
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
return QByteArray();
|
return QByteArray();
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
return data ? data->bookmark : QByteArray();
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
||||||
objc_FileBookmark::~objc_FileBookmark() {
|
objc_FileBookmark::~objc_FileBookmark() {
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
if (data && data->counter > 0) {
|
||||||
|
LOG(("Did not disable() bookmark, counter: %1").arg(data->counter));
|
||||||
|
[data->url stopAccessingSecurityScopedResource];
|
||||||
|
}
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
}
|
}
|
||||||
|
|
|
@ -176,7 +176,11 @@ void settingsParseArgs(int argc, char *argv[]) {
|
||||||
break;
|
break;
|
||||||
case dbipMac:
|
case dbipMac:
|
||||||
gUpdateURL = QUrl(qsl("http://tdesktop.com/mac/tupdates/current"));
|
gUpdateURL = QUrl(qsl("http://tdesktop.com/mac/tupdates/current"));
|
||||||
|
#ifndef OS_MAC_STORE
|
||||||
gPlatformString = qsl("MacOS");
|
gPlatformString = qsl("MacOS");
|
||||||
|
#else // OS_MAC_STORE
|
||||||
|
gPlatformString = qsl("MacAppStore");
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
gCustomNotifies = false;
|
gCustomNotifies = false;
|
||||||
break;
|
break;
|
||||||
case dbipMacOld:
|
case dbipMacOld:
|
||||||
|
|
|
@ -49,6 +49,10 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
|
||||||
#define OS_MAC_OLD
|
#define OS_MAC_OLD
|
||||||
#endif // QT_VERSION < 5.5.0
|
#endif // QT_VERSION < 5.5.0
|
||||||
|
|
||||||
|
#ifdef OS_MAC_STORE
|
||||||
|
#define MAC_USE_BREAKPAD
|
||||||
|
#endif // OS_MAC_STORE
|
||||||
|
|
||||||
#include <QtWidgets/QtWidgets>
|
#include <QtWidgets/QtWidgets>
|
||||||
#include <QtNetwork/QtNetwork>
|
#include <QtNetwork/QtNetwork>
|
||||||
|
|
||||||
|
|
|
@ -21,8 +21,6 @@ Error () {
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
FastParam="$1"
|
|
||||||
|
|
||||||
if [ ! -f "$FullScriptPath/target" ]; then
|
if [ ! -f "$FullScriptPath/target" ]; then
|
||||||
Error "Build target not found!"
|
Error "Build target not found!"
|
||||||
fi
|
fi
|
||||||
|
@ -70,13 +68,13 @@ elif [ "$BuildTarget" == "mac" ]; then
|
||||||
echo "Building version $AppVersionStrFull for OS X 10.8+.."
|
echo "Building version $AppVersionStrFull for OS X 10.8+.."
|
||||||
UpdateFile="tmacupd$AppVersion"
|
UpdateFile="tmacupd$AppVersion"
|
||||||
SetupFile="tsetup.$AppVersionStrFull.dmg"
|
SetupFile="tsetup.$AppVersionStrFull.dmg"
|
||||||
ReleasePath="$HomePath/../Mac/Release"
|
ReleasePath="$HomePath/../out/Release"
|
||||||
BinaryName="Telegram"
|
BinaryName="Telegram"
|
||||||
elif [ "$BuildTarget" == "mac32" ]; then
|
elif [ "$BuildTarget" == "mac32" ]; then
|
||||||
echo "Building version $AppVersionStrFull for OS X 10.6 and 10.7.."
|
echo "Building version $AppVersionStrFull for OS X 10.6 and 10.7.."
|
||||||
UpdateFile="tmac32upd$AppVersion"
|
UpdateFile="tmac32upd$AppVersion"
|
||||||
SetupFile="tsetup32.$AppVersionStrFull.dmg"
|
SetupFile="tsetup32.$AppVersionStrFull.dmg"
|
||||||
ReleasePath="$HomePath/../Mac/Release"
|
ReleasePath="$HomePath/../out/Release"
|
||||||
BinaryName="Telegram"
|
BinaryName="Telegram"
|
||||||
elif [ "$BuildTarget" == "macstore" ]; then
|
elif [ "$BuildTarget" == "macstore" ]; then
|
||||||
if [ "$BetaVersion" != "0" ]; then
|
if [ "$BetaVersion" != "0" ]; then
|
||||||
|
@ -84,7 +82,7 @@ elif [ "$BuildTarget" == "macstore" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Building version $AppVersionStrFull for Mac App Store.."
|
echo "Building version $AppVersionStrFull for Mac App Store.."
|
||||||
ReleasePath="$HomePath/../Mac/Release"
|
ReleasePath="$HomePath/../out/Release"
|
||||||
BinaryName="Telegram Desktop"
|
BinaryName="Telegram Desktop"
|
||||||
DropboxPath="/Volumes/Storage/Dropbox/Telegram/deploy/$AppVersionStrMajor"
|
DropboxPath="/Volumes/Storage/Dropbox/Telegram/deploy/$AppVersionStrMajor"
|
||||||
DropboxDeployPath="$DropboxPath/$AppVersionStrFull"
|
DropboxDeployPath="$DropboxPath/$AppVersionStrFull"
|
||||||
|
@ -214,10 +212,8 @@ if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ] || [ "$BuildTarg
|
||||||
Error "Dropbox path not found!"
|
Error "Dropbox path not found!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$FastParam" != "fast" ]; then
|
gyp/refresh.sh
|
||||||
touch "./Resources/telegram.qrc"
|
cd ../
|
||||||
touch "./Telegram.plist"
|
|
||||||
fi
|
|
||||||
xcodebuild -project Telegram.xcodeproj -alltargets -configuration Release build
|
xcodebuild -project Telegram.xcodeproj -alltargets -configuration Release build
|
||||||
|
|
||||||
if [ ! -d "$ReleasePath/$BinaryName.app" ]; then
|
if [ ! -d "$ReleasePath/$BinaryName.app" ]; then
|
||||||
|
@ -229,9 +225,17 @@ if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ] || [ "$BuildTarg
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ]; then
|
if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ]; then
|
||||||
echo "Removing Updater debug symbols.."
|
if [ ! -f "$ReleasePath/$BinaryName.app/Contents/Frameworks/Updater" ]; then
|
||||||
rm -rf "$ReleasePath/$BinaryName.app/Contents/Frameworks/Updater.dSYM"
|
Error "Updater not found!"
|
||||||
echo "Done!"
|
fi
|
||||||
|
if [ ! -f "$ReleasePath/$BinaryName.app/Contents/Helpers/crashpad_handler" ]; then
|
||||||
|
Error "crashpad_handler not found!"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ "$BuildTarget" == "macstore" ]; then
|
||||||
|
if [ ! -d "$ReleasePath/$BinaryName.app/Contents/Frameworks/Breakpad.framework" ]; then
|
||||||
|
Error "Breakpad.framework not found!"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Dumping debug symbols.."
|
echo "Dumping debug symbols.."
|
||||||
|
@ -246,7 +250,9 @@ if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ] || [ "$BuildTarg
|
||||||
if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ]; then
|
if [ "$BuildTarget" == "mac" ] || [ "$BuildTarget" == "mac32" ]; then
|
||||||
codesign --force --deep --sign "Developer ID Application: John Preston" "$ReleasePath/$BinaryName.app"
|
codesign --force --deep --sign "Developer ID Application: John Preston" "$ReleasePath/$BinaryName.app"
|
||||||
elif [ "$BuildTarget" == "macstore" ]; then
|
elif [ "$BuildTarget" == "macstore" ]; then
|
||||||
codesign --force --deep --sign "3rd Party Mac Developer Application: TELEGRAM MESSENGER LLP (6N38VWS5BX)" "$ReleasePath/$BinaryName.app" --entitlements "Telegram/Telegram Desktop.entitlements"
|
codesign --force --deep --sign "3rd Party Mac Developer Application: TELEGRAM MESSENGER LLP (6N38VWS5BX)" "$ReleasePath/$BinaryName.app" --entitlements "$HomePath/Telegram/Telegram Desktop.entitlements"
|
||||||
|
echo "Making an installer.."
|
||||||
|
productbuild --sign "3rd Party Mac Developer Installer: TELEGRAM MESSENGER LLP (6N38VWS5BX)" --component "$ReleasePath/$BinaryName.app" /Applications "$ReleasePath/$BinaryName.pkg"
|
||||||
fi
|
fi
|
||||||
echo "Done!"
|
echo "Done!"
|
||||||
|
|
||||||
|
|
|
@ -106,11 +106,6 @@ repl "\(AppVersion [ ]*=\) \([ ]*\)[0-9][0-9]*" "\1\2 $VersionFull" "$VersionHea
|
||||||
repl "\(AppVersionStr [ ]*=\) \([ ]*\)[^;][^;]*" "\1\2 \"$VersionStrSmall\"" "$VersionHeaderPath"
|
repl "\(AppVersionStr [ ]*=\) \([ ]*\)[^;][^;]*" "\1\2 \"$VersionStrSmall\"" "$VersionHeaderPath"
|
||||||
repl "\(AppAlphaVersion [ ]*=\) \([ ]*\)[a-z][a-z]*" "\1\2 $VersionAlphaBool" "$VersionHeaderPath"
|
repl "\(AppAlphaVersion [ ]*=\) \([ ]*\)[a-z][a-z]*" "\1\2 $VersionAlphaBool" "$VersionHeaderPath"
|
||||||
|
|
||||||
echo "Patching project.pbxproj..."
|
|
||||||
TelegramProjectPath="$FullScriptPath/../Telegram.xcodeproj/project.pbxproj"
|
|
||||||
repl "\(TDESKTOP_MAJOR_VERSION [ ]*=\) \([ ]*\)[^;][^;]*" "\1\2 $VersionMajor.$VersionMinor" "$TelegramProjectPath"
|
|
||||||
repl "\(TDESKTOP_VERSION [ ]*=\) \([ ]*\)[^;][^;]*" "\1\2 $VersionStrSmall" "$TelegramProjectPath"
|
|
||||||
|
|
||||||
echo "Patching Telegram.rc..."
|
echo "Patching Telegram.rc..."
|
||||||
ResourcePath="$FullScriptPath/../Resources/winrc/Telegram.rc"
|
ResourcePath="$FullScriptPath/../Resources/winrc/Telegram.rc"
|
||||||
repl "\(FILEVERSION\) \([ ]*\)[0-9][0-9]*,[0-9][0-9]*,[0-9][0-9]*,[0-9][0-9]*" "\1\2 $VersionMajor,$VersionMinor,$VersionPatch,$VersionBeta" "$ResourcePath"
|
repl "\(FILEVERSION\) \([ ]*\)[0-9][0-9]*,[0-9][0-9]*,[0-9][0-9]*,[0-9][0-9]*" "\1\2 $VersionMajor,$VersionMinor,$VersionPatch,$VersionBeta" "$ResourcePath"
|
||||||
|
|
|
@ -95,6 +95,7 @@
|
||||||
'<(src_loc)/application.h',
|
'<(src_loc)/application.h',
|
||||||
'<(src_loc)/autoupdater.cpp',
|
'<(src_loc)/autoupdater.cpp',
|
||||||
'<(src_loc)/autoupdater.h',
|
'<(src_loc)/autoupdater.h',
|
||||||
|
'<(src_loc)/config.h',
|
||||||
'<(src_loc)/dialogswidget.cpp',
|
'<(src_loc)/dialogswidget.cpp',
|
||||||
'<(src_loc)/dialogswidget.h',
|
'<(src_loc)/dialogswidget.h',
|
||||||
'<(src_loc)/dropdown.cpp',
|
'<(src_loc)/dropdown.cpp',
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
set -e
|
||||||
|
FullExecPath=$PWD
|
||||||
|
pushd `dirname $0` > /dev/null
|
||||||
|
FullScriptPath=`pwd`
|
||||||
|
popd > /dev/null
|
||||||
|
|
||||||
|
while IFS='' read -r line || [[ -n "$line" ]]; do
|
||||||
|
set $line
|
||||||
|
eval $1="$2"
|
||||||
|
done < "$FullScriptPath/../build/version"
|
||||||
|
|
||||||
|
echo $AppVersionStr
|
||||||
|
exit
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
'GCC_PREFIX_HEADER': '<(src_loc)/stdafx.h',
|
'GCC_PREFIX_HEADER': '<(src_loc)/stdafx.h',
|
||||||
'GCC_PRECOMPILE_PREFIX_HEADER': 'YES',
|
'GCC_PRECOMPILE_PREFIX_HEADER': 'YES',
|
||||||
'INFOPLIST_FILE': '../Telegram.plist',
|
'INFOPLIST_FILE': '../Telegram.plist',
|
||||||
'CURRENT_PROJECT_VERSION': '0.10.2',
|
'CURRENT_PROJECT_VERSION': '<!(./print_version.sh)',
|
||||||
'ASSETCATALOG_COMPILER_APPICON_NAME': 'AppIcon',
|
'ASSETCATALOG_COMPILER_APPICON_NAME': 'AppIcon',
|
||||||
'OTHER_LDFLAGS': [
|
'OTHER_LDFLAGS': [
|
||||||
'-lcups',
|
'-lcups',
|
||||||
|
@ -115,7 +115,7 @@
|
||||||
'mkdir', '-p', '${BUILT_PRODUCTS_DIR}/Telegram.app/Contents/Helpers/'
|
'mkdir', '-p', '${BUILT_PRODUCTS_DIR}/Telegram.app/Contents/Helpers/'
|
||||||
],
|
],
|
||||||
}, {
|
}, {
|
||||||
'postbuild_name': 'Copy crashpad_client to Helpers',
|
'postbuild_name': 'Copy crashpad_handler to Helpers',
|
||||||
'action': [
|
'action': [
|
||||||
'cp',
|
'cp',
|
||||||
'<(libs_loc)/crashpad_oldmac/crashpad/out/${CONFIGURATION}/crashpad_handler',
|
'<(libs_loc)/crashpad_oldmac/crashpad/out/${CONFIGURATION}/crashpad_handler',
|
||||||
|
@ -203,7 +203,7 @@
|
||||||
],
|
],
|
||||||
'defines': [
|
'defines': [
|
||||||
'TDESKTOP_DISABLE_AUTOUPDATE',
|
'TDESKTOP_DISABLE_AUTOUPDATE',
|
||||||
'MAC_USE_BREAKPAD',
|
'OS_MAC_STORE',
|
||||||
],
|
],
|
||||||
'postbuilds': [{
|
'postbuilds': [{
|
||||||
'postbuild_name': 'Clear Frameworks path',
|
'postbuild_name': 'Clear Frameworks path',
|
||||||
|
|
Loading…
Reference in New Issue