Merge fix for logging of mode changes by charly.
[jelmer/ctrlproxy.git] / Makefile
index 0de62323955d4f9cab643db6025fb955f094c1ce..121e5f31218e1f4ecc9af11561be650e5731053a 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,5 +1,5 @@
 # Makefile for ctrlproxy
-# Copyright (C) 2002-2008 Jelmer Vernooij <jelmer@samba.org>
+# Copyright (C) 2002-2009 Jelmer Vernooij <jelmer@samba.org>
 # NOTE: This file is *NOT* autogenerated.
 
 include Makefile.settings
@@ -18,48 +18,36 @@ LIBS += $(GNUTLS_LIBS)
 CFLAGS += $(GNUTLS_CFLAGS)
 
 CFLAGS+=-DHAVE_CONFIG_H -DDEFAULT_CONFIG_DIR=\"$(DEFAULT_CONFIG_DIR)\" -DHELPFILE=\"$(HELPFILE)\"
-CFLAGS+=-ansi -Wall -DMODULESDIR=\"$(modulesdir)\" -DSTRICT_MEMORY_ALLOCS=
-
-LIBIRC_STATIC = libirc.a
-LIBIRC = $(LIBIRC_STATIC)
-
-LIBIRC_SHARED = libirc.$(SHLIBEXT).$(PACKAGE_VERSION)
-LIBIRC_SOVERSION = 1.0
-LIBIRC_SONAME = libirc.$(SHLIBEXT).$(LIBIRC_SOVERSION)
+CFLAGS+=-DMODULESDIR=\"$(modulesdir)\" -DSTRICT_MEMORY_ALLOCS=
 
 .PHONY: all clean distclean install install-bin install-dirs install-doc install-data install-pkgconfig
 
-all: $(BINS) $(SBINS)
+all:: $(BINS) $(SBINS)
+
+ifeq ($(HAVE_PYTHON),yes)
+check:: check-python
+all:: python
+endif
 
 experimental:: all 
 
 doxygen:
        doxygen
 
-lib_objs = \
-          lib/state.o \
-          lib/client.o \
-          lib/transport.o \
-          lib/line.o \
-          lib/isupport.o \
-          lib/connection.o \
-          lib/url.o \
-          lib/util.o \
-          lib/listener.o
+libircdir = libirc
+include $(libircdir)/Makefile
 
 objs = src/posix.o \
+          src/redirect.o \
           src/cache.o \
           src/util.o \
           src/hooks.o \
-          src/linestack.o \
           src/plugins.o \
           src/settings.o \
           src/log.o \
           src/client.o \
-          src/redirect.o \
           src/gen_config.o \
           src/repl.o \
-          src/linestack_file.o \
           src/ctcp_redirect.o \
           src/ctcp.o \
           src/motd.o \
@@ -75,23 +63,13 @@ objs = src/posix.o \
           src/log_subst.o \
           src/auto_away.o \
           src/network.o \
-          $(SSL_OBJS)
-
-lib_headers = \
-                 lib/state.h \
-                 lib/client.h \
-                 lib/line.h \
-                 lib/isupport.h \
-                 lib/irc.h \
-                 lib/connection.h \
-                 lib/url.h \
-                 lib/listener.h
+          $(CTRLPROXY_SSL_OBJS)
+all_objs += $(objs)
 
 headers = src/admin.h \
                  src/ctcp.h \
                  src/ctrlproxy.h \
                  src/hooks.h \
-                 src/linestack.h \
                  src/log_support.h \
                  src/repl.h \
                  src/settings.h \
@@ -100,13 +78,9 @@ headers = src/admin.h \
                  src/cache.h
 dep_files = $(patsubst %.o, %.d, $(objs))
 
-linestack-cmd$(EXEEXT): src/linestack-cmd.o $(objs) $(LIBIRC)
-       @echo Linking $@
-       @$(LD) $(LIBS) -lreadline -rdynamic -o $@ $^
-
 ctrlproxy$(EXEEXT): src/main.o $(objs) $(LIBIRC)
-       @echo Linking $@
-       @$(LD) $(LDFLAGS) -rdynamic -o $@ $^ $(LIBS)
+       @echo Linking $@: $(LD) $(LDFLAGS) -rdynamic -o $@ $^ $(LIBS)
+       @$(LD) $(LDFLAGS) $(DYNAMIC) -o $@ $^ $(LIBS)
 
 src/settings.o: CFLAGS+=-DSYSCONFDIR=\"${sysconfdir}\"
 
@@ -118,18 +92,18 @@ daemon_objs += daemon/main.o daemon/user.o daemon/client.o daemon/backend.o
 
 ctrlproxyd$(EXEEXT): $(daemon_objs) $(objs) $(LIBIRC)
        @echo Linking $@
-       @$(LD) $(LDFLAGS) -rdynamic -o $@ $^ $(LIBS)
+       @$(CC) $(LDFLAGS) $(DYNAMIC) -o $@ $^ $(LIBS)
 
 ctrlproxy-admin$(EXEEXT): src/admin-cmd.o
        @echo Linking $@
-       @$(LD) $(LDFLAGS) -rdynamic -o $@ $^ $(LIBS)
+       @$(CC) $(LDFLAGS) $(DYNAMIC) -o $@ $^ $(LIBS)
 
 %.o: %.c
        @echo Compiling $<
-       @$(CC) -I. -Ilib -Isrc $(CFLAGS) $(GCOV_CFLAGS) -c $< -o $@
+       @$(CC) -I. -I$(libircdir) -Isrc $(CFLAGS) $(GCOV_CFLAGS) -c $< -o $@
 
 %.d: %.c config.h
-       @$(CC) -I. -Ilib -Isrc -M -MT $(<:.c=.o) $(CFLAGS) $< -o $@
+       @$(CC) -I. -I$(libircdir) -Isrc -M -MT $(<:.c=.o) $(CFLAGS) $(PYTHON_CFLAGS) $< -o $@
 
 # This looks a bit weird but is here to ensure that we never try to 
 # run ./autogen.sh outside of bzr checkouts
@@ -164,12 +138,12 @@ install-bin:
        $(INSTALL) $(SBINS) $(DESTDIR)$(sbindir)
 
 uninstall-header:
-       -rm -f $(patsubst %,$(DESTDIR)$(destincludedir)/%,$(notdir $(headers) $(lib_headers)))
+       -rm -f $(patsubst %,$(DESTDIR)$(destincludedir)/%,$(notdir $(headers) $(libirc_headers)))
        -rmdir $(DESTDIR)$(destincludedir)
 
 install-header::
        $(INSTALL) -d $(DESTDIR)$(destincludedir)
-       $(INSTALL) -m 0644 $(lib_headers) $(headers) $(DESTDIR)$(destincludedir)
+       $(INSTALL) -m 0644 $(libirc_headers) $(headers) $(DESTDIR)$(destincludedir)
 
 doc::
        $(MAKE) -C doc PACKAGE_VERSION=$(PACKAGE_VERSION)
@@ -209,24 +183,19 @@ lcov:
        lcov --base-directory `pwd` --directory . --capture --output-file ctrlproxy.info
        genhtml -o coverage ctrlproxy.info
 
-$(LIBIRC_STATIC): $(lib_objs)
+%.$(SHLIBEXT):
        @echo Linking $@
-       @ar -rcs $@ $^
-
-$(LIBIRC_SHARED): $(lib_objs)
-       $(LD) -shared $(LDFLAGS) -Wl,-soname,$(LIBIRC_SONAME) -o $@ $^
+       @$(CC) -shared $(LDFLAGS) -o $@ $^
 
 cscope.out::
        cscope -b -R
 
 clean::
-       @echo Removing dependency files
-       @rm -f $(dep_files)
        @echo Removing object files and executables
-       @rm -f src/*.o lib/*.o daemon/*.o testsuite/check ctrlproxy$(EXEEXT) testsuite/*.o *~
-       @rm -f linestack-cmd$(EXEEXT) ctrlproxy-admin$(EXEEXT)
+       @rm -f src/*.o daemon/*.o python/*.o testsuite/check ctrlproxy$(EXEEXT) testsuite/*.o *~
+       @rm -f ctrlproxy-admin$(EXEEXT)
        @rm -f ctrlproxyd$(EXEEXT)
-       @rm -f $(LIBIRC_STATIC) $(LIBIRC_SHARED)
+       @rm -f mods/*.$(SHLIBEXT) mods/*.o
        @echo Removing gcov output
        @rm -f *.gcov *.gcno *.gcda  */*.gcda */*.gcno */*.gcov
        @echo Removing test output
@@ -247,6 +216,25 @@ realclean:: distclean
 ctags:
        ctags -R .
 
+# Python specific stuff below this line
+mods/python.o python/ctrlproxy.o: CFLAGS+=$(PYTHON_CFLAGS)
+mods/python.o python/ctrlproxy.o: CFLAGS+=-fPIC
+mods/libpython.so: mods/python.o python/ctrlproxy.o $(pyirc_objs)
+mods/libpython.so: LDFLAGS+=$(PYTHON_LDFLAGS)
+
+ifeq ($(HAVE_PYTHON),yes)
+all_objs += $(pyirc_objs) mods/python.o python/ctrlproxy.o
+endif
+
+python:: mods/libpython.$(SHLIBEXT)
+
+install-python: all
+       $(PYTHON) setup.py install --root="$(DESTDIR)"
+
+clean::
+       @rm -f python/tests/*.pyc
+#      $(PYTHON) setup.py clean
+
 # RFC compliance testing using ircdtorture
 
 TEST_SERVER := localhost
@@ -285,4 +273,21 @@ check-nofork::
 check-gdb: 
        $(MAKE) check-nofork DEBUGGER="gdb --args"
 
+clean::
+       @echo Removing dependency files
+       @rm -f $(dep_files)
+
+examples:: example/libfoo.$(SHLIBEXT) example/libirc-simple
+
+example/libfoo.$(SHLIBEXT): example/foo.o
+example/foo.o: CFLAGS+=-I$(libircdir)
+
+example/libirc-simple: example/irc_simple.o $(LIBIRC)
+       @Linking $@
+       @$(CC) -o $@ $^
+
+example/irc_simple.o: CFLAGS+=-I$(libircdir)
+
+ifeq ($(GCC),yes)
 -include $(dep_files)
+endif