diff --git a/src/initialize_mdbnomics.m b/src/initialize_mdbnomics.m index c7c781d67616499656eb07ca6f8f1b8f303e9e89..29e9b68edf2d375c09b1e4c5838d1e038857eab9 100644 --- a/src/initialize_mdbnomics.m +++ b/src/initialize_mdbnomics.m @@ -24,6 +24,10 @@ mdbnomics_src_root = strrep(which('initialize_mdbnomics'), 'initialize_mdbnomics p = {'subroutines'}; % Add missing routines if dynare is not in the path +if ~exist('contains','file') + p{end+1} = 'missing/contains'; +end + if ~exist('get_file_extension','file') p{end+1} = 'missing/get_cells_id'; end diff --git a/src/missing/contains/contains.m b/src/missing/contains/contains.m new file mode 100644 index 0000000000000000000000000000000000000000..7c64704947ed499517410414ad58edc5f54bef9b --- /dev/null +++ b/src/missing/contains/contains.m @@ -0,0 +1,70 @@ +function tf = contains(string, pattern, varargin) + +% CONTAINS Returns 1 if the pattern is found in string, and 0 otherwise. +% +% INPUTS +% - string [string, char, cell(str)] String to be searhced. +% - pattern [string, char, cell(str)] The searched pattern. +% +% If 'IgnoreCase',IGNORE is provided, the function ignores case if IGNORE is true. +% The default value is false. +% +% OUTPUT +% - tf [logical] +% +% Copyright (C) 2019 Dynare Team +% +% This file is part of Dynare. +% +% Dynare 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. +% +% Dynare 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 Dynare. If not, see <http://www.gnu.org/licenses/>. + +if mod(nargin,2) ~= 0 + error('contains: inputs should be a text, followed by the queried patterns, then Name-Value pair arguments.'); +end + +if ~((ischar(string) || isstring(string) || iscellstr(string)) && (ischar(pattern) || isstring(pattern) || iscellstr(pattern))) + error('contains: first and second input arguments must be a string array, char array or cell array'); +end + +if ~isempty(varargin) + if ~ischar(varargin{1}) + error('The #%d and #%d inputs must be a Name-Value pair.', nargin-1, nargin); + end + parameters = {'ignorecase', 'caseignore','insensitivecase', 'caseinsensitive','insensitive','ignore',... + 'casesensitive', 'sensitive', 'sensitivecase'}; + if ~cellfun('isempty',(cellfun(@(s)strcmpi(varargin{1}, s), parameters, 'uni', 0))) + case_ignore = varargin{end}; + else + error('Unsupported parameter "%s".', varargin{1}); + end +else + case_ignore = false; +end + +string = cellstr(string); +pattern = cellstr(pattern); + +if case_ignore + string = lower(string); + pattern = lower(pattern); +end + +tf = false(size(string)); +for ii = 1:numel(pattern) + idx = regexp(string, pattern{ii}); + for jj = 1:numel(string) + tf(jj) = tf(jj) || ~isempty(idx{jj}); + end +end +end \ No newline at end of file