Home > classes > @timespan > eq.m

eq

PURPOSE ^

EQ overloads the == operator for timespan objects.

SYNOPSIS ^

function result = eq(c1,c2, varargin)

DESCRIPTION ^

 EQ overloads the == operator for timespan objects.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

 DESCRIPTION: EQ overloads the == operator for timespan objects.

              All fields are checked.

 CALL:        result = eq(c1,c2)
              result = eq(c1,c2,  exc_list)
              result = eq(c1,c2, 'property1', 'property2')
              result = eq(c1,c2, 'class/property', 'class/property')

 EXAMPLES:    result = eq(c1,c2, 'name', 'created')
              result = eq(c1,c2, 'ao/name')

 INPUTS:      c1,c2    - input timespan objects
              exc_list - exception list
                         List of properties which are not checked.

 OUTPUTS:     If the two timespan objects are considered equal, result == 1,
              otherwise, result == 0.

 VERSION:     $Id: eq.m,v 1.2 2007/10/22 11:51:52 ingo Exp $

 HISTORY:     29-08-2007 M Hewitson
                 Creation

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

CROSS-REFERENCE INFORMATION ^

This function calls: This function is called by:

SOURCE CODE ^

0001 function result = eq(c1,c2, varargin)
0002 
0003 % EQ overloads the == operator for timespan objects.
0004 %
0005 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
0006 %
0007 % DESCRIPTION: EQ overloads the == operator for timespan objects.
0008 %
0009 %              All fields are checked.
0010 %
0011 % CALL:        result = eq(c1,c2)
0012 %              result = eq(c1,c2,  exc_list)
0013 %              result = eq(c1,c2, 'property1', 'property2')
0014 %              result = eq(c1,c2, 'class/property', 'class/property')
0015 %
0016 % EXAMPLES:    result = eq(c1,c2, 'name', 'created')
0017 %              result = eq(c1,c2, 'ao/name')
0018 %
0019 % INPUTS:      c1,c2    - input timespan objects
0020 %              exc_list - exception list
0021 %                         List of properties which are not checked.
0022 %
0023 % OUTPUTS:     If the two timespan objects are considered equal, result == 1,
0024 %              otherwise, result == 0.
0025 %
0026 % VERSION:     $Id: eq.m,v 1.2 2007/10/22 11:51:52 ingo Exp $
0027 %
0028 % HISTORY:     29-08-2007 M Hewitson
0029 %                 Creation
0030 %
0031 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
0032 
0033 result = 1;
0034 
0035 %% Check class
0036 if ~strcmp(class(c1), class(c2))
0037   result = 0;
0038   return
0039 end
0040 
0041 fields = fieldnames(c1);
0042 
0043 for ii = 1:length(fields)
0044   field   = fields{ii};
0045 
0046   ck_field = {field, ['timespan/' field]};
0047 
0048   %% Check tag
0049   if ~(any(ismember(ck_field, varargin)))
0050 
0051     if isobject(c1.(field))
0052       if ~eq(c1.(field), c2.(field), varargin{:})
0053         result = 0;
0054         disp(sprintf('\nNOT EQUAL: %s.%s', class(c1), field));
0055         return
0056       end
0057     else
0058       if ~isequalwithequalnans(c1.(field), c2.(field))
0059         result = 0;
0060         disp(sprintf('\nNOT EQUAL: %s.%s', class(c1), field));
0061         return
0062       end
0063     end
0064 
0065   end
0066 end
0067 
0068 
0069 % function result = eq(t1,t2)
0070 %
0071 % % EQ overloads the == operator for timespan objects.
0072 % %
0073 % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
0074 % %
0075 % % DESCRIPTION: EQ overloads the == operator for timespan objects.
0076 % %
0077 % %              Start and stop times are compared.
0078 % %
0079 % % CALL:        result = eq(ts1,ts2)
0080 % %
0081 % % INPUTS:      ts1,ts2 - input timespan objects
0082 % %
0083 % % OUTPUTS:     If the two timespan objects are considered equal, result == 1,
0084 % %              otherwise, result == 0.
0085 % %
0086 % % VERSION:     $Id: eq.m,v 1.2 2007/10/22 11:51:52 ingo Exp $
0087 % %
0088 % % HISTORY:     29-08-2007 M Hewitson
0089 % %                 Creation
0090 % %
0091 % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
0092 %
0093 % % Assume true
0094 % result = 1;
0095 %
0096 % %% Check start
0097 % if t1.start ~= t2.start
0098 %   result = 0;
0099 %   return
0100 % end
0101 %
0102 % %% Check end
0103 % if t1.end ~= t2.end
0104 %   result = 0;
0105 %   return
0106 % end
0107 %
0108 % %% Check timeformat
0109 % if t1.timeformat ~= t2.timeformat
0110 %   result = 0;
0111 %   return
0112 % end
0113 %
0114 % %% Check timezone
0115 % if t1.timezone ~= t2.timezone
0116 %   result = 0;
0117 %   return
0118 % end

Generated on Tue 22-Jan-2008 10:39:13 by m2html © 2003