X-Git-Url: https://jfr.im/git/z_archive/twitter.git/blobdiff_plain/79d6cca767a245eb3a115f3698a9b388b36ab987..098660ce6ca34597e97f074b3af48f64dcf3ea03:/twitter/cmdline.py diff --git a/twitter/cmdline.py b/twitter/cmdline.py index 54a994e..a167c14 100644 --- a/twitter/cmdline.py +++ b/twitter/cmdline.py @@ -16,6 +16,8 @@ ACTIONS: mylist get list of your lists; give a list name to get tweets from that list public get latest public tweets + pyprompt start a Python prompt for interacting with the twitter + object directly replies get latest replies to you search search twitter (Beware: octothorpe, escape it) set set your twitter status @@ -59,6 +61,8 @@ prompt: '> home directory. """ +from __future__ import print_function + CONSUMER_KEY='uS6hO2sV6tDKIOeVjhnFnQ' CONSUMER_SECRET='MEYTOS97VvlHX7K1rwHPEqVpTSqZ71HtvoK4sVuYk' @@ -68,15 +72,22 @@ from getopt import gnu_getopt as getopt, GetoptError from getpass import getpass import re import os.path -from configparser import SafeConfigParser +try: + from ConfigParser import SafeConfigParser +except ImportError: + from configparser import ConfigParser as SafeConfigParser import datetime -from urllib.parse import quote +try: + from urllib.parse import quote +except ImportError: + from urllib2 import quote import webbrowser from .api import Twitter, TwitterError from .oauth import OAuth, write_token_file, read_token_file from .oauth_dance import oauth_dance from . import ansi +from .util import smrt_input, printNicely OPTIONS = { 'action': 'friends', @@ -349,10 +360,6 @@ class NoSuchAction(Action): def __call__(self, twitter, options): raise NoSuchActionError("No such action: %s" %(options['action'])) -def printNicely(string): - sys.stdout.buffer.write(string.encode('utf8')) - print() - class StatusAction(Action): def __call__(self, twitter, options): statuses = self.getStatuses(twitter, options) @@ -371,7 +378,7 @@ class SearchAction(Action): # We need to bypass the TwitterCall parameter encoding, so we # don't encode the plus sign, so we have to encode it ourselves query_string = "+".join( - [quote(term.decode(get_term_encoding())) + [quote(term) for term in options['extra_args']]) results = twitter.search(q=query_string)['results'] @@ -448,11 +455,10 @@ class LeaveAction(AdminAction): class SetStatusAction(Action): def __call__(self, twitter, options): - statusTxt = (" ".join(options['extra_args']).decode(get_term_encoding()) + statusTxt = (" ".join(options['extra_args']) if options['extra_args'] else str(input("message: "))) - status = (statusTxt.encode('utf8', 'replace')) - twitter.statuses.update(status=status) + twitter.statuses.update(status=statusTxt) class TwitterShell(Action): @@ -501,6 +507,14 @@ class TwitterShell(Action): else: raise SystemExit(0) +class PythonPromptAction(Action): + def __call__(self, twitter, options): + try: + while True: + smrt_input(globals(), locals()) + except EOFError: + pass + class HelpAction(Action): def __call__(self, twitter, options): print(__doc__) @@ -518,6 +532,7 @@ actions = { 'help' : HelpAction, 'leave' : LeaveAction, 'public' : PublicAction, + 'pyprompt' : PythonPromptAction, 'replies' : RepliesAction, 'search' : SearchAction, 'set' : SetStatusAction,