Mercurial > hg > octave-lyh
annotate src/DLD-FUNCTIONS/__dispatch__.cc @ 11226:16d744cce38c
deprecate the dispatch function
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Wed, 10 Nov 2010 16:04:31 -0500 |
parents | src/DLD-FUNCTIONS/dispatch.cc@8d8e10058df6 |
children | fd0a3ac60b0e |
rev | line source |
---|---|
5164 | 1 /* |
2 | |
8920 | 3 Copyright (C) 2001, 2005, 2006, 2007, 2008, 2009 |
4 John W. Eaton and Paul Kienzle | |
5164 | 5 |
7016 | 6 This file is part of Octave. |
7 | |
8 Octave is free software; you can redistribute it and/or modify it | |
5164 | 9 under the terms of the GNU General Public License as published by the |
7016 | 10 Free Software Foundation; either version 3 of the License, or (at your |
11 option) any later version. | |
5164 | 12 |
7016 | 13 Octave is distributed in the hope that it will be useful, but WITHOUT |
5164 | 14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
16 for more details. | |
17 | |
18 You should have received a copy of the GNU General Public License | |
7016 | 19 along with Octave; see the file COPYING. If not, see |
20 <http://www.gnu.org/licenses/>. | |
5164 | 21 |
22 */ | |
23 | |
24 #ifdef HAVE_CONFIG_H | |
25 #include <config.h> | |
26 #endif | |
27 | |
28 #include <list> | |
29 #include <map> | |
30 #include <string> | |
31 | |
7336 | 32 #include "Cell.h" |
33 #include "oct-map.h" | |
5164 | 34 #include "defun-dld.h" |
35 #include "ov.h" | |
36 #include "ov-fcn.h" | |
37 #include "ov-typeinfo.h" | |
38 #include "pager.h" | |
39 #include "parse.h" | |
40 #include "symtab.h" | |
41 #include "variables.h" | |
42 | |
11226
16d744cce38c
deprecate the dispatch function
John W. Eaton <jwe@octave.org>
parents:
11225
diff
changeset
|
43 DEFUN_DLD (__dispatch__, args, nargout, |
16d744cce38c
deprecate the dispatch function
John W. Eaton <jwe@octave.org>
parents:
11225
diff
changeset
|
44 "Undocumented internal function") |
5164 | 45 { |
46 octave_value retval; | |
7336 | 47 |
5164 | 48 int nargin = args.length (); |
49 | |
7336 | 50 std::string f, r, t; |
5164 | 51 |
7336 | 52 if (nargin > 0 && nargin < 4) |
5164 | 53 { |
7336 | 54 if (nargin > 0) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
55 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
56 f = args(0).string_value (); |
7336 | 57 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
58 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
59 { |
11226
16d744cce38c
deprecate the dispatch function
John W. Eaton <jwe@octave.org>
parents:
11225
diff
changeset
|
60 error ("__dispatch__: expecting first argument to be function name"); |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
61 return retval; |
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 } |
7336 | 64 |
65 if (nargin > 1) | |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
66 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
67 r = args(1).string_value (); |
5164 | 68 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
69 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
70 { |
11226
16d744cce38c
deprecate the dispatch function
John W. Eaton <jwe@octave.org>
parents:
11225
diff
changeset
|
71 error ("__dispatch__: expecting second argument to be function name"); |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
72 return retval; |
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 } |
7336 | 75 |
76 if (nargin > 2) | |
10154
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 t = args(2).string_value (); |
7336 | 79 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
80 if (error_state) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
81 { |
11226
16d744cce38c
deprecate the dispatch function
John W. Eaton <jwe@octave.org>
parents:
11225
diff
changeset
|
82 error ("__dispatch__: expecting third argument to be type name"); |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
83 return retval; |
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 } |
5164 | 86 |
7336 | 87 if (nargin == 1) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
88 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
89 if (nargout > 0) |
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 symbol_table::fcn_info::dispatch_map_type dm |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
92 = symbol_table::get_dispatch (f); |
7336 | 93 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
94 size_t len = dm.size (); |
7336 | 95 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
96 Cell type_field (len, 1); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
97 Cell name_field (len, 1); |
7336 | 98 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
99 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
|
100 = dm.begin (); |
7336 | 101 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
102 for (size_t i = 0; i < len; i++) |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
103 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
104 type_field(i) = p->first; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
105 name_field(i) = p->second; |
7336 | 106 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
107 p++; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
108 } |
7336 | 109 |
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
|
110 octave_scalar_map m; |
7336 | 111 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
112 m.assign ("type", type_field); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
113 m.assign ("name", name_field); |
7336 | 114 |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
115 retval = m; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
116 } |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
117 else |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
118 symbol_table::print_dispatch (octave_stdout, f); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
119 } |
7336 | 120 else if (nargin == 2) |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
121 { |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
122 t = r; |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
123 symbol_table::clear_dispatch (f, t); |
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
124 } |
7336 | 125 else |
10154
40dfc0c99116
DLD-FUNCTIONS/*.cc: untabify
John W. Eaton <jwe@octave.org>
parents:
9444
diff
changeset
|
126 symbol_table::add_dispatch (f, t, r); |
5164 | 127 } |
7336 | 128 else |
129 print_usage (); | |
5164 | 130 |
131 return retval; | |
132 } |