Mercurial > hg > octave-nkf
view scripts/miscellaneous/inputname.m @ 16772:7eff3032d144
Fix seealso HTML links when using Texinfo 4.X (bug #38862).
Use the prefix 'docX' instead of 'doc-' for Texinfo references.
* doc/interpreter/arith.txi, doc/interpreter/basics.txi,
doc/interpreter/container.txi, doc/interpreter/func.txi,
doc/interpreter/java.txi, doc/interpreter/matrix.txi,
doc/interpreter/munge-texi.pl, doc/interpreter/package.txi,
doc/interpreter/plot.txi, doc/interpreter/stats.txi,
doc/interpreter/strings.txi, doc/interpreter/system.txi,
doc/interpreter/var.txi, doc/interpreter/vectorize.txi,
libinterp/corefcn/qz.cc, libinterp/corefcn/regexp.cc,
libinterp/interpfcn/error.cc, scripts/general/accumarray.m,
scripts/general/structfun.m, scripts/miscellaneous/setfield.m,
scripts/optimization/fminbnd.m, scripts/optimization/fzero.m,
scripts/optimization/lsqnonneg.m:
Use the prefix 'docX' instead of 'doc-' for Texinfo references.
author | Rik <rik@octave.org> |
---|---|
date | Tue, 18 Jun 2013 20:35:12 -0700 |
parents | f3d52523cde1 |
children | d63878346099 |
line wrap: on
line source
## Copyright (C) 2004-2012 Paul Kienzle ## ## This file is part of Octave. ## ## Octave 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 3 of the License, or (at ## your option) any later version. ## ## Octave 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 Octave; see the file COPYING. If not, see ## <http://www.gnu.org/licenses/>. ## ## Original version by Paul Kienzle distributed as free software in the ## public domain. ## -*- texinfo -*- ## @deftypefn {Function File} {} inputname (@var{n}) ## Return the name of the @var{n}-th argument to the calling function. ## If the argument is not a simple variable name, return an empty string. ## @end deftypefn function s = inputname (n) if (nargin == 1) s = evalin ("caller", sprintf ("__varval__ (\".argn.\"){%d};", n)); ## For compatibility with Matlab, return empty string if argument ## name is not a valid identifier. if (! isvarname (s)) s = ""; endif else print_usage (); endif endfunction ## Warning: heap big magic in the following tests!!! ## The test function builds a private context for each ## test, with only the specified values shared between ## them. It does this using the following template: ## ## function [<shared>] = testfn(<shared>) ## <test> ## ## To test inputname, I need a function context invoked ## with known parameter names. So define a couple of ## shared parameters, et voila!, the test is trivial. %!shared hello, worldly %!assert (inputname (1), "hello") %!assert (inputname (2), "worldly")