X-Git-Url: https://vcs.fsf.org/?p=rainbowstream.git;a=blobdiff_plain;f=rainbowstream%2Fdraw.py;h=a94750682dda5753ead9be7092acc3a48cad3e90;hp=747a68b4d8d9eb1c4136878a47f89a2a67f59f61;hb=72f58edbf0bd853f8cb5a2a0f25d48de5c0e8268;hpb=223d2e05c222e9023fdbf5c31db7d032668a0f96 diff --git a/rainbowstream/draw.py b/rainbowstream/draw.py index 747a68b..a947506 100644 --- a/rainbowstream/draw.py +++ b/rainbowstream/draw.py @@ -1,4 +1,5 @@ import random +import textwrap import itertools import requests import locale @@ -14,6 +15,7 @@ from .c_image import * from .colors import * from .config import * from .py3patch import * +from .emoji import * # Draw global variables dg = {} @@ -36,6 +38,7 @@ def start_cycle(): """ dg['cyc'] = init_cycle() dg['cache'] = {} + dg['humanize_unsupported'] = False def order_rainbow(s): @@ -144,7 +147,34 @@ def color_func(func_name): return globals()[func_name] -def draw(t, keyword=None, humanize=True, fil=[], ig=[]): +def fallback_humanize(date, fallback_format=None, use_fallback=False): + """ + Format date with arrow and a fallback format + """ + # Convert to local timezone + date = arrow.get(date).to('local') + # Set default fallback format + if not fallback_format: + fallback_format = '%Y/%m/%d %H:%M:%S' + # Determine using fallback format or not by a variable + if use_fallback: + return date.datetime.strftime(fallback_format) + try: + # Use Arrow's humanize function + lang, encode = locale.getdefaultlocale() + clock = date.humanize(locale=lang) + except: + # Notice at the 1st time only + if not dg['humanize_unsupported']: + dg['humanize_unsupported'] = True + printNicely( + light_magenta('Humanized date display method does not support your $LC_ALL.')) + # Fallback when LC_ALL is not supported + clock = date.datetime.strftime(fallback_format) + return clock + + +def draw(t, keyword=None, humanize=True, noti=False, fil=[], ig=[]): """ Draw the rainbow """ @@ -160,28 +190,38 @@ def draw(t, keyword=None, humanize=True, fil=[], ig=[]): favorited = t['favorited'] retweet_count = t['retweet_count'] favorite_count = t['favorite_count'] + client = t['source'] date = parser.parse(created_at) - date = arrow.get(date).to('local') - if humanize: - lang, encode = locale.getdefaultlocale() - clock = arrow.get(date).to('local').humanize(locale=lang) - else: - try: - clock_format = c['FORMAT']['TWEET']['CLOCK_FORMAT'] - except: - clock_format = '%Y/%m/%d %H:%M:%S' - clock = date.datetime.strftime(clock_format) + try: + clock_format = c['FORMAT']['TWEET']['CLOCK_FORMAT'] + except: + clock_format = '%Y/%m/%d %H:%M:%S' + clock = fallback_humanize(date, clock_format, not humanize) # Pull extended retweet text try: text = 'RT @' + t['retweeted_status']['user']['screen_name'] + ': ' +\ t['retweeted_status']['text'] + # Display as a notification + target = t['retweeted_status']['user']['screen_name'] + if all([target == c['original_name'], not noti]): + # Add to evens for 'notification' command + t['event'] = 'retweet' + c['events'].append(t) + notify_retweet(t) + return except: pass # Unescape HTML character text = unescape(text) + # Get client name + try: + client = client.split('>')[-2].split('<')[0] + except: + client = None + # Get expanded url try: expanded_url = [] @@ -204,6 +244,7 @@ def draw(t, keyword=None, humanize=True, fil=[], ig=[]): media_url = None # Filter and ignore + mytweet = screen_name == c['original_name'] screen_name = '@' + screen_name fil = list(set((fil or []) + c['ONLY_LIST'])) ig = list(set((ig or []) + c['IGNORE_LIST'])) @@ -221,7 +262,10 @@ def draw(t, keyword=None, humanize=True, fil=[], ig=[]): # Format info name = cycle_color(name) - nick = color_func(c['TWEET']['nick'])(screen_name) + if mytweet: + nick = color_func(c['TWEET']['mynick'])(screen_name) + else: + nick = color_func(c['TWEET']['nick'])(screen_name) clock = clock id = str(rid) fav = '' @@ -248,7 +292,7 @@ def draw(t, keyword=None, humanize=True, fil=[], ig=[]): # Highlight link tweet = lmap( lambda x: color_func(c['TWEET']['link'])(x) - if x[0:4] == 'http' + if x.startswith('http') else x, tweet) # Highlight hashtag @@ -257,6 +301,15 @@ def draw(t, keyword=None, humanize=True, fil=[], ig=[]): if x.startswith('#') else x, tweet) + # Highlight my tweet + if mytweet: + tweet = [color_func(c['TWEET']['mytweet'])(x) + for x in tweet + if not any([ + x == 'RT', + x.startswith('http'), + x.startswith('#')]) + ] # Highlight keyword tweet = ' '.join(tweet) if keyword: @@ -275,28 +328,41 @@ def draw(t, keyword=None, humanize=True, fil=[], ig=[]): formater = nick.join(formater.split('#nick')) formater = fav.join(formater.split('#fav')) formater = tweet.join(formater.split('#tweet')) + formater = emojize(formater) # Change clock word - word = [w for w in formater.split() if '#clock' in w][0] + word = [wo for wo in formater.split() if '#clock' in wo][0] delimiter = color_func(c['TWEET']['clock'])( clock.join(word.split('#clock'))) formater = delimiter.join(formater.split(word)) # Change id word - word = [w for w in formater.split() if '#id' in w][0] + word = [wo for wo in formater.split() if '#id' in wo][0] delimiter = color_func(c['TWEET']['id'])(id.join(word.split('#id'))) formater = delimiter.join(formater.split(word)) # Change retweet count word - word = [w for w in formater.split() if '#rt_count' in w][0] + word = [wo for wo in formater.split() if '#rt_count' in wo][0] delimiter = color_func(c['TWEET']['retweet_count'])( str(retweet_count).join(word.split('#rt_count'))) formater = delimiter.join(formater.split(word)) # Change favorites count word - word = [w for w in formater.split() if '#fa_count' in w][0] + word = [wo for wo in formater.split() if '#fa_count' in wo][0] delimiter = color_func(c['TWEET']['favorite_count'])( str(favorite_count).join(word.split('#fa_count'))) formater = delimiter.join(formater.split(word)) + # Change client word + word = [wo for wo in formater.split() if '#client' in wo][0] + delimiter = color_func(c['TWEET']['client'])( + client.join(word.split('#client'))) + formater = delimiter.join(formater.split(word)) except: pass + # Add spaces in begining of line if this is inside a notification + if noti: + formater = '\n '.join(formater.split('\n')) + # Reformat + if formater.startswith('\n'): + formater = formater[1:] + # Draw printNicely(formater) @@ -323,8 +389,8 @@ def print_threads(d): name = partner[1] screen_name = color_func(c['MESSAGE']['partner'])(screen_name) name = cycle_color(name) - thread_id = color_func(c['MESSAGE']['id'])('thread id:'+str(id)) - line = ' '*2 + name + ' ' + screen_name + \ + thread_id = color_func(c['MESSAGE']['id'])('thread_id:' + str(id)) + line = ' ' * 2 + name + ' ' + screen_name + \ ' (' + str(count) + ' message) ' + thread_id printNicely(line) rel[id] = partner @@ -339,20 +405,31 @@ def print_thread(partner, me_nick, me_name): """ # Sort messages by time messages = dg['thread'][partner] - messages.sort(key = lambda x:parser.parse(x['created_at'])) - # Print the 1st line - dg['message_thread_margin'] = margin = 2 - left_size = len(partner[0])+len(partner[1]) + margin - right_size = len(me_nick) + len(me_name) + margin - partner_screen_name = color_func(c['MESSAGE']['partner'])('@' + partner[0]) - partner_name = cycle_color(partner[1]) + messages.sort(key=lambda x: parser.parse(x['created_at'])) + # Use legacy display on non-ascii text message + ms = [m['text'] for m in messages] + ums = [m for m in ms if not all(ord(c) < 128 for c in m)] + if ums: + for m in messages: + print_message(m) + printNicely('') + return + # Print the first line + dg['frame_margin'] = margin = 2 + partner_nick = partner[0] + partner_name = partner[1] + left_size = len(partner_nick) + len(partner_name) + 2 + right_size = len(me_nick) + len(me_name) + 2 + partner_nick = color_func(c['MESSAGE']['partner'])('@' + partner_nick) + partner_name = cycle_color(partner_name) me_screen_name = color_func(c['MESSAGE']['me'])('@' + me_nick) me_name = cycle_color(me_name) - left = ' ' * margin + partner_name + ' ' + partner_screen_name + left = ' ' * margin + partner_name + ' ' + partner_nick right = me_name + ' ' + me_screen_name + ' ' * margin h, w = os.popen('stty size', 'r').read().split() w = int(w) - line = '{}{}{}'.format(left, ' '*(w - left_size - right_size - 2 * margin), right) + line = '{}{}{}'.format( + left, ' ' * (w - left_size - right_size - 2 * margin), right) printNicely('') printNicely(line) printNicely('') @@ -370,12 +447,13 @@ def print_right_message(m): """ h, w = os.popen('stty size', 'r').read().split() w = int(w) - frame_width = w //3 - dg['message_thread_margin'] - step = frame_width - 2 * dg['message_thread_margin'] - slicing = [m['text'][i:i+step] for i in range(0, len(m['text']), step)] - spaces = w - frame_width - dg['message_thread_margin'] + frame_width = w // 3 - dg['frame_margin'] + frame_width = max(c['THREAD_MIN_WIDTH'], frame_width) + step = frame_width - 2 * dg['frame_margin'] + slicing = textwrap.wrap(m['text'], step) + spaces = w - frame_width - dg['frame_margin'] dotline = ' ' * spaces + '-' * frame_width - dotline = color_func(c['MESSAGE']['me_bg'])(dotline) + dotline = color_func(c['MESSAGE']['me_frame'])(dotline) # Draw the frame printNicely(dotline) for line in slicing: @@ -385,10 +463,10 @@ def print_right_message(m): screen_line = screen_line + ' >' else: screen_line = screen_line + '|' - screen_line = color_func(c['MESSAGE']['me_bg'])(screen_line) + screen_line = color_func(c['MESSAGE']['me_frame'])(screen_line) printNicely(screen_line) printNicely(dotline) - # Print clock + # Format clock date = parser.parse(m['created_at']) date = arrow.get(date).to('local').datetime clock_format = '%Y/%m/%d %H:%M:%S' @@ -397,18 +475,34 @@ def print_right_message(m): except: pass clock = date.strftime(clock_format) - # Get rainbow id + # Format id if m['id'] not in c['message_dict']: c['message_dict'].append(m['id']) rid = len(c['message_dict']) - 1 else: rid = c['message_dict'].index(m['id']) - rid = str(rid) - # Create line and print - meta = color_func(c['MESSAGE']['clock'])(clock) + \ - color_func(c['MESSAGE']['id'])(' ('+rid+')') - line = ' ' * (w - len(clock + rid) - 3 - dg['message_thread_margin']) + \ - meta + id = str(rid) + # Print meta + formater = '' + try: + virtual_meta = formater = c['THREAD_META_RIGHT'] + virtual_meta = clock.join(virtual_meta.split('#clock')) + virtual_meta = id.join(virtual_meta.split('#id')) + # Change clock word + word = [wo for wo in formater.split() if '#clock' in wo][0] + delimiter = color_func(c['MESSAGE']['clock'])( + clock.join(word.split('#clock'))) + formater = delimiter.join(formater.split(word)) + # Change id word + word = [wo for wo in formater.split() if '#id' in wo][0] + delimiter = color_func(c['MESSAGE']['id'])(id.join(word.split('#id'))) + formater = delimiter.join(formater.split(word)) + formater = emojize(formater) + except Exception: + printNicely(red('Wrong format in config.')) + return + meta = formater + line = ' ' * (w - len(virtual_meta) - dg['frame_margin']) + meta printNicely(line) @@ -418,25 +512,26 @@ def print_left_message(m): """ h, w = os.popen('stty size', 'r').read().split() w = int(w) - frame_width = w //3 - dg['message_thread_margin'] - step = frame_width - 2 * dg['message_thread_margin'] - slicing = [m['text'][i:i+step] for i in range(0, len(m['text']), step)] - spaces = dg['message_thread_margin'] + frame_width = w // 3 - dg['frame_margin'] + frame_width = max(c['THREAD_MIN_WIDTH'], frame_width) + step = frame_width - 2 * dg['frame_margin'] + slicing = textwrap.wrap(m['text'], step) + spaces = dg['frame_margin'] dotline = ' ' * spaces + '-' * frame_width - dotline = color_func(c['MESSAGE']['partner_bg'])(dotline) + dotline = color_func(c['MESSAGE']['partner_frame'])(dotline) # Draw the frame printNicely(dotline) for line in slicing: fill = step - len(line) screen_line = ' ' + line + ' ' * fill + ' |' if slicing[-1] == line: - screen_line = ' ' * (spaces-1) + '< ' + screen_line + screen_line = ' ' * (spaces - 1) + '< ' + screen_line else: screen_line = ' ' * spaces + '|' + screen_line - screen_line = color_func(c['MESSAGE']['partner_bg'])(screen_line) + screen_line = color_func(c['MESSAGE']['partner_frame'])(screen_line) printNicely(screen_line) printNicely(dotline) - # Print clock + # Format clock date = parser.parse(m['created_at']) date = arrow.get(date).to('local').datetime clock_format = '%Y/%m/%d %H:%M:%S' @@ -445,18 +540,34 @@ def print_left_message(m): except: pass clock = date.strftime(clock_format) - # Get rainbow id + # Format id if m['id'] not in c['message_dict']: c['message_dict'].append(m['id']) rid = len(c['message_dict']) - 1 else: rid = c['message_dict'].index(m['id']) - rid = str(rid) - # Create line and print - meta = color_func(c['MESSAGE']['clock'])(clock) + \ - color_func(c['MESSAGE']['id'])(' ('+rid+')') - line = ' ' * dg['message_thread_margin'] + \ - meta + id = str(rid) + # Print meta + formater = '' + try: + virtual_meta = formater = c['THREAD_META_LEFT'] + virtual_meta = clock.join(virtual_meta.split('#clock')) + virtual_meta = id.join(virtual_meta.split('#id')) + # Change clock word + word = [wo for wo in formater.split() if '#clock' in wo][0] + delimiter = color_func(c['MESSAGE']['clock'])( + clock.join(word.split('#clock'))) + formater = delimiter.join(formater.split(word)) + # Change id word + word = [wo for wo in formater.split() if '#id' in wo][0] + delimiter = color_func(c['MESSAGE']['id'])(id.join(word.split('#id'))) + formater = delimiter.join(formater.split(word)) + formater = emojize(formater) + except Exception: + printNicely(red('Wrong format in config.')) + return + meta = formater + line = ' ' * dg['frame_margin'] + meta printNicely(line) @@ -509,14 +620,15 @@ def print_message(m): formater = recipient_nick.join(formater.split("#recipient_nick")) formater = text.join(formater.split("#message")) # Change clock word - word = [w for w in formater.split() if '#clock' in w][0] + word = [wo for wo in formater.split() if '#clock' in wo][0] delimiter = color_func(c['MESSAGE']['clock'])( clock.join(word.split('#clock'))) formater = delimiter.join(formater.split(word)) # Change id word - word = [w for w in formater.split() if '#id' in w][0] + word = [wo for wo in formater.split() if '#id' in wo][0] delimiter = color_func(c['MESSAGE']['id'])(id.join(word.split('#id'))) formater = delimiter.join(formater.split(word)) + formater = emojize(formater) except: printNicely(red('Wrong format in config.')) return @@ -525,6 +637,264 @@ def print_message(m): printNicely(formater) +def notify_retweet(t): + """ + Notify a retweet + """ + source = t['user'] + created_at = t['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'retweeted your tweet') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + draw(t=t['retweeted_status'], noti=True) + + +def notify_favorite(e): + """ + Notify a favorite event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + target_object = e['target_object'] + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'favorited your tweet') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + draw(t=target_object, noti=True) + + +def notify_unfavorite(e): + """ + Notify a unfavorite event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + target_object = e['target_object'] + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'unfavorited your tweet') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + draw(t=target_object, noti=True) + + +def notify_follow(e): + """ + Notify a follow event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'followed you') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + + +def notify_list_member_added(e): + """ + Notify a list_member_added event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + target_object = [e['target_object']] # list of Twitter list + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'added you to a list') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + print_list(target_object, noti=True) + + +def notify_list_member_removed(e): + """ + Notify a list_member_removed event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + target_object = [e['target_object']] # list of Twitter list + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'removed you from a list') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + print_list(target_object, noti=True) + + +def notify_list_user_subscribed(e): + """ + Notify a list_user_subscribed event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + target_object = [e['target_object']] # list of Twitter list + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'subscribed to your list') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + print_list(target_object, noti=True) + + +def notify_list_user_unsubscribed(e): + """ + Notify a list_user_unsubscribed event + """ + # Retrieve info + target = e['target'] + if target['screen_name'] != c['original_name']: + return + source = e['source'] + target_object = [e['target_object']] # list of Twitter list + created_at = e['created_at'] + # Format + source_user = cycle_color(source['name']) + \ + color_func(c['NOTIFICATION']['source_nick'])( + ' @' + source['screen_name']) + notify = color_func(c['NOTIFICATION']['notify'])( + 'unsubscribed from your list') + date = parser.parse(created_at) + clock = fallback_humanize(date) + clock = color_func(c['NOTIFICATION']['clock'])(clock) + meta = c['NOTIFY_FORMAT'] + meta = source_user.join(meta.split('#source_user')) + meta = notify.join(meta.split('#notify')) + meta = clock.join(meta.split('#clock')) + meta = emojize(meta) + # Output + printNicely('') + printNicely(meta) + print_list(target_object, noti=True) + + +def print_event(e): + """ + Notify an event + """ + event_dict = { + 'retweet': notify_retweet, + 'favorite': notify_favorite, + 'unfavorite': notify_unfavorite, + 'follow': notify_follow, + 'list_member_added': notify_list_member_added, + 'list_member_removed': notify_list_member_removed, + 'list_user_subscribed': notify_list_user_subscribed, + 'list_user_unsubscribed': notify_list_user_unsubscribed, + } + event_dict.get(e['event'], lambda *args: None)(e) + + def show_profile(u): """ Show a profile @@ -565,8 +935,7 @@ def show_profile(u): location = 'Location : ' + color_func(c['PROFILE']['location'])(location) url = 'URL : ' + (color_func(c['PROFILE']['url'])(url) if url else '') date = parser.parse(created_at) - lang, encode = locale.getdefaultlocale() - clock = arrow.get(date).to('local').humanize(locale=lang) + clock = fallback_humanize(date) clock = 'Join at ' + color_func(c['PROFILE']['clock'])(clock) # Format @@ -623,7 +992,7 @@ def print_trends(trends): printNicely('') -def print_list(group): +def print_list(group, noti=False): """ Display a list """ @@ -644,15 +1013,18 @@ def print_list(group): mode = color_func(c['GROUP']['mode'])('Type: ' + mode) created_at = grp['created_at'] date = parser.parse(created_at) - lang, encode = locale.getdefaultlocale() - clock = arrow.get(date).to('local').humanize(locale=lang) + clock = fallback_humanize(date) clock = 'Created at ' + color_func(c['GROUP']['clock'])(clock) + prefix = ' ' * 2 + # Add spaces in begining of line if this is inside a notification + if noti: + prefix = ' ' * 2 + prefix # Create lines - line1 = ' ' * 2 + name + member + ' ' + subscriber - line2 = ' ' * 4 + description - line3 = ' ' * 4 + mode - line4 = ' ' * 4 + clock + line1 = prefix + name + member + ' ' + subscriber + line2 = prefix + ' ' * 2 + description + line3 = prefix + ' ' * 2 + mode + line4 = prefix + ' ' * 2 + clock # Display printNicely('') @@ -661,7 +1033,8 @@ def print_list(group): printNicely(line3) printNicely(line4) - printNicely('') + if not noti: + printNicely('') def show_calendar(month, date, rel): @@ -705,6 +1078,7 @@ def format_quote(tweet): formater = screen_name.join(formater.split('#owner')) formater = text.join(formater.split('#tweet')) formater = u2str(formater) + formater = emojize(formater) except: pass # Highlight like a tweet