Mercurial > octave-nkf
view liboctave/singleton-cleanup.cc @ 14394:ed8c4921bf61 stable
correctly fill result for M * v for Nx0 * 0x1 operations
* dColVector.cc (operator * (const Matrix&, const ColumnVector&)):
Fill result if NC is 0.
* CColVector.cc (operator * (const ComplexMatrix&, const
ComplexColumnVector&)): Likewise.
* fCColVector.cc (const FloatComplexMatrix&, const
FloatComplexColumnVector&)): Likewise.
* fColVector.cc (const FloatMatrix&, const FloatColumnVector&)):
Likewise.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Thu, 23 Feb 2012 13:50:26 -0500 |
parents | 72c96de7a403 |
children |
line wrap: on
line source
/* Copyright (C) 2012 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 3 of the License, 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, see <http://www.gnu.org/licenses/>. */ #ifdef HAVE_CONFIG_H #include <config.h> #endif #include <lo-error.h> #include <singleton-cleanup.h> singleton_cleanup_list *singleton_cleanup_list::instance = 0; singleton_cleanup_list::~singleton_cleanup_list (void) { for (std::set<fptr>::iterator p = fcn_list.begin (); p != fcn_list.end (); p++) { fptr fcn = *p; fcn (); } } bool singleton_cleanup_list::instance_ok (void) { bool retval = true; if (! instance) instance = new singleton_cleanup_list (); if (! instance) { current_liboctave_error_handler ("unable to create singleton_cleanup_list object!"); retval = false; } return retval; }