Mercurial > hg > octave-nkf
view src/pt-arg-list.h @ 10784:ca2df6737d6b
generalize cell2mat optimization to n dimensions
author | Jaroslav Hajek <highegg@gmail.com> |
---|---|
date | Mon, 12 Jul 2010 21:32:18 +0200 |
parents | f3b65e1ae355 |
children | fd0a3ac60b0e |
line wrap: on
line source
/* Copyright (C) 1996, 1997, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 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/>. */ #if !defined (octave_tree_arg_list_h) #define octave_tree_arg_list_h 1 #include <list> class octave_value_list; class octave_lvalue; class tree_expression; class tree_walker; #include "str-vec.h" #include "base-list.h" // Argument lists. Used to hold the list of expressions that are the // arguments in a function call or index expression. class tree_argument_list : public octave_base_list<tree_expression *> { public: typedef tree_expression* element_type; tree_argument_list (void) : list_includes_magic_end (false), list_includes_magic_tilde (false), simple_assign_lhs (false) { } tree_argument_list (tree_expression *t) : list_includes_magic_end (false), list_includes_magic_tilde (false), simple_assign_lhs (false) { append (t); } ~tree_argument_list (void); bool has_magic_end (void) const; bool has_magic_tilde (void) const { return list_includes_magic_tilde; } tree_expression *remove_front (void) { iterator p = begin (); tree_expression *retval = *p; erase (p); return retval; } void append (const element_type& s); void mark_as_simple_assign_lhs (void) { simple_assign_lhs = true; } bool is_simple_assign_lhs (void) { return simple_assign_lhs; } bool all_elements_are_constant (void) const; octave_value_list convert_to_const_vector (const octave_value *object = 0); std::list<octave_lvalue> lvalue_list (void); string_vector get_arg_names (void) const; tree_argument_list *dup (symbol_table::scope_id scope, symbol_table::context_id context) const; void accept (tree_walker& tw); private: bool list_includes_magic_end; bool list_includes_magic_tilde; bool simple_assign_lhs; // No copying! tree_argument_list (const tree_argument_list&); tree_argument_list& operator = (const tree_argument_list&); }; #endif