Mercurial > octave-nkf
annotate libinterp/corefcn/__dispatch__.cc @ 20617:ba2b07c13913
use new string_value method to handle value extraction errors
* __dispatch__.cc, balance.cc, colloc.cc, conv2.cc, data.cc, debug.cc,
graphics.cc, input.cc, matrix_type.cc, oct-hist.cc, schur.cc,
spparms.cc, symtab.cc, sysdep.cc, toplev.cc, utils.cc:
Use new string_value method.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Fri, 09 Oct 2015 10:06:39 -0400 |
parents | 610c74748518 |
children |
rev | line source |
---|---|
5164 | 1 /* |
2 | |
19731
4197fc428c7d
maint: Update copyright notices for 2015.
John W. Eaton <jwe@octave.org>
parents:
17787
diff
changeset
|
3 Copyright (C) 2001-2015 John W. Eaton and Paul Kienzle |
5164 | 4 |
7016 | 5 This file is part of Octave. |
6 | |
7 Octave is free software; you can redistribute it and/or modify it | |
5164 | 8 under the terms of the GNU General Public License as published by the |
7016 | 9 Free Software Foundation; either version 3 of the License, or (at your |
10 option) any later version. | |
5164 | 11 |
7016 | 12 Octave is distributed in the hope that it will be useful, but WITHOUT |
5164 | 13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
15 for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
7016 | 18 along with Octave; see the file COPYING. If not, see |
19 <http://www.gnu.org/licenses/>. | |
5164 | 20 |
21 */ | |
22 | |
23 #ifdef HAVE_CONFIG_H | |
24 #include <config.h> | |
25 #endif | |
26 | |
27 #include <list> | |
28 #include <map> | |
29 #include <string> | |
30 | |
7336 | 31 #include "Cell.h" |
32 #include "oct-map.h" | |
15039
e753177cde93
maint: Move non-dynamically linked functions from DLD-FUNCTIONS/ to corefcn/ directory
Rik <rik@octave.org>
parents:
14501
diff
changeset
|
33 #include "defun.h" |
5164 | 34 #include "ov.h" |
35 #include "ov-fcn.h" | |
36 #include "ov-typeinfo.h" | |
37 #include "pager.h" | |
38 #include "parse.h" | |
39 #include "symtab.h" | |
40 #include "variables.h" | |
41 | |
15039
e753177cde93
maint: Move non-dynamically linked functions from DLD-FUNCTIONS/ to corefcn/ directory
Rik <rik@octave.org>
parents:
14501
diff
changeset
|
42 DEFUN (__dispatch__, args, nargout, |
17787
175b392e91fe
Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents:
17744
diff
changeset
|
43 "Undocumented internal function") |
5164 | 44 { |
45 octave_value retval; | |
7336 | 46 |
5164 | 47 int nargin = args.length (); |
48 | |
7336 | 49 if (nargin > 0 && nargin < 4) |
5164 | 50 { |
20617
ba2b07c13913
use new string_value method to handle value extraction errors
John W. Eaton <jwe@octave.org>
parents:
20478
diff
changeset
|
51 std::string f, r, t; |
7336 | 52 |
20617
ba2b07c13913
use new string_value method to handle value extraction errors
John W. Eaton <jwe@octave.org>
parents:
20478
diff
changeset
|
53 f = args(0).string_value ("__dispatch__: first argument must be a function name"); |
7336 | 54 |
55 if (nargin > 1) | |
20617
ba2b07c13913
use new string_value method to handle value extraction errors
John W. Eaton <jwe@octave.org>
parents:
20478
diff
changeset
|
56 r = args(1).string_value ("__dispatch__: second argument must be a function name"); |
7336 | 57 |
58 if (nargin > 2) | |
20617
ba2b07c13913
use new string_value method to handle value extraction errors
John W. Eaton <jwe@octave.org>
parents:
20478
diff
changeset
|
59 t = args(2).string_value ("__dispatch__: third argument must be a type name"); |
5164 | 60 |
7336 | 61 if (nargin == 1) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
62 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
63 if (nargout > 0) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
64 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
65 symbol_table::fcn_info::dispatch_map_type dm |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
66 = symbol_table::get_dispatch (f); |
7336 | 67 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
68 size_t len = dm.size (); |
7336 | 69 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
70 Cell type_field (len, 1); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
71 Cell name_field (len, 1); |
7336 | 72 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
73 symbol_table::fcn_info::dispatch_map_type::const_iterator p |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
74 = dm.begin (); |
7336 | 75 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
76 for (size_t i = 0; i < len; i++) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
77 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
78 type_field(i) = p->first; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
79 name_field(i) = p->second; |
7336 | 80 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
81 p++; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
82 } |
7336 | 83 |
11045
cc3aad9dd3ef
dispatch.cc, fltk_backend.cc, regexp.cc: use octave_scalar_map instead of Octave_map
John W. Eaton <jwe@octave.org>
parents:
10154
diff
changeset
|
84 octave_scalar_map m; |
7336 | 85 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
86 m.assign ("type", type_field); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
87 m.assign ("name", name_field); |
7336 | 88 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
89 retval = m; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
90 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
91 else |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
92 symbol_table::print_dispatch (octave_stdout, f); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
93 } |
7336 | 94 else if (nargin == 2) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
95 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
96 t = r; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
97 symbol_table::clear_dispatch (f, t); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
98 } |
7336 | 99 else |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
100 symbol_table::add_dispatch (f, t, r); |
5164 | 101 } |
7336 | 102 else |
103 print_usage (); | |
5164 | 104 |
105 return retval; | |
106 } | |
12823
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
107 |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
108 /* |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
109 ## No test needed for internal helper function. |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
110 %!assert (1) |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
111 */ |