diff src/ov-range.h @ 2376:2142216bf85a

[project @ 1996-10-12 01:39:07 by jwe]
author jwe
date Sat, 12 Oct 1996 01:39:21 +0000
parents
children 367485171742
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/ov-range.h	Sat Oct 12 01:39:21 1996 +0000
@@ -0,0 +1,164 @@
+/*
+
+Copyright (C) 1996 John W. Eaton
+
+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 2, 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, write to the Free
+Software Foundation, 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+
+*/
+
+#if !defined (octave_range_h)
+#define octave_range_h 1
+
+#if defined (__GNUG__)
+#pragma interface
+#endif
+
+#include <cstdlib>
+
+#include <string>
+
+class ostream;
+
+#include "Range.h"
+
+#include "lo-utils.h"
+#include "mx-base.h"
+#include "str-vec.h"
+
+#include "error.h"
+#include "mappers.h"
+#include "ov-base.h"
+#include "ov-typeinfo.h"
+
+class Octave_map;
+class octave_value_list;
+
+class tree_walker;
+
+// Range values.
+
+class
+octave_range : public octave_base_value
+{
+public:
+
+  octave_range (void)
+    : octave_base_value () { }
+
+  octave_range (double base, double limit, double inc)
+    : octave_base_value (), range (base, limit, inc)
+      {
+	if (range.nelem () < 0)
+	  ::error ("invalid range");
+      }
+
+  octave_range (const Range& r)
+    : octave_base_value (), range (r)
+      {
+	if (range.nelem () < 0)
+	  ::error ("invalid range");
+      }
+
+  octave_range (const octave_range& r)
+    : octave_base_value (), range (r.range) { }
+
+  ~octave_range (void) { }
+
+  octave_value *clone (void) { return new octave_range (*this); }
+
+#if 0
+  void *operator new (size_t size);
+  void operator delete (void *p, size_t size);
+#endif
+
+  numeric_conv_fcn numeric_conversion_function (void) const;
+
+  idx_vector index_vector (void) const { return idx_vector (range); }
+
+  int rows (void) const { return (columns () > 0); }
+  int columns (void) const { return range.nelem (); }
+
+  bool is_defined (void) const { return true; }
+
+  bool is_range (void) const { return true; }
+
+  // XXX DO ME XXX
+  octave_value all (void) const;
+  octave_value any (void) const;
+
+  bool is_real_type (void) const { return true; }
+
+  bool valid_as_scalar_index (void) const
+    {
+      return (range.nelem () == 1
+	      && ! xisnan (range.base ())
+	      && NINT (range.base ()) == 1);
+    }
+
+  bool valid_as_zero_index (void) const
+    {
+      return (range.nelem () == 1
+	      && ! xisnan (range.base ())
+	      && NINT (range.base ()) == 0);
+    }
+
+  // XXX DO ME XXX
+  bool is_true (void) const;
+
+  double double_value (bool) const;
+
+  Matrix matrix_value (bool) const
+    { return range.matrix_value (); }
+
+  Complex complex_value (bool) const;
+
+  ComplexMatrix complex_matrix_value (bool) const
+    { return range.matrix_value (); }
+
+  Range range_value (void) const { return range; }
+
+  octave_value transpose (void) const;
+
+  octave_value hermitian (void) const;
+
+  void print (ostream& os);
+
+  int type_id (void) const { return t_id; }
+
+  string type_name (void) const { return t_name; }
+
+  static int static_type_id (void) { return t_id; }
+
+  static void register_type (void)
+    { t_id = octave_value_typeinfo::register_type (t_name); }
+
+private:
+
+  Range range;
+
+  static int t_id;
+
+  static const string t_name;
+};
+
+#endif
+
+/*
+;;; Local Variables: ***
+;;; mode: C++ ***
+;;; End: ***
+*/