Change entities filter to be singular.

Also remove the faulty example completely since it should be no longer needed.
This commit is contained in:
Jacob Bom 2016-09-24 13:38:56 +02:00
parent 97bb04cd38
commit e16c1da6b1
2 changed files with 11 additions and 26 deletions

View file

@ -86,29 +86,19 @@ class Filters(object):
return bool(message.forward_date)
@staticmethod
def entities(entity_types):
def entity(entity_type):
"""Filters messages to only allow those which have a :class:`telegram.MessageEntity`
that match `entity_types`.
Note:
This filter functions as an OR filter, meaning that just one of the entity_type.
If you want AND filtering instead, you have to specify multiple of this filter in the
`filters` attribute. Example:
>>> MessageHandler([Filters.entities([TEXT_MENTION, MENTION]),
... Filters.entities([HASHTAG])], callback)
Will require either a one type of mention AND a hashtag in the message.
where their `type` matches `entity_type`.
Args:
entity_types: List of entity types to check for. All types can be found as constants
entity_type: Entity type to check for. All types can be found as constants
in :class:`telegram.MessageEntity`.
Returns: function to use as filter
"""
def entities_filter(message):
return any([entity.type in entity_types for entity in message.entities])
return any([entity.type == entity_type for entity in message.entities])
return entities_filter
@ -169,6 +159,7 @@ class MessageHandler(Handler):
return self.callback(dispatcher.bot, update, **optional_args)
# old non-PEP8 Handler methods
m = "telegram.MessageHandler."
checkUpdate = deprecate(check_update, m + "checkUpdate", m + "check_update")
handleUpdate = deprecate(handle_update, m + "handleUpdate", m + "handle_update")

View file

@ -155,22 +155,16 @@ class FiltersTest(BaseTest, unittest.TestCase):
e = functools.partial(MessageEntity, offset=0, length=0)
self.message.entities = [e(MessageEntity.MENTION)]
self.assertTrue(Filters.entities([MessageEntity.MENTION])(self.message))
self.assertTrue(Filters.entity(MessageEntity.MENTION)(self.message))
self.message.entities = []
self.assertFalse(Filters.entities([MessageEntity.MENTION])(self.message))
self.assertFalse(Filters.entity(MessageEntity.MENTION)(self.message))
self.message.entities = [e(MessageEntity.BOLD)]
self.assertFalse(Filters.entities([MessageEntity.MENTION])(self.message))
self.assertFalse(Filters.entity(MessageEntity.MENTION)(self.message))
self.message.entities = [e(MessageEntity.MENTION)]
self.assertTrue(
Filters.entities([MessageEntity.MENTION, MessageEntity.BOLD])(self.message))
self.message.entities = [e(MessageEntity.BOLD)]
self.assertTrue(
Filters.entities([MessageEntity.MENTION, MessageEntity.BOLD])(self.message))
self.assertFalse(
Filters.entities([MessageEntity.MENTION, MessageEntity.TEXT_MENTION])(self.message))
self.message.entities = [e(MessageEntity.BOLD), e(MessageEntity.MENTION)]
self.assertTrue(Filters.entity(MessageEntity.MENTION)(self.message))
if __name__ == '__main__':