Mercurial > hg > octave-lyh
annotate libinterp/corefcn/__dispatch__.cc @ 17535:c12c688a35ed default tip lyh
Fix warnings
author | LYH <lyh.kernel@gmail.com> |
---|---|
date | Fri, 27 Sep 2013 17:43:27 +0800 |
parents | 2fc554ffbc28 |
children |
rev | line source |
---|---|
5164 | 1 /* |
2 | |
14138
72c96de7a403
maint: update copyright notices for 2012
John W. Eaton <jwe@octave.org>
parents:
12823
diff
changeset
|
3 Copyright (C) 2001-2012 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, |
11226
16d744cce38c
deprecate the dispatch function
John W. Eaton <jwe@octave.org>
parents:
11225
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 { |
7336 | 53 if (nargin > 0) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
54 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
55 f = args(0).string_value (); |
7336 | 56 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
57 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
58 { |
11553
01f703952eff
Improve docstrings for functions in DLD-FUNCTIONS directory.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
59 error ("__dispatch__: first argument must be a function name"); |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
60 return retval; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
61 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
62 } |
7336 | 63 |
64 if (nargin > 1) | |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
65 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
66 r = args(1).string_value (); |
5164 | 67 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
68 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
69 { |
11553
01f703952eff
Improve docstrings for functions in DLD-FUNCTIONS directory.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
70 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
|
71 return retval; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
72 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
73 } |
7336 | 74 |
75 if (nargin > 2) | |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
76 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
77 t = args(2).string_value (); |
7336 | 78 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
79 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
80 { |
11553
01f703952eff
Improve docstrings for functions in DLD-FUNCTIONS directory.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
81 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
|
82 return retval; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
83 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
84 } |
5164 | 85 |
7336 | 86 if (nargin == 1) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
87 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
88 if (nargout > 0) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
89 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
90 symbol_table::fcn_info::dispatch_map_type dm |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
91 = symbol_table::get_dispatch (f); |
7336 | 92 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
93 size_t len = dm.size (); |
7336 | 94 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
95 Cell type_field (len, 1); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
96 Cell name_field (len, 1); |
7336 | 97 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
98 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
|
99 = dm.begin (); |
7336 | 100 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
101 for (size_t i = 0; i < len; i++) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
102 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
103 type_field(i) = p->first; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
104 name_field(i) = p->second; |
7336 | 105 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
106 p++; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
107 } |
7336 | 108 |
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
|
109 octave_scalar_map m; |
7336 | 110 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
111 m.assign ("type", type_field); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
112 m.assign ("name", name_field); |
7336 | 113 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
114 retval = m; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
115 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
116 else |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
117 symbol_table::print_dispatch (octave_stdout, f); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
118 } |
7336 | 119 else if (nargin == 2) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
120 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
121 t = r; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
122 symbol_table::clear_dispatch (f, t); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
123 } |
7336 | 124 else |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
125 symbol_table::add_dispatch (f, t, r); |
5164 | 126 } |
7336 | 127 else |
128 print_usage (); | |
5164 | 129 |
130 return retval; | |
131 } | |
12823
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
132 |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
133 /* |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
134 ## 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
|
135 %!assert (1) |
ab6fc7b40541
codesprint: add assert(1) test for __dispatch__
John W. Eaton <jwe@octave.org>
parents:
11553
diff
changeset
|
136 */ |