summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUwe Hermann <uwe@hermann-uwe.de>2012-01-23 19:58:06 +0100
committerUwe Hermann <uwe@hermann-uwe.de>2012-01-23 19:58:06 +0100
commit9d9fcb375d7702082146bf917a5d19cc83480eae (patch)
tree629b1160bf21fe61b7655a531e65c9d120f79188
parentbe873260307fb879200ace642c15164c39234007 (diff)
downloadlibsigrokdecode-9d9fcb375d7702082146bf917a5d19cc83480eae.tar.gz
libsigrokdecode-9d9fcb375d7702082146bf917a5d19cc83480eae.zip
srd: Prepend (not append) PD dirs to sys.path.
-rw-r--r--controller.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/controller.c b/controller.c
index 845208a..f3c1446 100644
--- a/controller.c
+++ b/controller.c
@@ -118,10 +118,19 @@ int srd_exit(void)
/**
- * Add search directories for the protocol decoders.
+ * Add an additional search directory for the protocol decoders.
+ *
+ * The specified directory is prepended (not appended!) to Python's sys.path,
+ * in order to search for sigrok protocol decoders in the specified
+ * directories first, and in the generic Python module directories (and in
+ * the current working directory) last. This avoids conflicts if there are
+ * Python modules which have the same name as a sigrok protocol decoder in
+ * sys.path or in the current working directory.
*
* TODO: add path from env var SIGROKDECODE_PATH, config etc
* TODO: Should take directoryname/path as input.
+ *
+ * @return TODO.
*/
int set_modulepath(void)
{
@@ -143,9 +152,8 @@ int set_modulepath(void)
path = g_strdup(DECODERS_DIR);
#endif
- /* TODO: Prepend instead of appending. */
/* TODO: Sanity check on 'path' (length, escape special chars, ...). */
- s = g_strdup_printf("import sys; sys.path.append(r'%s')", path);
+ s = g_strdup_printf("import sys; sys.path.insert(0, r'%s')", path);
ret = PyRun_SimpleString(s);