47 arg_nm (), dyn_field () { }
53 arg_nm (), dyn_field ()
62 arg_nm (), dyn_field ()
71 arg_nm (), dyn_field ()
82 dyn_field.push_back (static_cast<tree_expression *> (0));
85 error (
"invalid use of empty argument (~) in index expression");
91 args.push_back (static_cast<tree_argument_list *> (0));
94 dyn_field.push_back (static_cast<tree_expression *> (0));
100 args.push_back (static_cast<tree_argument_list *> (0));
110 while (!
args.empty ())
112 std::list<tree_argument_list *>::iterator p =
args.begin ();
119 std::list<tree_expression *>::iterator p =
dyn_field.begin ();
128 for (std::list<tree_argument_list *>::const_iterator p =
args.begin ();
162 int n = arg_values.
length ();
170 for (
int i = 0; i < n; i++)
171 retval(0,i) = arg_values(i);
186 if (rvalue &&
object && args->
has_magic_end () &&
object->is_undefined ())
205 (std::list<string_vector>::const_iterator p_arg_nm,
206 std::list<tree_expression *>::const_iterator p_dyn_field)
const
208 std::string fn = (*p_arg_nm)(0);
223 error (
"dynamic structure field names must be strings");
236 int n =
args.size ();
238 Cell type_field (n, 1);
239 Cell subs_field (n, 1);
241 std::list<tree_argument_list *>::const_iterator p_args =
args.begin ();
242 std::list<string_vector>::const_iterator p_arg_nm =
arg_nm.begin ();
243 std::list<tree_expression *>::const_iterator p_dyn_field =
dyn_field.begin ();
247 for (
int i = 0; i < n; i++)
275 m.
assign (
"type", type_field);
276 m.
assign (
"subs", subs_field);
289 const std::list<octave_lvalue> *lvalue_list)
300 bool have_args =
false;
310 size_t n = al ? al->
length () : 0;
316 first_args = al -> convert_to_const_vector ();
320 first_expr_val =
id->do_lookup (first_args);
333 std::list<octave_value_list> idx;
335 int n =
args.size ();
337 std::list<tree_argument_list *>::iterator p_args =
args.begin ();
338 std::list<string_vector>::iterator p_arg_nm =
arg_nm.begin ();
339 std::list<tree_expression *>::iterator p_dyn_field =
dyn_field.begin ();
341 for (
int i = 0; i < n; i++)
352 bool force_split =
type[i-1] ==
'(' &&
type[i] !=
'.';
367 = tmp.
subsref (
type.substr (tmpi, i - tmpi), idx, nargout);
406 idx.push_back (first_args);
436 retval = tmp.
subsref (
type.substr (tmpi, n - tmpi), idx, nargout,
449 retval = (lvalue_list
479 std::list<octave_value_list> idx;
480 std::string tmp_type;
482 int n =
args.size ();
484 std::list<tree_argument_list *>::iterator p_args =
args.begin ();
485 std::list<string_vector>::iterator p_arg_nm =
arg_nm.begin ();
486 std::list<tree_expression *>::iterator p_dyn_field =
dyn_field.begin ();
495 std::list<octave_value_list> tmpidx;
497 for (
int i = 0; i < n; i++)
499 if (retval.
numel () != 1)
503 tmp = tmp.
subsref (
type.substr (tmpi, i - tmpi), tmpidx,
true);
517 idx.push_back (tidx);
521 if (
type[i+1] ==
'.')
523 tmpidx.push_back (tidx);
527 error (
"() must be followed by . or close the index chain");
555 idx.push_back (tidx);
556 tmpidx.push_back (tidx);
571 if (i > 0 &&
type[i-1] ==
'(')
590 tmpidx.push_back (tidx);
604 tmpidx.push_back (tidx);
611 idx.push_back (tidx);
619 if (idx.back ().empty ())
620 error (
"invalid empty index list");
684 std::list<tree_argument_list *> new_args;
686 for (std::list<tree_argument_list *>::const_iterator p =
args.begin ();
692 new_args.push_back (elt ? elt->
dup (scope, context) : 0);
695 new_idx_expr->
args = new_args;
701 std::list<tree_expression *> new_dyn_field;
703 for (std::list<tree_expression *>::const_iterator p =
dyn_field.begin ();
709 new_dyn_field.push_back (elt ? elt->
dup (scope, context) : 0);
std::list< tree_argument_list * > args
bool has_magic_tilde(void) const
octave_value_list rvalue(int nargout)
size_t length(void) const
octave_value subsref(const std::string &type, const std::list< octave_value_list > &idx)
octave_idx_type rows(void) const
virtual bool is_postfix_index_handled(char type) const
void assign(const std::string &k, const Cell &val)
bool is_function(void) const
~tree_index_expression(void)
octave_idx_type length(void) const
octave_value_list convert_to_const_vector(const octave_value *object=0)
std::list< tree_expression * > dyn_field
virtual tree_expression * dup(symbol_table::scope_id, symbol_table::context_id context) const =0
void error(const char *fmt,...)
std::list< string_vector > arg_nm
virtual void copy_base(const tree_expression &e)
virtual bool is_variable(void)
std::string name(void) const
void gripe_invalid_inquiry_subscript(void)
void gripe_indexed_cs_list(void)
octave_lvalue lvalue(void)
octave_value_list do_multi_index_op(int nargout, const octave_value_list &idx)
static Cell make_subs_cell(tree_argument_list *args, const string_vector &arg_nm)
octave_map make_arg_struct(void) const
octave_value value(void) const
bool has_magic_end(void) const
string_vector get_arg_names(void) const
octave_value rvalue1(int nargout=1)
octave_idx_type numel(const octave_value_list &idx)
static llvm::LLVMContext & context
std::string string_value(bool force=false) const
bool is_matrix_type(void) const
bool is_string(void) const
void set_index(const std::string &t, const std::list< octave_value_list > &i)
void numel(octave_idx_type n)
void resize(const dim_vector &dv, const T &rfv)
bool has_magic_colon(void) const
#define panic_impossible()
static octave_value_list make_value_list(tree_argument_list *args, const string_vector &arg_nm, const octave_value *object, bool rvalue=true)
tree_argument_list * dup(symbol_table::scope_id scope, symbol_table::context_id context) const
tree_index_expression(tree_expression *e=0, tree_argument_list *lst=0, int l=-1, int c=-1, char t= '(')
octave_function * function_value(bool silent=false) const
virtual void visit_index_expression(tree_index_expression &)=0
virtual std::string name(void) const
virtual octave_value rvalue1(int nargout=1)
bool has_magic_end(void) const
bool is_cs_list(void) const
void accept(tree_walker &tw)
virtual octave_lvalue lvalue(void)
bool is_undefined(void) const
void append(tree_argument_list *lst=0, char t= '(')
virtual int column(void) const
bool is_zero_by_zero(void) const
virtual bool is_identifier(void) const
return octave_value(v1.char_array_value().concat(v2.char_array_value(), ra_idx),((a1.is_sq_string()||a2.is_sq_string())? '\'': '"'))
std::string get_struct_index(std::list< string_vector >::const_iterator p_arg_nm, std::list< tree_expression * >::const_iterator p_dyn_field) const
tree_index_expression * dup(symbol_table::scope_id scope, symbol_table::context_id context) const
void stash_name_tags(const string_vector &nm)