Mercurial > octave-nkf
annotate libinterp/corefcn/__dispatch__.cc @ 20597:bc6daa38ff50
eliminate more simple uses of error_state
* graphics.cc: Eliminate simple uses of error_state.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Tue, 06 Oct 2015 14:47:41 -0400 |
parents | 610c74748518 |
children | ba2b07c13913 |
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 std::string f, r, t; |
5164 | 50 |
7336 | 51 if (nargin > 0 && nargin < 4) |
5164 | 52 { |
20478
610c74748518
maint: Clean up code based on static analysis suggestions.
Rik <rik@octave.org>
parents:
19731
diff
changeset
|
53 f = args(0).string_value (); |
7336 | 54 |
20478
610c74748518
maint: Clean up code based on static analysis suggestions.
Rik <rik@octave.org>
parents:
19731
diff
changeset
|
55 if (error_state) |
610c74748518
maint: Clean up code based on static analysis suggestions.
Rik <rik@octave.org>
parents:
19731
diff
changeset
|
56 { |
610c74748518
maint: Clean up code based on static analysis suggestions.
Rik <rik@octave.org>
parents:
19731
diff
changeset
|
57 error ("__dispatch__: first argument must be a function name"); |
610c74748518
maint: Clean up code based on static analysis suggestions.
Rik <rik@octave.org>
parents:
19731
diff
changeset
|
58 return retval; |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
59 } |
7336 | 60 |
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 r = args(1).string_value (); |
5164 | 64 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
65 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
66 { |
11553
01f703952eff
Improve docstrings for functions in DLD-FUNCTIONS directory.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
67 error ("__dispatch__: second argument must be a function name"); |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
68 return retval; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
69 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
70 } |
7336 | 71 |
72 if (nargin > 2) | |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
73 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
74 t = args(2).string_value (); |
7336 | 75 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
76 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
77 { |
11553
01f703952eff
Improve docstrings for functions in DLD-FUNCTIONS directory.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
78 error ("__dispatch__: third argument must be a type name"); |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
79 return retval; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
80 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
81 } |
5164 | 82 |
7336 | 83 if (nargin == 1) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
84 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
85 if (nargout > 0) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
86 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
87 symbol_table::fcn_info::dispatch_map_type dm |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
88 = symbol_table::get_dispatch (f); |
7336 | 89 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
90 size_t len = dm.size (); |
7336 | 91 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
92 Cell type_field (len, 1); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
93 Cell name_field (len, 1); |
7336 | 94 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
95 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
|
96 = dm.begin (); |
7336 | 97 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
98 for (size_t i = 0; i < len; i++) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
99 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
100 type_field(i) = p->first; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
101 name_field(i) = p->second; |
7336 | 102 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
103 p++; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
104 } |
7336 | 105 |
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
|
106 octave_scalar_map m; |
7336 | 107 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
108 m.assign ("type", type_field); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
109 m.assign ("name", name_field); |
7336 | 110 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
111 retval = m; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
112 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
113 else |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
114 symbol_table::print_dispatch (octave_stdout, f); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
115 } |
7336 | 116 else if (nargin == 2) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
117 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
118 t = r; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
119 symbol_table::clear_dispatch (f, t); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
120 } |
7336 | 121 else |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
122 symbol_table::add_dispatch (f, t, r); |
5164 | 123 } |
7336 | 124 else |
125 print_usage (); | |
5164 | 126 |
127 return retval; | |
128 } | |
12823
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
129 |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
130 /* |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
131 ## 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
|
132 %!assert (1) |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
133 */ |