Gtk2-Ex-WidgetBits
view release on metacpan or search on metacpan
lib/Gtk2/Ex/Statusbar/DynamicContext.pm view on Meta::CPAN
sub DESTROY {
my ($self) = @_;
if (my $statusbar = $self->statusbar) {
push @{$statusbar->{__PACKAGE__.'.free'}}, $self->str;
}
}
1;
__END__
=for stopwords Statusbar DynamicContext runtime DynamicContexts statusbar statusbars Ryde Gtk2-Ex-WidgetBits
=head1 NAME
Gtk2::Ex::Statusbar::DynamicContext -- pool of Gtk2::Statusbar context strings
=for test_synopsis my ($statusbar)
=head1 SYNOPSIS
use Gtk2::Ex::Statusbar::DynamicContext;
my $dc = Gtk2::Ex::Statusbar::DynamicContext->new
($statusbar);
$statusbar->push ($dc->id, 'Some message');
$statusbar->pop ($dc->id);
=head1 DESCRIPTION
A DynamicContext object is a generated context string and ID number for a
C<Gtk2::Statusbar> widget. It's designed for message sources or contexts
which are created and destroyed dynamically at runtime.
Usually you don't need a dynamic context. Most libraries or parts of a
program can just take something distinctive from their name as a context
string. For example a Perl package name, or package name plus component.
# fixed id for package
$id = $statusbar->get_context_id(__PACKAGE__.'.warning');
Dynamic context is when you do something like spawn multiple object
instances each of which might display a status message. In that case they
need a separate context string each.
# dynamic id for each instance of a package
$obj = MyPackage->new;
$obj->{'dc'} = Gtk2::Ex::Statusbar::DynamicContext->new($statusbar);
$id = $obj->{'dc'}->id;
When a DynamicContext object is garbage collected the string is returned to
a pool for future re-use on the Statusbar widget. This is important for a
long-running program because a context string and its ID in a Statusbar are
permanent additions to the memory of that widget and to the global quark
table. That means a simple approach like sequentially numbered context
strings is not enough, it would consume ever more memory. With
DynamicContext style re-use the space is capped at the peak number of
contexts used at any one time.
=head2 Weakening
DynamicContext only holds a weak reference to its C<$statusbar>, so the mere
fact a message context exists doesn't keep the Statusbar alive.
=head1 FUNCTIONS
=over 4
=item C<< $dc = Gtk2::Ex::Statusbar::DynamicContext->new ($statusbar) >>
Create and return a new DynamicContext object for C<$statusbar> (a
C<Gtk2::Statusbar> widget).
=item C<< $id = $dc->id() >>
Return the context ID (an integer) from C<$dc>. It can be used with
C<< $statusbar->push >> etc.
$statusbar->push ($dc->id, 'Some message');
If the statusbar has been garbage collected then the return from C<id()> is
unspecified.
=item C<< $str = $dc->str() >>
Return the context description string from C<$dc>. This is not often
needed, usually the integer C<id()> is enough. In the current
implementation the string is like
"Gtk2::Ex::Statusbar::DynamicContext.123"
but don't depend on its exact form, only that it's unique within the target
C<$statusbar>. The C<id()> method above is simply
$statusbar->get_context_id($dc->str)
DynamicContext strings are unique within the particular C<$statusbar> but
are not globally unique, ie. the same string might be used by another
DynamicContext object on another statusbar. Doing so keeps down the size of
the Glib quark table.
=item C<< $statusbar = $dc->statusbar() >>
Return the C<Gtk2::Statusbar> from C<$dc>. If the statusbar has been
garbage collected then this is C<undef>.
=back
=head1 SEE ALSO
L<Gtk2::Statusbar>,
L<Scalar::Util/weaken>
L<Gtk2::Ex::Statusbar::Message>,
L<Gtk2::Ex::Statusbar::MessageUntilKey>
=head1 HOME PAGE
L<http://user42.tuxfamily.org/gtk2-ex-widgetbits/index.html>
=head1 LICENSE
Copyright 2008, 2009, 2010, 2011, 2012 Kevin Ryde
( run in 0.700 second using v1.01-cache-2.11-cpan-483215c6ad5 )