Changeset c8eeadd


Ignore:
Timestamp:
2010-07-04T10:16:07Z (15 years ago)
Author:
Wilmer van der Gaast <wilmer@…>
Branches:
master
Children:
5c7b45c
Parents:
0bd948e
Message:

Added automatic joining of channels. Auto-rejoin functionality for
groupchats not reimplemented yet but that's the next step.

Files:
4 edited

Legend:

Unmodified
Added
Removed
  • irc.c

    r0bd948e rc8eeadd  
    653653                        ic = irc->default_channel = irc_channel_new( irc, ROOT_CHAN );
    654654                        irc_channel_set_topic( ic, CONTROL_TOPIC, irc->root );
    655                         irc_channel_add_user( ic, irc->user );
     655                        set_setstr( &ic->set, "auto_join", "true" );
     656                        irc_channel_auto_joins( irc, NULL );
    656657                       
    657658                        irc->last_root_cmd = g_strdup( ROOT_CHAN );
  • irc.h

    r0bd948e rc8eeadd  
    237237int irc_channel_set_topic( irc_channel_t *ic, const char *topic, const irc_user_t *who );
    238238void irc_channel_user_set_mode( irc_channel_t *ic, irc_user_t *iu, irc_channel_user_flags_t flags );
     239void irc_channel_auto_joins( irc_t *irc, struct account *acc );
    239240void irc_channel_printf( irc_channel_t *ic, char *format, ... );
    240241gboolean irc_channel_name_ok( const char *name );
  • irc_channel.c

    r0bd948e rc8eeadd  
    4848        irc->channels = g_slist_append( irc->channels, ic );
    4949       
     50        set_add( &ic->set, "auto_join", "false", set_eval_bool, ic );
    5051        set_add( &ic->set, "type", "control", set_eval_channel_type, ic );
    5152       
     
    309310}
    310311
     312void irc_channel_auto_joins( irc_t *irc, account_t *acc )
     313{
     314        GSList *l;
     315       
     316        for( l = irc->channels; l; l = l->next )
     317        {
     318                irc_channel_t *ic = l->data;
     319                gboolean aj = set_getbool( &ic->set, "auto_join" );
     320                char *type;
     321               
     322                if( acc &&
     323                    ( type = set_getstr( &ic->set, "chat_type" ) ) &&
     324                    strcmp( type, "room" ) == 0 )
     325                {
     326                        /* Bit of an ugly special case: Handle chatrooms here, we
     327                           can only auto-join them if their account is online. */
     328                        char *acc_s;
     329                       
     330                        if( !aj && !( ic->flags & IRC_CHANNEL_JOINED ) )
     331                                /* Only continue if this one's marked as auto_join
     332                                   or if we're in it already. (Possible if the
     333                                   client auto-rejoined it before identyfing.) */
     334                                continue;
     335                        else if( !( acc_s = set_getstr( &ic->set, "account" ) ) )
     336                                continue;
     337                        else if( account_get( irc->b, acc_s ) != acc )
     338                                continue;
     339                        else if( acc->ic == NULL || !( acc->ic->flags & OPT_LOGGED_IN ) )
     340                                continue;
     341                        else
     342                                ic->f->join( ic );
     343                }
     344                else if( aj )
     345                {
     346                        irc_channel_add_user( ic, irc->user );
     347                }
     348        }
     349}
     350
    311351void irc_channel_printf( irc_channel_t *ic, char *format, ... )
    312352{
     
    521561                bee_irc_channel_update( ic->irc, ic, NULL );
    522562        }
     563       
     564        return TRUE;
     565}
     566
     567static gboolean control_channel_join( irc_channel_t *ic )
     568{
     569        bee_irc_channel_update( ic->irc, ic, NULL );
    523570       
    524571        return TRUE;
     
    608655static const struct irc_channel_funcs control_channel_funcs = {
    609656        control_channel_privmsg,
    610         NULL,
     657        control_channel_join,
    611658        NULL,
    612659        NULL,
  • root_commands.c

    r0bd948e rc8eeadd  
    157157                irc->status |= USTATUS_IDENTIFIED;
    158158                irc_umode_set( irc, "+R", 1 );
     159                irc_channel_auto_joins( irc, NULL );
    159160                if( load && set_getbool( &irc->b->set, "auto_connect" ) )
    160161                        cmd_account( irc, account_on );
Note: See TracChangeset for help on using the changeset viewer.