Mercurial > hg > octave-nkf
diff examples/structdemo.cc @ 11051:2204120e38d2
structdemo.cc: use octave_scalar_map instead of Octave_map
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Wed, 29 Sep 2010 04:23:13 -0400 |
parents | 6cb30a539481 |
children | db1f49eaba6b |
line wrap: on
line diff
--- a/examples/structdemo.cc +++ b/examples/structdemo.cc @@ -6,33 +6,39 @@ int nargin = args.length (); octave_value retval; - if (nargin != 2) - print_usage (); - else + if (args.length () == 2) { - Octave_map arg0 = args(0).map_value (); - std::string arg1 = args(1).string_value (); + octave_scalar_map arg0 = args(0).scalar_map_value (); - if (! error_state && arg0.contains (arg1)) + if (! error_state) { - // The following two lines might be written as - // octave_value tmp; - // for (Octave_map::iterator p0 = - // arg0.begin(); - // p0 != arg0.end(); p0++ ) - // if (arg0.key (p0) == arg1) - // { - // tmp = arg0.contents (p0) (0); - // break; - // } - // though using seek is more concise. - Octave_map::const_iterator p1 = arg0.seek (arg1); - octave_value tmp = arg0.contents(p1)(0); - Octave_map st; - st.assign ("selected", tmp); - retval = octave_value (st); + std::string arg1 = args(1).string_value (); + + if (! error_state) + { + octave_value tmp = arg0.contents (arg1); + + if (tmp.is_defined ()) + { + octave_scalar_map st; + + st.assign ("selected", tmp); + + retval = octave_value (st); + } + else + error ("sruct does not contain field named '%s'\n", + arg1.c_str ()); + } + else + error ("expecting character string as second argument"); } + else + error ("expecting struct as first argument"); } + else + print_usage (); + return retval; }