diff src/ov-mapper.h @ 2974:ebbc34ff7f66

[project @ 1997-05-15 19:36:16 by jwe]
author jwe
date Thu, 15 May 1997 19:42:59 +0000
parents
children 30770ba4457a
line wrap: on
line diff
new file mode 100644
--- /dev/null
+++ b/src/ov-mapper.h
@@ -0,0 +1,129 @@
+/*
+
+Copyright (C) 1996, 1997 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_mapper_h)
+#define octave_mapper_h 1
+
+#if defined (__GNUG__)
+#pragma interface
+#endif
+
+#include <string>
+
+#include "ov-fcn.h"
+#include "ov-typeinfo.h"
+
+class octave_value;
+class octave_value_list;
+
+// Builtin mapper functions.
+
+class
+octave_mapper : public octave_function
+{
+public:
+
+  typedef int (*ch_mapper) (int);
+  typedef double (*d_d_mapper) (double);
+  typedef double (*d_c_mapper) (const Complex&);
+  typedef Complex (*c_c_mapper) (const Complex&);
+
+  octave_mapper (ch_mapper ch, d_d_mapper dd, d_c_mapper dc,
+		 c_c_mapper cc, double ll, double ul, int f,
+		 const string& nm = string (),
+		 const string& ds = string ())
+    : octave_function (nm, ds), ch_map_fcn (ch), d_d_map_fcn (dd),
+      d_c_map_fcn (dc), c_c_map_fcn (cc),
+      lower_limit (ll), upper_limit (ul), flag (f) { }
+
+  ~octave_mapper (void) { }
+
+  void *operator new (size_t size)
+    { return allocator.alloc (size); }
+
+  void operator delete (void *p, size_t size)
+    { allocator.free (p, size); }
+
+  octave_function *function_value (bool) { return this; }
+
+  octave_value_list do_index_op (int nargout, const octave_value_list& args);
+
+  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:
+
+  octave_mapper (void);
+
+  octave_mapper (const octave_mapper& m);
+
+  octave_value apply (const octave_value& arg) const;
+
+  // ch_map_fcn is a kluge.
+
+  ch_mapper ch_map_fcn;
+  d_d_mapper d_d_map_fcn;
+  d_c_mapper d_c_map_fcn;
+  c_c_mapper c_c_map_fcn;
+
+  // If flag is nonzero and we are not calling ch_map_fcn, lower_limit
+  // and  upper_limit specify the range of values for which a real arg
+  // returns a real value.  Outside that range, we have to convert args
+  // to complex, and call the complex valued function.
+
+  double lower_limit;
+  double upper_limit;
+
+  // For ch_map_fcn, flag has the following meanings:
+  //
+  //   0  =>  this function returns a matrix of ones and zeros
+  //   1  =>  this function returns a numeric matrix (any values)
+  //   2  =>  this function returns a string array
+  //
+  // For other mappers, nonzero means that this function can return a
+  // complex value for some real arguments.
+
+  int flag;
+
+  // For custom memory management.
+  static octave_allocator allocator;
+
+  // Type id of list objects, set by register_type().
+  static int t_id;
+
+  // Type name of list objects, defined in ov-list.cc.
+  static const string t_name;
+};
+
+#endif
+
+/*
+;;; Local Variables: ***
+;;; mode: C++ ***
+;;; End: ***
+*/