Inputname statement - useful example

7 views (last 30 days)
Hi everyone,
could you help me to understand what is the useful of the inputname statement? I run the following example:
function c = somma(a, b)
disp(inputname(1))
c = a + b;
in workspace:
x = 1;
y = 2;
somma(x, y) %x is the result
From my example is not clear the useful of inputname. If you have a best example, let me know please.
Thank you.
  1 Comment
Stephen23
Stephen23 on 29 May 2017
Edited: Stephen23 on 29 May 2017
In general it is not useful: the names that variables have inside and outside of functions should be totally irrelevant from outside and inside respectively.

Sign in to comment.

Accepted Answer

Walter Roberson
Walter Roberson on 29 May 2017
inputname() is useful for giving error messages that reference variable names in the form the user knowns them.
  4 Comments
Gennaro Arguzzi
Gennaro Arguzzi on 29 May 2017
Walter, unfortunately matlab shows the following errors:
tryme(1)
Error using exist The optional second input to exist must be 'var', 'builtin', 'class', 'dir' or 'file'.
Error in tryme (line 2) if ~exist('var1', 'variable') isempty(var1) ndims(var1) ~= 3
Walter Roberson
Walter Roberson on 29 May 2017
function tryme(var1)
if ~exist('var1', 'var') || isempty(var1) || ndims(var1) ~= 3
varname = inputname(1);
if isempty(varname); varname = 'first input'; end
error('%s must be a 3D array', varname);
end

Sign in to comment.

More Answers (2)

Jan
Jan on 29 May 2017
The command inputname is not useful. The name of a variable should not matter. Some inputs do not even have a name, e.g. in: somma(1, 2) or somma(x+1, y+2).
There are some rare situations, where the name is useful, e.g. when you want to display a variable.
I'm programming for many years now and was never faced with the need of using inputname. If the name of a value matters, I create a struct, which carries the name in an extra field.

dpb
dpb on 29 May 2017
I don't know as I have a directly useful real example on hand, and in general functions shouldn't rely on needing outside knowledge for their use, but one could imagine places in which what the function should do depends on what the variable passed is.
A totally generic routine for reading some data could by this mechanism create a labeled output of the inputs if it were called with different arguments at different points in the code. One could envision this particularly in cases using the dreaded eval in the calling routine so that the calling routine actually is also variable.
I would NOT recommend this as a common practice; it's there for those rare situations that might call for it.
  2 Comments
Stephen23
Stephen23 on 29 May 2017
"One could envision this particularly in cases using the dreaded eval in the calling routine"
The inputname documentation explicitly warns against this: "Avoid using inputname in the critical path of code or to obtain variable names to be used with commands such as eval, evalin, and assignin. This use of inputname can lead to code that is difficult to maintain."
dpb
dpb on 29 May 2017
Oh, yeah, did say it is "the dreaded eval" and I meant that explicitly, NOT tongue-in-cheek. I was just trying to come up with a reason why one could need to retrieve a name from the caller in the callee, not recommending same.

Sign in to comment.

Tags

No tags entered yet.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!