Ignore:
Timestamp:
2015-02-20T22:47:33Z (10 years ago)
Author:
dequis <dx@…>
Branches:
master
Children:
af359b4
Parents:
34afea7
Message:

Revert "Twitter format strings"

This reverts commit ce402b20d82ec323e6bd5e306de934773590742d.

See discussion in PR #10 for more details.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • protocols/twitter/twitter_lib.c

    r34afea7 r0ca1d79  
    6363        guint64 reply_to;
    6464        gboolean from_filter;
    65         struct twitter_xml_status *rt;
    6665};
    6766
     
    8988        g_free(txs->text);
    9089        txu_free(txs->user);
    91         txs_free(txs->rt);
    9290        g_free(txs);
    9391}
     
    491489                if (rtxs) {
    492490                        g_free(txs->text);
    493                         txs->text = g_strdup(rtxs->text);
     491                        txs->text = g_strdup_printf("RT @%s: %s", rtxs->user->screen_name, rtxs->text);
    494492                        txs->id = rtxs->id;
    495                         txs->rt = rtxs;
     493                        txs_free(rtxs);
    496494                }
    497495        } else if (entities) {
     
    611609}
    612610
    613 /**
    614  * Function to properly format a tweet as per the users configuration.
    615  */
    616 static char *twitter_msg_get_text(struct im_connection *ic, int log_id, int reply_to,
    617                                 struct twitter_xml_status *txs, const char *prefix) {
    618         gchar * format = set_getstr(&ic->acc->set, "format_string");
    619         GString * text = g_string_new(NULL);
    620 
    621         gchar *c;
    622         if (reply_to != -1)
    623                 format = set_getstr(&ic->acc->set, "reply_format_string");
    624         if (txs->rt)
    625                 format = set_getstr(&ic->acc->set, "retweet_format_string");
    626 
    627         for (c = format; *c ; c++) {
    628                 if (!(*c == '%' && *(c+1))) {
    629                         text = g_string_append_c(text, *c);
    630                         continue;
    631                 }
    632                 c++; // Move past the %
    633                 switch (*c) {
    634                         case 'i':
    635                                 g_string_append_printf(text, "%02x", log_id);
    636                                 break;
    637                         case 'r':
    638                                 if (reply_to != -1) // In case someone does put %r in the wrong format_string
    639                                 g_string_append_printf(text, "%02x", reply_to);
    640                                 break;
    641                         case 'a':
    642                                 if (txs->rt) // In case someone does put %a in the wrong format_string
    643                                         text = g_string_append(text, txs->rt->user->screen_name);
    644                                 break;
    645                         case 'c':
    646                                 text = g_string_append(text, txs->text);
    647                                 break;
    648                         default:
    649                                 text = g_string_append_c(text, *c);
    650                 }
    651         }
    652         text = g_string_prepend(text, prefix);
    653         return g_string_free(text, FALSE);
    654 }
    655 
    656611/* Will log messages either way. Need to keep track of IDs for stream deduping.
    657612   Plus, show_ids is on by default and I don't see why anyone would disable it. */
     
    692647                td->log[td->log_id].id = txs->rt_id;
    693648       
    694         return twitter_msg_get_text(ic, td->log_id, reply_to, txs, prefix);
     649        if (set_getbool(&ic->acc->set, "show_ids")) {
     650                if (reply_to != -1)
     651                        return g_strdup_printf("\002[\002%02x->%02x\002]\002 %s%s",
     652                                               td->log_id, reply_to, prefix, txs->text);
     653                else
     654                        return g_strdup_printf("\002[\002%02x\002]\002 %s%s",
     655                                               td->log_id, prefix, txs->text);
     656        } else {
     657                if (*prefix)
     658                        return g_strconcat(prefix, txs->text, NULL);
     659                else
     660                        return NULL;
     661        }
    695662}
    696663
Note: See TracChangeset for help on using the changeset viewer.