/* 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 (__GNUG__) #pragma implementation #endif #ifdef HAVE_CONFIG_H #include #endif #include #include "Bounds.h" #include "lo-error.h" // error handling void Bounds::error (const char* msg) { (*current_liboctave_error_handler) ("fatal bounds error: ", msg); } Bounds& Bounds::set_bounds (const ColumnVector l, const ColumnVector u) { if (l.capacity () != u.capacity ()) { error ("inconsistent sizes for lower and upper bounds"); return *this; } lb = l; ub = u; return *this; } Bounds& Bounds::set_lower_bounds (const ColumnVector l) { if (ub.capacity () != l.capacity ()) { error ("inconsistent size for lower bounds"); return *this; } lb = l; return *this; } Bounds& Bounds::set_upper_bounds (const ColumnVector u) { if (lb.capacity () != u.capacity ()) { error ("inconsistent size for upper bounds"); return *this; } ub = u; return *this; } ostream& operator << (ostream& os, const Bounds& b) { for (int i = 0; i < b.size (); i++) os << b.lower_bound (i) << " " << b.upper_bound (i) << "\n"; return os; } /* ;;; Local Variables: *** ;;; mode: C++ *** ;;; End: *** */