# HG changeset patch # User jwe # Date 1144220185 0 # Node ID d090d39bb82c95826cf9cb7ceabfdf55f06f5390 # Parent 126d7f1945eee386adaa592b46a75e3ebf91a1e9 [project @ 2006-04-05 06:56:24 by jwe] diff --git a/src/ChangeLog b/src/ChangeLog --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,14 @@ +2006-04-05 John W. Eaton + + * Makefile.in (mk-pkg-add): Use mfilename to simplify. + (PKG_ADD): Don't pass --prefix arg to mk-pkg-add. + (PKG_ADD.inst): Delete target. + (clean): Don't remove PKG_ADD.inst. + (install-oct): Don't depend on PKG_ADD.inst. Install PKG_ADD, not + PKG_ADD.inst. + + * parse.y (Fmfilename): New function. + 2006-04-04 David Bateman * help.cc (Flookfor): Skip overloaded functions. Lookup help text diff --git a/src/Makefile.in b/src/Makefile.in --- a/src/Makefile.in +++ b/src/Makefile.in @@ -345,11 +345,7 @@ @$(top_srcdir)/move-if-change $@-t $@ PKG_ADD: $(DLD_DEF_FILES) - $(srcdir)/mk-pkg-add --prefix $(shell pwd) $(DLD_DEF_FILES) > $@-t - mv $@-t $@ - -PKG_ADD.inst: $(srcdir)/mk-pkg-add $(DLD_DEF_FILES) - $(srcdir)/mk-pkg-add --install $(DLD_DEF_FILES) > $@-t + $(srcdir)/mk-pkg-add $(DLD_DEF_FILES) > $@-t mv $@-t $@ DOCSTRINGS: gendoc$(BUILD_EXEEXT) @@ -402,9 +398,9 @@ cd $(DESTDIR)$(bindir) ; $(LN_S) octave-$(version)$(EXEEXT) octave$(EXEEXT) .PHONY: install-bin -install-oct: PKG_ADD.inst +install-oct: $(top_srcdir)/mkinstalldirs $(DESTDIR)$(octfiledir) - $(INSTALL_DATA) PKG_ADD.inst $(DESTDIR)$(octfiledir)/PKG_ADD + $(INSTALL_DATA) PKG_ADD $(DESTDIR)$(octfiledir)/PKG_ADD if [ -n "$(OCT_FILES)" ]; then \ xfiles="$(OCT_FILES)"; \ for f in $$xfiles; do \ @@ -478,7 +474,6 @@ rm -f $(PICOBJ) $(DLD_PICOBJ) stmp-pic gendoc$(EXEEXT) rm -f builtins.cc ops.cc defaults.h oct-conf.h def-files var-files rm -f PKG_ADD - rm -f PKG_ADD.inst -rmdir pic .PHONY: clean diff --git a/src/mk-pkg-add b/src/mk-pkg-add --- a/src/mk-pkg-add +++ b/src/mk-pkg-add @@ -2,26 +2,6 @@ SED=${SED:-'sed'} -install=false -if [ $1 = "--prefix" ]; then - shift - prefix="$1" - shift -elif [ $1 = "--install" ]; then - install=true - shift -fi - -if [ $# -gt 0 ]; then - if $install; then - cat < 1) + { + print_usage ("mfilename"); + return retval; + } + + std::string arg; + + if (nargin == 1) + { + arg = args(0).string_value (); + + if (error_state) + { + error ("mfilename: expecting argument to be a character string"); + return retval; + } + } + + std::string fname; + + if (curr_caller_function) + fname = curr_caller_function->fcn_file_name (); + + if (arg == "fullpathext") + retval = fname; + else + { + size_t pos = fname.rfind ('.'); + + fname = (pos != NPOS) ? fname.substr (0, pos) : fname; + + if (arg == "fullpath") + retval = fname; + else + { + pos = fname.rfind (file_ops::dir_sep_char); + + retval = (pos != NPOS) ? fname.substr (pos+1) : fname; + } + } + + return retval; +} + + DEFUN (source, args, , "-*- texinfo -*-\n\ @deftypefn {Built-in Function} {} source (@var{file})\n\