Mercurial > hg > octave-nkf
view liboctave/dir-ops.cc @ 12107:1fc9fd052f0c release-3-2-x
fix typo in expm
author | Jaroslav Hajek <highegg@gmail.com> |
---|---|
date | Wed, 25 Nov 2009 12:05:03 +0100 |
parents | eb63fbe60fab |
children | 4c0cdbe0acca |
line wrap: on
line source
/* Copyright (C) 1996, 1997, 2000, 2005, 2006, 2007, 2008 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 <cerrno> #include <cstdlib> #include <cstring> #include <list> #include <string> #include "sysdir.h" #include "dir-ops.h" #include "file-ops.h" #include "lo-error.h" #include "lo-sysdep.h" #include "str-vec.h" bool dir_entry::open (const std::string& n) { fail = true; if (! n.empty ()) name = n; if (! name.empty ()) { close (); std::string fullname = file_ops::tilde_expand (name); dir = static_cast<void *> (opendir (fullname.c_str ())); if (dir) fail = false; else { using namespace std; errmsg = strerror (errno); } } else errmsg = "dir_entry::open: empty file name"; return ! fail; } string_vector dir_entry::read (void) { string_vector retval; if (ok ()) { std::list<std::string> dirlist; struct dirent *dir_ent; while ((dir_ent = readdir (static_cast<DIR *> (dir)))) { if (dir_ent) dirlist.push_back (dir_ent->d_name); else break; } retval = string_vector (dirlist); } return retval; } void dir_entry::close (void) { if (dir) closedir (static_cast<DIR *> (dir)); dir = 0; } void dir_entry::copy (const dir_entry& de) { name = de.name; dir = de.dir; fail = de.fail; errmsg = de.errmsg; } /* ;;; Local Variables: *** ;;; mode: C++ *** ;;; End: *** */