Mercurial > hg > octave-lyh
annotate scripts/miscellaneous/inputname.m @ 11523:fd0a3ac60b0e
update copyright notices
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Fri, 14 Jan 2011 05:47:45 -0500 |
parents | d90736774da2 |
children | 1e4dfc7a9487 |
rev | line source |
---|---|
11523 | 1 ## Copyright (C) 2004-2011 Paul Kienzle |
5837 | 2 ## |
3 ## This file is part of Octave. | |
4 ## | |
7016 | 5 ## Octave is free software; you can redistribute it and/or modify it |
6 ## under the terms of the GNU General Public License as published by | |
7 ## the Free Software Foundation; either version 3 of the License, or (at | |
8 ## your option) any later version. | |
9 ## | |
10 ## Octave is distributed in the hope that it will be useful, but | |
11 ## WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 ## General Public License for more details. | |
14 ## | |
15 ## You should have received a copy of the GNU General Public License | |
16 ## along with Octave; see the file COPYING. If not, see | |
17 ## <http://www.gnu.org/licenses/>. | |
18 ## | |
19 ## Original version by Paul Kienzle distributed as free software in the | |
20 ## public domain. | |
5837 | 21 |
22 ## -*- texinfo -*- | |
23 ## @deftypefn {Function File} {} inputname (@var{n}) | |
10091
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
24 ## Return the name of the @var{n}-th argument to the calling function. |
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
25 ## If the argument is not a simple variable name, return an empty string. |
5837 | 26 ## @end deftypefn |
27 | |
28 function s = inputname (n) | |
7125 | 29 |
10091
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
30 if (nargin == 1) |
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
31 s = evalin ("caller", sprintf ("deblank (argn(%d,:));", n)); |
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
32 ## For compatibility with Matlab, return empty string if argument |
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
33 ## name is not a valid identifier. |
10093
d90736774da2
inputname: use isvarname instead of regexp
John W. Eaton <jwe@octave.org>
parents:
10091
diff
changeset
|
34 if (! isvarname (s)) |
10091
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
35 s = ""; |
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
36 endif |
a115046d462d
inputname: compatibility fix
John W. Eaton <jwe@octave.org>
parents:
7125
diff
changeset
|
37 else |
7125 | 38 print_usage (); |
39 endif | |
40 | |
5837 | 41 endfunction |
42 | |
43 ## Warning: heap big magic in the following tests!!! | |
44 ## The test function builds a private context for each | |
45 ## test, with only the specified values shared between | |
46 ## them. It does this using the following template: | |
47 ## | |
48 ## function [<shared>] = testfn(<shared>) | |
49 ## <test> | |
50 ## | |
51 ## To test inputname, I need a function context invoked | |
52 ## with known parameter names. So define a couple of | |
53 ## shared parameters, et voila!, the test is trivial. | |
54 %!shared hello,worldly | |
55 %!assert(inputname(1),'hello'); | |
56 %!assert(inputname(2),'worldly'); |