summaryrefslogtreecommitdiff
path: root/src/core/ignore.c
diff options
context:
space:
mode:
authorailin-nemui <ailin-nemui@users.noreply.github.com>2018-06-15 14:28:09 +0200
committerGitHub <noreply@github.com>2018-06-15 14:28:09 +0200
commitb382bd12328c794b038a3dfd66adeec17f0b9324 (patch)
treebef59783a5d2a3b6e721c8c74c231d3234c3916f /src/core/ignore.c
parentdaf6ce86cb668d24f278dca91846fc7b8619757d (diff)
parentba2554dd1485259b95b4b37f281c989086b24739 (diff)
downloadirssi-b382bd12328c794b038a3dfd66adeec17f0b9324.zip
Merge pull request #884 from vague666/ignore_hiddenHEADmaster
Added HIDDEN level to ignores
Diffstat (limited to 'src/core/ignore.c')
-rw-r--r--src/core/ignore.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/src/core/ignore.c b/src/core/ignore.c
index cec91e6b..8745c434 100644
--- a/src/core/ignore.c
+++ b/src/core/ignore.c
@@ -81,10 +81,11 @@ static int ignore_match_pattern(IGNORE_REC *rec, const char *text)
* used as a flag to indicate it should only look at ignore items with NO_ACT.
* However we also want to allow NO_ACT combined with levels, so mask it out and
* match levels if set. */
+#define FLAG_MSGLEVELS ( MSGLEVEL_NO_ACT | MSGLEVEL_HIDDEN )
#define ignore_match_level(rec, level) \
- (((level & MSGLEVEL_NO_ACT) != 0) ? \
- ((~MSGLEVEL_NO_ACT & level) & (rec)->level) != 0 : \
- ((rec)->level & MSGLEVEL_NO_ACT ? 0 : \
+ (((level & FLAG_MSGLEVELS) != 0) ? \
+ ((~FLAG_MSGLEVELS & level) & (rec)->level) != 0 : \
+ ((rec)->level & FLAG_MSGLEVELS ? 0 : \
(level & (rec)->level) != 0))
#define ignore_match_nickmask(rec, nick, nickmask) \
@@ -212,6 +213,12 @@ IGNORE_REC *ignore_find_full(const char *servertag, const char *mask, const char
if (!(flags & IGNORE_FIND_NOACT) && (rec->level & MSGLEVEL_NO_ACT) != 0)
continue;
+ if ((flags & IGNORE_FIND_HIDDEN) && (rec->level & MSGLEVEL_HIDDEN) == 0)
+ continue;
+
+ if (!(flags & IGNORE_FIND_HIDDEN) && (rec->level & MSGLEVEL_HIDDEN) != 0)
+ continue;
+
if ((rec->mask == NULL && mask != NULL) ||
(rec->mask != NULL && mask == NULL))
continue;
@@ -264,6 +271,11 @@ IGNORE_REC *ignore_find_noact(const char *servertag, const char *mask, char **ch
return ignore_find_full(servertag, mask, NULL, channels, IGNORE_FIND_NOACT);
}
+IGNORE_REC *ignore_find_hidden(const char *servertag, const char *mask, char **channels, int hidden)
+{
+ return ignore_find_full(servertag, mask, NULL, channels, IGNORE_FIND_HIDDEN);
+}
+
static void ignore_set_config(IGNORE_REC *rec)
{
CONFIG_NODE *node;