/* This file is part of Telegram Desktop, the official desktop application for the Telegram messaging service. For license and copyright information please follow this link: https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL */ #pragma once #include "ui/style/style_core.h" #include "emoji.h" #define DeclareReadSetting(Type, Name) extern Type g##Name; \ inline const Type &c##Name() { \ return g##Name; \ } #define DeclareSetting(Type, Name) DeclareReadSetting(Type, Name) \ inline void cSet##Name(const Type &Name) { \ g##Name = Name; \ } #define DeclareRefSetting(Type, Name) DeclareSetting(Type, Name) \ inline Type &cRef##Name() { \ return g##Name; \ } DeclareSetting(Qt::LayoutDirection, LangDir); inline bool rtl() { return style::RightToLeft(); } DeclareSetting(bool, InstallBetaVersion); DeclareSetting(uint64, AlphaVersion); DeclareSetting(uint64, RealAlphaVersion); DeclareSetting(QByteArray, AlphaPrivateKey); DeclareSetting(bool, AutoStart); DeclareSetting(bool, StartMinimized); DeclareSetting(bool, StartInTray); DeclareSetting(bool, SendToMenu); DeclareSetting(bool, UseExternalVideoPlayer); DeclareSetting(bool, UseFreeType); enum LaunchMode { LaunchModeNormal = 0, LaunchModeAutoStart, LaunchModeFixPrevious, LaunchModeCleanup, }; DeclareReadSetting(LaunchMode, LaunchMode); DeclareSetting(QString, WorkingDir); inline void cForceWorkingDir(const QString &newDir) { cSetWorkingDir(newDir); if (!gWorkingDir.isEmpty()) { QDir().mkpath(gWorkingDir); QFile::setPermissions(gWorkingDir, QFileDevice::ReadUser | QFileDevice::WriteUser | QFileDevice::ExeUser); } } DeclareReadSetting(QString, ExeName); DeclareReadSetting(QString, ExeDir); DeclareSetting(QString, DialogLastPath); DeclareSetting(QString, DialogHelperPath); inline const QString &cDialogHelperPathFinal() { return cDialogHelperPath().isEmpty() ? cExeDir() : cDialogHelperPath(); } DeclareSetting(bool, AutoUpdate); DeclareSetting(bool, SeenTrayTooltip); DeclareSetting(bool, RestartingUpdate); DeclareSetting(bool, Restarting); DeclareSetting(bool, RestartingToSettings); DeclareSetting(bool, WriteProtected); DeclareSetting(int32, LastUpdateCheck); DeclareSetting(bool, NoStartUpdate); DeclareSetting(bool, StartToSettings); DeclareSetting(bool, DebugMode); DeclareReadSetting(bool, ManyInstance); DeclareSetting(QByteArray, LocalSalt); DeclareSetting(int, ScreenScale); DeclareSetting(int, ConfigScale); DeclareSetting(QString, TimeFormat); using RecentEmojiPreloadOldOld = QVector>; using RecentEmojiPreloadOld = QVector>; using RecentEmojiPreload = QVector>; using RecentEmojiPack = QVector>; using EmojiColorVariantsOld = QMap; using EmojiColorVariants = QMap; DeclareRefSetting(RecentEmojiPack, RecentEmoji); DeclareSetting(RecentEmojiPreload, RecentEmojiPreload); DeclareRefSetting(EmojiColorVariants, EmojiVariants); class DocumentData; typedef QList> RecentStickerPackOld; typedef QVector> RecentStickerPreload; typedef QVector> RecentStickerPack; DeclareSetting(RecentStickerPreload, RecentStickersPreload); DeclareRefSetting(RecentStickerPack, RecentStickers); typedef QList> RecentHashtagPack; DeclareRefSetting(RecentHashtagPack, RecentWriteHashtags); DeclareSetting(RecentHashtagPack, RecentSearchHashtags); class UserData; typedef QVector RecentInlineBots; DeclareRefSetting(RecentInlineBots, RecentInlineBots); DeclareSetting(bool, PasswordRecovered); DeclareSetting(int32, PasscodeBadTries); DeclareSetting(crl::time, PasscodeLastTry); DeclareSetting(QStringList, SendPaths); DeclareSetting(QString, StartUrl); DeclareSetting(int, OtherOnline); inline void cChangeTimeFormat(const QString &newFormat) { if (!newFormat.isEmpty()) cSetTimeFormat(newFormat); } RecentEmojiPack &GetRecentEmoji(); QVector GetRecentEmojiSection(); void AddRecentEmoji(EmojiPtr emoji); [[nodiscard]] rpl::producer<> UpdatedRecentEmoji(); inline bool passcodeCanTry() { if (cPasscodeBadTries() < 3) return true; auto dt = crl::now() - cPasscodeLastTry(); switch (cPasscodeBadTries()) { case 3: return dt >= 5000; case 4: return dt >= 10000; case 5: return dt >= 15000; case 6: return dt >= 20000; case 7: return dt >= 25000; } return dt >= 30000; } inline float64 cRetinaFactor() { return style::DevicePixelRatio(); } inline int32 cIntRetinaFactor() { return style::DevicePixelRatio(); } inline int cEvalScale(int scale) { return (scale == style::kScaleAuto) ? cScreenScale() : scale; } inline int cScale() { return style::Scale(); } inline void SetScaleChecked(int scale) { cSetConfigScale(style::CheckScale(scale)); } inline void ValidateScale() { SetScaleChecked(cConfigScale()); style::SetScale(cEvalScale(cConfigScale())); }