This is a static copy of a profile report

Home

Function details for genpathThis is a static copy of a profile report

Home

genpath (Calls: 954, Time: 0.801 s)
Generated 01-May-2020 08:41:14 using performance time.
function in file /Applications/MATLAB_R2018a.app/toolbox/matlab/general/genpath.m
Copy to new window for comparing multiple runs

Parents (calling functions)

Function NameFunction TypeCalls
OC2function1
genpathfunction951
optiklfunction1
con_klfunction1
Lines where the most time was spent

Line NumberCodeCallsTotal Time% TimeTime Plot
38
files = dir(d);
9540.541 s67.6%
61
p = [p genpath(fullfile(d,dirn...
9510.147 s18.3%
47
isdir = logical(cat(1,files.is...
9540.034 s4.2%
44
p = [p d pathsep];
9540.033 s4.1%
63
end
28590.010 s1.2%
All other lines  0.036 s4.5%
Totals  0.801 s100% 
Children (called functions)

Function NameFunction TypeCallsTotal Time% TimeTime Plot
fullfilefunction9510.130 s16.2%
pathsepfunction9540.019 s2.4%
genpathfunction9510 s0%
Self time (built-ins, overhead, etc.)  0.652 s81.4%
Totals  0.801 s100% 
Code Analyzer results
Line numberMessage
26Extra comma is unnecessary in IF statement before newline.
61The variable 'p' appears to change size on every loop iteration. Consider preallocating for speed.
Coverage results
Show coverage for parent directory
Total lines in function63
Non-code lines (comments, blank lines)35
Code lines (lines that can run)28
Code lines that did run22
Code lines that did not run6
Coverage (did run/can run)78.57 %
Function listing
time 
Calls 
 line
   1 
function p = genpath(d)
   2 
%GENPATH Generate recursive toolbox path.
   3 
%   P = GENPATH returns a character vector containing a path name 
   4 
%   that includes all the folders and subfolders below MATLABROOT/toolbox, 
   5 
%   including empty subfolders.
   6 
%
   7 
%   P = GENPATH(FOLDERNAME) returns a character vector containing a path 
   8 
%   name that includes FOLDERNAME and all subfolders of FOLDERNAME, 
   9 
%   including empty subfolders.
  10 
%   
  11 
%   NOTE 1: GENPATH will not exactly recreate the original MATLAB path.
  12 
%
  13 
%   NOTE 2: GENPATH only includes subfolders allowed on the MATLAB
  14 
%   path.
  15 
%
  16 
%   See also PATH, ADDPATH, RMPATH, SAVEPATH.
  17 

  18 
%   Copyright 1984-2017 The MathWorks, Inc.
  19 
%------------------------------------------------------------------------------
  20 

  21 
% String Adoption
< 0.001 
    954 
  22
if nargin > 0 
< 0.001 
    954 
  23
    d = convertStringsToChars(d); 
< 0.001 
    954 
  24
end 
  25 

< 0.001 
    954 
  26
if nargin==0, 
  27 
  p = genpath(fullfile(matlabroot,'toolbox'));
  28 
  if length(p) > 1, p(end) = []; end % Remove trailing pathsep
  29 
  return
  30 
end
  31 

  32 
% initialise variables
< 0.001 
    954 
  33
classsep = '@';  % qualifier for overloaded class directories 
< 0.001 
    954 
  34
packagesep = '+';  % qualifier for overloaded package directories 
< 0.001 
    954 
  35
p = '';           % path to be returned 
  36 

  37 
% Generate path based on given root directory
  0.541 
    954 
  38
files = dir(d); 
< 0.001 
    954 
  39
if isempty(files) 
  40 
  return
  41 
end
  42 

  43 
% Add d to the path even if it is empty.
  0.033 
    954 
  44
p = [p d pathsep]; 
  45 

  46 
% set logical vector for subdirectory entries in d
  0.034 
    954 
  47
isdir = logical(cat(1,files.isdir)); 
  48 
%
  49 
% Recursively descend through directories which are neither
  50 
% private nor "class" directories.
  51 
%
  0.008 
    954 
  52
dirs = files(isdir); % select only directory entries from the current listing 
  53 

< 0.001 
    954 
  54
for i=1:length(dirs) 
  0.009 
   2859 
  55
   dirname = dirs(i).name; 
  0.013 
   2859 
  56
   if    ~strcmp( dirname,'.')          && ... 
   1905 
  57
         ~strcmp( dirname,'..')         && ... 
    951 
  58
         ~strncmp( dirname,classsep,1) && ... 
    951 
  59
         ~strncmp( dirname,packagesep,1) && ... 
    951 
  60
         ~strcmp( dirname,'private') 
  0.147 
    951 
  61
      p = [p genpath(fullfile(d,dirname))]; % recursive calling of this function. 
< 0.001 
    951 
  62
   end 
  0.010 
   2859 
  63
end 

Other subfunctions in this file are not included in this listing.