Mercurial > hg > octave-lyh
view scripts/help/type.m @ 15039:e753177cde93
maint: Move non-dynamically linked functions from DLD-FUNCTIONS/ to corefcn/ directory
* __contourc__.cc, __dispatch__.cc, __lin_interpn__.cc, __pchip_deriv__.cc,
__qp__.cc, balance.cc, besselj.cc, betainc.cc, bsxfun.cc, cellfun.cc,
colloc.cc, conv2.cc, daspk.cc, dasrt.cc, dassl.cc, det.cc, dlmread.cc, dot.cc,
eig.cc, fft.cc, fft2.cc, fftn.cc, filter.cc, find.cc, gammainc.cc, gcd.cc,
getgrent.cc, getpwent.cc, getrusage.cc, givens.cc, hess.cc, hex2num.cc, inv.cc,
kron.cc, lookup.cc, lsode.cc, lu.cc, luinc.cc, matrix_type.cc, max.cc,
md5sum.cc, mgorth.cc, nproc.cc, pinv.cc, quad.cc, quadcc.cc, qz.cc,
rand.cc, rcond.cc, regexp.cc, schur.cc, spparms.cc, sqrtm.cc, str2double.cc,
strfind.cc, sub2ind.cc, svd.cc, syl.cc, time.cc, tril.cc, typecast.cc:
Move functions from DLD-FUNCTIONS/ to corefcn/ directory. Include "defun.h",
not "defun-dld.h". Change docstring to refer to these as "Built-in Functions".
* build-aux/mk-opts.pl: Generate options code with '#include "defun.h"'. Change
option docstrings to refer to these as "Built-in Functions".
* corefcn/module.mk: List of functions to build in corefcn/ dir.
* DLD-FUNCTIONS/config-module.awk: Update to new build system.
* DLD-FUNCTIONS/module-files: Remove functions which are now in corefcn/ directory.
* src/Makefile.am: Update to build "convenience library" in corefcn/. Octave
program now links against all other libraries + corefcn libary.
* src/find-defun-files.sh: Strip $srcdir from filename.
* src/link-deps.mk: Add REGEX and FFTW link dependencies for liboctinterp.
* type.m, which.m: Change failing tests to use 'amd', still a dynamic function,
rather than 'dot', which isn't.
author | Rik <rik@octave.org> |
---|---|
date | Fri, 27 Jul 2012 15:35:00 -0700 |
parents | f3d52523cde1 |
children | 049e8bbff782 |
line wrap: on
line source
## Copyright (C) 2009-2012 S�ren Hauberg ## ## 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/>. ## -*- texinfo -*- ## @deftypefn {Command} {} type @var{name} @dots{} ## @deftypefnx {Command} {} type -q @var{name} @dots{} ## @deftypefnx {Function File} {dfns =} type ("@var{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 @option{-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 function retval = type (varargin) ## Parse input if (nargin == 0) error ("type: not enough input arguments"); endif if (!iscellstr (varargin)) error ("type: input arguments must be strings"); endif quiet = false; idx = strcmpi (varargin, "-q") | strcmpi (varargin, "-quiet"); if (any (idx)) quiet = true; varargin (idx) = []; endif if (nargout > 0) retval = cell (size (varargin)); endif for n = 1:length (varargin) name = varargin {n}; ## Find function and get its code text = ""; cmd = sprintf ("exist ('%s')", name); e = evalin ("caller", cmd); if (e == 1) ## Variable cmd = sprintf ("disp (%s);", name); desc = evalin ("caller", cmd); if (quiet) text = desc; else text = sprintf ("%s is a variable\n%s", name, desc); endif elseif (e == 2) ## m-file or ordinary file file = which (name); if (isempty (file)) ## 'name' is an ordinary file, and not a function name. ## FIXME: Should we just print it anyway? error ("type: `%s' undefined\n", name); endif ## Read the file fid = fopen (file, "r"); if (fid < 0) error ("type: couldn't open `%s' for reading", file); endif contents = char (fread (fid).'); fclose (fid); if (quiet) text = contents; else text = sprintf ("%s is the user-defined function defined from: %s\n\n%s", name, file, contents); endif elseif (e == 3) text = sprintf ("%s is a dynamically-linked function", name); elseif (e == 5) text = sprintf ("%s is a built-in function", name); elseif (any (strcmp (__operators__ (), name))) text = sprintf ("%s is an operator", name); elseif (any (strcmp (__keywords__ (), name))) text = sprintf ("%s is a keyword", name); else error ("type: `%s' undefined\n", name); endif ## Should we return the text or print if if (nargout == 0) disp (text); else retval {n} = text; endif endfor endfunction %!test %! var = 1; %! typestr = type ("var"); %! typestr = typestr{1}(1:17); %! assert (typestr, "var is a variable"); %!assert (type ("amd"){1}, "amd is a dynamically-linked function") %!assert (type ("cat"){1}, "cat is a built-in function") %!assert (type ("+"){1}, "+ is an operator") %!assert (type ("end"){1}, "end is a keyword") %!error (type ('NO_NAME'))