mirror of https://github.com/procxx/kepka.git
Fix working with layers.
Regression was introduced in df64c97
.
New base::flags work correctly only if all mutually exclusive flag
values use mutually exclusive bits (a & b == 0 for exclusive (a, b)).
Closes #3856.
This commit is contained in:
parent
8f82880b93
commit
2e374e68c5
|
@ -570,12 +570,12 @@ enum ForwardWhatMessages {
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ShowLayerOption {
|
enum ShowLayerOption {
|
||||||
CloseOtherLayers = 0x00,
|
CloseOtherLayers = (1 << 0),
|
||||||
KeepOtherLayers = 0x01,
|
KeepOtherLayers = (1 << 1),
|
||||||
ShowAfterOtherLayers = 0x03,
|
ShowAfterOtherLayers = (1 << 2),
|
||||||
|
|
||||||
AnimatedShowLayer = 0x00,
|
AnimatedShowLayer = (1 << 3),
|
||||||
ForceFastShowLayer = 0x04,
|
ForceFastShowLayer = (1 << 4),
|
||||||
};
|
};
|
||||||
using ShowLayerOptions = base::flags<ShowLayerOption>;
|
using ShowLayerOptions = base::flags<ShowLayerOption>;
|
||||||
inline constexpr auto is_flag_type(ShowLayerOption) { return true; };
|
inline constexpr auto is_flag_type(ShowLayerOption) { return true; };
|
||||||
|
|
|
@ -175,11 +175,11 @@ private:
|
||||||
|
|
||||||
void itemRemoved(HistoryItem *item);
|
void itemRemoved(HistoryItem *item);
|
||||||
enum class UpdateRowSection {
|
enum class UpdateRowSection {
|
||||||
Default = 0x01,
|
Default = (1 << 0),
|
||||||
Filtered = 0x02,
|
Filtered = (1 << 1),
|
||||||
PeerSearch = 0x04,
|
PeerSearch = (1 << 2),
|
||||||
MessageSearch = 0x08,
|
MessageSearch = (1 << 3),
|
||||||
All = 0x0F,
|
All = Default | Filtered | PeerSearch | MessageSearch,
|
||||||
};
|
};
|
||||||
using UpdateRowSections = base::flags<UpdateRowSection>;
|
using UpdateRowSections = base::flags<UpdateRowSection>;
|
||||||
friend inline constexpr auto is_flag_type(UpdateRowSection) { return true; };
|
friend inline constexpr auto is_flag_type(UpdateRowSection) { return true; };
|
||||||
|
|
|
@ -172,8 +172,8 @@ struct HistoryMessageReply : public RuntimeComponent<HistoryMessageReply> {
|
||||||
void itemRemoved(HistoryMessage *holder, HistoryItem *removed);
|
void itemRemoved(HistoryMessage *holder, HistoryItem *removed);
|
||||||
|
|
||||||
enum class PaintFlag {
|
enum class PaintFlag {
|
||||||
InBubble = 0x01,
|
InBubble = (1 << 0),
|
||||||
Selected = 0x02,
|
Selected = (1 << 1),
|
||||||
};
|
};
|
||||||
using PaintFlags = base::flags<PaintFlag>;
|
using PaintFlags = base::flags<PaintFlag>;
|
||||||
friend inline constexpr auto is_flag_type(PaintFlag) { return true; };
|
friend inline constexpr auto is_flag_type(PaintFlag) { return true; };
|
||||||
|
|
|
@ -691,8 +691,8 @@ private:
|
||||||
void countHistoryShowFrom();
|
void countHistoryShowFrom();
|
||||||
|
|
||||||
enum class TextUpdateEvent {
|
enum class TextUpdateEvent {
|
||||||
SaveDraft = 0x01,
|
SaveDraft = (1 << 0),
|
||||||
SendTyping = 0x02,
|
SendTyping = (1 << 1),
|
||||||
};
|
};
|
||||||
using TextUpdateEvents = base::flags<TextUpdateEvent>;
|
using TextUpdateEvents = base::flags<TextUpdateEvent>;
|
||||||
friend inline constexpr auto is_flag_type(TextUpdateEvent) { return true; };
|
friend inline constexpr auto is_flag_type(TextUpdateEvent) { return true; };
|
||||||
|
|
|
@ -82,8 +82,8 @@ private:
|
||||||
QSize countFrameSize() const;
|
QSize countFrameSize() const;
|
||||||
|
|
||||||
enum class StateFlag {
|
enum class StateFlag {
|
||||||
Over = 0x01,
|
Over = (1 << 0),
|
||||||
DeleteOver = 0x02,
|
DeleteOver = (1 << 1),
|
||||||
};
|
};
|
||||||
using StateFlags = base::flags<StateFlag>;
|
using StateFlags = base::flags<StateFlag>;
|
||||||
friend inline constexpr auto is_flag_type(StateFlag) { return true; };
|
friend inline constexpr auto is_flag_type(StateFlag) { return true; };
|
||||||
|
|
|
@ -35,45 +35,45 @@ struct PeerUpdate {
|
||||||
PeerData *peer;
|
PeerData *peer;
|
||||||
|
|
||||||
enum class Flag : uint32 {
|
enum class Flag : uint32 {
|
||||||
None = 0x00000000U,
|
None = 0,
|
||||||
|
|
||||||
// Common flags
|
// Common flags
|
||||||
NameChanged = 0x00000001U,
|
NameChanged = (1 << 0),
|
||||||
UsernameChanged = 0x00000002U,
|
UsernameChanged = (1 << 1),
|
||||||
PhotoChanged = 0x00000004U,
|
PhotoChanged = (1 << 2),
|
||||||
AboutChanged = 0x00000008U,
|
AboutChanged = (1 << 3),
|
||||||
NotificationsEnabled = 0x00000010U,
|
NotificationsEnabled = (1 << 4),
|
||||||
SharedMediaChanged = 0x00000020U,
|
SharedMediaChanged = (1 << 5),
|
||||||
MigrationChanged = 0x00000040U,
|
MigrationChanged = (1 << 6),
|
||||||
PinnedChanged = 0x00000080U,
|
PinnedChanged = (1 << 7),
|
||||||
RestrictionReasonChanged = 0x00000100U,
|
RestrictionReasonChanged = (1 << 8),
|
||||||
|
|
||||||
// For chats and channels
|
// For chats and channels
|
||||||
InviteLinkChanged = 0x00000200U,
|
InviteLinkChanged = (1 << 9),
|
||||||
MembersChanged = 0x00000400U,
|
MembersChanged = (1 << 10),
|
||||||
AdminsChanged = 0x00000800U,
|
AdminsChanged = (1 << 11),
|
||||||
BannedUsersChanged = 0x00001000U,
|
BannedUsersChanged = (1 << 12),
|
||||||
UnreadMentionsChanged = 0x00002000U,
|
UnreadMentionsChanged = (1 << 13),
|
||||||
|
|
||||||
// For users
|
// For users
|
||||||
UserCanShareContact = 0x00010000U,
|
UserCanShareContact = (1 << 16),
|
||||||
UserIsContact = 0x00020000U,
|
UserIsContact = (1 << 17),
|
||||||
UserPhoneChanged = 0x00040000U,
|
UserPhoneChanged = (1 << 18),
|
||||||
UserIsBlocked = 0x00080000U,
|
UserIsBlocked = (1 << 19),
|
||||||
BotCommandsChanged = 0x00100000U,
|
BotCommandsChanged = (1 << 20),
|
||||||
UserOnlineChanged = 0x00200000U,
|
UserOnlineChanged = (1 << 21),
|
||||||
BotCanAddToGroups = 0x00400000U,
|
BotCanAddToGroups = (1 << 22),
|
||||||
UserCommonChatsChanged = 0x00800000U,
|
UserCommonChatsChanged = (1 << 23),
|
||||||
UserHasCalls = 0x01000000U,
|
UserHasCalls = (1 << 24),
|
||||||
|
|
||||||
// For chats
|
// For chats
|
||||||
ChatCanEdit = 0x00010000U,
|
ChatCanEdit = (1 << 16),
|
||||||
|
|
||||||
// For channels
|
// For channels
|
||||||
ChannelAmIn = 0x00010000U,
|
ChannelAmIn = (1 << 16),
|
||||||
ChannelRightsChanged = 0x00020000U,
|
ChannelRightsChanged = (1 << 17),
|
||||||
ChannelStickersChanged = 0x00040000U,
|
ChannelStickersChanged = (1 << 18),
|
||||||
ChannelPinnedChanged = 0x00080000U,
|
ChannelPinnedChanged = (1 << 19),
|
||||||
};
|
};
|
||||||
using Flags = base::flags<Flag>;
|
using Flags = base::flags<Flag>;
|
||||||
friend inline constexpr auto is_flag_type(Flag) { return true; }
|
friend inline constexpr auto is_flag_type(Flag) { return true; }
|
||||||
|
|
|
@ -55,11 +55,11 @@ public:
|
||||||
|
|
||||||
// Custom shadows.
|
// Custom shadows.
|
||||||
enum class ShadowsChange {
|
enum class ShadowsChange {
|
||||||
Moved = 0x01,
|
Moved = (1 << 0),
|
||||||
Resized = 0x02,
|
Resized = (1 << 1),
|
||||||
Shown = 0x04,
|
Shown = (1 << 2),
|
||||||
Hidden = 0x08,
|
Hidden = (1 << 3),
|
||||||
Activate = 0x10,
|
Activate = (1 << 4),
|
||||||
};
|
};
|
||||||
using ShadowsChanges = base::flags<ShadowsChange>;
|
using ShadowsChanges = base::flags<ShadowsChange>;
|
||||||
friend inline constexpr auto is_flag_type(ShadowsChange) { return true; };
|
friend inline constexpr auto is_flag_type(ShadowsChange) { return true; };
|
||||||
|
|
|
@ -76,8 +76,8 @@ bool _userWorking() {
|
||||||
}
|
}
|
||||||
|
|
||||||
enum class FileOption {
|
enum class FileOption {
|
||||||
User = 0x01,
|
User = (1 << 0),
|
||||||
Safe = 0x02,
|
Safe = (1 << 1),
|
||||||
};
|
};
|
||||||
using FileOptions = base::flags<FileOption>;
|
using FileOptions = base::flags<FileOption>;
|
||||||
inline constexpr auto is_flag_type(FileOption) { return true; };
|
inline constexpr auto is_flag_type(FileOption) { return true; };
|
||||||
|
|
|
@ -76,10 +76,10 @@ signals:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
enum class StateFlag {
|
enum class StateFlag {
|
||||||
None = 0x00,
|
None = 0,
|
||||||
Over = 0x01,
|
Over = (1 << 0),
|
||||||
Down = 0x02,
|
Down = (1 << 1),
|
||||||
Disabled = 0x04,
|
Disabled = (1 << 2),
|
||||||
};
|
};
|
||||||
using State = base::flags<StateFlag>;
|
using State = base::flags<StateFlag>;
|
||||||
|
|
||||||
|
|
|
@ -188,18 +188,18 @@ QImage prepareColored(style::color add, QImage image);
|
||||||
QImage prepareOpaque(QImage image);
|
QImage prepareOpaque(QImage image);
|
||||||
|
|
||||||
enum class Option {
|
enum class Option {
|
||||||
None = 0x000,
|
None = 0,
|
||||||
Smooth = 0x001,
|
Smooth = (1 << 0),
|
||||||
Blurred = 0x002,
|
Blurred = (1 << 1),
|
||||||
Circled = 0x004,
|
Circled = (1 << 2),
|
||||||
RoundedLarge = 0x008,
|
RoundedLarge = (1 << 3),
|
||||||
RoundedSmall = 0x010,
|
RoundedSmall = (1 << 4),
|
||||||
RoundedTopLeft = 0x020,
|
RoundedTopLeft = (1 << 5),
|
||||||
RoundedTopRight = 0x040,
|
RoundedTopRight = (1 << 6),
|
||||||
RoundedBottomLeft = 0x080,
|
RoundedBottomLeft = (1 << 7),
|
||||||
RoundedBottomRight = 0x100,
|
RoundedBottomRight = (1 << 8),
|
||||||
Colored = 0x200,
|
Colored = (1 << 9),
|
||||||
TransparentBackground = 0x400,
|
TransparentBackground = (1 << 10),
|
||||||
};
|
};
|
||||||
using Options = base::flags<Option>;
|
using Options = base::flags<Option>;
|
||||||
inline constexpr auto is_flag_type(Option) { return true; };
|
inline constexpr auto is_flag_type(Option) { return true; };
|
||||||
|
|
|
@ -129,9 +129,9 @@ public:
|
||||||
|
|
||||||
struct StateRequest {
|
struct StateRequest {
|
||||||
enum class Flag {
|
enum class Flag {
|
||||||
BreakEverywhere = 0x01,
|
BreakEverywhere = (1 << 0),
|
||||||
LookupSymbol = 0x02,
|
LookupSymbol = (1 << 1),
|
||||||
LookupLink = 0x04,
|
LookupLink = (1 << 2),
|
||||||
};
|
};
|
||||||
using Flags = base::flags<Flag>;
|
using Flags = base::flags<Flag>;
|
||||||
friend inline constexpr auto is_flag_type(Flag) { return true; };
|
friend inline constexpr auto is_flag_type(Flag) { return true; };
|
||||||
|
|
|
@ -30,34 +30,34 @@ QString GetOverride(const QString &familyName);
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
enum class RectPart {
|
enum class RectPart {
|
||||||
None = 0,
|
None = 0,
|
||||||
|
|
||||||
TopLeft = (1 << 0),
|
TopLeft = (1 << 0),
|
||||||
Top = (1 << 1),
|
Top = (1 << 1),
|
||||||
TopRight = (1 << 2),
|
TopRight = (1 << 2),
|
||||||
Left = (1 << 3),
|
Left = (1 << 3),
|
||||||
Center = (1 << 4),
|
Center = (1 << 4),
|
||||||
Right = (1 << 5),
|
Right = (1 << 5),
|
||||||
BottomLeft = (1 << 6),
|
BottomLeft = (1 << 6),
|
||||||
Bottom = (1 << 7),
|
Bottom = (1 << 7),
|
||||||
BottomRight = (1 << 8),
|
BottomRight = (1 << 8),
|
||||||
|
|
||||||
FullTop = TopLeft | Top | TopRight,
|
FullTop = TopLeft | Top | TopRight,
|
||||||
NoTopBottom = Left | Center | Right,
|
NoTopBottom = Left | Center | Right,
|
||||||
FullBottom = BottomLeft | Bottom | BottomRight,
|
FullBottom = BottomLeft | Bottom | BottomRight,
|
||||||
NoTop = NoTopBottom | FullBottom,
|
NoTop = NoTopBottom | FullBottom,
|
||||||
NoBottom = FullTop | NoTopBottom,
|
NoBottom = FullTop | NoTopBottom,
|
||||||
|
|
||||||
FullLeft = TopLeft | Left | BottomLeft,
|
FullLeft = TopLeft | Left | BottomLeft,
|
||||||
NoLeftRight = Top | Center | Bottom,
|
NoLeftRight = Top | Center | Bottom,
|
||||||
FullRight = TopRight | Right | BottomRight,
|
FullRight = TopRight | Right | BottomRight,
|
||||||
NoLeft = NoLeftRight | FullRight,
|
NoLeft = NoLeftRight | FullRight,
|
||||||
NoRight = FullLeft | NoLeftRight,
|
NoRight = FullLeft | NoLeftRight,
|
||||||
|
|
||||||
CornersMask = TopLeft | TopRight | BottomLeft | BottomRight,
|
CornersMask = TopLeft | TopRight | BottomLeft | BottomRight,
|
||||||
SidesMask = Top | Bottom | Left | Right,
|
SidesMask = Top | Bottom | Left | Right,
|
||||||
|
|
||||||
Full = FullTop | NoTop,
|
Full = FullTop | NoTop,
|
||||||
};
|
};
|
||||||
using RectParts = base::flags<RectPart>;
|
using RectParts = base::flags<RectPart>;
|
||||||
inline constexpr auto is_flag_type(RectPart) { return true; };
|
inline constexpr auto is_flag_type(RectPart) { return true; };
|
||||||
|
|
|
@ -25,12 +25,12 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
namespace Window {
|
namespace Window {
|
||||||
|
|
||||||
enum class GifPauseReason {
|
enum class GifPauseReason {
|
||||||
Any = 0,
|
Any = 0,
|
||||||
InlineResults = (1 << 0),
|
InlineResults = (1 << 0),
|
||||||
SavedGifs = (1 << 1),
|
SavedGifs = (1 << 1),
|
||||||
Layer = (1 << 2),
|
Layer = (1 << 2),
|
||||||
RoundPlaying = (1 << 3),
|
RoundPlaying = (1 << 3),
|
||||||
MediaPreview = (1 << 4),
|
MediaPreview = (1 << 4),
|
||||||
};
|
};
|
||||||
using GifPauseReasons = base::flags<GifPauseReason>;
|
using GifPauseReasons = base::flags<GifPauseReason>;
|
||||||
inline constexpr bool is_flag_type(GifPauseReason) { return true; };
|
inline constexpr bool is_flag_type(GifPauseReason) { return true; };
|
||||||
|
|
Loading…
Reference in New Issue