From e2c6f2eea4792732e1dbb1873cf7860eb252c97a Mon Sep 17 00:00:00 2001 From: Luke Shumaker Date: Thu, 29 Oct 2009 22:00:30 -0400 Subject: rework rvs's build system, currently, it doesn't build :( it fails on the plugins, the wrapper works fine --- plugins/Makefile | 42 ------------------------ plugins/filedata/info.mk | 2 -- plugins/filedata/info.mk.in | 2 ++ plugins/files/info.mk | 2 -- plugins/files/info.mk.in | 2 ++ plugins/main.mk.in | 71 +++++++++------------------------------- plugins/plugin.mk.in | 79 +++++++++++++++++++++++++++++++++++++++++++++ plugins/users/info.mk | 2 -- plugins/users/info.mk.in | 2 ++ wrapper/main.mk.in | 2 +- wrapper/runcom.c | 15 ++++++--- 11 files changed, 111 insertions(+), 110 deletions(-) delete mode 100644 plugins/Makefile delete mode 100644 plugins/filedata/info.mk create mode 100644 plugins/filedata/info.mk.in delete mode 100644 plugins/files/info.mk create mode 100644 plugins/files/info.mk.in create mode 100644 plugins/plugin.mk.in delete mode 100644 plugins/users/info.mk create mode 100644 plugins/users/info.mk.in diff --git a/plugins/Makefile b/plugins/Makefile deleted file mode 100644 index 53ebc17..0000000 --- a/plugins/Makefile +++ /dev/null @@ -1,42 +0,0 @@ -#!/usr/bin/make -f -name=rvs plugins -#version='1.0' -# Copyright (C) 2009 Luke Shumaker -# -# This program is free software; you can redistribute it and/or -# modify it under the terms of the GNU General Public License as -# published by the Free Software Foundation; either version 2 of the -# License, or (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -# General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program; see the file COPYING. -# If not, see . - -# programs -SHELL = /bin/sh - -# variables -mods = $(patsubst ./%,%,$(shell find ./* -maxdepth 0 -type d)) - -.PHONY : all -all : build - -.PHONY : install build -install : $(addprefix install-,$(mods)) -build : $(addprefix build-,$(mods)) - -.SECONDARY: - -%/main.mk : main.mk %/; cp $< $@ - -complete-% : %/ %/main.mk -build-% : %/ complete-% %/main.mk; $(MAKE) -C $< -install-% : %/ complete-% %/main.mk; $(MAKE) -C $< install -clean-% : %/ complete-% %/main.mk; $(MAKE) -C $< clean -distclean-% : %/ complete-% %/main.mk; $(MAKE) -C $< distclean - diff --git a/plugins/filedata/info.mk b/plugins/filedata/info.mk deleted file mode 100644 index 77643cd..0000000 --- a/plugins/filedata/info.mk +++ /dev/null @@ -1,2 +0,0 @@ -name = filedata -ver = 0.9 diff --git a/plugins/filedata/info.mk.in b/plugins/filedata/info.mk.in new file mode 100644 index 0000000..77643cd --- /dev/null +++ b/plugins/filedata/info.mk.in @@ -0,0 +1,2 @@ +name = filedata +ver = 0.9 diff --git a/plugins/files/info.mk b/plugins/files/info.mk deleted file mode 100644 index d7ccb97..0000000 --- a/plugins/files/info.mk +++ /dev/null @@ -1,2 +0,0 @@ -name = files -ver = 0.9 diff --git a/plugins/files/info.mk.in b/plugins/files/info.mk.in new file mode 100644 index 0000000..d7ccb97 --- /dev/null +++ b/plugins/files/info.mk.in @@ -0,0 +1,2 @@ +name = files +ver = 0.9 diff --git a/plugins/main.mk.in b/plugins/main.mk.in index ed5dca8..8ffa1d7 100644 --- a/plugins/main.mk.in +++ b/plugins/main.mk.in @@ -1,7 +1,6 @@ #!/usr/bin/make -f -#name=rvs plugin Makefile -#ver=0.9 -include info.mk # this contains the actuall name/version for the plugin +#name=rvs plugins +#version='1.0' # Copyright (C) 2009 Luke Shumaker # # This program is free software; you can redistribute it and/or @@ -18,62 +17,22 @@ include info.mk # this contains the actuall name/version for the plugin # along with this program; see the file COPYING. # If not, see . -rvs = @name@ -id = $(name)-$(ver) +mods = $(patsubst ./%,%,$(shell find ./* -maxdepth 0 -type d)) -# phony targets #################################################### -all : $(name) -.PHONY : $(name) install uninstall clean distclean dist -.SUFFIXES : +.PHONY : all +all : build -# build ############################################################ -mysrcdir = $(srcdir)/plugins/$(name) -myoutdir = out +.PHONY : install build +install : $(addprefix install-,$(mods)) +build : $(addprefix build-,$(mods)) -srcFiles = $(filter-out %/Makefile.in,$(shell find $(mysrcdir)/ -type f)) +.SECONDARY: -shSrcFiles = $(filter %.sh,$(srcFiles)) -shOutFiles = $(patsubst $(mysrcdir)/%,$(myoutdir)/%,$(basename $(shSrcFiles))) +%/main.mk : plugin.mk %/; cp $< $@ -$(name) : $(myoutdir) $(shOutFiles) $(myoutdir)/plugin.conf - -$(myoutdir)/plugin.conf : $(mysrcdir)/plugin.conf - $(INSTALL_DATA) $< $@ - -# (un)install ###################################################### - -install : all - $(RVS) install $(name)-$(ver) $(myoutdir) - -uninstall : - $(RVS) uninstall $(name) - -# clean ############################################################ - -clean : - -distclean : clean - $(RM) Makefile - $(RM) -r out - -# implicit rules ################################################### - -b := @ -# build shell scripts -$(myoutdir)/% : $(mysrcdir)/%.sh $(myoutdir) - $(INSTALL_PROGRAM) $< $@ - $(SED) -i \ - -e 's/$bSHELL@/$(subst /,\/,$(SHELL))/g' \ - -e 's/$blibexecdir@/$(subst /,\/,$(libexecdir))/g' \ - -e 's/$bID@/$(subst /,\/,$(id))/g' \ - $@ - -plugin.conf : plugin.conf.in - $(SED) \ - -e 's/$bname@/$(subst /,\/,$(name))/g' \ - -e 's/$bver@/$(subst /,\/,$(ver))/g' \ - $< > $@ - -$(DESTDIR)$(libexecdir)/$(rvs) $(myoutdir) : - $(MKDIR) $@ +complete-% : %/ %/main.mk +build-% : %/ complete-% %/main.mk; $(MAKE) -C $< +install-% : %/ complete-% %/main.mk; $(MAKE) -C $< install +clean-% : %/ complete-% %/main.mk; $(MAKE) -C $< clean +distclean-% : %/ complete-% %/main.mk; $(MAKE) -C $< distclean diff --git a/plugins/plugin.mk.in b/plugins/plugin.mk.in new file mode 100644 index 0000000..ed5dca8 --- /dev/null +++ b/plugins/plugin.mk.in @@ -0,0 +1,79 @@ +#!/usr/bin/make -f +#name=rvs plugin Makefile +#ver=0.9 +include info.mk # this contains the actuall name/version for the plugin +# Copyright (C) 2009 Luke Shumaker +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License as +# published by the Free Software Foundation; either version 2 of the +# License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; see the file COPYING. +# If not, see . + +rvs = @name@ +id = $(name)-$(ver) + +# phony targets #################################################### +all : $(name) +.PHONY : $(name) install uninstall clean distclean dist +.SUFFIXES : + +# build ############################################################ +mysrcdir = $(srcdir)/plugins/$(name) +myoutdir = out + +srcFiles = $(filter-out %/Makefile.in,$(shell find $(mysrcdir)/ -type f)) + +shSrcFiles = $(filter %.sh,$(srcFiles)) +shOutFiles = $(patsubst $(mysrcdir)/%,$(myoutdir)/%,$(basename $(shSrcFiles))) + +$(name) : $(myoutdir) $(shOutFiles) $(myoutdir)/plugin.conf + +$(myoutdir)/plugin.conf : $(mysrcdir)/plugin.conf + $(INSTALL_DATA) $< $@ + +# (un)install ###################################################### + +install : all + $(RVS) install $(name)-$(ver) $(myoutdir) + +uninstall : + $(RVS) uninstall $(name) + +# clean ############################################################ + +clean : + +distclean : clean + $(RM) Makefile + $(RM) -r out + +# implicit rules ################################################### + +b := @ +# build shell scripts +$(myoutdir)/% : $(mysrcdir)/%.sh $(myoutdir) + $(INSTALL_PROGRAM) $< $@ + $(SED) -i \ + -e 's/$bSHELL@/$(subst /,\/,$(SHELL))/g' \ + -e 's/$blibexecdir@/$(subst /,\/,$(libexecdir))/g' \ + -e 's/$bID@/$(subst /,\/,$(id))/g' \ + $@ + +plugin.conf : plugin.conf.in + $(SED) \ + -e 's/$bname@/$(subst /,\/,$(name))/g' \ + -e 's/$bver@/$(subst /,\/,$(ver))/g' \ + $< > $@ + +$(DESTDIR)$(libexecdir)/$(rvs) $(myoutdir) : + $(MKDIR) $@ + diff --git a/plugins/users/info.mk b/plugins/users/info.mk deleted file mode 100644 index 8289128..0000000 --- a/plugins/users/info.mk +++ /dev/null @@ -1,2 +0,0 @@ -name = users -ver = 0.9 diff --git a/plugins/users/info.mk.in b/plugins/users/info.mk.in new file mode 100644 index 0000000..8289128 --- /dev/null +++ b/plugins/users/info.mk.in @@ -0,0 +1,2 @@ +name = users +ver = 0.9 diff --git a/wrapper/main.mk.in b/wrapper/main.mk.in index 7959612..7d9cc19 100644 --- a/wrapper/main.mk.in +++ b/wrapper/main.mk.in @@ -28,7 +28,7 @@ CFLAGS = -g \ -Dplugin_conf=\"plugin.conf\" # phony targets #################################################### -all : rvs runcom Makefiles +all : Makefiles rvs runcom .PHONY : install uninstall clean distclean dist install-runcom .SUFFIXES : .c .o VPATH = $(srcdir)/wrapper diff --git a/wrapper/runcom.c b/wrapper/runcom.c index 5928bb3..30603a2 100644 --- a/wrapper/runcom.c +++ b/wrapper/runcom.c @@ -41,15 +41,20 @@ main ( int argc, char *argv[] ) plugins=load_plugins(stdin); struct plugin_command_list *list; if ( strchr(argv[1],'/') == NULL ) + /* this is a normal command */ list=plugin_find_commands(plugins,argv[1]); else { /* this is a command for a specific plugin */ - list=xmalloc(sizeof(*list)); - list->command=plugin_depend_parse(stralloc(argv[1])); - list->next=NULL; + + list=xmalloc(sizeof(*list)); list->next=NULL; + + list->command=plugin_depend_parse( + // | command-name |plugins|ret if name==""| + stralloc(argv[1]),plugins,NULL); if ( list->command == NULL ) { - /* plugin_depend_parse should fail the program*\ - \* on its own, but just to be safe... */ + // `command->list' should be NULL if + // no plugin/command was found + // no command was specified (argv[1]=="") plugin_free_list(list); list=NULL; } -- cgit v1.2.3-2-g168b