aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/Makefile12
-rw-r--r--src/a2l.c4
-rw-r--r--src/alias11
-rwxr-xr-xsrc/makealias.sh90
4 files changed, 114 insertions, 3 deletions
diff --git a/src/Makefile b/src/Makefile
index 44d4ec9..9ded18f 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -89,7 +89,17 @@ distclean: realclean
tests: all
make -C $(TESTDIR)
-install: install-abs install-bin install-doc
+alias: alias-bin alias-abs
+
+alias-bin: all
+ ./makealias.sh ../src/alias ../src ../reference
+
+
+alias-abs:
+ ./makealias.sh ../abs/alias ../abs
+
+
+install: all install-abs install-bin install-doc
install-bin:
-install -d $(INSTALL_BIN)
diff --git a/src/a2l.c b/src/a2l.c
index 65847ac..aff11f7 100644
--- a/src/a2l.c
+++ b/src/a2l.c
@@ -73,9 +73,9 @@ static void *a2l_new(void)
void a2l_setup(void)
{
- a2l_class = class_new(gensym("any2list"), (t_newmethod)a2l_new,
+ a2l_class = class_new(gensym("a2l"), (t_newmethod)a2l_new,
0, sizeof(t_a2l), 0, 0);
- class_addcreator((t_newmethod)a2l_new, gensym("a2l"), 0);
+ class_addcreator((t_newmethod)a2l_new, gensym("any2list"), 0);
class_addbang (a2l_class, a2l_bang);
diff --git a/src/alias b/src/alias
new file mode 100644
index 0000000..22fab27
--- /dev/null
+++ b/src/alias
@@ -0,0 +1,11 @@
+a2l any2list
+demultiplex~ demux~
+demultiplex demux
+drip unfold
+list2int l2i
+list2symbol l2s
+lister l
+lpt lp
+multiplex~ mux~
+multiplex mux
+symbol2list s2l
diff --git a/src/makealias.sh b/src/makealias.sh
new file mode 100755
index 0000000..4617bc9
--- /dev/null
+++ b/src/makealias.sh
@@ -0,0 +1,90 @@
+#!/bin/sh
+
+EXTENSIONS=".pd -help.pd .pd_linux .pd_darwin .pd_freebsd .dll .b_i386 .l_ia64 .l_i386 .d_fat .d_i386 .d_ppc .m_i386"
+
+ALIASFILE=$1
+shift
+
+if [ "x$ALIASFILE" = "x-clean" ]
+then
+ CLEANMODE=yes
+ ALIASFILE=$1
+ shift
+else
+ CLEANMODE=
+fi
+
+
+if [ -e "${ALIASFILE}" ]; then :; else
+ echo cannot find alias-file ${ALIASFILE}
+ exit 1
+fi
+
+
+function debug() {
+ :
+# echo $@
+}
+
+function do_makealias() {
+ if [ "x${CLEANMODE}" = "xyes" ]
+ then
+ if [ -e "$2" ]; then
+ debug "removing alias $2"
+ rm $2
+ else
+ debug "alias $2 does not exist"
+ fi
+ else
+ debug "aliasing $1 to $2"
+ ln -s $1 $2
+ fi
+}
+
+function do_makealiases() {
+ local dir
+ local master
+ local slave
+ local extension
+
+ dir=$1
+ master=$2
+ shift; shift
+
+ if [ "x${master}" = "x" ]; then
+ # no realname provided
+ return
+ fi
+
+ if [ "x$@" = "x" ]; then
+ # no aliases provided...
+ return
+ fi
+
+ for extension in ${EXTENSIONS}
+ do
+# echo "checking aliases for ${dir}/${master}${extension}"
+ if [ -f "${dir}/${master}${extension}" ]
+ then
+ for slave in $@
+ do
+ do_makealias ${dir}/${master}${extension} ${dir}/${slave}${extension}
+ done
+ fi
+ done
+}
+
+for d in $@
+do
+ if [ -d "$d" ]
+ then
+ debug "scanning directory $d for aliases"
+ cat ${ALIASFILE} | while read line
+ do
+ do_makealiases $d $line
+ done
+ else
+ echo "skipping non-directory $d"
+ fi
+done
+