Mercurial > hg > octave-nkf
view src/oct-fstrm.cc @ 15023:75d1bc2fd6d2
Compile top level while loops in JIT.
* src/pt-eval.cc (tree_evaluator::visit_while_command): Try compile while loops.
* src/pt-jit.cc (jit_convert::jit_convert): Add first terminator to worklist.
(tree_jit::execute): New overload.
* src/pt-jit.h (tree_jit::execute): New overload.
* src/pt-loop.cc (tree_while_command::~tree_while_command): Delete compiled.
(tree_simple_for_command::~tree_simple_for_command): Only delete compiled if JIT
is enabled.
* src/pt-loop.h (tree_while_command::get_info, tree_while_command::stash_info):
New function.
author | Max Brister <max@2bass.com> |
---|---|
date | Thu, 26 Jul 2012 12:17:56 -0500 |
parents | 72c96de7a403 |
children |
line wrap: on
line source
/* Copyright (C) 1996-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 <cerrno> #include <cstring> #include "error.h" #include "oct-fstrm.h" octave_stream octave_fstream::create (const std::string& nm_arg, std::ios::openmode arg_md, oct_mach_info::float_format ff) { return octave_stream (new octave_fstream (nm_arg, arg_md, ff)); } octave_fstream::octave_fstream (const std::string& nm_arg, std::ios::openmode arg_md, oct_mach_info::float_format ff) : octave_base_stream (arg_md, ff), nm (nm_arg) { #if CXX_ISO_COMPLIANT_LIBRARY fs.open (nm.c_str (), arg_md); #else // Override default protection of 0664 so that umask will appear to // do the right thing. fs.open (nm.c_str (), arg_md, 0666); #endif if (! fs) error (gnulib::strerror (errno)); } // Position a stream at OFFSET relative to ORIGIN. int octave_fstream::seek (long, int) { error ("fseek: invalid_operation"); return -1; } // Return current stream position. long octave_fstream::tell (void) { error ("ftell: invalid_operation"); return -1; } // Return non-zero if EOF has been reached on this stream. bool octave_fstream::eof (void) const { return fs.eof (); } void octave_fstream::do_close (void) { fs.close (); } std::istream * octave_fstream::input_stream (void) { std::istream *retval = 0; if (mode () & std::ios::in) retval = &fs; return retval; } std::ostream * octave_fstream::output_stream (void) { std::ostream *retval = 0; if (mode () & std::ios::out) retval = &fs; return retval; }