| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 156
 157
 158
 159
 160
 161
 162
 163
 164
 165
 166
 167
 168
 169
 170
 171
 172
 173
 174
 175
 176
 177
 178
 179
 180
 181
 182
 183
 184
 185
 186
 187
 188
 189
 190
 191
 192
 193
 194
 195
 196
 197
 198
 199
 200
 201
 202
 203
 204
 205
 206
 207
 208
 209
 210
 211
 212
 213
 214
 215
 216
 217
 218
 219
 220
 221
 222
 223
 224
 225
 226
 227
 228
 229
 230
 231
 232
 233
 234
 235
 236
 237
 238
 239
 240
 241
 242
 243
 244
 245
 246
 247
 248
 249
 250
 251
 252
 253
 254
 255
 256
 257
 258
 259
 260
 261
 262
 263
 264
 265
 266
 267
 268
 269
 270
 271
 272
 273
 274
 275
 276
 277
 278
 279
 280
 281
 282
 283
 284
 285
 286
 287
 288
 289
 290
 291
 292
 293
 294
 295
 296
 297
 298
 299
 300
 301
 302
 303
 304
 305
 306
 307
 308
 309
 310
 311
 312
 313
 314
 315
 316
 317
 318
 319
 320
 321
 322
 323
 324
 325
 326
 327
 328
 329
 330
 331
 332
 333
 334
 335
 336
 337
 338
 339
 340
 341
 342
 343
 344
 345
 346
 347
 348
 349
 350
 351
 352
 353
 354
 355
 356
 357
 358
 359
 360
 361
 362
 363
 364
 365
 366
 367
 368
 369
 370
 371
 372
 373
 374
 375
 376
 377
 378
 379
 380
 381
 382
 383
 384
 385
 386
 387
 388
 389
 390
 391
 392
 393
 394
 395
 396
 397
 398
 399
 400
 401
 402
 403
 404
 405
 406
 407
 408
 409
 410
 411
 412
 413
 414
 415
 416
 417
 418
 419
 420
 421
 422
 423
 424
 425
 426
 427
 428
 429
 430
 431
 432
 433
 434
 435
 436
 437
 438
 439
 440
 441
 442
 443
 444
 445
 446
 447
 448
 449
 450
 451
 452
 453
 454
 455
 456
 457
 458
 459
 460
 461
 462
 463
 464
 465
 466
 467
 468
 469
 470
 471
 472
 473
 474
 475
 476
 477
 478
 479
 480
 481
 482
 483
 484
 485
 486
 487
 488
 489
 490
 491
 492
 493
 494
 495
 496
 497
 498
 499
 500
 501
 502
 503
 504
 505
 506
 507
 508
 509
 510
 511
 512
 513
 514
 515
 516
 517
 518
 519
 520
 521
 522
 523
 524
 525
 526
 527
 528
 529
 530
 531
 532
 533
 534
 535
 536
 537
 538
 539
 540
 541
 542
 543
 544
 545
 546
 547
 548
 549
 550
 551
 552
 553
 554
 555
 556
 557
 558
 559
 560
 561
 562
 563
 564
 565
 566
 567
 568
 569
 570
 571
 572
 573
 574
 575
 576
 577
 578
 579
 580
 581
 582
 583
 584
 585
 586
 587
 588
 589
 590
 591
 592
 593
 594
 595
 596
 597
 598
 599
 600
 601
 602
 603
 604
 605
 606
 607
 608
 609
 610
 611
 612
 613
 614
 615
 616
 617
 618
 619
 620
 621
 622
 623
 624
 625
 626
 627
 628
 629
 630
 631
 632
 633
 634
 635
 636
 637
 638
 639
 640
 641
 642
 643
 644
 645
 646
 647
 648
 649
 650
 651
 652
 653
 654
 655
 656
 657
 658
 659
 660
 661
 662
 663
 664
 665
 666
 667
 668
 669
 670
 671
 672
 673
 674
 675
 676
 677
 678
 679
 680
 681
 682
 683
 684
 685
 686
 687
 688
 689
 690
 691
 692
 693
 694
 695
 696
 697
 698
 699
 700
 701
 702
 703
 704
 705
 706
 707
 708
 709
 710
 711
 712
 713
 714
 715
 716
 717
 718
 719
 720
 721
 722
 723
 724
 725
 726
 727
 728
 729
 730
 731
 732
 733
 734
 735
 736
 737
 738
 739
 740
 741
 742
 743
 744
 745
 746
 747
 748
 749
 750
 751
 752
 753
 754
 755
 756
 757
 758
 759
 
 | @c DO NOT EDIT!  Generated automatically by munge-texi.
@c Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005,
@c               2006, 2007, 2008, 2009 John W. Eaton
@c
@c This file is part of Octave.
@c
@c Octave is free software; you can redistribute it and/or modify it
@c under the terms of the GNU General Public License as published by the
@c Free Software Foundation; either version 3 of the License, or (at
@c your option) any later version.
@c 
@c Octave is distributed in the hope that it will be useful, but WITHOUT
@c ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
@c FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
@c for more details.
@c 
@c You should have received a copy of the GNU General Public License
@c along with Octave; see the file COPYING.  If not, see
@c <http://www.gnu.org/licenses/>.
@node Variables
@chapter Variables
@cindex variables, user-defined
@cindex user-defined variables
Variables let you give names to values and refer to them later.  You have
already seen variables in many of the examples.  The name of a variable
must be a sequence of letters, digits and underscores, but it may not begin
with a digit.  Octave does not enforce a limit on the length of variable
names, but it is seldom useful to have variables with names longer than
about 30 characters.  The following are all valid variable names
@cindex job hunting
@cindex getting a good job
@cindex flying high and fast
@example
@group
x
x15
__foo_bar_baz__
fucnrdthsucngtagdjb
@end group
@end example
@noindent
However, names like @code{__foo_bar_baz__} that begin and end with two
underscores are understood to be reserved for internal use by Octave.
You should not use them in code you write, except to access Octave's
documented internal variables and built-in symbolic constants.
Case is significant in variable names.  The symbols @code{a} and
@code{A} are distinct variables.
A variable name is a valid expression by itself.  It represents the
variable's current value.  Variables are given new values with
@dfn{assignment operators} and @dfn{increment operators}.
@xref{Assignment Ops, ,Assignment Expressions}.
There is one built-in variable with a special meaning.  The @code{ans} variable
always contains the result of the last computation, where the output wasn't
assigned to any variable.  The code @code{a = cos (pi)} will assign the value -1
to the variable @code{a}, but will not change the value of @code{ans}.  However,
the code @code{cos (pi)} will set the value of @code{ans} to -1.
Variables in Octave do not have fixed types, so it is possible to first
store a numeric value in a variable and then to later use the same name
to hold a string value in the same program.  Variables may not be used
before they have been given a value.  Doing so results in an error.
@cindex @code{ans}
@c ./miscellaneous/ans.m
@anchor{doc-ans}
@defvr {Automatic Variable} ans
The most recently computed result that was not
explicitly assigned to a variable.  For example, after the expression
@example
3^2 + 4^2
@end example
@noindent
is evaluated, the value returned by @code{ans} is 25.
@end defvr
@c utils.cc
@anchor{doc-isvarname}
@deftypefn {Built-in Function} {} isvarname (@var{name})
Return true if @var{name} is a valid variable name
@end deftypefn
@c ./general/genvarname.m
@anchor{doc-genvarname}
@deftypefn {Function File} {@var{varname} =} genvarname (@var{str})
@deftypefnx {Function File} {@var{varname} =} genvarname (@var{str}, @var{exclusions})
Create unique variable(s) from @var{str}.  If @var{exclusions} is
given, then the variable(s) will be unique to each other and to
@var{exclusions} (@var{exclusions} may be either a string or a cellstr).
If @var{str} is a cellstr, then a unique variable is created for each
cell in @var{str}.
@example
@group
x = 3.141;
genvarname ("x", who ())
@result{} x1
@end group
@end example
If @var{wanted} is a cell array, genvarname will make sure the returned
strings are distinct:
@example
@group
genvarname (@{"foo", "foo"@})
@result{}
@{
  [1,1] = foo
  [1,2] = foo1
@}
@end group
@end example
Note that the result is a char array/cell array of strings, not the
variables themselves.  To define a variable, @code{eval()} can be
used.  The following trivial example sets @code{x} to @code{42}.
@example
@group
name = genvarname ("x");
eval([name " = 42"]);
@result{} x =  42
@end group
@end example
Also, this can be useful for creating unique struct field names.
@example
@group
x = struct ();
for i = 1:3
  x.(genvarname ("a", fieldnames (x))) = i;
endfor
@result{}
x =
@{
  a =  1
  a1 =  2
  a2 =  3
@}
@end group
@end example
Since variable names may only contain letters, digits and underscores,
genvarname replaces any sequence of disallowed characters with
an underscore.  Also, variables may not begin with a digit; in this
case an underscore is added before the variable name.
Variable names beginning and ending with two underscores "__" are valid but
they are used internally by octave and should generally be avoided, therefore
genvarname will not generate such names.
genvarname will also make sure that returned names do not clash with
keywords such as "for" and "if".  A number will be appended if necessary.
Note, however, that this does @strong{not} include function names,
such as "sin".  Such names should be included in @var{avoid} if necessary.
@seealso{@ref{doc-isvarname,,isvarname}, @ref{doc-exist,,exist}, @ref{doc-tmpnam,,tmpnam}, @ref{doc-eval,,eval}}
@end deftypefn
@c ./miscellaneous/namelengthmax.m
@anchor{doc-namelengthmax}
@deftypefn {Function File} {} namelengthmax ()
Returns the @sc{matlab} compatible maximum variable name length.  Octave is
capable of storing strings up to 
@tex
$2^{31} - 1$
@end tex
@ifnottex
@code{2 ^ 31 - 1}
@end ifnottex
in length.  However for @sc{matlab} compatibility all variable, function
and structure field names should be shorter than the length supplied by
@code{namelengthmax}.  In particular variables stored to a @sc{matlab} file
format will have their names truncated to this length.
@end deftypefn
@menu
* Global Variables::            
* Persistent Variables::        
* Status of Variables::         
@end menu
@node Global Variables
@section Global Variables
@cindex global variables
@cindex @code{global} statement
@cindex variables, global
A variable that has been declared @dfn{global} may be accessed from
within a function body without having to pass it as a formal parameter.
A variable may be declared global using a @code{global} declaration
statement.  The following statements are all global declarations.
@example
@group
global a
global a b
global c = 2
global d = 3 e f = 5
@end group
@end example
A global variable may only be initialized once in a @code{global}
statement.  For example, after executing the following code
@example
@group
global gvar = 1
global gvar = 2
@end group
@end example
@noindent
the value of the global variable @code{gvar} is 1, not 2.  Issuing a
@samp{clear gvar} command does not change the above behavior, but
@samp{clear all} does.
It is necessary declare a variable as global within a function body in
order to access it.  For example,
@example
@group
global x
function f ()
  x = 1;
endfunction
f ()
@end group
@end example
@noindent
does @emph{not} set the value of the global variable @code{x} to 1.  In
order to change the value of the global variable @code{x}, you must also
declare it to be global within the function body, like this
@example
@group
function f ()
  global x;
  x = 1;
endfunction
@end group
@end example
Passing a global variable in a function parameter list will
make a local copy and not modify the global value.  For example, given
the function
@example
@group
function f (x)
  x = 0
endfunction
@end group
@end example
@noindent
and the definition of @code{x} as a global variable at the top level,
@example
global x = 13
@end example
@noindent
the expression
@example
f (x)
@end example
@noindent
will display the value of @code{x} from inside the function as 0,
but the value of @code{x} at the top level remains unchanged, because
the function works with a @emph{copy} of its argument.
@c variables.cc
@anchor{doc-isglobal}
@deftypefn {Built-in Function} {} isglobal (@var{name})
Return 1 if @var{name} is globally visible.  Otherwise, return 0.  For
example,
@example
@group
global x
isglobal ("x")
     @result{} 1
@end group
@end example
@end deftypefn
@node Persistent Variables
@section Persistent Variables
@cindex persistent variables
@cindex @code{persistent} statement
@cindex variables, persistent
@anchor{doc-persistent}
A variable that has been declared @dfn{persistent} within a function
will retain its contents in memory between subsequent calls to the
same function.  The difference between persistent variables and global
variables is that persistent variables are local in scope to a
particular function and are not visible elsewhere.
The following example uses a persistent variable to create a function
that prints the number of times it has been called.
@example
@group
function count_calls ()
  persistent calls = 0;
  printf ("'count_calls' has been called %d times\n",
          ++calls);
endfunction
for i = 1:3
  count_calls ();
endfor
@print{} 'count_calls' has been called 1 times
@print{} 'count_calls' has been called 2 times
@print{} 'count_calls' has been called 3 times
@end group
@end example
As the example shows, a variable may be declared persistent using a
@code{persistent} declaration statement.  The following statements are
all persistent declarations.
@example
@group
persistent a
persistent a b
persistent c = 2
persistent d = 3 e f = 5
@end group
@end example
The behavior of persistent variables is equivalent to the behavior of
static variables in C.  The command @code{static} in Octave is also
recognized and is equivalent to @code{persistent}.
Like global variables, a persistent variable may only be initialized once.
For example, after executing the following code
@example
@group
persistent pvar = 1
persistent pvar = 2
@end group
@end example
@noindent
the value of the persistent variable @code{pvar} is 1, not 2.
If a persistent variable is declared but not initialized to a specific
value, it will contain an empty matrix.  So, it is also possible to
initialize a persistent variable by checking whether it is empty, as the
following example illustrates.
@example
@group
function count_calls ()
  persistent calls;
  if (isempty (calls))
    calls = 0;
  endif
  printf ("'count_calls' has been called %d times\n",
          ++calls);
endfunction
@end group
@end example
@noindent
This implementation behaves in exactly the same way as the previous
implementation of @code{count_calls}.
The value of a persistent variable is kept in memory until it is
explicitly cleared.  Assuming that the implementation of @code{count_calls}
is saved on disk, we get the following behavior.
@example
for i = 1:2
  count_calls ();
endfor
@print{} 'count_calls' has been called 1 times
@print{} 'count_calls' has been called 2 times
clear
for i = 1:2
  count_calls();
endfor
@print{} 'count_calls' has been called 3 times
@print{} 'count_calls' has been called 4 times
clear all
for i = 1:2
  count_calls();
endfor
@print{} 'count_calls' has been called 1 times
@print{} 'count_calls' has been called 2 times
clear count_calls
for i = 1:2
  count_calls();
endfor
@print{} 'count_calls' has been called 1 times
@print{} 'count_calls' has been called 2 times
@end example
@noindent
That is, the persistent variable is only removed from memory when the
function containing the variable is removed.  Note that if the function
definition is typed directly into the Octave prompt, the persistent
variable will be cleared by a simple @code{clear} command as the entire
function definition will be removed from memory.  If you do not want
a persistent variable to be removed from memory even if the function is
cleared, you should use the @code{mlock} function as described in
@xref{Function Locking}.
@node Status of Variables
@section Status of Variables
When creating simple one-shot programs it can be very convenient to
see which variables are available at the prompt.  The function @code{who}
and its siblings @code{whos} and @code{whos_line_format} will show
different information about what is in memory, as the following shows.
@example
@group
str = "A random string";
who -variables
     @print{} *** local user variables:
     @print{} 
     @print{} __nargin__  str
@end group
@end example
@c variables.cc
@anchor{doc-who}
@deffn  {Command} who
@deffnx {Command} who pattern @dots{}
@deffnx {Command} who option pattern @dots{}
@deffnx {Command} C = who("pattern", @dots{})
List currently defined variables matching the given patterns.  Valid
pattern syntax is the same as described for the @code{clear} command.
If no patterns are supplied, all variables are listed.
By default, only variables visible in the local scope are displayed.
The following are valid options but may not be combined.
@table @code
@item global
List variables in the global scope rather than the current scope.
@item -regexp
The patterns are considered to be regular expressions when matching the
variables to display.  The same pattern syntax accepted by
the @code{regexp} function is used.
@item -file
The next argument is treated as a filename.  All variables found within the
specified file are listed.  No patterns are accepted when reading variables
from a file.
@end table
If called as a function, return a cell array of defined variable names
matching the given patterns.
@seealso{@ref{doc-whos,,whos}, @ref{doc-regexp,,regexp}}
@end deffn
@c variables.cc
@anchor{doc-whos}
@deffn  {Command} whos
@deffnx {Command} whos pattern @dots{}
@deffnx {Command} whos option pattern @dots{}
@deffnx {Command} S = whos("pattern", @dots{})
Provide detailed information on currently defined variables matching the
given patterns.  Options and pattern syntax are the same as for the
@code{who} command.  Extended information about each variable is
summarized in a table with the following default entries.
@table @asis
@item Attr
Attributes of the listed variable.  Possible attributes are:
@table @asis
@item blank
Variable in local scope
@item @code{g}
Variable with global scope
@item @code{p}
Persistent variable
@end table
@item Name
The name of the variable.
@item Size
The logical size of the variable.  A scalar is 1x1, a vector is 1xN or Nx1,
a 2-D matrix is MxN.
@item Bytes
The amount of memory currently used to store the variable.
@item Class
The class of the variable.  Examples include double, single, char, uint16,
cell, and struct.
@end table
The table can be customized to display more or less information through
the function @code{whos_line_format}.
If @code{whos} is called as a function, return a struct array of defined
variable names matching the given patterns.  Fields in the structure
describing each variable are: name, size, bytes, class, global, sparse, 
complex, nesting, persistent.
@seealso{@ref{doc-who,,who}, @ref{doc-whos_line_format,,whos_line_format}}
@end deffn
@c variables.cc
@anchor{doc-whos_line_format}
@deftypefn  {Built-in Function} {@var{val} =} whos_line_format ()
@deftypefnx {Built-in Function} {@var{old_val} =} whos_line_format (@var{new_val})
Query or set the format string used by the command @code{whos}.
A full format string is:
@c Set example in small font to prevent overfull line
@smallexample
%[modifier]<command>[:width[:left-min[:balance]]];
@end smallexample
The following command sequences are available:
@table @code
@item %a
Prints attributes of variables (g=global, p=persistent,
f=formal parameter, a=automatic variable).
@item %b
Prints number of bytes occupied by variables.
@item %c
Prints class names of variables.
@item %e
Prints elements held by variables.
@item %n
Prints variable names.
@item %s
Prints dimensions of variables.
@item %t
Prints type names of variables.
@end table
Every command may also have an alignment modifier:
@table @code
@item l
Left alignment.
@item r
Right alignment (default).
@item c
Column-aligned (only applicable to command %s).
@end table
The @code{width} parameter is a positive integer specifying the minimum
number of columns used for printing.  No maximum is needed as the field will
auto-expand as required.
The parameters @code{left-min} and @code{balance} are only available when the
column-aligned modifier is used with the command @samp{%s}.
@code{balance} specifies the column number within the field width which will
be aligned between entries.  Numbering starts from 0 which indicates the
leftmost column.  @code{left-min} specifies the minimum field width to the
left of the specified balance column.
The default format is
@code{"  %a:4; %ln:6; %cs:16:6:1;  %rb:12;  %lc:-1;\n"}.
@seealso{@ref{doc-whos,,whos}}
@end deftypefn
Instead of displaying which variables are in memory, it is possible
to determine if a given variable is available.  That way it is possible
to alter the behavior of a program depending on the existence of a
variable.  The following example illustrates this.
@example
@group
if (! exist ("meaning", "var"))
  disp ("The program has no 'meaning'");
endif
@end group
@end example
@c variables.cc
@anchor{doc-exist}
@deftypefn {Built-in Function} {} exist (@var{name}, @var{type})
Return 1 if the name exists as a variable, 2 if the name is an
absolute file name, an ordinary file in Octave's @code{path}, or (after
appending @samp{.m}) a function file in Octave's @code{path}, 3 if the
name is a @samp{.oct} or @samp{.mex} file in Octave's @code{path},
5 if the name is a built-in function, 7 if the name is a directory, or 103
if the name is a function not associated with a file (entered on
the command line).
Otherwise, return 0.
This function also returns 2 if a regular file called @var{name}
exists in Octave's search path.  If you want information about
other types of files, you should use some combination of the functions
@code{file_in_path} and @code{stat} instead.
If the optional argument @var{type} is supplied, check only for
symbols of the specified type.  Valid types are
@table @samp
@item "var"
Check only for variables.
@item "builtin"
Check only for built-in functions.
@item "file"
Check only for files.
@item "dir"
Check only for directories.
@end table
@end deftypefn
Usually Octave will manage the memory, but sometimes it can be practical
to remove variables from memory manually.  This is usually needed when
working with large variables that fill a substantial part of the memory.
On a computer that uses the IEEE floating point format, the following
program allocates a matrix that requires around 128 MB memory.
@example
large_matrix = zeros (4000, 4000);
@end example
@noindent
Since having this variable in memory might slow down other computations,
it can be necessary to remove it manually from memory.  The @code{clear}
function allows this.
@c variables.cc
@anchor{doc-clear}
@deffn {Command} clear [options] pattern @dots{}
Delete the names matching the given patterns from the symbol table.  The
pattern may contain the following special characters:
@table @code
@item ?
Match any single character.
@item *
Match zero or more characters.
@item [ @var{list} ]
Match the list of characters specified by @var{list}.  If the first
character is @code{!} or @code{^}, match all characters except those
specified by @var{list}.  For example, the pattern @samp{[a-zA-Z]} will
match all lower and upper case alphabetic characters.
@end table
For example, the command
@example
clear foo b*r
@end example
@noindent
clears the name @code{foo} and all names that begin with the letter
@code{b} and end with the letter @code{r}.
If @code{clear} is called without any arguments, all user-defined
variables (local and global) are cleared from the symbol table.  If
@code{clear} is called with at least one argument, only the visible
names matching the arguments are cleared.  For example, suppose you have
defined a function @code{foo}, and then hidden it by performing the
assignment @code{foo = 2}.  Executing the command @kbd{clear foo} once
will clear the variable definition and restore the definition of
@code{foo} as a function.  Executing @kbd{clear foo} a second time will
clear the function definition.
The following options are available in both long and short form
@table @code
@item -all, -a
Clears all local and global user-defined variables and all functions
from the symbol table.
@item -exclusive, -x
Clears the variables that don't match the following pattern.
@item -functions, -f
Clears the function names and the built-in symbols names.
@item -global, -g
Clears the global symbol names.
@item -variables, -v
Clears the local variable names.
@item -classes, -c
Clears the class structure table and clears all objects.
@item -regexp, -r
The arguments are treated as regular expressions as any variables that
match will be cleared.
@end table
With the exception of @code{exclusive}, all long options can be used 
without the dash as well.
@end deffn
Information about a function or variable such as its location in the
file system can also be acquired from within Octave.  This is usually
only useful during development of programs, and not within a program.
@c ./help/type.m
@anchor{doc-type}
@deftypefn {Command} type options name @dots{}
Display the definition of each @var{name} that refers to a function.
Normally also displays whether each @var{name} is user-defined or built-in;
the @code{-q} option suppresses this behavior.
If an output argument is requested nothing is displayed.  Instead, a cell 
array of strings is returned, where each element corresponds to the 
definition of each requested function.
@end deftypefn
@c ./help/which.m
@anchor{doc-which}
@deffn {Command} which name @dots{}
Display the type of each @var{name}.  If @var{name} is defined from a
function file, the full name of the file is also displayed.
@seealso{@ref{doc-help,,help}, @ref{doc-lookfor,,lookfor}}
@end deffn
@c ./miscellaneous/what.m
@anchor{doc-what}
@deftypefn {Command} {} what 
@deftypefnx {Command} {} what @var{dir}
@deftypefnx {Function File} {w =} what (@var{dir})
List the Octave specific files in a directory.  If the variable @var{dir}
is given then check that directory rather than the current directory.  If
a return argument is requested, the files found are returned in the 
structure @var{w}.
@seealso{@ref{doc-which,,which}}
@end deftypefn
 |