]> git.0d.be Git - empathy.git/commitdiff
Run from the source directory without installing
authorEmanuele Aina <emanuele.aina@collabora.com>
Mon, 5 Mar 2012 23:04:51 +0000 (00:04 +0100)
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>
Tue, 6 Mar 2012 15:14:47 +0000 (16:14 +0100)
Use the tools/empathy-env wrapper to set an appropriate environment
and launch the compiled programs without installing them.

https://bugzilla.gnome.org/show_bug.cgi?id=671447

HACKING
data/.gitignore
data/Makefile.am
tools/.gitignore
tools/Makefile.am
tools/empathy-env.in [new file with mode: 0644]

diff --git a/HACKING b/HACKING
index bae9b0b81a542de9998ea59aa14d9d36c8832432..b486e3370e72831079ef4e550cfc6c482d263494 100644 (file)
--- a/HACKING
+++ b/HACKING
@@ -6,16 +6,16 @@ Empathy is split in different processes:
 - src/empathy-debugger: debug tool
 
 Each process can be run directly from source without having to be installed to
-its prefix. You just have to define the environment variable EMPATHY_SRCDIR
-to the path of your empathy source dir. For example:
-  export EMPATHY_SRCDIR=/home/cassidy/gnome/empathy
+its prefix. You just have to define an appropriate environment using the
+wrapper found in the tools/ directory.. For example:
+  ./tools/empathy-env ./src/empathy
 
 The chat and call UI are automatically started by telepathy-mission-control
 when receiving or requesting a chat/call. In order to use your custom version
 you have to kill any existing instance of empathy-{chat,call} and then start
 it with EMPATHY_PERSIST=1 to prevent it from auto exiting if there is no
 channel to handle. For example:
-  EMPATHY_PERSIST=1 ./src/empathy-chat
+  EMPATHY_PERSIST=1 ./tools/empathy-env ./src/empathy-chat
 
 Debugging can be turned on using EMPATHY_DEBUG=all and logged to a file
 with EMPATHY_LOGFILE=/tmp/empathy.log
index e004da8edb0c22fef1dbffc35f008ce0bc290cb8..2c0f33226f8585a81aff05c9e8f815d2796c293b 100644 (file)
@@ -2,6 +2,7 @@ empathy.desktop
 empathy.desktop.in
 org.gnome.Empathy.gschema.valid
 org.gnome.Empathy.gschema.xml
+gschemas.compiled
 org.freedesktop.Telepathy.Client.Empathy.Chat.service
 org.freedesktop.Telepathy.Client.Empathy.AudioVideo.service
 org.freedesktop.Telepathy.Client.Empathy.Call.service
index f3da574ae772485489c3509a501147315c45ae04..a2be750cfe7f0cc76fecbfbf942de4c81885a9af 100644 (file)
@@ -15,6 +15,13 @@ gsettings_SCHEMAS = $(gsettings_files:.xml.in=.xml)
 @INTLTOOL_XML_NOMERGE_RULE@
 @GSETTINGS_RULES@
 
+# We need to compile schemas at make time
+# to run from source tree
+gschemas.compiled: $(gsettings_SCHEMAS:.xml=.valid)
+       $(AM_V_GEN) $(GLIB_COMPILE_SCHEMAS) --targetdir=. .
+
+all-local: gschemas.compiled
+
 convertdir = $(datarootdir)/GConf/gsettings
 convert_DATA = \
        empathy.convert
@@ -82,4 +89,5 @@ DISTCLEANFILES =              \
        $(schemas_DATA)         \
        $(servicefile_DATA)     \
        $(gsettings_SCHEMAS)    \
+       gschemas.compiled       \
        $(NULL)
index 2578e98833d3e37d28838bda5875513733416511..d6ba5d9dc90c05ddcf05da0326e41bbbb195df93 100644 (file)
@@ -1,3 +1,4 @@
 _gen
 extensions.html
 telepathy-glib-env
+empathy-env
index 96cc60f58924e6a7d2b7cad60823a49d70a10d3a..49bcb04b52bc44d536dc0b0779f032c88accfc79 100644 (file)
@@ -1,11 +1,15 @@
 abs_top_builddir = @abs_top_builddir@
 
-noinst_SCRIPTS = telepathy-glib-env
+noinst_SCRIPTS = telepathy-glib-env empathy-env
 
 telepathy-glib-env: telepathy-glib-env.in Makefile
        sed -e 's![@]abs_top_builddir[@]!$(abs_top_builddir)!' $< > $@
        chmod +x $@
 
+empathy-env: empathy-env.in Makefile
+       sed -e 's![@]abs_top_builddir[@]!$(abs_top_builddir)!' $< > $@
+       chmod +x $@
+
 EXTRA_DIST = \
     c-constants-gen.py \
     check-coding-style.mk \
@@ -34,6 +38,7 @@ EXTRA_DIST = \
     telepathy.am \
     telepathy-glib.supp \
     telepathy-glib-env.in \
+    empathy-env.in \
     test-wrapper.sh \
     with-session-bus.sh \
     xincludator.py
diff --git a/tools/empathy-env.in b/tools/empathy-env.in
new file mode 100644 (file)
index 0000000..3de4779
--- /dev/null
@@ -0,0 +1,9 @@
+#!/bin/sh
+abs_top_builddir="@abs_top_builddir@"
+export abs_top_builddir
+EMPATHY_SRCDIR=$abs_top_builddir
+export EMPATHY_SRCDIR
+GSETTINGS_SCHEMA_DIR="${EMPATHY_SRCDIR}/data/"
+export GSETTINGS_SCHEMA_DIR
+
+exec "$@"