From d95e41572f860bc5f8d02f82660cc03e535555ba Mon Sep 17 00:00:00 2001 From: Berkus Decker Date: Mon, 20 Nov 2017 22:10:26 +0200 Subject: [PATCH] Remove obsolete files --- Telegram/Patches/mini_chromium.diff | 52 -- Telegram/Patches/openal.diff | 22 - Telegram/SetupFiles/data | 0 Telegram/SetupFiles/log.txt | 0 Telegram/SourceFiles/base/virtual_method.h | 717 ------------------ .../platform/mac/mac_iconv_helper.c | 45 -- Telegram/gyp/PrecompiledHeader.cmake | 165 ---- Telegram/gyp/Telegram.gyp | 130 ---- Telegram/gyp/codegen.gyp | 169 ----- Telegram/gyp/codegen_rules.gypi | 178 ----- Telegram/gyp/common.gypi | 121 --- Telegram/gyp/common_executable.gypi | 34 - Telegram/gyp/create_env.py | 57 -- Telegram/gyp/list_sources.py | 162 ---- Telegram/gyp/print_version.sh | 15 - Telegram/gyp/qt.gypi | 256 ------- Telegram/gyp/qt_moc.gypi | 40 - Telegram/gyp/qt_rcc.gypi | 40 - Telegram/gyp/refresh.bat | 63 -- Telegram/gyp/refresh.sh | 38 - Telegram/gyp/settings_linux.gypi | 81 -- Telegram/gyp/settings_mac.gypi | 112 --- Telegram/gyp/settings_win.gypi | 121 --- Telegram/gyp/telegram_linux.gypi | 106 --- Telegram/gyp/telegram_mac.gypi | 233 ------ Telegram/gyp/telegram_qrc.gypi | 52 -- Telegram/gyp/telegram_sources.txt | 612 --------------- Telegram/gyp/telegram_win.gypi | 91 --- Telegram/gyp/tests/common_test.gypi | 34 - Telegram/gyp/tests/list_tests.py | 79 -- Telegram/gyp/tests/tests.gyp | 86 --- Telegram/gyp/tests/tests_list.txt | 3 - Telegram/gyp/update_dependent.py | 184 ----- Telegram/gyp/utils.gyp | 166 ---- docs/building-msvc.md | 167 ---- docs/building-qmake.md | 137 ---- docs/building-qtcreator.md | 193 ----- docs/building-xcode-old.md | 242 ------ docs/building-xcode.md | 234 ------ 39 files changed, 5237 deletions(-) delete mode 100644 Telegram/Patches/mini_chromium.diff delete mode 100644 Telegram/Patches/openal.diff delete mode 100644 Telegram/SetupFiles/data delete mode 100644 Telegram/SetupFiles/log.txt delete mode 100644 Telegram/SourceFiles/base/virtual_method.h delete mode 100644 Telegram/SourceFiles/platform/mac/mac_iconv_helper.c delete mode 100644 Telegram/gyp/PrecompiledHeader.cmake delete mode 100644 Telegram/gyp/Telegram.gyp delete mode 100644 Telegram/gyp/codegen.gyp delete mode 100644 Telegram/gyp/codegen_rules.gypi delete mode 100644 Telegram/gyp/common.gypi delete mode 100644 Telegram/gyp/common_executable.gypi delete mode 100644 Telegram/gyp/create_env.py delete mode 100644 Telegram/gyp/list_sources.py delete mode 100755 Telegram/gyp/print_version.sh delete mode 100644 Telegram/gyp/qt.gypi delete mode 100644 Telegram/gyp/qt_moc.gypi delete mode 100644 Telegram/gyp/qt_rcc.gypi delete mode 100644 Telegram/gyp/refresh.bat delete mode 100755 Telegram/gyp/refresh.sh delete mode 100644 Telegram/gyp/settings_linux.gypi delete mode 100644 Telegram/gyp/settings_mac.gypi delete mode 100644 Telegram/gyp/settings_win.gypi delete mode 100644 Telegram/gyp/telegram_linux.gypi delete mode 100644 Telegram/gyp/telegram_mac.gypi delete mode 100644 Telegram/gyp/telegram_qrc.gypi delete mode 100644 Telegram/gyp/telegram_sources.txt delete mode 100644 Telegram/gyp/telegram_win.gypi delete mode 100644 Telegram/gyp/tests/common_test.gypi delete mode 100644 Telegram/gyp/tests/list_tests.py delete mode 100644 Telegram/gyp/tests/tests.gyp delete mode 100644 Telegram/gyp/tests/tests_list.txt delete mode 100644 Telegram/gyp/update_dependent.py delete mode 100644 Telegram/gyp/utils.gyp delete mode 100644 docs/building-msvc.md delete mode 100644 docs/building-qmake.md delete mode 100644 docs/building-qtcreator.md delete mode 100644 docs/building-xcode-old.md delete mode 100644 docs/building-xcode.md diff --git a/Telegram/Patches/mini_chromium.diff b/Telegram/Patches/mini_chromium.diff deleted file mode 100644 index 3dab62ec2..000000000 --- a/Telegram/Patches/mini_chromium.diff +++ /dev/null @@ -1,52 +0,0 @@ -diff --git a/base/mac/scoped_nsobject.h b/base/mac/scoped_nsobject.h -index 2e157a4..5a306a1 100644 ---- a/base/mac/scoped_nsobject.h -+++ b/base/mac/scoped_nsobject.h -@@ -11,6 +11,7 @@ - - #include "base/compiler_specific.h" - #include "base/mac/scoped_typeref.h" -+#include "base/template_util.h" - - namespace base { - -@@ -55,7 +56,7 @@ class scoped_nsobject : public scoped_nsprotocol { - public: - using scoped_nsprotocol::scoped_nsprotocol; - -- static_assert(std::is_same::value == false, -+ static_assert(is_same::value == false, - "Use ScopedNSAutoreleasePool instead"); - }; - -diff --git a/base/macros.h b/base/macros.h -index 5d96783..096704c 100644 ---- a/base/macros.h -+++ b/base/macros.h -@@ -42,8 +42,9 @@ char (&ArraySizeHelper(const T (&array)[N]))[N]; - - template - inline Dest bit_cast(const Source& source) { -+#if __cplusplus >= 201103L - static_assert(sizeof(Dest) == sizeof(Source), "sizes must be equal"); -- -+#endif - Dest dest; - memcpy(&dest, &source, sizeof(dest)); - return dest; -diff --git a/build/common.gypi b/build/common.gypi -index 1affc70..6e8f292 100644 ---- a/build/common.gypi -+++ b/build/common.gypi -@@ -66,6 +66,11 @@ - 'conditions': [ - ['clang!=0', { - 'CLANG_CXX_LANGUAGE_STANDARD': 'c++11', # -std=c++11 -+ 'conditions': [ -+ ['mac_deployment_target=="10.8"', { -+ 'CLANG_CXX_LIBRARY': 'libc++', # force -stdlib=libc++ for 10.8 -+ }] -+ ], - - # Don't link in libarclite_macosx.a, see http://crbug.com/156530. - 'CLANG_LINK_OBJC_RUNTIME': 'NO', # -fno-objc-link-runtime diff --git a/Telegram/Patches/openal.diff b/Telegram/Patches/openal.diff deleted file mode 100644 index b2a71ad17..000000000 --- a/Telegram/Patches/openal.diff +++ /dev/null @@ -1,22 +0,0 @@ -diff --git a/Alc/backends/winmm.c b/Alc/backends/winmm.c -index 9d8f8e9..8c8e44a 100644 ---- a/Alc/backends/winmm.c -+++ b/Alc/backends/winmm.c -@@ -219,7 +219,7 @@ FORCE_ALIGN static int ALCwinmmPlayback_mixerProc(void *arg) - SetRTPriority(); - althrd_setname(althrd_current(), MIXER_THREAD_NAME); - -- while(GetMessage(&msg, NULL, 0, 0)) -+ if (!self->killNow) while(GetMessage(&msg, NULL, 0, 0)) - { - if(msg.message != WOM_DONE) - continue; -@@ -504,7 +504,7 @@ static int ALCwinmmCapture_captureProc(void *arg) - - althrd_setname(althrd_current(), RECORD_THREAD_NAME); - -- while(GetMessage(&msg, NULL, 0, 0)) -+ if (!self->killNow) while(GetMessage(&msg, NULL, 0, 0)) - { - if(msg.message != WIM_DATA) - continue; diff --git a/Telegram/SetupFiles/data b/Telegram/SetupFiles/data deleted file mode 100644 index e69de29bb..000000000 diff --git a/Telegram/SetupFiles/log.txt b/Telegram/SetupFiles/log.txt deleted file mode 100644 index e69de29bb..000000000 diff --git a/Telegram/SourceFiles/base/virtual_method.h b/Telegram/SourceFiles/base/virtual_method.h deleted file mode 100644 index 4edebad4f..000000000 --- a/Telegram/SourceFiles/base/virtual_method.h +++ /dev/null @@ -1,717 +0,0 @@ -/* -This file is part of Telegram Desktop, -the official desktop version of Telegram messaging app, see https://telegram.org - -Telegram Desktop is free software: you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation, either version 3 of the License, or -(at your option) any later version. - -It 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. - -In addition, as a special exception, the copyright holders give permission -to link the code of portions of this program with the OpenSSL library. - -Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org -*/ -#pragma once - -namespace base { - -template -class virtual_object; - -template -class virtual_method; - -template -class virtual_override; - -namespace virtual_methods { - -struct child_entry; -using is_parent_check = bool(*)(const child_entry &possible_parent); -struct child_entry { - is_parent_check check_is_parent; - int *table_index; -}; -using child_entries = std::vector; - -// Recursive method to find if some class is a child of some other class. -template -struct is_parent { - static inline bool check(const child_entry &possible_parent) { - // Generate a good error message if ConcreteObject is not a child of virtual_object<>. - using all_objects_must_derive_virtual_object = typename ConcreteObject::virtual_object_parent; - using ConcreteObjectParent = all_objects_must_derive_virtual_object; - return (possible_parent.check_is_parent == &is_parent::check) - || is_parent::check(possible_parent); - } -}; - -template <> -struct is_parent { - static inline bool check(const child_entry &possible_parent) { - return (possible_parent.check_is_parent == &is_parent::check); - } -}; - -// Just force the compiler not to optimize away the object that "enforce" points at. -inline void dont_optimize_away(void *enforce) { - static volatile void *result = nullptr; - if (result) { - result = enforce; - } -} - -template -struct dont_optimize_away_struct { -}; - -inline bool first_dispatch_fired(bool did_fire = false) { - static bool fired = false; - if (did_fire) { - fired = true; - } - return fired; -} - -template -class object_registrator { -public: - inline object_registrator() { - Assert(!first_dispatch_fired()); - Creator(child_entry { - &is_parent::check, - &_index, - }); - } - static inline int &Index() { - return _index; - } - -private: - static int _index; - -}; - -template -int object_registrator::_index = -1; - -class object_base { -protected: - virtual ~object_base() = default; - -}; - -template -struct multi_index_collector; -template -struct override_key_collector_helper; -template -struct table_fill_entry_helper; -template -struct table_count_size; - -} // namespace virtual_methods - -// This should be a base class for every child object in your hierarchy. -// It registers this child in the root virtual_objects classes list. -// Also it holds its own index in the classes list that is used for fast -// invoking of methods from the virtual tables in different virtual_methods. -template -class virtual_object : public ParentObject { -protected: - virtual ~virtual_object() { - virtual_methods::dont_optimize_away(&_virtual_object_registrator); - } - -private: - using virtual_object_parent = ParentObject; - - friend struct virtual_methods::is_parent; - template - friend struct virtual_methods::multi_index_collector; - template - friend struct virtual_methods::override_key_collector_helper; - template - friend class virtual_object; - template - friend class virtual_method; - - static inline void virtual_object_register_child(const virtual_methods::child_entry &entry) { - return ParentObject::virtual_object_register_child(entry); - } - - using virtual_object_registrator = virtual_methods::object_registrator; - static virtual_object_registrator _virtual_object_registrator; - using virtual_object_dont_optimize_away_registrator = virtual_methods::dont_optimize_away_struct; - - static inline int &virtual_object_child_index_static() { - return virtual_object_registrator::Index(); - } - int &virtual_object_child_index() override { - return virtual_object_child_index_static(); - } - -}; - -template -typename virtual_object::virtual_object_registrator virtual_object::_virtual_object_registrator = {}; - -// This should be a base class for the root of the whole hierarchy. -// It holds the table of all child classes in a list. -// This list is used by virtual_methods to generate virtual table. -template -class virtual_object : public virtual_methods::object_base { -protected: - virtual ~virtual_object() { - virtual_methods::dont_optimize_away(&_virtual_object_registrator); - } - -private: - using virtual_object_parent = void; - - friend struct virtual_methods::is_parent; - template - friend struct virtual_methods::table_count_size; - template - friend struct virtual_methods::multi_index_collector; - template - friend struct virtual_methods::override_key_collector_helper; - template - friend struct virtual_methods::table_fill_entry_helper; - template - friend class virtual_object; - template - friend class virtual_method; - - static inline virtual_methods::child_entries &virtual_object_get_child_entries() { - static virtual_methods::child_entries entries; - return entries; - } - - // Registers a new child class. - // After that on the next call to virtual_method::virtual_method_prepare_table() will - // generate a new virtual table for that virtual method. - static inline void virtual_object_register_child(const virtual_methods::child_entry &entry) { - auto &entries = virtual_object_get_child_entries(); - for (auto i = entries.begin(), e = entries.end(); i != e; ++i) { - if (entry.check_is_parent(*i)) { - *entry.table_index = (i - entries.begin()); - i = entries.insert(i, entry); - for (++i, e = entries.end(); i != e; ++i) { - ++*(i->table_index); - } - return; - } - } - *entry.table_index = entries.size(); - entries.push_back(entry); - } - - using virtual_object_registrator = virtual_methods::object_registrator; - static virtual_object_registrator _virtual_object_registrator; - using virtual_object_dont_optimize_away_registrator = virtual_methods::dont_optimize_away_struct; - - static inline int &virtual_object_child_index_static() { - return virtual_object_registrator::Index(); - } - virtual int &virtual_object_child_index() { - return virtual_object_child_index_static(); - } - -}; - -template -typename virtual_object::virtual_object_registrator virtual_object::_virtual_object_registrator = {}; - -namespace virtual_methods { - -template -struct is_virtual_argument : public std::integral_constant::is_pointer::value - ? std::is_base_of::pointed_type>::value - : false> { -}; - -template -class multi_int_wrap { -public: - inline multi_int_wrap(int *indices) : _indices(indices) { - } - inline multi_int_wrap subindex() const { - static_assert(N > 0, "Wrong multi_int_wrap created!"); - return multi_int_wrap(_indices + 1); - } - inline int ¤t() const { - return *_indices; - } - -private: - int *_indices; - -}; - -template -class multi_int_wrap<0, Instance> { -public: - inline multi_int_wrap(int *indices) { - } - inline int current() const { - return 1; - } - -}; - -template -using multi_index_wrap = multi_int_wrap; -template -using multi_size_wrap = multi_int_wrap; - -template -struct multi_index_collector { - static constexpr int N = sizeof...(ConcreteArgs) + 1; - static inline void call(multi_index_wrap indices, ConcreteArg arg, ConcreteArgs... args) { - indices.current() = computeIndex(is_virtual_argument(), arg); - multi_index_collector::call(indices.subindex(), args...); - } - - static inline int computeIndex(std::integral_constant, ConcreteArg arg) { - return 0; - } - static inline int computeIndex(std::integral_constant, ConcreteArg arg) { - return arg->virtual_object_child_index(); - } - -}; - -template <> -struct multi_index_collector<> { - static inline void call(multi_index_wrap<0> indices) { - } -}; - -template -class override_key; - -template -class multi_int { -public: - inline multi_int_wrap data_wrap() { - return multi_int_wrap(_indices); - } - - template - static inline multi_int collect(ConcreteArgs... args) { - multi_int result; - multi_index_collector::call(result.data_wrap(), args...); - return result; - } - - inline void reset() { - memset(_indices, 0, sizeof(_indices)); - } - - inline int value(int index) const { - return _indices[index]; - } - - inline void copy(multi_int_wrap other) { - memcpy(_indices, &other.current(), sizeof(_indices)); - } - -private: - int _indices[N] = { 0 }; - friend class override_key; - -}; - -template -using multi_index = multi_int; -template -using multi_size = multi_int; - -template -class table_data_wrap { -public: - inline table_data_wrap(Call *data, multi_size_wrap size) : _data(data), _size(size) { - } - inline table_data_wrap operator[](int index) const { - return table_data_wrap(_data + index * _size.subindex().current(), _size.subindex()); - } - inline Call &operator[](multi_index_wrap index) const { - return (*this)[index.current()][index.subindex()]; - } - inline int size() const { - return count_size(std::integral_constant()); - } - -private: - template - inline int count_size(std::integral_constant) const { - return _size.current() / _size.subindex().current(); - } - inline int count_size(std::integral_constant) const { - return _size.current(); - } - - Call *_data; - multi_size_wrap _size; - -}; - -template -class table_data_wrap { -public: - inline table_data_wrap(Call *data, multi_size_wrap<0> size) : _data(data) { - } - inline Call &operator[](multi_index_wrap<0> index) const { - return *_data; - } - -private: - Call *_data; - -}; - -template -class table_data_wrap; - -template -struct table_count_size { - static constexpr int N = sizeof...(Args) + 1; - static inline void call(multi_size_wrap index) { - auto subindex = index.subindex(); - table_count_size::call(subindex); - index.current() = count(is_virtual_argument()) * subindex.current(); - } - - static inline int count(std::integral_constant) { - return 1; - } - static inline int count(std::integral_constant) { - return base::type_traits::pointed_type::virtual_object_get_child_entries().size(); - } - -}; - -template <> -struct table_count_size<> { - static inline void call(multi_size_wrap<0> index) { - } -}; - -template -class table_data { -public: - inline table_data_wrap data_wrap() { - return table_data_wrap(_data.data(), _size.data_wrap()); - } - - inline Call &operator[](multi_index index) { - int flat_index = 0; - for (int i = 0; i != N - 1; ++i) { - flat_index += _size.value(i + 1) * index.value(i); - } - flat_index += index.value(N - 1); - return _data[flat_index]; - } - - template - inline bool changed() { - if (!_data.empty()) { - return false; - } - - multi_size size; - table_count_size::call(size.data_wrap()); - _size = size; - _data.resize(_size.value(0), nullptr); - return true; - } - -private: - std::vector _data; - multi_size _size; - -}; - -template -class table_data { -public: - inline table_data_wrap data_wrap() { - return table_data_wrap(&_call, multi_size_wrap<0>(nullptr)); - } - - inline Call &operator[](multi_index<0> index) { - return _call; - } - - inline bool changed() const { - return false; - } - -private: - Call _call = nullptr; - -}; - -template -struct table_fill_entry_helper; - -template -struct table_fill_entry_helper { - static constexpr int N = sizeof...(Args) + 1; - - static inline bool call(table_data_wrap table, multi_index_wrap index, Call &fill) { - auto start = index.current(); - for (auto i = start, count = table.size(); i != count; ++i) { - auto foundGoodType = good(is_virtual_argument(), start, index.current()); - if (foundGoodType) { - index.current() = i; - if (table_fill_entry_helper::call(table[i], index.subindex(), fill)) { - return true; - } - } - } - index.current() = start; - return false; - } - - static inline bool good(std::integral_constant, int start, int current) { - return (start == current); - } - static inline bool good(std::integral_constant, int start, int current) { - using BaseObject = typename base::type_traits::pointed_type; - auto &entries = BaseObject::virtual_object_get_child_entries(); - return (start == current) || entries[start].check_is_parent(entries[current]); - } - -}; - -template -struct table_fill_entry_helper { - static inline bool call(table_data_wrap table, multi_index_wrap<0> index, Call &fill) { - if (auto overrideMethod = table[index]) { - fill = overrideMethod; - return true; - } - return false; - } -}; - -template -struct table_fill_entry; - -template -struct table_fill_entry { - using Call = ReturnType(*)(BaseMethod*, Args...); - static inline void call(table_data_wrap table, multi_index_wrap index, Call &fill) { - table_fill_entry_helper::call(table, index, fill); - } -}; - -template -inline void fill_entry(table_data_wrap table, multi_index_wrap index, Call &fill) { - return virtual_methods::table_fill_entry::call(table, index, fill); -} - -template -struct override_key_collector_helper; - -template -struct override_key_collector_helper { - static inline void call(int **indices) { - setValue(is_virtual_argument(), indices); - override_key_collector_helper::call(indices); - } - - static inline void setValue(std::integral_constant, int **indices) { - indices[M] = nullptr; - } - static inline void setValue(std::integral_constant, int **indices) { - using ConcreteObject = typename base::type_traits::pointed_type; - using IsParentCheckStruct = is_parent; - using IsParentCheckPointer = decltype(&IsParentCheckStruct::check); - using override_key_collector_dont_optimize_away = dont_optimize_away_struct; - override_key_collector_dont_optimize_away dont_optimize_away_object; - (void)dont_optimize_away_object; - - // Check that is_parent<> can be instantiated. - // So every ConcreteObject is a valid child of virtual_object<>. - dont_optimize_away(reinterpret_cast(&IsParentCheckStruct::check)); - indices[M] = &ConcreteObject::virtual_object_child_index_static(); - } - -}; - -template -struct override_key_collector_helper { - static inline void call(int **indices) { - } -}; - -template -struct override_key_collector; - -template -struct override_key_collector { - static inline void call(int **indices) { - override_key_collector_helper<0, ConcreteArgs...>::call(indices); - } -}; - -template -class override_key { -public: - inline multi_index value() const { - multi_index result; - for (int i = 0; i != N; ++i) { - auto pointer = _indices[i]; - result._indices[i] = (pointer ? *pointer : 0); - } - return result; - } - - friend inline bool operator<(const override_key &k1, const override_key &k2) { - for (int i = 0; i != N; ++i) { - auto pointer1 = k1._indices[i], pointer2 = k2._indices[i]; - if (pointer1 < pointer2) { - return true; - } else if (pointer1 > pointer2) { - return false; - } - } - return false; - } - - template - inline void collect() { - override_key_collector::call(_indices); - } - -private: - int *_indices[N]; - -}; - -template -struct static_cast_helper; - -template -struct static_cast_helper { - static inline ReturnType call(BaseMethod *context, Args ...args) { - return ConcreteMethod::call(context, static_cast(args)...); - } -}; - -} // namespace virtual_methods - -// This is a base class for all your virtual methods. -// It dispatches a call to one of the registered virtual_overrides -// or calls the fallback method of the BaseMethod class. -template -class virtual_method { - static constexpr int N = sizeof...(Args); - using virtual_method_call = ReturnType(*)(BaseMethod *context, Args... args); - -public: - inline ReturnType call(Args... args) { - auto context = static_cast(this); - auto index = virtual_methods::multi_index::collect(args...); - auto &table = virtual_method_prepare_table(); - auto &entry = table[index]; - if (!entry) { - virtual_methods::fill_entry(table.data_wrap(), index.data_wrap(), entry); - if (!entry) { - entry = &virtual_method::virtual_method_base_instance; - } - } - return (*entry)(context, args...); - } - -private: - // This map of methods contains only the original registered overrides. - using virtual_method_override_key = virtual_methods::override_key; - using virtual_method_override_map = std::map; - static inline virtual_method_override_map &virtual_method_get_override_map() { - static virtual_method_override_map override_map; - return override_map; - } - - // This method generates and returns a virtual table which holds a method - // for any child in the hierarchy or nullptr if none of the virtual_overrides fit. - using virtual_method_table_data = virtual_methods::table_data; - static inline virtual_method_table_data &virtual_method_get_table_data() { - static virtual_method_table_data virtual_table; - return virtual_table; - } - - static inline virtual_method_table_data &virtual_method_prepare_table() { - auto &virtual_table = virtual_method_get_table_data(); - if (virtual_table.template changed()) { - virtual_methods::first_dispatch_fired(true); - - // The class hierarchy has changed - we need to generate the virtual table once again. - // All other handlers will be placed if they're called. - for (auto &i : virtual_method_get_override_map()) { - virtual_table[i.first.value()] = i.second; - } - } - return virtual_table; - } - - static ReturnType virtual_method_base_instance(BaseMethod *context, Args... args) { - return BaseMethod::default_call(context, args...); - } - - template - static ReturnType virtual_method_override_instance(BaseMethod *context, Args... args) { - return virtual_methods::static_cast_helper::call(context, args...); - } - - template - static inline void virtual_method_register_override() { - auto call = &virtual_method_override_instance; - - virtual_methods::override_key key; - key.template collect(); - - virtual_method_get_override_map()[key] = call; - } - - template - friend class virtual_override; - -}; - -template -class virtual_override { -protected: - virtual ~virtual_override() { - virtual_methods::dont_optimize_away(&_virtual_override_registrator); - } - -private: - class virtual_override_registrator { - public: - inline virtual_override_registrator() { - Assert(!virtual_methods::first_dispatch_fired()); - BaseMethod::template virtual_method_register_override(); - } - - }; - static virtual_override_registrator _virtual_override_registrator; - using virtual_override_dont_optimize_away_registrator = virtual_methods::dont_optimize_away_struct; - -}; - -template -typename virtual_override::virtual_override_registrator virtual_override::_virtual_override_registrator = {}; - -} // namespace base diff --git a/Telegram/SourceFiles/platform/mac/mac_iconv_helper.c b/Telegram/SourceFiles/platform/mac/mac_iconv_helper.c deleted file mode 100644 index 82f72a5da..000000000 --- a/Telegram/SourceFiles/platform/mac/mac_iconv_helper.c +++ /dev/null @@ -1,45 +0,0 @@ -/* -This file is part of Telegram Desktop, -the official desktop version of Telegram messaging app, see https://telegram.org - -Telegram Desktop is free software: you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation, either version 3 of the License, or -(at your option) any later version. - -It 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. - -In addition, as a special exception, the copyright holders give permission -to link the code of portions of this program with the OpenSSL library. - -Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org -*/ -#include - -#ifdef iconv_open -#undef iconv_open -#endif // iconv_open - -#ifdef iconv -#undef iconv -#endif // iconv - -#ifdef iconv_close -#undef iconv_close -#endif // iconv_close - -iconv_t iconv_open(const char* tocode, const char* fromcode) { - return libiconv_open(tocode, fromcode); -} - -size_t iconv(iconv_t cd, char** inbuf, size_t *inbytesleft, char** outbuf, size_t *outbytesleft) { - return libiconv(cd, inbuf, inbytesleft, outbuf, outbytesleft); -} - -int iconv_close(iconv_t cd) { - return libiconv_close(cd); -} diff --git a/Telegram/gyp/PrecompiledHeader.cmake b/Telegram/gyp/PrecompiledHeader.cmake deleted file mode 100644 index 5d6830e96..000000000 --- a/Telegram/gyp/PrecompiledHeader.cmake +++ /dev/null @@ -1,165 +0,0 @@ -## -## Modified for Telegram Desktop project by Telegram Desktop authors. -## -# Function for setting up precompiled headers. Usage: -# -# add_library/executable(target -# pchheader.c pchheader.cpp pchheader.h) -# -# add_precompiled_header(target pchheader.h -# [FORCEINCLUDE] -# [SOURCE_C pchheader.c] -# [SOURCE_CXX pchheader.cpp]) -# -# Options: -# -# FORCEINCLUDE: Add compiler flags to automatically include the -# pchheader.h from every source file. Works with both GCC and -# MSVC. This is recommended. -# -# SOURCE_C/CXX: Specifies the .c/.cpp source file that includes -# pchheader.h for generating the pre-compiled header -# output. Defaults to pchheader.c. Only required for MSVC. -# -# Caveats: -# -# * Its not currently possible to use the same precompiled-header in -# more than a single target in the same directory (No way to set -# the source file properties differently for each target). -# -# * MSVC: A source file with the same name as the header must exist -# and be included in the target (E.g. header.cpp). Name of file -# can be changed using the SOURCE_CXX/SOURCE_C options. -# -# License: -# -# Copyright (C) 2009-2013 Lars Christensen -# -# Permission is hereby granted, free of charge, to any person -# obtaining a copy of this software and associated documentation files -# (the 'Software') deal in the Software without restriction, -# including without limitation the rights to use, copy, modify, merge, -# publish, distribute, sublicense, and/or sell copies of the Software, -# and to permit persons to whom the Software is furnished to do so, -# subject to the following conditions: -# -# The above copyright notice and this permission notice shall be -# included in all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, -# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND -# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS -# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN -# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -# SOFTWARE. - -include(CMakeParseArguments) - -macro(combine_arguments _variable) - set(_result "") - foreach(_element ${${_variable}}) - set(_result "${_result} \"${_element}\"") - endforeach() - string(STRIP "${_result}" _result) - set(${_variable} "${_result}") -endmacro() - -function(export_all_flags _filename _source_name_for_flags) - set(_include_directories "$") - set(_compile_definitions "$") - get_source_file_property(_compile_flags "${_source_name_for_flags}" COMPILE_FLAGS) - set(_compile_options "$") - set(_include_directories "$<$:-I$\n>") - set(_compile_definitions "$<$:-D$\n>") - set(_compile_flags "$<$:$\n>") - set(_compile_options "$<$:$\n>") - file(GENERATE OUTPUT "${_filename}" CONTENT "${_compile_definitions}${_include_directories}${_compile_flags}${_compile_options}\n") -endfunction() - -function(add_precompiled_header _target _input) - if(CMAKE_COMPILER_IS_GNUCXX) - get_filename_component(_name ${_input} NAME) - set(_pch_header "${CMAKE_CURRENT_SOURCE_DIR}/${_input}") - set(_pch_binary_dir "${CMAKE_CURRENT_BINARY_DIR}/${_target}_pch") - set(_pchfile "${_pch_binary_dir}/${_name}") - set(_outdir "${_pch_binary_dir}/${_name}.gch") - make_directory(${_outdir}) - set(_output_cxx "${_outdir}/.c++") - set(_output_c "${_outdir}/.c") - - get_property(_sources TARGET ${_target} PROPERTY SOURCES) - foreach(_source ${_sources}) - if(_source MATCHES \\.\(c\)$ AND NOT _source_for_c_flags) - set(_source_for_c_flags "${_source}") - elseif(_source MATCHES \\.\(cc|cxx|cpp\)$ AND NOT _source_for_cpp_flags) - set(_source_for_cpp_flags "${_source}") - endif() - endforeach() - - add_custom_command( - OUTPUT "${_pchfile}" - COMMAND "${CMAKE_COMMAND}" -E copy "${_pch_header}" "${_pchfile}" - DEPENDS "${_pch_header}" - IMPLICIT_DEPENDS CXX "${_pch_header}" - IMPLICIT_DEPENDS C "${_pch_header}" - COMMENT "Updating ${_name}") - - if(_source_for_c_flags) - set(_pch_c_flags_file "${_pch_binary_dir}/compile_flags_c.rsp") - export_all_flags("${_pch_c_flags_file}" "${_source_for_c_flags}") - set(_compiler_FLAGS "@${_pch_c_flags_file}") - add_custom_command( - OUTPUT "${_output_c}" - COMMAND "${CMAKE_C_COMPILER}" ${_compiler_FLAGS} -x c-header -o "${_output_c}" -c "${_pchfile}" - DEPENDS "${_pchfile}" "${_pch_c_flags_file}" - IMPLICIT_DEPENDS C "${_pch_header}" - COMMENT "Precompiling ${_name} for ${_target} (C)") - endif() - if(_source_for_cpp_flags) - set(_pch_cpp_flags_file "${_pch_binary_dir}/compile_flags_cpp.rsp") - export_all_flags("${_pch_cpp_flags_file}" "${_source_for_cpp_flags}") - set(_compiler_FLAGS "@${_pch_cpp_flags_file}") - add_custom_command( - OUTPUT "${_output_cxx}" - COMMAND "${CMAKE_CXX_COMPILER}" ${_compiler_FLAGS} -x c++-header -o "${_output_cxx}" -c "${_pchfile}" - DEPENDS "${_pchfile}" "${_pch_cpp_flags_file}" - IMPLICIT_DEPENDS CXX "${_pch_header}" - COMMENT "Precompiling ${_name} for ${_target} (C++)") - endif() - - foreach(_source ${_sources}) - set(_pch_compile_flags "") - - if(_source MATCHES \\.\(cc|cxx|cpp|c\)$) - get_source_file_property(_pch_compile_flags "${_source}" COMPILE_FLAGS) - if(NOT _pch_compile_flags) - set(_pch_compile_flags) - endif() - separate_arguments(_pch_compile_flags) - if(_source MATCHES \\.\(cc|cxx|cpp\)$) - list(APPEND _pch_compile_flags -include "${_pchfile}") - else() - list(APPEND _pch_compile_flags "-I${_pch_binary_dir}") - endif() - - get_source_file_property(_object_depends "${_source}" OBJECT_DEPENDS) - if(NOT _object_depends) - set(_object_depends) - endif() - list(APPEND _object_depends "${_pchfile}") - if(_source MATCHES \\.\(cc|cxx|cpp\)$) - list(APPEND _object_depends "${_output_cxx}") - else() - list(APPEND _object_depends "${_output_c}") - endif() - - combine_arguments(_pch_compile_flags) - set_source_files_properties(${_source} PROPERTIES - COMPILE_FLAGS "${_pch_compile_flags}" - OBJECT_DEPENDS "${_object_depends}") - endif() - endforeach() - endif(CMAKE_COMPILER_IS_GNUCXX) -endfunction() diff --git a/Telegram/gyp/Telegram.gyp b/Telegram/gyp/Telegram.gyp deleted file mode 100644 index 6fa545e5d..000000000 --- a/Telegram/gyp/Telegram.gyp +++ /dev/null @@ -1,130 +0,0 @@ -# This file is part of Telegram Desktop, -# the official desktop version of Telegram messaging app, see https://telegram.org -# -# Telegram Desktop is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# It 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. -# -# In addition, as a special exception, the copyright holders give permission -# to link the code of portions of this program with the OpenSSL library. -# -# Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -# Copyright (c) 2014 John Preston, https://desktop.telegram.org - -{ - 'includes': [ - 'common.gypi', - ], - 'targets': [{ - 'target_name': 'Telegram', - 'variables': { - 'variables': { - 'libs_loc': '../../../Libraries', - }, - 'libs_loc': '<(libs_loc)', - 'src_loc': '../SourceFiles', - 'res_loc': '../Resources', - 'submodules_loc': '../ThirdParty', - 'minizip_loc': '<(submodules_loc)/minizip', - 'sp_media_key_tap_loc': '<(submodules_loc)/SPMediaKeyTap', - 'emoji_suggestions_loc': '<(submodules_loc)/emoji_suggestions', - 'style_files': [ - '<(res_loc)/colors.palette', - '<(res_loc)/basic.style', - '<(src_loc)/boxes/boxes.style', - '<(src_loc)/calls/calls.style', - '<(src_loc)/dialogs/dialogs.style', - '<(src_loc)/history/history.style', - '<(src_loc)/intro/intro.style', - '<(src_loc)/media/view/mediaview.style', - '<(src_loc)/media/player/media_player.style', - '<(src_loc)/overview/overview.style', - '<(src_loc)/profile/profile.style', - '<(src_loc)/settings/settings.style', - '<(src_loc)/chat_helpers/chat_helpers.style', - '<(src_loc)/ui/widgets/widgets.style', - '<(src_loc)/window/window.style', - ], - 'langpacks': [ - 'en', - 'de', - 'es', - 'it', - 'nl', - 'ko', - 'pt-BR', - ], - 'build_defines%': '', - 'list_sources_command': 'python <(DEPTH)/list_sources.py --input <(DEPTH)/telegram_sources.txt --replace src_loc=<(src_loc)', - }, - 'includes': [ - 'common_executable.gypi', - 'telegram_qrc.gypi', - 'telegram_win.gypi', - 'telegram_mac.gypi', - 'telegram_linux.gypi', - 'qt.gypi', - 'qt_moc.gypi', - 'qt_rcc.gypi', - 'codegen_rules.gypi', - ], - - 'dependencies': [ - 'codegen.gyp:codegen_emoji', - 'codegen.gyp:codegen_lang', - 'codegen.gyp:codegen_numbers', - 'codegen.gyp:codegen_style', - 'tests/tests.gyp:tests', - 'utils.gyp:Updater', - '../ThirdParty/libtgvoip/libtgvoip.gyp:libtgvoip', - ], - - 'defines': [ - 'AL_LIBTYPE_STATIC', - 'AL_ALEXT_PROTOTYPES', - 'TGVOIP_USE_CXX11_LIB', - ' 0 - -my_path = os.path.dirname(os.path.realpath(__file__)).replace('\\', '/') - -file_paths = [] -platform_rules = {} -next_input_path = 0 -input_path = '' -next_moc_prefix = 0 -moc_prefix = '' -next_replace = 0 -replaces = [] -next_exclude_for = 0 -exclude_for = '' -next_self = 1 -for arg in sys.argv: - if next_self != 0: - next_self = 0 - continue - - if arg == '--moc-prefix': - next_moc_prefix = 1 - continue - elif next_moc_prefix == 1: - next_moc_prefix = 0 - moc_prefix = arg.replace('SHARED_INTERMEDIATE_DIR', '<(SHARED_INTERMEDIATE_DIR)') - continue - - if arg == '--input': - next_input_path = 1 - continue - elif next_input_path == 1: - next_input_path = 0 - input_path = arg - continue - - if arg == '--replace': - next_replace = 1 - continue - elif next_replace == 1: - next_replace = 0 - replaces.append(arg) - continue - - if arg == '--exclude_for': - next_exclude_for = 1 - continue - elif next_exclude_for == 1: - next_exclude_for = 0 - exclude_for = arg - continue - - file_paths.append(arg) - -if input_path != '': - if len(file_paths) != 0: - eprint('You need to specify input file or input paths in command line.') - elif not os.path.isfile(input_path): - eprint('Input path not found.') - else: - platforms = [] - with open(input_path, 'r') as f: - for line in f: - file_path = line.strip() - if file_path[0:10] == 'platforms:': - platforms_list = file_path[10:].split(' ') - platforms = [] - for platform in file_path[10:].split(' '): - platform = platform.strip() - if platform != '': - platforms.append(platform) - elif file_path[0:2] != '//' and file_path != '': - file_paths.append(file_path) - if len(platforms): - platform_rules[file_path] = platforms - elif '/platform/win/' in file_path: - platform_rules[file_path] = [ 'win' ] - elif '/platform/mac/' in file_path: - platform_rules[file_path] = [ 'mac' ] - elif '/platform/linux/' in file_path: - platform_rules[file_path] = [ 'linux' ] - -for replace in replaces: - replace_parts = replace.split('=', 1) - if len(replace_parts) != 2: - eprint('Bad replace: ' + replace) - real_paths = [] - real_platform_rules = {} - for file_path in file_paths: - real_path = file_path.replace('<(' + replace_parts[0] + ')', replace_parts[1]) - real_paths.append(real_path) - if file_path in platform_rules: - real_platform_rules[real_path] = platform_rules[file_path] - file_paths = real_paths - platform_rules = real_platform_rules - -if exclude_for != '': - real_paths = [] - for file_path in file_paths: - if not file_path in platform_rules: - continue - if not should_exclude(platform_rules[file_path], exclude_for): - continue - real_paths.append(file_path) - file_paths = real_paths - -for file_path in file_paths: - print(file_path) -if moc_prefix != '': - for file_path in file_paths: - if check_non_empty_moc(file_path): - m = re.search(r'(^|/)([^/]+)\.h$', file_path) - if not m: - eprint('Bad file path: ' + file_path) - print(moc_prefix + m.group(2) + '.cpp') diff --git a/Telegram/gyp/print_version.sh b/Telegram/gyp/print_version.sh deleted file mode 100755 index 791a5318d..000000000 --- a/Telegram/gyp/print_version.sh +++ /dev/null @@ -1,15 +0,0 @@ -#!/usr/bin/env bash -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 - diff --git a/Telegram/gyp/qt.gypi b/Telegram/gyp/qt.gypi deleted file mode 100644 index 67f7976e2..000000000 --- a/Telegram/gyp/qt.gypi +++ /dev/null @@ -1,256 +0,0 @@ -# This file is part of Telegram Desktop, -# the official desktop version of Telegram messaging app, see https://telegram.org -# -# Telegram Desktop is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# It 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. -# -# In addition, as a special exception, the copyright holders give permission -# to link the code of portions of this program with the OpenSSL library. -# -# Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -# Copyright (c) 2014 John Preston, https://desktop.telegram.org - -{ - 'variables': { - 'variables': { - 'variables': { - 'variables': { - 'variables': { - 'conditions': [ - [ 'build_macold', { - 'qt_version%': '5.3.2', - }, { - 'qt_version%': '5.6.2', - }] - ], - }, - 'qt_libs': [ - 'qwebp', - 'Qt5PrintSupport', - 'Qt5PlatformSupport', - 'Qt5Network', - 'Qt5Widgets', - 'Qt5Gui', - 'qtharfbuzzng', - ], - 'qt_version%': '<(qt_version)', - 'conditions': [ - [ 'build_macold', { - 'linux_path_qt%': '/usr/local/macold/Qt-<(qt_version)', - }, { - 'linux_path_qt%': '/usr/local/tdesktop/Qt-<(qt_version)', - }] - ] - }, - 'qt_version%': '<(qt_version)', - 'qt_loc_unix': '<(linux_path_qt)', - 'conditions': [ - [ 'build_win', { - 'qt_lib_prefix': '<(ld_lib_prefix)', - 'qt_lib_debug_postfix': 'd<(ld_lib_postfix)', - 'qt_lib_release_postfix': '<(ld_lib_postfix)', - 'qt_libs': [ - '<@(qt_libs)', - 'Qt5Core', - 'qtmain', - 'qwindows', - 'qtfreetype', - 'qtpcre', - ], - }], - [ 'build_mac', { - 'qt_lib_prefix': '<(ld_lib_prefix)', - 'qt_lib_debug_postfix': '_debug<(ld_lib_postfix)', - 'qt_lib_release_postfix': '<(ld_lib_postfix)', - 'qt_libs': [ - '<@(qt_libs)', - 'Qt5Core', - 'qgenericbearer', - 'qcocoa', - ], - }], - [ 'build_mac and not build_macold', { - 'qt_libs': [ - '<@(qt_libs)', - 'Qt5Core', - 'qtfreetype', - 'qtpcre', - ], - }], - [ 'build_linux', { - 'qt_lib_prefix': 'lib', - 'qt_lib_debug_postfix': '.a', - 'qt_lib_release_postfix': '.a', - 'qt_libs': [ - 'qxcb', - 'Qt5XcbQpa', - 'qconnmanbearer', - 'qgenericbearer', - 'qnmbearer', - '<@(qt_libs)', - 'Qt5DBus', - 'Qt5Core', - 'qtpcre', - 'Xi', - 'Xext', - 'Xfixes', - 'SM', - 'ICE', - 'fontconfig', - 'expat', - 'freetype', - 'z', - 'xcb-shm', - 'xcb-xfixes', - 'xcb-render', - 'xcb-static', - ], - }], - ], - }, - 'qt_version%': '<(qt_version)', - 'qt_loc_unix': '<(qt_loc_unix)', - 'qt_version_loc': 'nul" -if "%1" == "-v" set "Silence=" - -if exist "%FullScriptPath%..\build\target" ( - FOR /F "tokens=1* delims= " %%i in (%FullScriptPath%..\build\target) do set "BuildTarget=%%i" -) else ( - set "BuildTarget=" -) - -rem strangely linking of Release Telegram build complains about the absence of lib.pdb -if exist "%FullScriptPath%..\..\..\Libraries\openssl\tmp32\lib.pdb" ( - if not exist "%FullScriptPath%..\..\..\Libraries\openssl\Release\lib\lib.pdb" ( - xcopy "%FullScriptPath%..\..\..\Libraries\openssl\tmp32\lib.pdb" "%FullScriptPath%..\..\..\Libraries\openssl\Release\lib\" %Silence% - ) -) - -set BUILD_DEFINES= -if not "%TDESKTOP_BUILD_DEFINES%" == "" ( - set "BUILD_DEFINES=-Dbuild_defines=%TDESKTOP_BUILD_DEFINES%" - echo [INFO] Set build defines to !BUILD_DEFINES! -) - -set GYP_MSVS_VERSION=2017 - -cd "%FullScriptPath%" -call gyp --depth=. --generator-output=.. -Goutput_dir=../out !BUILD_DEFINES! -Dofficial_build_target=%BuildTarget% Telegram.gyp --format=ninja -if %errorlevel% neq 0 goto error -call gyp --depth=. --generator-output=.. -Goutput_dir=../out !BUILD_DEFINES! -Dofficial_build_target=%BuildTarget% Telegram.gyp --format=msvs-ninja -if %errorlevel% neq 0 goto error -cd ../.. - -rem looks like ninja build works without sdk 7.1 which was used by generating custom environment.arch files - -rem cd "%FullScriptPath%" -rem call gyp --depth=. --generator-output=../.. -Goutput_dir=out -Gninja_use_custom_environment_files=1 Telegram.gyp --format=ninja -rem if %errorlevel% neq 0 goto error -rem call gyp --depth=. --generator-output=../.. -Goutput_dir=out -Gninja_use_custom_environment_files=1 Telegram.gyp --format=msvs-ninja -rem if %errorlevel% neq 0 goto error -rem cd ../.. - -rem call msbuild /target:SetBuildDefaultEnvironmentVariables Telegram.vcxproj /fileLogger %Silence% -rem if %errorlevel% neq 0 goto error - -rem call python "%FullScriptPath%create_env.py" -rem if %errorlevel% neq 0 goto error - -rem call move environment.x86 out\Debug\ %Silence% -rem if %errorlevel% neq 0 goto error - -cd "%FullExecPath%" -exit /b - -:error -echo FAILED -if exist "%FullScriptPath%..\..\msbuild.log" del "%FullScriptPath%..\..\msbuild.log" -if exist "%FullScriptPath%..\..\environment.x86" del "%FullScriptPath%..\..\environment.x86" -cd "%FullExecPath%" -exit /b 1 diff --git a/Telegram/gyp/refresh.sh b/Telegram/gyp/refresh.sh deleted file mode 100755 index d9e90a16b..000000000 --- a/Telegram/gyp/refresh.sh +++ /dev/null @@ -1,38 +0,0 @@ -#!/usr/bin/env bash -set -e -FullExecPath=$PWD -pushd `dirname $0` > /dev/null -FullScriptPath=`pwd` -popd > /dev/null - -if [ -f "$FullScriptPath/../build/target" ]; then - while IFS='' read -r line || [[ -n "$line" ]]; do - BuildTarget="$line" - done < "$FullScriptPath/../build/target" -else - BuildTarget="" -fi - -MySystem=`uname -s` -cd $FullScriptPath - -if [ "$MySystem" == "Linux" ]; then - ../../../Libraries/gyp/gyp --depth=. --generator-output=.. -Goutput_dir=../out -Dofficial_build_target=$BuildTarget Telegram.gyp --format=cmake - cd ../../out/Debug - ../../../Libraries/cmake-3.6.2/bin/cmake . - cd ../Release - ../../../Libraries/cmake-3.6.2/bin/cmake . - cd ../../Telegram/gyp -else - #gyp --depth=. --generator-output=../.. -Goutput_dir=out Telegram.gyp --format=ninja - #gyp --depth=. --generator-output=../.. -Goutput_dir=out Telegram.gyp --format=xcode-ninja - #gyp --depth=. --generator-output=../.. -Goutput_dir=out Telegram.gyp --format=xcode - # use patched gyp with Xcode project generator - ../../../Libraries/gyp/gyp --depth=. --generator-output=.. -Goutput_dir=../out -Gxcode_upgrade_check_project_version=830 -Dofficial_build_target=$BuildTarget Telegram.gyp --format=xcode -fi - -cd ../.. - -cd $FullExecPath -exit - diff --git a/Telegram/gyp/settings_linux.gypi b/Telegram/gyp/settings_linux.gypi deleted file mode 100644 index fde88dcd1..000000000 --- a/Telegram/gyp/settings_linux.gypi +++ /dev/null @@ -1,81 +0,0 @@ -# This file is part of Telegram Desktop, -# the official desktop version of Telegram messaging app, see https://telegram.org -# -# Telegram Desktop is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# It 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. -# -# In addition, as a special exception, the copyright holders give permission -# to link the code of portions of this program with the OpenSSL library. -# -# Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -# Copyright (c) 2014 John Preston, https://desktop.telegram.org - -{ - 'conditions': [ - [ 'build_linux', { - 'variables': { - 'linux_common_flags': [ - '-pipe', - '-g', - '-Wall', - '-Werror', - '-W', - '-fPIC', - '-Wno-unused-variable', - '-Wno-unused-parameter', - '-Wno-unused-function', - '-Wno-switch', - '-Wno-comment', - '-Wno-unused-but-set-variable', - '-Wno-missing-field-initializers', - '-Wno-sign-compare', - ], - }, - 'conditions': [ - [ '" createPlatformIntegration -> QXcbIntegrationPlugin::create - #'xkbcommon', - ], - 'linux_path_ffmpeg%': '/usr/local', - 'linux_path_openal%': '/usr/local', - 'linux_path_libexif_lib%': '<(libs_loc)/libexif-0.6.20/libexif/.libs', - 'linux_path_va%': '/usr/local', - 'linux_path_vdpau%': '/usr/local', - 'linux_path_breakpad%': '<(libs_loc)/breakpad', - 'linux_path_opus_include%': '<(libs_loc)/opus/include', - }, - 'include_dirs': [ - '/usr/local/include', - '<(linux_path_ffmpeg)/include', - '<(linux_path_openal)/include', - '<(linux_path_breakpad)/include/breakpad', - '<(linux_path_opus_include)', - ], - 'library_dirs': [ - '/usr/local/lib', - '<(linux_path_ffmpeg)/lib', - '<(linux_path_openal)/lib', - '<(linux_path_libexif_lib)', - '<(linux_path_va)/lib', - '<(linux_path_vdpau)/lib', - '<(linux_path_breakpad)/lib', - ], - 'libraries': [ - 'breakpad_client', - 'composeplatforminputcontextplugin', - 'ibusplatforminputcontextplugin', - 'fcitxplatforminputcontextplugin', - 'himeplatforminputcontextplugin', - 'liblzma.a', - 'libopenal.a', - 'libavformat.a', - 'libavcodec.a', - 'libswresample.a', - 'libswscale.a', - 'libavutil.a', - 'libopus.a', - 'libva-x11.a', - 'libva-drm.a', - 'libva.a', - 'libvdpau.a', - 'libdrm.a', - 'libz.a', -# ' /dev/null --libs <@(pkgconfig_libs))', - ], - 'conditions': [['not_need_gtk!="True"', { - 'cflags_cc': [ - ' /dev/null --cflags appindicator-0.1)', - ' /dev/null --cflags gtk+-2.0)', - ' /dev/null --cflags glib-2.0)', - ' /dev/null --cflags dee-1.0)', - ], - }]], - 'configurations': { - 'Release': { - 'cflags': [ - '-Ofast', - '-flto', - '-fno-strict-aliasing', - ], - 'cflags_cc': [ - '-Ofast', - '-flto', - '-fno-strict-aliasing', - ], - 'ldflags': [ - '-Ofast', - '-flto', - ], - }, - }, - 'cmake_precompiled_header': '<(src_loc)/stdafx.h', - 'cmake_precompiled_header_script': 'PrecompiledHeader.cmake', - }]], -} diff --git a/Telegram/gyp/telegram_mac.gypi b/Telegram/gyp/telegram_mac.gypi deleted file mode 100644 index c87eb4763..000000000 --- a/Telegram/gyp/telegram_mac.gypi +++ /dev/null @@ -1,233 +0,0 @@ -# This file is part of Telegram Desktop, -# the official desktop version of Telegram messaging app, see https://telegram.org -# -# Telegram Desktop is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# It 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. -# -# In addition, as a special exception, the copyright holders give permission -# to link the code of portions of this program with the OpenSSL library. -# -# Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -# Copyright (c) 2014 John Preston, https://desktop.telegram.org - -{ - 'conditions': [[ 'build_mac', { - 'xcode_settings': { - 'GCC_PREFIX_HEADER': '<(src_loc)/stdafx.h', - 'GCC_PRECOMPILE_PREFIX_HEADER': 'YES', - 'INFOPLIST_FILE': '../Telegram.plist', - 'CURRENT_PROJECT_VERSION': ']*)?>([^<]+)', line) - if file_match: - full_path = dir_name + '/' + file_match.group(2) - dependencies[full_path] = 1 - return dependencies - -def list_qrc_dependencies(file_path): - global one_modified - dependencies = get_qrc_dependencies(file_path) - for path in dependencies: - print(path) - sys.exit(0) - -one_modified = 0 -def handle_qrc_dependencies(file_path): - global one_modified - dependencies = get_qrc_dependencies(file_path) - file_modified = os.path.getmtime(file_path) - latest_modified = file_modified - for path in dependencies: - if os.path.isfile(path): - dependency_modified = os.path.getmtime(path) - if latest_modified < dependency_modified: - latest_modified = dependency_modified - else: - eprint('File not found: ' + path) - if file_modified < latest_modified: - os.utime(file_path, None); - one_modified = 1 - -def get_direct_style_dependencies(file_path): - dependencies = {} - dependencies[file_path] = 1 - if not os.path.isfile(file_path): - eprint('File not found: ' + file_path) - with open(file_path) as f: - for line in f: - using_match = re.match('^\s*using "([^"]+)"', line) - if using_match: - path = using_match.group(1) - found = 0 - for include_dir in include_dirs: - full_path = include_dir + '/' + path - if os.path.isfile(full_path): - try: - if dependencies[full_path]: - eprint('Cyclic dependencies: ' + full_path) - except KeyError: - dependencies[full_path] = 1 - found = 1 - break - if found != 1: - eprint('File not found: ' + path) - return dependencies - -include_dirs = [] -def handle_style_dependencies(file_path): - global one_modified - all_dependencies = {} - all_dependencies[file_path] = 1 - added_from = {} - while len(added_from) != len(all_dependencies): - for dependency in all_dependencies: - try: - if added_from[dependency]: - continue - except KeyError: - added_from[dependency] = 1 - add = get_direct_style_dependencies(dependency) - for new_dependency in add: - all_dependencies[new_dependency] = 1 - break - - file_modified = os.path.getmtime(file_path) - latest_modified = file_modified - for path in all_dependencies: - if path != file_path: - dependency_modified = os.path.getmtime(path) - if latest_modified < dependency_modified: - latest_modified = dependency_modified - if file_modified < latest_modified: - os.utime(file_path, None); - one_modified = 1 - -file_paths = [] -request = '' -output_file = '' -next_include_dir = 0 -next_output_file = 0 -next_self = 1 -for arg in sys.argv: - if next_self != 0: - next_self = 0 - continue - if arg == '--styles' or arg == '--qrc_list' or arg == '--qrc': - if request == '': - request = arg[2:] - else: - eprint('Only one request required.') - continue - if next_include_dir != 0: - next_include_dir = 0 - include_dirs.append(arg) - continue - if next_output_file != 0: - next_output_file = 0 - output_file = arg - continue - - include_dir_match = re.match(r'^\-I(.*)$', arg) - if include_dir_match: - include_dir = include_dir_match.group(1) - if include_dir == '': - next_include_dir = 1 - else: - include_dirs.append(include_dir) - continue - - output_match = re.match(r'^-o(.*)$', arg) - if output_match: - output_file = output_match.group(1) - if output_file == '': - next_output_file = 1 - continue - - file_paths.append(arg) - -if request == 'styles': - for file_path in file_paths: - handle_style_dependencies(file_path) -elif request == 'qrc': - for file_path in file_paths: - handle_qrc_dependencies(file_path) -elif request == 'qrc_list': - for file_path in file_paths: - list_qrc_dependencies(file_path) -else: - eprint('Request required.') - -if not os.path.isfile(output_file): - with open(output_file, "w") as f: - f.write('1') -elif one_modified != 0: - os.utime(output_file, None); diff --git a/Telegram/gyp/utils.gyp b/Telegram/gyp/utils.gyp deleted file mode 100644 index c7dcb6965..000000000 --- a/Telegram/gyp/utils.gyp +++ /dev/null @@ -1,166 +0,0 @@ -# This file is part of Telegram Desktop, -# the official desktop version of Telegram messaging app, see https://telegram.org -# -# Telegram Desktop is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# It 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. -# -# In addition, as a special exception, the copyright holders give permission -# to link the code of portions of this program with the OpenSSL library. -# -# Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE -# Copyright (c) 2014 John Preston, https://desktop.telegram.org - -{ - 'includes': [ - 'common.gypi', - ], - 'targets': [{ - 'target_name': 'Updater', - 'variables': { - 'libs_loc': '../../../Libraries', - 'src_loc': '../SourceFiles', - 'res_loc': '../Resources', - }, - 'includes': [ - 'common_executable.gypi', - ], - - 'include_dirs': [ - '<(src_loc)', - ], - 'sources': [ - '<(src_loc)/_other/updater.cpp', - '<(src_loc)/_other/updater.h', - '<(src_loc)/_other/updater_linux.cpp', - '<(src_loc)/_other/updater_osx.m', - ], - 'conditions': [ - [ 'build_win', { - 'sources': [ - '<(res_loc)/winrc/Updater.rc', - ], - }], - [ '"<(build_linux)" != "1"', { - 'sources!': [ - '<(src_loc)/_other/updater_linux.cpp', - ], - }], - [ '"<(build_mac)" != "1"', { - 'sources!': [ - '<(src_loc)/_other/updater_osx.m', - ], - }], - [ '"<(build_win)" != "1"', { - 'sources!': [ - '<(src_loc)/_other/updater.cpp', - ], - }], - ], - }, { - 'target_name': 'Packer', - 'variables': { - 'libs_loc': '../../../Libraries', - 'src_loc': '../SourceFiles', - 'mac_target': '10.10', - }, - 'includes': [ - 'common_executable.gypi', - 'qt.gypi', - ], - 'conditions': [ - [ 'build_win', { - 'libraries': [ - 'libeay32', - 'ssleay32', - 'Crypt32', - 'zlibstat', - 'LzmaLib', - ], - }], - [ 'build_linux', { - 'libraries': [ - 'ssl', - 'crypto', - 'lzma', - ], - }], - [ 'build_mac', { - 'include_dirs': [ - '<(libs_loc)/openssl-xcode/include' - ], - 'library_dirs': [ - '<(libs_loc)/openssl-xcode', - ], - 'xcode_settings': { - 'OTHER_LDFLAGS': [ - '-lssl', - '-lcrypto', - '-llzma', - ], - }, - }], - ], - 'include_dirs': [ - '<(src_loc)', - '<(libs_loc)/lzma/C', - '<(libs_loc)/zlib', - ], - 'sources': [ - '<(src_loc)/_other/packer.cpp', - '<(src_loc)/_other/packer.h', - ], - 'configurations': { - 'Debug': { - 'conditions': [ - [ 'build_win', { - 'include_dirs': [ - '<(libs_loc)/openssl/Debug/include', - ], - 'library_dirs': [ - '<(libs_loc)/openssl/Debug/lib', - '<(libs_loc)/lzma/C/Util/LzmaLib/Debug', - '<(libs_loc)/zlib/contrib/vstudio/vc14/x86/ZlibStatDebug', - ], - }, { - 'include_dirs': [ - '/usr/local/include', - '<(libs_loc)/openssl-xcode/include' - ], - 'library_dirs': [ - '/usr/local/lib', - ], - }] - ], - }, - 'Release': { - 'conditions': [ - [ 'build_win', { - 'include_dirs': [ - '<(libs_loc)/openssl/Release/include', - ], - 'library_dirs': [ - '<(libs_loc)/openssl/Release/lib', - '<(libs_loc)/lzma/C/Util/LzmaLib/Release', - '<(libs_loc)/zlib/contrib/vstudio/vc14/x86/ZlibStatReleaseWithoutAsm', - ], - }, { - 'include_dirs': [ - '/usr/local/include', - '<(libs_loc)/openssl-xcode/include' - ], - 'library_dirs': [ - '/usr/local/lib', - ], - }] - ], - }, - }, - }], -} diff --git a/docs/building-msvc.md b/docs/building-msvc.md deleted file mode 100644 index 9b8de4178..000000000 --- a/docs/building-msvc.md +++ /dev/null @@ -1,167 +0,0 @@ -# Build instructions for Visual Studio 2017 - -- [Prepare folder](#prepare-folder) -- [Install third party software](#install-third-party-software) -- [Clone source code and prepare libraries](#clone-source-code-and-prepare-libraries) -- [Build the project](#build-the-project) -- [Qt Visual Studio Tools](#qt-visual-studio-tools) - -## Prepare folder - -Choose an empty folder for the future build, for example **D:\\TBuild**. It will be named ***BuildPath*** in the rest of this document. Create two folders there, ***BuildPath*\\ThirdParty** and ***BuildPath*\\Libraries** - -All commands (if not stated otherwise) will be launched from **x86 Native Tools Command Prompt for VS 2017.bat** (should be in **Start Menu > Visual Studio 2017** menu folder). Pay attention not to use any other Command Prompt. - -## Install third party software - -* Download **ActivePerl** installer from [https://www.activestate.com/activeperl/downloads](https://www.activestate.com/activeperl/downloads) and install to ***BuildPath*\\ThirdParty\\Perl** -* Download **NASM** installer from [http://www.nasm.us](http://www.nasm.us) and install to ***BuildPath*\\ThirdParty\\NASM** -* Download **Yasm** executable from [http://yasm.tortall.net/Download.html](http://yasm.tortall.net/Download.html), rename to *yasm.exe* and put to ***BuildPath*\\ThirdParty\\yasm** -* Download **MSYS2** installer from [http://www.msys2.org/](http://www.msys2.org/) and install to ***BuildPath*\\ThirdParty\\msys64** -* Download **jom** archive from [http://download.qt.io/official_releases/jom/jom.zip](http://download.qt.io/official_releases/jom/jom.zip) and unpack to ***BuildPath*\\ThirdParty\\jom** -* Download **Python 2.7** installer from [https://www.python.org/downloads/](https://www.python.org/downloads/) and install to ***BuildPath*\\ThirdParty\\Python27** -* Download **CMake** installer from [https://cmake.org/download/](https://cmake.org/download/) and install to ***BuildPath*\\ThirdParty\\cmake** -* Download **Ninja** executable from [https://github.com/ninja-build/ninja/releases/download/v1.7.2/ninja-win.zip](https://github.com/ninja-build/ninja/releases/download/v1.7.2/ninja-win.zip) and unpack to ***BuildPath*\\ThirdParty\\Ninja** - -Open **x86 Native Tools Command Prompt for VS 2017.bat**, go to ***BuildPath*** and run - - cd ThirdParty - git clone https://chromium.googlesource.com/external/gyp - cd gyp - git checkout a478c1ab51 - cd ..\.. - -Add **GYP** and **Ninja** to your PATH: - -* Open **Control Panel** -> **System** -> **Advanced system settings** -* Press **Environment Variables...** -* Select **Path** -* Press **Edit** -* Add ***BuildPath*\\ThirdParty\\gyp** value -* Add ***BuildPath*\\ThirdParty\\Ninja** value - -## Clone source code and prepare libraries - -Open **x86 Native Tools Command Prompt for VS 2017.bat**, go to ***BuildPath*** and run - - SET PATH=%cd%\ThirdParty\Perl\bin;%cd%\ThirdParty\Python27;%cd%\ThirdParty\NASM;%cd%\ThirdParty\jom;%cd%\ThirdParty\cmake\bin;%cd%\ThirdParty\yasm;%PATH% - - git clone --recursive https://github.com/telegramdesktop/tdesktop.git - - mkdir Libraries - cd Libraries - - git clone https://github.com/telegramdesktop/lzma.git - cd lzma\C\Util\LzmaLib - msbuild LzmaLib.sln /property:Configuration=Debug - msbuild LzmaLib.sln /property:Configuration=Release - cd ..\..\..\.. - - git clone https://github.com/openssl/openssl.git - cd openssl - git checkout OpenSSL_1_0_1-stable - perl Configure no-shared --prefix=%cd%\Release --openssldir=%cd%\Release VC-WIN32 - ms\do_ms - nmake -f ms\nt.mak - nmake -f ms\nt.mak install - xcopy tmp32\lib.pdb Release\lib\ - nmake -f ms\nt.mak clean - perl Configure no-shared --prefix=%cd%\Debug --openssldir=%cd%\Debug debug-VC-WIN32 - ms\do_ms - nmake -f ms\nt.mak - nmake -f ms\nt.mak install - xcopy tmp32.dbg\lib.pdb Debug\lib\ - cd .. - - git clone https://github.com/telegramdesktop/zlib.git - cd zlib - git checkout tdesktop - cd contrib\vstudio\vc14 - msbuild zlibstat.vcxproj /property:Configuration=Debug - msbuild zlibstat.vcxproj /property:Configuration=ReleaseWithoutAsm - cd ..\..\..\.. - - git clone git://repo.or.cz/openal-soft.git - cd openal-soft - git checkout 18bb46163af - cd build - cmake -G "Visual Studio 15 2017" -D LIBTYPE:STRING=STATIC -D FORCE_STATIC_VCRT:STRING=ON .. - msbuild OpenAL32.vcxproj /property:Configuration=Debug - msbuild OpenAL32.vcxproj /property:Configuration=Release - cd ..\.. - - git clone https://github.com/google/breakpad - cd breakpad - git checkout a1dbcdcb43 - git apply ../../tdesktop/Telegram/Patches/breakpad.diff - cd src - git clone https://github.com/google/googletest testing - cd client\windows - set GYP_MSVS_VERSION=2017 - gyp --no-circular-check breakpad_client.gyp --format=ninja - cd ..\.. - ninja -C out/Debug common crash_generation_client exception_handler - ninja -C out/Release common crash_generation_client exception_handler - cd ..\.. - - git clone https://github.com/telegramdesktop/opus.git - cd opus - git checkout tdesktop - cd win32\VS2015 - msbuild opus.sln /property:Configuration=Debug /property:Platform="Win32" - msbuild opus.sln /property:Configuration=Release /property:Platform="Win32" - - cd ..\..\..\.. - SET PATH_BACKUP_=%PATH% - SET PATH=%cd%\ThirdParty\msys64\usr\bin;%PATH% - cd Libraries - - git clone https://github.com/FFmpeg/FFmpeg.git ffmpeg - cd ffmpeg - git checkout release/3.2 - - set CHERE_INVOKING=enabled_from_arguments - set MSYS2_PATH_TYPE=inherit - bash --login ../../tdesktop/Telegram/Patches/build_ffmpeg_win.sh - - SET PATH=%PATH_BACKUP_% - cd .. - - git clone git://code.qt.io/qt/qt5.git qt5_6_2 - cd qt5_6_2 - perl init-repository --module-subset=qtbase,qtimageformats - git checkout v5.6.2 - cd qtimageformats - git checkout v5.6.2 - cd ..\qtbase - git checkout v5.6.2 - git apply ../../../tdesktop/Telegram/Patches/qtbase_5_6_2.diff - cd .. - - configure -debug-and-release -force-debug-info -opensource -confirm-license -static -I "%cd%\..\openssl\Release\include" -no-opengl -openssl-linked OPENSSL_LIBS_DEBUG="%cd%\..\openssl\Debug\lib\ssleay32.lib %cd%\..\openssl\Debug\lib\libeay32.lib" OPENSSL_LIBS_RELEASE="%cd%\..\openssl\Release\lib\ssleay32.lib %cd%\..\openssl\Release\lib\libeay32.lib" -mp -nomake examples -nomake tests -platform win32-msvc2015 - - jom -j4 - jom -j4 install - cd .. - - cd ../tdesktop/Telegram - gyp\refresh.bat - -## Build the project - -If you want to pass a build define (like `TDESKTOP_DISABLE_AUTOUPDATE` or `TDESKTOP_DISABLE_NETWORK_PROXY`), call `set TDESKTOP_BUILD_DEFINES=TDESKTOP_DISABLE_AUTOUPDATE,TDESKTOP_DISABLE_NETWORK_PROXY,...` (comma seperated string) - -After, call **gyp\refresh.bat** once again. - -* Open ***BuildPath*\\tdesktop\\Telegram\\Telegram.sln** in Visual Studio 2017 -* Select Telegram project and press Build > Build Telegram (Debug and Release configurations) -* The result Telegram.exe will be located in **D:\TBuild\tdesktop\out\Debug** (and **Release**) - -### Qt Visual Studio Tools - -For better debugging you may want to install Qt Visual Studio Tools: - -* Open **Tools** -> **Extensions and Updates...** -* Go to **Online** tab -* Search for **Qt** -* Install **Qt Visual Studio Tools** extension diff --git a/docs/building-qmake.md b/docs/building-qmake.md deleted file mode 100644 index aeca87688..000000000 --- a/docs/building-qmake.md +++ /dev/null @@ -1,137 +0,0 @@ -Building via qmake -================== - -**NB** These are outdated, please refer to [Building using GYP/CMake][cmake] instructions. - -The following commands assume the following environment variables are set: - - * `$srcdir`: The directory into which the source has been downloaded and - unpacked. - * `_qtver`: The Qt version being used (eg: `5.6.2`). - * `$pkgdir`: The directory into which installable files are places. This is - `/` for local installations, or can be different directory when preparing a - redistributable package. - -Either set them accordingly, or replace them in the below commands as desired. - -The following sources should be downloaded and unpacked into `$srcdir`: - - * This repository (either `master` or a specific tag). - * `git clone git://code.qt.io/qt/qt5.git` - * `git clone git+https://chromium.googlesource.com/breakpad/breakpad breakpad` - * `git clone git+https://chromium.googlesource.com/linux-syscall-support breakpad-lss` - * telegramdesktop.desktop (The intention is to include this file inside the - source package at some point): - `https://aur.archlinux.org/cgit/aur.git/plain/telegramdesktop.desktop?h=telegram-desktop` - * tg.protocol: `https://aur.archlinux.org/cgit/aur.git/plain/tg.protocol?h=telegram-desktop` - -Preparation ------------ - - cd "$srcdir/tdesktop" - - mkdir -p "$srcdir/Libraries" - - local qt_patch_file="$srcdir/tdesktop/Telegram/Patches/qtbase_${_qtver//./_}.diff" - local qt_dir="$srcdir/Libraries/qt${_qtver//./_}" - if [ "$qt_patch_file" -nt "$qt_dir" ]; then - rm -rf "$qt_dir" - git clone git://code.qt.io/qt/qt5.git - cd "$qt_dir" - perl init-repository --module-subset=qtbase,qtimageformats - git checkout v$_qtver - cd qtimageformats - git checkout v$_qtver - cd ../qtbase - git checkout v$_qtver - git apply "$qt_patch_file" - fi - - if [ ! -h "$srcdir/Libraries/breakpad" ]; then - ln -s "$srcdir/breakpad" "$srcdir/Libraries/breakpad" - ln -s "$srcdir/breakpad-lss" "$srcdir/Libraries/breakpad/src/third_party/lss" - fi - - sed -i 's/CUSTOM_API_ID//g' "$srcdir/tdesktop/Telegram/Telegram.pro" - - ( - echo "DEFINES += TDESKTOP_DISABLE_AUTOUPDATE" - echo "DEFINES += TDESKTOP_DISABLE_REGISTER_CUSTOM_SCHEME" - ) >> "$srcdir/tdesktop/Telegram/Telegram.pro" - -Building --------- - - - # Build patched Qt - cd "$qtdir" - ./configure -prefix "$srcdir/qt" -release -opensource -confirm-license -qt-zlib \ - -qt-libpng -qt-libjpeg -qt-freetype -qt-harfbuzz -qt-pcre -qt-xcb \ - -qt-xkbcommon-x11 -no-opengl -no-gtkstyle -static -nomake examples -nomake tests - make module-qtbase module-qtimageformats - make module-qtbase-install_subtargets module-qtimageformats-install_subtargets - - export PATH="$srcdir/qt/bin:$PATH" - - # Build breakpad - cd "$srcdir/Libraries/breakpad" - ./configure - make - - # Build codegen_style - mkdir -p "$srcdir/tdesktop/Linux/obj/codegen_style/Debug" - cd "$srcdir/tdesktop/Linux/obj/codegen_style/Debug" - qmake CONFIG+=debug ../../../../Telegram/build/qmake/codegen_style/codegen_style.pro - make - - # Build codegen_numbers - mkdir -p "$srcdir/tdesktop/Linux/obj/codegen_numbers/Debug" - cd "$srcdir/tdesktop/Linux/obj/codegen_numbers/Debug" - qmake CONFIG+=debug ../../../../Telegram/build/qmake/codegen_numbers/codegen_numbers.pro - make - - # Build MetaLang - mkdir -p "$srcdir/tdesktop/Linux/DebugIntermediateLang" - cd "$srcdir/tdesktop/Linux/DebugIntermediateLang" - qmake CONFIG+=debug "../../Telegram/MetaLang.pro" - make - - # Build Telegram Desktop - mkdir -p "$srcdir/tdesktop/Linux/ReleaseIntermediate" - cd "$srcdir/tdesktop/Linux/ReleaseIntermediate" - - qmake CONFIG+=release "../../Telegram/Telegram.pro" - make - -Installation ------------- - - - install -dm755 "$pkgdir/usr/bin" - install -m755 "$srcdir/tdesktop/Linux/Release/Telegram" "$pkgdir/usr/bin/telegram-desktop" - - install -d "$pkgdir/usr/share/applications" - install -m644 "$srcdir/telegramdesktop.desktop" "$pkgdir/usr/share/applications/telegramdesktop.desktop" - - install -d "$pkgdir/usr/share/kde4/services" - install -m644 "$srcdir/tg.protocol" "$pkgdir/usr/share/kde4/services/tg.protocol" - - local icon_size icon_dir - for icon_size in 16 32 48 64 128 256 512; do - icon_dir="$pkgdir/usr/share/icons/hicolor/${icon_size}x${icon_size}/apps" - - install -d "$icon_dir" - install -m644 "$srcdir/tdesktop/Telegram/SourceFiles/art/icon${icon_size}.png" "$icon_dir/telegram-desktop.png" - done - -Notes ------ - -These instructions are based on the [ArchLinux package][arch-package] for -telegram-desktop. - -In case these instructions are at some point out of date, the above may serve -as an update reference. - -[arch-package]: https://aur.archlinux.org/packages/telegram-desktop/ -[cmake]: building-cmake.md diff --git a/docs/building-qtcreator.md b/docs/building-qtcreator.md deleted file mode 100644 index 3115fb2d2..000000000 --- a/docs/building-qtcreator.md +++ /dev/null @@ -1,193 +0,0 @@ -## Build instructions for Qt Creator 3.5.1 under Ubuntu 12.04 - -**NB** These are outdated, please refer to [Building using GYP/CMake][cmake] instructions. - -### Prepare - -* Install git by command **sudo apt-get install git** in Terminal -* Install g++ by command **sudo apt-get install g++** in Terminal -* Install Qt Creator from [**Downloads page**](https://www.qt.io/download/) - -You need to install g++ version 4.9 manually by such commands - -* sudo add-apt-repository ppa:ubuntu-toolchain-r/test -* sudo apt-get update -* sudo apt-get install gcc-4.9 g++-4.9 -* sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.9 21 -* sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.9 21 - -### Prepare folder - -Choose a folder for the future build, for example **/home/user/TBuild** There you will have two folders, **Libraries** for third-party libs and **tdesktop** (or **tdesktop-master**) for the app. - -### Clone source code - -By git – in Terminal go to **/home/user/TBuild** and run - - git clone --recursive https://github.com/telegramdesktop/tdesktop.git - -### Prepare libraries - -Install dev libraries - - sudo apt-get install libexif-dev liblzma-dev libz-dev libssl-dev libappindicator-dev libunity-dev - -#### zlib 1.2.8 - -http://www.zlib.net/ > Download [**zlib source code, version 1.2.8, zipfile format**](http://zlib.net/zlib128.zip) - -Extract to **/home/user/TBuild/Libraries** - -##### Building library - -In Terminal go to **/home/user/TBuild/Libraries/zlib-1.2.8** and run: - - ./configure - make - sudo make install - -Install audio libraries - -#### Opus codec - -In Terminal go to **/home/user/TBuild/Libraries** and run - - git clone https://github.com/xiph/opus - cd opus - git checkout v1.2-alpha2 - ./autogen.sh - ./configure - make - sudo make install - -#### FFmpeg - -In Terminal go to **/home/user/TBuild/Libraries** and run - - git clone git://anongit.freedesktop.org/git/libva - cd libva - ./autogen.sh --enable-static - make - sudo make install - cd .. - - git clone https://github.com/FFmpeg/FFmpeg.git ffmpeg - cd ffmpeg - git checkout release/3.2 - - sudo apt-get update - sudo apt-get -y --force-yes install autoconf automake build-essential libass-dev libfreetype6-dev libgpac-dev libsdl1.2-dev libtheora-dev libtool libva-dev libvdpau-dev libvorbis-dev libxcb1-dev libxcb-shm0-dev libxcb-xfixes0-dev pkg-config texi2html zlib1g-dev - sudo apt-get install yasm - - ./configure --prefix=/usr/local --disable-programs --disable-doc --disable-everything --enable-protocol=file --enable-libopus --enable-decoder=aac --enable-decoder=aac_latm --enable-decoder=aasc --enable-decoder=flac --enable-decoder=gif --enable-decoder=h264 --enable-decoder=h264_vdpau --enable-decoder=mp1 --enable-decoder=mp1float --enable-decoder=mp2 --enable-decoder=mp2float --enable-decoder=mp3 --enable-decoder=mp3adu --enable-decoder=mp3adufloat --enable-decoder=mp3float --enable-decoder=mp3on4 --enable-decoder=mp3on4float --enable-decoder=mpeg4 --enable-decoder=mpeg4_vdpau --enable-decoder=msmpeg4v2 --enable-decoder=msmpeg4v3 --enable-decoder=opus --enable-decoder=pcm_alaw --enable-decoder=pcm_alaw_at --enable-decoder=pcm_f32be --enable-decoder=pcm_f32le --enable-decoder=pcm_f64be --enable-decoder=pcm_f64le --enable-decoder=pcm_lxf --enable-decoder=pcm_mulaw --enable-decoder=pcm_mulaw_at --enable-decoder=pcm_s16be --enable-decoder=pcm_s16be_planar --enable-decoder=pcm_s16le --enable-decoder=pcm_s16le_planar --enable-decoder=pcm_s24be --enable-decoder=pcm_s24daud --enable-decoder=pcm_s24le --enable-decoder=pcm_s24le_planar --enable-decoder=pcm_s32be --enable-decoder=pcm_s32le --enable-decoder=pcm_s32le_planar --enable-decoder=pcm_s64be --enable-decoder=pcm_s64le --enable-decoder=pcm_s8 --enable-decoder=pcm_s8_planar --enable-decoder=pcm_u16be --enable-decoder=pcm_u16le --enable-decoder=pcm_u24be --enable-decoder=pcm_u24le --enable-decoder=pcm_u32be --enable-decoder=pcm_u32le --enable-decoder=pcm_u8 --enable-decoder=pcm_zork --enable-decoder=vorbis --enable-decoder=wavpack --enable-decoder=wmalossless --enable-decoder=wmapro --enable-decoder=wmav1 --enable-decoder=wmav2 --enable-decoder=wmavoice --enable-encoder=libopus --enable-hwaccel=h264_vaapi --enable-hwaccel=h264_vdpau --enable-hwaccel=mpeg4_vaapi --enable-hwaccel=mpeg4_vdpau --enable-parser=aac --enable-parser=aac_latm --enable-parser=flac --enable-parser=h264 --enable-parser=mpeg4video --enable-parser=mpegaudio --enable-parser=opus --enable-parser=vorbis --enable-demuxer=aac --enable-demuxer=flac --enable-demuxer=gif --enable-demuxer=h264 --enable-demuxer=mov --enable-demuxer=mp3 --enable-demuxer=ogg --enable-demuxer=wav --enable-muxer=ogg --enable-muxer=opus - - make - sudo make install - -#### PortAudio 19 - -[Download portaudio sources](http://www.portaudio.com/archives/pa_stable_v19_20140130.tgz) from **http://www.portaudio.com/download.html**, extract to **/home/user/TBuild/Libraries**, go to **/home/user/TBuild/Libraries/portaudio** and run - - ./configure - make - sudo make install - -#### OpenAL Soft - -In Terminal go to **/home/user/TBuild/Libraries** and run - - git clone git://repo.or.cz/openal-soft.git - -then go to **/home/user/TBuild/Libraries/openal-soft/build** and run - - sudo apt-get install cmake - cmake -D LIBTYPE:STRING=STATIC .. - make - sudo make install - -#### OpenSSL - -In Terminal go to **/home/user/TBuild/Libraries** and run - - git clone https://github.com/openssl/openssl - cd openssl - git checkout OpenSSL_1_0_1-stable - ./config - make - sudo make install - -#### libxkbcommon (required for Fcitx Qt plugin) - -In Terminal go to **/home/user/TBuild/Libraries** and run - - sudo apt-get install xutils-dev bison python-xcbgen - git clone https://github.com/xkbcommon/libxkbcommon.git - cd libxkbcommon - ./autogen.sh --disable-x11 - make - sudo make install - -#### Qt 5.6.2, slightly patched - -In Terminal go to **/home/user/TBuild/Libraries** and run - - git clone git://code.qt.io/qt/qt5.git qt5_6_2 - cd qt5_6_2 - perl init-repository --module-subset=qtbase,qtimageformats - git checkout v5.6.2 - cd qtimageformats && git checkout v5.6.2 && cd .. - cd qtbase && git checkout v5.6.2 && cd .. - -##### Apply the patch - - cd qtbase && git apply ../../../tdesktop/Telegram/Patches/qtbase_5_6_2.diff && cd .. - -##### Building library - -Install some packages for Qt (see **/home/user/TBuild/Libraries/qt5_6_2/qtbase/src/plugins/platforms/xcb/README**) - - sudo apt-get install libxcb1-dev libxcb-image0-dev libxcb-keysyms1-dev libxcb-icccm4-dev libxcb-render-util0-dev libxcb-util0-dev libxrender-dev libasound-dev libpulse-dev libxcb-sync0-dev libxcb-xfixes0-dev libxcb-randr0-dev libx11-xcb-dev libffi-dev - -In Terminal go to **/home/user/TBuild/Libraries/qt5_6_2** and there run - - ./configure -prefix "/usr/local/tdesktop/Qt-5.6.2" -release -force-debug-info -opensource -confirm-license -qt-zlib -qt-libpng -qt-libjpeg -qt-freetype -qt-harfbuzz -qt-pcre -qt-xcb -qt-xkbcommon-x11 -no-opengl -no-gtkstyle -static -openssl-linked -nomake examples -nomake tests - make -j4 - sudo make install - -building (**make** command) will take really long time. - -#### Google Breakpad - -In Terminal go to **/home/user/TBuild/Libraries** and run - - git clone https://chromium.googlesource.com/breakpad/breakpad - git clone https://chromium.googlesource.com/linux-syscall-support breakpad/src/third_party/lss - cd breakpad - ./configure - make - sudo make install - -### Building Telegram codegen utilities - -In Terminal go to **/home/user/TBuild/tdesktop** and run - - mkdir -p Linux/obj/codegen_style/Debug - cd Linux/obj/codegen_style/Debug - /usr/local/tdesktop/Qt-5.6.2/bin/qmake CONFIG+=debug ../../../../Telegram/build/qmake/codegen_style/codegen_style.pro - make - mkdir -p ../../codegen_numbers/Debug - cd ../../codegen_numbers/Debug - /usr/local/tdesktop/Qt-5.6.2/bin/qmake CONFIG+=debug ../../../../Telegram/build/qmake/codegen_numbers/codegen_numbers.pro - make - -### Building Telegram Desktop - -* Launch Qt Creator, all projects will be taken from **/home/user/TBuild/tdesktop/Telegram** -* Tools > Options > Build & Run > Qt Versions tab > Add > File System /usr/local/tdesktop/Qt-5.6.2/bin/qmake > **Qt 5.6.2 (Qt-5.6.2)** > Apply -* Tools > Options > Build & Run > Kits tab > Desktop (default) > change **Qt version** to **Qt 5.6.2 (Qt-5.6.2)** > Apply -* Open MetaLang.pro, configure project with paths **/home/user/TBuild/tdesktop/Linux/DebugIntermediateLang** and **/home/user/TBuild/tdesktop/Linux/ReleaseIntermediateLang** and build for Debug -* Open Telegram.pro, configure project with paths **/home/user/TBuild/tdesktop/Linux/DebugIntermediate** and **/home/user/TBuild/tdesktop/Linux/ReleaseIntermediate** and build for Debug, if GeneratedFiles are not found click **Run qmake** from **Build** menu and try again -* Open Updater.pro, configure project with paths **/home/user/TBuild/tdesktop/Linux/DebugIntermediateUpdater** and **/home/user/TBuild/tdesktop/Linux/ReleaseIntermediateUpdater** and build for Debug -* Release Telegram build will require removing **CUSTOM_API_ID** definition in Telegram.pro project and may require changing paths in **/home/user/TBuild/tdesktop/Telegram/FixMake.sh** or **/home/user/TBuild/tdesktop/Telegram/FixMake32.sh** for static library linking fix, static linking applies only on second Release build (first uses old Makefile) - -[cmake]: building-cmake.md diff --git a/docs/building-xcode-old.md b/docs/building-xcode-old.md deleted file mode 100644 index af6367ad4..000000000 --- a/docs/building-xcode-old.md +++ /dev/null @@ -1,242 +0,0 @@ -## Build instructions for Xcode 7.2.1 - -**NB** These are outdated, please refer to [Building using Xcode][xcode] instructions. - -### Prepare folder - -Choose a folder for the future build, for example **/Users/user/TBuild** There you will have two folders, **Libraries** for third-party libs and **tdesktop** (or **tdesktop-master**) for the app. - -### Clone source code - -By git – in Terminal go to **/Users/user/TBuild** and run - - git clone --recursive https://github.com/telegramdesktop/tdesktop.git - -then go to **/Users/user/TBuild/tdesktop** and run - - git checkout dev - -#### Prepare latest cmake - -Download the [latest sources](https://cmake.org/download/) and unpack to **/Users/user/TBuild/Libraries/macold** - - ./bootstrap - make -j4 - sudo make install - -### Prepare libraries - -In your build Terminal run - - MACOSX_DEPLOYMENT_TARGET=10.6 - -to set minimal supported OS version to 10.6 for future console builds. - -#### custom build of libc++ - -From **/Users/user/TBuild/Libraries/macold** run - - svn co http://llvm.org/svn/llvm-project/llvm/trunk llvm - cd llvm/projects - svn co http://llvm.org/svn/llvm-project/libcxx/trunk libcxx - svn co http://llvm.org/svn/llvm-project/libcxxabi/trunk libcxxabi - - cd ../../ - mkdir libcxxabi - cd libcxxabi - - cmake -G "Unix Makefiles" -DCMAKE_OSX_DEPLOYMENT_TARGET:STRING=10.6 -DCMAKE_BUILD_TYPE:STRING=Release -DLIBCXX_ENABLE_SHARED:BOOL=NO -DCMAKE_INSTALL_PREFIX:PATH=/usr/local/macold -DLLVM_PATH=../llvm -DLIBCXXABI_LIBCXX_PATH=../llvm/projects/libcxx ../llvm/projects/libcxxabi/ - make -j4 - sudo make install - - cd ../ - mkdir libcxx - cd libcxx - - cmake -G "Unix Makefiles" -DCMAKE_OSX_DEPLOYMENT_TARGET:STRING=10.6 -DCMAKE_BUILD_TYPE:STRING=Release -DCMAKE_INSTALL_PREFIX:PATH=/usr/local/macold -DLIBCXX_ENABLE_SHARED:BOOL=NO -DLIBCXX_CXX_ABI:STRING=libstdc++ -DLIBCXX_CXX_ABI_INCLUDE_PATHS="/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include/c++/4.2.1/" -DLLVM_PATH=../llvm/ ../llvm/projects/libcxx/ - make -j4 - sudo make install - -#### zlib - -In Terminal go to **/Users/user/TBuild/Libraries** and run: - - git clone https://github.com/telegramdesktop/zlib.git - cd zlib - prefix=/usr/local/macold CFLAGS="-mmacosx-version-min=10.6" LDFLAGS="-mmacosx-version-min=10.6" ./configure - make - sudo make install - -#### OpenSSL 1.0.1g - -http://www.openssl.org/source/ > Download [**openssl-1.0.1h.tar.gz**](http://www.openssl.org/source/openssl-1.0.1h.tar.gz) (4.3 Mb) - -Extract openssl-1.0.1h.tar.gz to **/Users/user/TBuild/Libraries/macold/openssl-1.0.1h** - - ./Configure --install_prefix=/usr/local/macold darwin64-x86_64-cc -static -mmacosx-version-min=10.6 - make build_crypto build_ssl -j4 - -#### liblzma - -http://tukaani.org/xz/ > Download [**xz-5.0.5.tar.gz**](http://tukaani.org/xz/xz-5.0.5.tar.gz) - -Extract to **/Users/user/TBuild/Libraries** - -##### Building library - -In Terminal go to **/Users/user/TBuild/Libraries/xz-5.0.5** and there run - - ./configure - make - sudo make install - -#### libexif 0.6.20 - -Get sources from https://github.com/telegramdesktop/libexif-0.6.20, by git – in Terminal go to **/Users/user/TBuild/Libraries/macold** and run - - git clone https://github.com/telegramdesktop/libexif-0.6.20.git - -##### Building library - -In Terminal go to **/Users/user/TBuild/Libraries/macold/libexif-0.6.20** and there run - - CFLAGS="-mmacosx-version-min=10.6" CPPFLAGS="-mmacosx-version-min=10.6 -nostdinc++" LDFLAGS="-mmacosx-version-min=10.6" ./configure --prefix=/usr/local/macold - make -j4 - sudo make install - -#### OpenAL Soft - -Get sources by git – in Terminal go to **/Users/user/TBuild/Libraries/macold** and run - - git clone git://repo.or.cz/openal-soft.git - -to have **/Users/user/TBuild/Libraries/macold/openal-soft/CMakeLists.txt** - -##### Building library - -In Terminal go to **/Users/user/TBuild/Libraries/openal-soft/build** and there run - - cmake -DLIBTYPE:STRING=STATIC -DCMAKE_OSX_DEPLOYMENT_TARGET:STRING=10.6 -DCMAKE_INSTALL_PREFIX:STRING=/usr/local/macold .. - make - sudo make install - -#### Opus codec - -In Terminal go to **/Users/user/TBuild/Libraries/macold** and there run - - git clone https://github.com/xiph/opus - cd opus - git checkout v1.2-alpha2 - ./autogen.sh - CFLAGS="-mmacosx-version-min=10.6" CPPFLAGS="-mmacosx-version-min=10.6" LDFLAGS="-mmacosx-version-min=10.6" ./configure --prefix=/usr/local/macold - make - sudo make install - -#### FFmpeg - -In Terminal go to **/Users/user/TBuild/Libraries/macold** and run: - - git clone https://github.com/FFmpeg/FFmpeg.git ffmpeg - cd ffmpeg - git checkout release/3.2 - -##### Building libraries - -Download [libiconv-1.14](http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz) from http://www.gnu.org/software/libiconv/#downloading, extract it to **/Users/user/TBuild/Libraries/macold** - -In Termianl go to **/Users/user/TBuild/Libraries/macold/libiconv-1.14** and run - - CFLAGS="-mmacosx-version-min=10.6" CPPFLAGS="-mmacosx-version-min=10.6 -nostdinc++" LDFLAGS="-mmacosx-version-min=10.6" ./configure --enable-static --prefix=/usr/local/macold - make -j4 - sudo make install - -Then in Terminal go to **/Users/user/TBuild/Libraries/macold/ffmpeg** and run - - ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" - - brew install automake fdk-aac git lame libass libtool libvorbis libvpx opus sdl shtool texi2html theora wget x264 xvid yasm - - CFLAGS=`freetype-config --cflags` - LDFLAGS=`freetype-config --libs` - PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig:/usr/lib/pkgconfig:/usr/X11/lib/pkgconfig - - ./configure --prefix=/usr/local/macold --disable-programs --disable-doc --disable-everything --enable-protocol=file --enable-libopus --enable-decoder=aac --enable-decoder=aac_latm --enable-decoder=aasc --enable-decoder=flac --enable-decoder=gif --enable-decoder=h264 --enable-decoder=mp1 --enable-decoder=mp1float --enable-decoder=mp2 --enable-decoder=mp2float --enable-decoder=mp3 --enable-decoder=mp3adu --enable-decoder=mp3adufloat --enable-decoder=mp3float --enable-decoder=mp3on4 --enable-decoder=mp3on4float --enable-decoder=mpeg4 --enable-decoder=msmpeg4v2 --enable-decoder=msmpeg4v3 --enable-decoder=opus --enable-decoder=pcm_alaw --enable-decoder=pcm_alaw_at --enable-decoder=pcm_f32be --enable-decoder=pcm_f32le --enable-decoder=pcm_f64be --enable-decoder=pcm_f64le --enable-decoder=pcm_lxf --enable-decoder=pcm_mulaw --enable-decoder=pcm_mulaw_at --enable-decoder=pcm_s16be --enable-decoder=pcm_s16be_planar --enable-decoder=pcm_s16le --enable-decoder=pcm_s16le_planar --enable-decoder=pcm_s24be --enable-decoder=pcm_s24daud --enable-decoder=pcm_s24le --enable-decoder=pcm_s24le_planar --enable-decoder=pcm_s32be --enable-decoder=pcm_s32le --enable-decoder=pcm_s32le_planar --enable-decoder=pcm_s64be --enable-decoder=pcm_s64le --enable-decoder=pcm_s8 --enable-decoder=pcm_s8_planar --enable-decoder=pcm_u16be --enable-decoder=pcm_u16le --enable-decoder=pcm_u24be --enable-decoder=pcm_u24le --enable-decoder=pcm_u32be --enable-decoder=pcm_u32le --enable-decoder=pcm_u8 --enable-decoder=pcm_zork --enable-decoder=vorbis --enable-decoder=wavpack --enable-decoder=wmalossless --enable-decoder=wmapro --enable-decoder=wmav1 --enable-decoder=wmav2 --enable-decoder=wmavoice --enable-encoder=libopus --enable-parser=aac --enable-parser=aac_latm --enable-parser=flac --enable-parser=h264 --enable-parser=mpeg4video --enable-parser=mpegaudio --enable-parser=opus --enable-parser=vorbis --enable-demuxer=aac --enable-demuxer=flac --enable-demuxer=gif --enable-demuxer=h264 --enable-demuxer=mov --enable-demuxer=mp3 --enable-demuxer=ogg --enable-demuxer=wav --enable-muxer=ogg --enable-muxer=opus --extra-cflags="-mmacosx-version-min=10.6" --extra-cxxflags="-mmacosx-version-min=10.6 -nostdinc++" --extra-ldflags="-mmacosx-version-min=10.6" - - make - sudo make install - -#### Qt 5.3.2, slightly patched -##### Get the source code - -In Terminal go to **/Users/user/TBuild/Libraries** and run: - - git clone git://code.qt.io/qt/qt5.git qt5_3_2 - cd qt5_3_2 - perl init-repository --module-subset=qtbase,qtimageformats - git checkout v5.3.2 - cd qtimageformats && git checkout v5.3.2 && cd .. - cd qtbase && git checkout v5.3.2 && cd .. - -##### Apply the patch - -From **/Users/user/TBuild/Libraries/macold/qt5_3_2/qtbase**, run: - - git apply ../../../../tdesktop/Telegram/Patches/macold/qtbase_5_3_2.diff - -From **/Users/user/TBuild/Libraries/macold/qt5_3_2/qtimageformats**, run: - - git apply ../../../../tdesktop/Telegram/Patches/macold/qtimageformats_5_3_2.diff - -##### Building library - -Go to **/Users/user/TBuild/Libraries/macold/qt5_3_2** and run: - - OPENSSL_LIBS="/Users/user/TBuild/Libraries/macold/openssl-1.0.1h/libssl.a /Users/user/TBuild/Libraries/macold/openssl-1.0.1h/libcrypto.a" ./configure -prefix "/usr/local/macold/Qt-5.3.2" -debug-and-release -force-debug-info -opensource -confirm-license -static -opengl desktop -openssl-linked -I "/Users/user/TBuild/Libraries/macold/openssl-1.0.1h/include" -nomake examples -nomake tests -platform macx-g++ - make -j4 - sudo make -j4 install - -building (**make** command) will take really long time. - -#### Google Crashpad - -##### Install gyp - -.. the same as modern .. - -##### Build crashpad - -In Terminal go to **/Users/user/TBuild/Libraries/macold** and run: - - git clone https://chromium.googlesource.com/crashpad/crashpad.git - cd crashpad - git checkout feb3aa3923 - git apply ../../../tdesktop/Telegram/Patches/macold/crashpad.diff - cd third_party/mini_chromium - git clone https://chromium.googlesource.com/chromium/mini_chromium - cd mini_chromium - git checkout 7c5b0c1ab4 - git apply ../../../../../../tdesktop/Telegram/Patches/macold/mini_chromium.diff - cd ../../gtest - git clone https://chromium.googlesource.com/external/github.com/google/googletest gtest - cd gtest - git checkout d62d6c6556 - cd ../../../ - - build/gyp_crashpad.py -Dmac_deployment_target=10.6 - ninja -C out/Debug - ninja -C out/Release - -#### Prepare GYP - -.. the same as modern .. - -### Building Telegram Desktop - -* Launch Xcode, all projects will be taken from **/Users/user/TBuild/tdesktop/Telegram** -* Open MetaEmoji.xcodeproj and build for Debug (Release optionally) -* Open MetaLang.xcodeproj and build for Debug (Release optionally) -* Open Telegram.xcodeproj and build for Debug -* Build Updater target as well, it is required for Telegram relaunch -* Release Telegram build will require removing **CUSTOM_API_ID** definition in Telegram target settings (Apple LLVM 6.1 - Custom Compiler Flags > Other C / C++ Flags > Release) - -[xcode]: building-xcode.md diff --git a/docs/building-xcode.md b/docs/building-xcode.md deleted file mode 100644 index 9fa0d7420..000000000 --- a/docs/building-xcode.md +++ /dev/null @@ -1,234 +0,0 @@ -## Build instructions for Xcode 8.0 - -### Prepare folder - -Choose a folder for the future build, for example **/Users/user/TBuild** - -There you will have two folders, **Libraries** for third-party libs and **tdesktop** (or **tdesktop-master**) for the app. - -**You will need this hierarchy to be able to follow this README !** - -### Clone source code - -By git – in Terminal go to **/Users/user/TBuild** and run: - - git clone --recursive https://github.com/telegramdesktop/tdesktop.git - -### Prepare libraries - -In your build Terminal run: - - MACOSX_DEPLOYMENT_TARGET=10.8 - -to set minimal supported OS version to 10.8 for future console builds. - -#### zlib - -In Terminal go to **/Users/user/TBuild/Libraries/zlib** and run: - - git clone https://github.com/telegramdesktop/zlib.git - cd zlib - CFLAGS="-mmacosx-version-min=10.8" LDFLAGS="-mmacosx-version-min=10.8" ./configure - make - sudo make install - -#### OpenSSL 1.0.1g - -##### Get openssl-xcode project file - -From https://github.com/telegramdesktop/openssl-xcode with git in Terminal: - -* go to **/Users/user/TBuild/Libraries -* run: - - git clone https://github.com/telegramdesktop/openssl-xcode.git - -The path to openssl.xcodeproj should now be: **/Users/user/TBuild/Libraries/openssl-xcode/openssl.xcodeproj** - -##### Get the source code: - -Download [**openssl-1.0.1h.tar.gz**](http://www.openssl.org/source/openssl-1.0.1h.tar.gz) (4.3 Mb) - -* Extract openssl-1.0.1h.tar.gz -* Copy everything from **openssl-1.0.1h** to **/Users/user/TBuild/Libraries/openssl-xcode** - -The folder include of openssl should be: -**/Users/user/TBuild/Libraries/openssl-xcode/include** - -##### Building library - -* Open **/Users/user/TBuild/Libraries/openssl-xcode/openssl.xcodeproj** with Xcode -* Product > Build - -#### liblzma -##### Get the source code - -Download [**xz-5.0.5.tar.gz**](http://tukaani.org/xz/xz-5.0.5.tar.gz) - -Extract to **/Users/user/TBuild/Libraries** - -##### Building library - -In Terminal go to **/Users/user/TBuild/Libraries/xz-5.0.5** and there run: - - ./configure - make - sudo make install - -#### libexif 0.6.20 -##### Get the source code - -From https://github.com/telegramdesktop/libexif-0.6.20 with git in Terminal: - -* go to **/Users/user/TBuild/Libraries** -* run: - - git clone https://github.com/telegramdesktop/libexif-0.6.20.git - -The folder configure should have this path: -**/Users/user/TBuild/Libraries/libexif-0.6.20/configure** - -##### Building library - -In Terminal go to **/Users/user/TBuild/Libraries/libexif-0.6.20** and there run - - ./configure - make - sudo make install - -#### OpenAL Soft - -Get sources by git – in Terminal go to **/Users/user/TBuild/Libraries** and run - - git clone git://repo.or.cz/openal-soft.git - cd openal-soft/build - cmake -D LIBTYPE:STRING=STATIC -D CMAKE_OSX_DEPLOYMENT_TARGET:STRING=10.8 .. - make - sudo make install - -#### Opus codec - -In Terminal go to **/Users/user/TBuild/Libraries** and there run - - git clone https://github.com/xiph/opus - cd opus - git checkout v1.2-alpha2 - ./autogen.sh - CFLAGS="-mmacosx-version-min=10.8" CPPFLAGS="-mmacosx-version-min=10.8" LDFLAGS="-mmacosx-version-min=10.8" ./configure - make - sudo make install - -#### FFmpeg and Libiconv -##### Get the source code - -In Terminal go to **/Users/user/TBuild/Libraries** and run: - - git clone https://github.com/FFmpeg/FFmpeg.git ffmpeg - cd ffmpeg - git checkout release/3.2 - -* Download [libiconv-1.14](http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz) from http://www.gnu.org/software/libiconv/#downloading -* Extract to **/Users/user/TBuild/Libraries** to have **/Users/user/TBuild/Libraries/ibiconv-1.14** - -##### Building library - -In Terminal go to **/Users/user/TBuild/Libraries/libiconv-1.14** and run: - - CFLAGS="-mmacosx-version-min=10.8" CPPFLAGS="-mmacosx-version-min=10.8" LDFLAGS="-mmacosx-version-min=10.8" ./configure --enable-static - make - sudo make install - -Then in Terminal go to **/Users/user/TBuild/Libraries/ffmpeg** and run: - - ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" - - brew install automake fdk-aac git lame libass libtool libvorbis libvpx opus sdl shtool texi2html theora wget x264 xvid yasm - - CFLAGS=`freetype-config --cflags` - LDFLAGS=`freetype-config --libs` - PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig:/usr/lib/pkgconfig:/usr/X11/lib/pkgconfig - - ./configure --prefix=/usr/local --disable-programs --disable-doc --disable-everything --enable-protocol=file --enable-libopus --enable-decoder=aac --enable-decoder=aac_latm --enable-decoder=aasc --enable-decoder=flac --enable-decoder=gif --enable-decoder=h264 --enable-decoder=h264_vda --enable-decoder=mp1 --enable-decoder=mp1float --enable-decoder=mp2 --enable-decoder=mp2float --enable-decoder=mp3 --enable-decoder=mp3adu --enable-decoder=mp3adufloat --enable-decoder=mp3float --enable-decoder=mp3on4 --enable-decoder=mp3on4float --enable-decoder=mpeg4 --enable-decoder=msmpeg4v2 --enable-decoder=msmpeg4v3 --enable-decoder=opus --enable-decoder=pcm_alaw --enable-decoder=pcm_alaw_at --enable-decoder=pcm_f32be --enable-decoder=pcm_f32le --enable-decoder=pcm_f64be --enable-decoder=pcm_f64le --enable-decoder=pcm_lxf --enable-decoder=pcm_mulaw --enable-decoder=pcm_mulaw_at --enable-decoder=pcm_s16be --enable-decoder=pcm_s16be_planar --enable-decoder=pcm_s16le --enable-decoder=pcm_s16le_planar --enable-decoder=pcm_s24be --enable-decoder=pcm_s24daud --enable-decoder=pcm_s24le --enable-decoder=pcm_s24le_planar --enable-decoder=pcm_s32be --enable-decoder=pcm_s32le --enable-decoder=pcm_s32le_planar --enable-decoder=pcm_s64be --enable-decoder=pcm_s64le --enable-decoder=pcm_s8 --enable-decoder=pcm_s8_planar --enable-decoder=pcm_u16be --enable-decoder=pcm_u16le --enable-decoder=pcm_u24be --enable-decoder=pcm_u24le --enable-decoder=pcm_u32be --enable-decoder=pcm_u32le --enable-decoder=pcm_u8 --enable-decoder=pcm_zork --enable-decoder=vorbis --enable-decoder=wavpack --enable-decoder=wmalossless --enable-decoder=wmapro --enable-decoder=wmav1 --enable-decoder=wmav2 --enable-decoder=wmavoice --enable-encoder=libopus --enable-hwaccel=mpeg4_videotoolbox --enable-hwaccel=h264_vda --enable-hwaccel=h264_videotoolbox --enable-parser=aac --enable-parser=aac_latm --enable-parser=flac --enable-parser=h264 --enable-parser=mpeg4video --enable-parser=mpegaudio --enable-parser=opus --enable-parser=vorbis --enable-demuxer=aac --enable-demuxer=flac --enable-demuxer=gif --enable-demuxer=h264 --enable-demuxer=mov --enable-demuxer=mp3 --enable-demuxer=ogg --enable-demuxer=wav --enable-muxer=ogg --enable-muxer=opus --extra-cflags="-mmacosx-version-min=10.8" --extra-cxxflags="-mmacosx-version-min=10.8" --extra-ldflags="-mmacosx-version-min=10.8" - - make - sudo make install - -#### Qt 5.6.2, slightly patched -##### Get the source code - -In Terminal go to **/Users/user/TBuild/Libraries** and run: - - git clone git://code.qt.io/qt/qt5.git qt5_6_2 - cd qt5_6_2 - perl init-repository --module-subset=qtbase,qtimageformats - git checkout v5.6.2 - cd qtimageformats && git checkout v5.6.2 && cd .. - cd qtbase && git checkout v5.6.2 && cd .. - -##### Apply the patch - -From **/Users/user/TBuild/Libraries/qt5_6_2/qtbase**, run: - - git apply ../../../tdesktop/Telegram/Patches/qtbase_5_6_2.diff - -##### Building library - -Go to **/Users/user/TBuild/Libraries/qt5_6_2** and run: - - ./configure -prefix "/usr/local/tdesktop/Qt-5.6.2" -debug-and-release -force-debug-info -opensource -confirm-license -static -opengl desktop -no-openssl -securetransport -nomake examples -nomake tests -platform macx-clang - make -j4 - sudo make install - -Building (**make** command) will take a really long time. - -#### Google Crashpad - -##### Install gyp - -In Terminal go to **/Users/user/TBuild/Libraries** and run: - - git clone https://chromium.googlesource.com/external/gyp - git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git - cd gyp - git checkout 702ac58e47 - git apply ../../tdesktop/Telegram/Patches/gyp.diff - ./setup.py build - sudo ./setup.py install - cd .. - -##### Build crashpad - -In Terminal go to **/Users/user/TBuild/Libraries** and run: - - git clone https://chromium.googlesource.com/crashpad/crashpad.git - cd crashpad - git checkout feb3aa3923 - cd third_party/mini_chromium - git clone https://chromium.googlesource.com/chromium/mini_chromium - cd mini_chromium - git checkout 7c5b0c1ab4 - git apply ../../../../../tdesktop/Telegram/Patches/mini_chromium.diff - cd ../../gtest - git clone https://chromium.googlesource.com/external/github.com/google/googletest gtest - cd gtest - git checkout d62d6c6556 - cd ../../../ - - build/gyp_crashpad.py -Dmac_deployment_target=10.8 - ninja -C out/Debug - ninja -C out/Release - -#### Prepare GYP - -In Terminal go to **/Users/user/TBuild/Libraries** and run - - cd gyp - git apply ../../tdesktop/Telegram/Patches/gyp.diff - -### Building Telegram Desktop - -In Terminal go to **/home/user/TBuild/tdesktop/Telegram** and run - - gyp/refresh.sh - -Then launch Xcode, open **/Users/user/TBuild/tdesktop/Telegram/Telegram.xcodeproj** and build for Debug / Release.