Changeset 27ac72d


Ignore:
Timestamp:
2006-03-03T10:32:53Z (18 years ago)
Author:
Wilmer van der Gaast <wilmer@…>
Branches:
master
Children:
26fdfc5, 96ace1b
Parents:
5e713f6 (diff), cdb92c5 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge from Jelmer.

Files:
1 added
8 edited

Legend:

Unmodified
Added
Removed
  • .bzrignore

    r5e713f6 r27ac72d  
    1010decode
    1111encode
     12bitlbee.pc
  • Makefile

    r5e713f6 r27ac72d  
    1111# Program variables
    1212objects = account.o bitlbee.o conf.o crypting.o help.o ini.o ipc.o irc.o irc_commands.o log.o nick.o query.o root_commands.o set.o storage.o storage_text.o unix.o url.o user.o util.o
     13headers = account.h bitlbee.h commands.h conf.h config.h crypting.h help.h ini.h ipc.h irc.h log.h nick.h query.h set.h sock.h storage.h url.h user.h protocols/http_client.h protocols/md5.h protocols/nogaim.h protocols/proxy.h protocols/sha.h protocols/ssl_client.h
    1314subdirs = protocols
    1415
     
    2021        $(MAKE) -C doc
    2122
    22 uninstall: uninstall-bin uninstall-doc
     23uninstall: uninstall-bin uninstall-doc 
    2324        @echo -e '\nmake uninstall does not remove files in '$(DESTDIR)$(ETCDIR)', you can use make uninstall-etc to do that.\n'
    2425
     
    5657uninstall-bin:
    5758        rm -f $(DESTDIR)$(BINDIR)/$(OUTFILE)
     59
     60install-dev:
     61        mkdir -p $(DESTDIR)$(INCLUDEDIR)
     62        install -m 0644 $(headers) $(DESTDIR)$(INCLUDEDIR)
     63        mkdir -p $(DESTDIR)$(PCDIR)
     64        install -m 0644 bitlbee.pc $(DESTDIR)$(PCDIR)
     65
     66uninstall-dev:
     67        rm -f $(foreach hdr,$(headers),$(DESTDIR)$(INCLUDEDIR)/$(hdr))
     68        -rmdir $(DESTDIR)$(INCLUDEDIR)
     69        rm -f $(DESTDIR)$(PCDIR)/bitlbee.pc
    5870
    5971install-etc:
  • bitlbee.c

    r5e713f6 r27ac72d  
    118118        if( global.conf->runmode == RUNMODE_FORKDAEMON )
    119119                ipc_master_load_state();
     120
     121        if( global.conf->runmode == RUNMODE_DAEMON ||
     122                global.conf->runmode == RUNMODE_FORKDAEMON )
     123                ipc_master_listen_socket();
    120124       
    121125        if( ( fp = fopen( global.conf->pidfile, "w" ) ) )
  • bitlbee.h

    r5e713f6 r27ac72d  
    102102#include "storage.h"
    103103#include "set.h"
    104 #include "protocols/nogaim.h"
     104#include "nogaim.h"
    105105#include "commands.h"
    106106#include "account.h"
  • configure

    r5e713f6 r27ac72d  
    1515config='/var/lib/bitlbee/'
    1616pidfile='/var/run/bitlbee.pid'
     17ipcsocket='/var/run/bitlbee'
    1718plugindir='$prefix/lib/bitlbee'
     19pcdir='$prefix/lib/pkgconfig'
     20includedir='$prefix/include/bitlbee'
    1821
    1922msn=1
     
    4952--pidfile=...                                           $pidfile
    5053--config=...                                            $config
     54--ipcsocket=...                                         $ipcsocket
    5155
    5256--msn=0/1       Disable/enable MSN part                 $msn
     
    7680config=`eval echo "$config/" | sed 's/\/\{1,\}/\//g'`
    7781plugindir=`eval echo "$plugindir/" | sed 's/\/\{1,\}/\//g'`
    78 pidfile=`eval echo "$pidfile/" | sed 's/\/\{1,\}/\//g'`
     82pidfile=`eval echo "$pidfile" | sed 's/\/\{1,\}/\//g'`
     83ipcsocket=`eval echo "$ipcsocket" | sed 's/\/\{1,\}/\//g'`
     84includedir=`eval echo "$includedir" | sed 's/\/\{1,\}/\//g'`
     85pcdir=`eval echo "$pcdir" | sed 's/\/\{1,\}/\//g'`
    7986
    8087cat<<EOF>Makefile.settings
     
    8693DATADIR=$datadir
    8794PLUGINDIR=$plugindir
    88 PIDFILE=$pidfile
    8995CONFIG=$config
     96IPCSOCKET=$ipcsocket
     97INCLUDEDIR=$includedir
     98PCDIR=$pcdir
    9099
    91100ARCH=$arch
     
    109118#define PLUGINDIR "$plugindir"
    110119#define PIDFILE "$pidfile"
     120#define IPCSOCKET "$ipcsocket"
    111121#define ARCH "$arch"
    112122#define CPU "$cpu"
     
    307317fi
    308318
     319cat <<EOF>bitlbee.pc
     320prefix=$prefix
     321includedir=$includedir
     322
     323Name: bitlbee
     324Description: IRC to IM gateway
     325Requires: glib-2.0
     326Version: $BITLBEE_VERSION
     327Libs:
     328Cflags: -I\${includedir}
     329
     330EOF
     331
    309332protocols=''
    310333protoobjs=''
  • doc/example_plugin.c

    r5e713f6 r27ac72d  
    33 * a shared library and place it in the plugin directory:
    44 *
    5  * gcc -o example.so -shared example.c
     5 * gcc -o example.so -shared example.c `pkg-config --cflags bitlbee`
    66 * cp example.so /usr/local/lib/bitlbee
    77 */
    88#include <stdio.h>
     9#include <bitlbee.h>
    910
    1011void init_plugin(void)
  • ipc.c

    r5e713f6 r27ac72d  
    2828#include "ipc.h"
    2929#include "commands.h"
     30#ifndef _WIN32
     31#include <sys/un.h>
     32#endif
    3033
    3134GSList *child_list = NULL;
     
    461464}
    462465
     466
     467static gboolean new_ipc_client (GIOChannel *gio, GIOCondition cond, gpointer data)
     468{
     469        struct bitlbee_child *child = g_new0( struct bitlbee_child, 1 );
     470        int serversock;
     471
     472        serversock = g_io_channel_unix_get_fd(gio);
     473
     474        child->ipc_fd = accept(serversock, NULL, 0);
     475
     476        if (child->ipc_fd == -1) {
     477                log_message( LOGLVL_WARNING, "Unable to accept connection on UNIX domain socket: %s", strerror(errno) );
     478                return TRUE;
     479        }
     480               
     481        child->ipc_inpa = gaim_input_add( child->ipc_fd, GAIM_INPUT_READ, ipc_master_read, child );
     482               
     483        child_list = g_slist_append( child_list, child );
     484
     485        return TRUE;
     486}
     487
     488#ifndef _WIN32
     489int ipc_master_listen_socket()
     490{
     491        struct sockaddr_un un_addr;
     492        int serversock;
     493        GIOChannel *gio;
     494
     495        /* Clean up old socket files that were hanging around.. */
     496        if (unlink(IPCSOCKET) == -1 && errno != ENOENT) {
     497                log_message( LOGLVL_ERROR, "Could not remove old IPC socket at %s: %s", IPCSOCKET, strerror(errno) );
     498                return 0;
     499        }
     500
     501        un_addr.sun_family = AF_UNIX;
     502        strcpy(un_addr.sun_path, IPCSOCKET);
     503
     504        serversock = socket(AF_UNIX, SOCK_STREAM, PF_UNIX);
     505
     506        if (serversock == -1) {
     507                log_message( LOGLVL_WARNING, "Unable to create UNIX socket: %s", strerror(errno) );
     508                return 0;
     509        }
     510
     511        if (bind(serversock, &un_addr, sizeof(un_addr)) == -1) {
     512                log_message( LOGLVL_WARNING, "Unable to bind UNIX socket to %s: %s", IPCSOCKET, strerror(errno) );
     513                return 0;
     514        }
     515
     516        if (listen(serversock, 5) == -1) {
     517                log_message( LOGLVL_WARNING, "Unable to listen on UNIX socket: %s", strerror(errno) );
     518                return 0;
     519        }
     520       
     521        gio = g_io_channel_unix_new(serversock);
     522       
     523        if (gio == NULL) {
     524                log_message( LOGLVL_WARNING, "Unable to create IO channel for unix socket" );
     525                return 0;
     526        }
     527
     528        g_io_add_watch(gio, G_IO_IN, new_ipc_client, NULL);
     529        return 1;
     530}
     531#else
     532        /* FIXME: Open named pipe \\.\BITLBEE */
     533#endif
     534
    463535int ipc_master_load_state()
    464536{
  • ipc.h

    r5e713f6 r27ac72d  
    5757void ipc_master_set_statefile( char *fn );
    5858int ipc_master_load_state();
    59 
     59int ipc_master_listen_socket();
    6060
    6161extern GSList *child_list;
Note: See TracChangeset for help on using the changeset viewer.