1POE::Component::PluggabUlsee:r:PCiopnetlriinbeu(t3e)d PePrOlE:D:oCcoummpeonnteantti:o:nPluggable::Pipeline(3)
2
3
4
6 POE::Component::Pluggable::Pipeline - the plugin pipeline for
7 POE::Component::Pluggable
8
10 version 1.28
11
13 use POE qw( Component::Pluggable );
14 use POE::Component::Pluggable::Pipeline;
15 use My::Plugin;
16
17 my $self = POE::Component::Pluggable->new();
18
19 # the following operations are presented in pairs
20 # the first is the general procedure, the second is
21 # the specific way using the pipeline directly
22
23 # to install a plugin
24 $self->plugin_add(mine => My::Plugin->new);
25 $self->pipeline->push(mine => My::Plugin->new);
26
27 # to remove a plugin
28 $self->plugin_del('mine'); # or the object
29 $self->pipeline->remove('mine'); # or the object
30
31 # to get a plugin
32 my $plug = $self->plugin_get('mine');
33 my $plug = $self->pipeline->get('mine');
34
35 # there are other very specific operations that
36 # the pipeline offers, demonstrated here:
37
38 # to get the pipeline object itself
39 my $pipe = $self->pipeline;
40
41 # to install a plugin at the front of the pipeline
42 $pipe->unshift(mine => My::Plugin->new);
43
44 # to remove the plugin at the end of the pipeline
45 my $plug = $pipe->pop;
46
47 # to remove the plugin at the front of the pipeline
48 my $plug = $pipe->shift;
49
50 # to replace a plugin with another
51 $pipe->replace(mine => newmine => My::Plugin->new);
52
53 # to insert a plugin before another
54 $pipe->insert_before(mine => newmine => My::Plugin->new);
55
56 # to insert a plugin after another
57 $pipe->insert_after(mine => newmine => My::Plugin->new);
58
59 # to get the location in the pipeline of a plugin
60 my $index = $pipe->get_index('mine');
61
62 # to move a plugin closer to the front of the pipeline
63 $pipe->bump_up('mine');
64
65 # to move a plugin closer to the end of the pipeline
66 $pipe->bump_down('mine');
67
69 POE::Component::Pluggable::Pipeline defines the Plugin pipeline system
70 for POE::Component::Pluggable instances.
71
73 "new"
74 Takes one argument, the POE::Component::Pluggable object to attach to.
75
76 "push"
77 Takes two arguments, an alias for a plugin and the plugin object
78 itself. If a plugin with that alias already exists, $@ will be set and
79 "undef" will be returned. Otherwise, it adds the plugin to the end of
80 the pipeline and registers it. This will yield a "plugin_add" event. If
81 successful, it returns the size of the pipeline.
82
83 my $new_size = $pipe->push($name, $plug);
84
85 "unshift"
86 Takes two arguments, an alias for a plugin and the plugin object
87 itself. If a plugin with that alias already exists, $@ will be set and
88 "undef" will be returned. Otherwise, it adds the plugin to the
89 beginning of the pipeline and registers it. This will yield a
90 "plugin_add" event. If successful, it returns the size of the pipeline.
91
92 my $new_size = $pipe->push($name, $plug);
93
94 "shift"
95 Takes no arguments. The first plugin in the pipeline is removed. This
96 will yield a "plugin_del" event. In list context, it returns the plugin
97 and its alias; in scalar context, it returns only the plugin. If there
98 were no elements, an empty list or "undef" will be returned.
99
100 my ($plug, $name) = $pipe->shift;
101 my $plug = $pipe->shift;
102
103 "pop"
104 Takes no arguments. The last plugin in the pipeline is removed. This
105 will yield an "plugin_del" event. In list context, it returns the
106 plugin and its alias; in scalar context, it returns only the plugin. If
107 there were no elements, an empty list or "undef" will be returned.
108
109 my ($plug, $name) = $pipe->pop;
110 my $plug = $pipe->pop;
111
112 "replace"
113 Take three arguments, the old plugin or its alias, an alias for the new
114 plugin and the new plugin object itself. If the old plugin doesn't
115 exist, or if there is already a plugin with the new alias (besides the
116 old plugin), $@ will be set and "undef" will be returned. Otherwise, it
117 removes the old plugin (yielding an "plugin_del" event) and replaces it
118 with the new plugin. This will yield an "plugin_add" event. If
119 successful, it returns 1.
120
121 my $success = $pipe->replace($name, $new_name, $new_plug);
122 my $success = $pipe->replace($plug, $new_name, $new_plug);
123
124 "insert_before"
125 Takes three arguments, the plugin that is relative to the operation, an
126 alias for the new plugin and the new plugin object itself. If the first
127 plugin doesn't exist, or if there is already a plugin with the new
128 alias, $@ will be set and "undef" will be returned. Otherwise, the new
129 plugin is placed just prior to the other plugin in the pipeline. If
130 successful, it returns 1.
131
132 my $success = $pipe->insert_before($name, $new_name, $new_plug);
133 my $success = $pipe->insert_before($plug, $new_name, $new_plug);
134
135 "insert_after"
136 Takes three arguments, the plugin that is relative to the operation, an
137 alias for the new plugin and the new plugin object itself. If the first
138 plugin doesn't exist, or if there is already a plugin with the new
139 alias, $@ will be set and "undef" will be returned. Otherwise, the new
140 plugin is placed just after to the other plugin in the pipeline. If
141 successful, it returns 1.
142
143 my $success = $pipe->insert_after($name, $new_name, $new_plug);
144 my $success = $pipe->insert_after($plug, $new_name, $new_plug);
145
146 "bump_up"
147 Takes one or two arguments, the plugin or its alias, and the distance
148 to bump the plugin. The distance defaults to 1. If the plugin doesn't
149 exist, $@ will be set and -1 will be returned, not undef. Otherwise,
150 the plugin will be moved the given distance closer to the front of the
151 pipeline. A warning is issued alerting you if it would have been moved
152 past the beginning of the pipeline, and the plugin is placed at the
153 beginning. If successful, the new index of the plugin in the pipeline
154 is returned.
155
156 my $pos = $pipe->bump_up($name);
157 my $pos = $pipe->bump_up($plug);
158 my $pos = $pipe->bump_up($name, $delta);
159 my $pos = $pipe->bump_up($plug, $delta);
160
161 "bump_down"
162 Takes one or two arguments, the plugin or its alias, and the distance
163 to bump the plugin. The distance defaults to 1. If the plugin doesn't
164 exist, $@ will be set and -1 will be returned, not "undef". Otherwise,
165 the plugin will be moved the given distance closer to the end of the
166 pipeline. A warning is issued alerting you if it would have been moved
167 past the end of the pipeline, and the plugin is placed at the end. If
168 successful, the new index of the plugin in the pipeline is returned.
169
170 my $pos = $pipe->bump_down($name);
171 my $pos = $pipe->bump_down($plug);
172 my $pos = $pipe->bump_down($name, $delta);
173 my $pos = $pipe->bump_down($plug, $delta);
174
175 "remove"
176 Takes one argument, a plugin or its alias. If the plugin doesn't exist,
177 $@ will be set and "undef" will be returned. Otherwise, the plugin is
178 removed from the pipeline. This will yield an "plugin_del" event. In
179 list context,it returns the plugin and its alias; in scalar context, it
180 returns only the plugin.
181
182 my ($plug, $name) = $pipe->remove($the_name);
183 my ($plug, $name) = $pipe->remove($the_plug);
184 my $plug = $pipe->remove($the_name);
185 my $plug = $pipe->remove($the_plug);
186
187 "get"
188 Takes one argument, a plugin or its alias. If no such plugin exists, $@
189 will be set and "undef" will be returned. In list context, it returns
190 the plugin and its alias; in scalar context, it returns only the
191 plugin.
192
193 my ($plug, $name) = $pipe->get($the_name);
194 my ($plug, $name) = $pipe->get($the_plug);
195 my $plug = $pipe->get($the_name);
196 my $plug = $pipe->get($the_plug);
197
198 "get_index"
199 Takes one argument, a plugin or its alias. If no such plugin exists, $@
200 will be set and -1 will be returned, not "undef". Otherwise, the index
201 in the pipeline is returned.
202
203 my $pos = $pipe->get_index($name);
204 my $pos = $pipe->get_index($plug);
205
207 None known so far.
208
210 POE::Component::IRC,
211
212 POE::Component::Pluggable.
213
215 · Chris Williams <chris@bingosnet.co.uk>
216
217 · Apocalypse <perl@0ne.us>
218
219 · Hinrik Örn Sigurðsson
220
221 · Jeff Pinyan
222
224 This software is copyright (c) 2017 by Chris Williams.
225
226 This is free software; you can redistribute it and/or modify it under
227 the same terms as the Perl 5 programming language system itself.
228
229
230
231perl v5.30.0 2019-07P-O2E6::Component::Pluggable::Pipeline(3)