mirror of
https://github.com/Mikaela/Limnoria.git
synced 2024-11-19 08:59:27 +01:00
Better formatting in supybot.Author if some fields are missing
This commit is contained in:
parent
bace9cb6c0
commit
7854db7135
@ -40,6 +40,10 @@ del builtins['supybotInternationalization']
|
|||||||
(__builtins__ if isinstance(__builtins__, dict) else __builtins__.__dict__)['format'] = utils.str.format
|
(__builtins__ if isinstance(__builtins__, dict) else __builtins__.__dict__)['format'] = utils.str.format
|
||||||
|
|
||||||
class Author(object):
|
class Author(object):
|
||||||
|
"""
|
||||||
|
Describes a plugin author. All fields are optional, but the standard practice
|
||||||
|
is to include an email and at least one of 'name' and 'nick'.
|
||||||
|
"""
|
||||||
def __init__(self, name=None, nick=None, email=None, **kwargs):
|
def __init__(self, name=None, nick=None, email=None, **kwargs):
|
||||||
self.__dict__.update(kwargs)
|
self.__dict__.update(kwargs)
|
||||||
self.name = name
|
self.name = name
|
||||||
@ -47,10 +51,17 @@ class Author(object):
|
|||||||
self.email = email
|
self.email = email
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
if self.name != self.nick:
|
# If only one of these are defined, take the nick as the name
|
||||||
return '%s (%s) <%s>' % (self.name, self.nick, self.email)
|
name = self.name or self.nick or 'Unknown author'
|
||||||
else:
|
|
||||||
return '%s <%s>' % (self.name, self.email)
|
s = name
|
||||||
|
if self.nick and name != self.nick:
|
||||||
|
# Format as "Name (nick)" if both are given and different
|
||||||
|
s += ' (%s)' % self.nick
|
||||||
|
if self.email:
|
||||||
|
# Add "Name (nick) <email>" or "Name <email>" if provided
|
||||||
|
s += ' <%s>' % self.email
|
||||||
|
return s
|
||||||
|
|
||||||
class authors(object): # This is basically a bag.
|
class authors(object): # This is basically a bag.
|
||||||
jemfinch = Author('Jeremy Fincher', 'jemfinch', 'jemfinch@users.sf.net')
|
jemfinch = Author('Jeremy Fincher', 'jemfinch', 'jemfinch@users.sf.net')
|
||||||
@ -64,8 +75,8 @@ class authors(object): # This is basically a bag.
|
|||||||
grantbow = Author('Grant Bowman', 'Grantbow', 'grantbow@grantbow.com')
|
grantbow = Author('Grant Bowman', 'Grantbow', 'grantbow@grantbow.com')
|
||||||
stepnem = Author('Štěpán Němec', 'stepnem', 'stepnem@gmail.com')
|
stepnem = Author('Štěpán Němec', 'stepnem', 'stepnem@gmail.com')
|
||||||
progval = Author('Valentin Lorentz', 'ProgVal', 'progval@gmail.com')
|
progval = Author('Valentin Lorentz', 'ProgVal', 'progval@gmail.com')
|
||||||
jlu = Author('James Lu', 'GLolol', 'james@overdrivenetworks.com')
|
jlu = Author('James Lu', email='james@overdrivenetworks.com')
|
||||||
unknown = Author('Unknown author', 'unknown', 'unknown@email.invalid')
|
unknown = Author('Unknown author', email='unknown@email.invalid')
|
||||||
|
|
||||||
# Let's be somewhat safe about this.
|
# Let's be somewhat safe about this.
|
||||||
def __getattr__(self, attr):
|
def __getattr__(self, attr):
|
||||||
|
57
test/test_misc.py
Normal file
57
test/test_misc.py
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
###
|
||||||
|
# Copyright (c) 2019, James Lu <james@overdrivenetworks.com>
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# * Redistributions of source code must retain the above copyright notice,
|
||||||
|
# this list of conditions, and the following disclaimer.
|
||||||
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
# this list of conditions, and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
# * Neither the name of the author of this software nor the name of
|
||||||
|
# contributors to this software may be used to endorse or promote products
|
||||||
|
# derived from this software without specific prior written consent.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
# POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
###
|
||||||
|
|
||||||
|
import supybot
|
||||||
|
from supybot.test import *
|
||||||
|
|
||||||
|
class MiscTestCase(SupyTestCase):
|
||||||
|
|
||||||
|
def testAuthorExpand(self):
|
||||||
|
# The standard 3 pair: name, nick, email
|
||||||
|
self.assertEqual(str(supybot.authors.progval),
|
||||||
|
'Valentin Lorentz (ProgVal) <progval@gmail.com>')
|
||||||
|
# All 3 provided, but name == nick
|
||||||
|
self.assertEqual(str(supybot.Author('foobar', 'foobar', 'foobar@example.net')),
|
||||||
|
'foobar <foobar@example.net>')
|
||||||
|
# Only name provided
|
||||||
|
self.assertEqual(str(supybot.Author('somedev')), 'somedev')
|
||||||
|
# Only nick provided
|
||||||
|
self.assertEqual(str(supybot.Author(nick='somedev')), 'somedev')
|
||||||
|
# Only name and nick provided
|
||||||
|
self.assertEqual(str(supybot.Author('James Lu', 'tacocat')), 'James Lu (tacocat)')
|
||||||
|
# Only name and nick provided, but name == nick
|
||||||
|
self.assertEqual(str(supybot.Author('tacocat', 'tacocat')), 'tacocat')
|
||||||
|
# Only name and email
|
||||||
|
self.assertEqual(str(supybot.authors.jlu), 'James Lu <james@overdrivenetworks.com>')
|
||||||
|
# Only nick and email
|
||||||
|
self.assertEqual(str(supybot.Author(nick='abcdef', email='abcdef@example.org')), 'abcdef <abcdef@example.org>')
|
||||||
|
# Only email?
|
||||||
|
self.assertEqual(str(supybot.Author(email='xyzzy@localhost.localdomain')), 'Unknown author <xyzzy@localhost.localdomain>')
|
||||||
|
|
||||||
|
# vim:set shiftwidth=4 softtabstop=4 expandtab textwidth=79:
|
Loading…
Reference in New Issue
Block a user