1Gtk2::UniqueApp(3) User Contributed Perl Documentation Gtk2::UniqueApp(3)
2
3
4
6 Gtk2::UniqueApp - Base class for singleton applications
7
9 use Gtk2 '-init';
10 use Gtk2::Unique;
11
12 my $COMMAND_FOO = 1;
13 my $COMMAND_BAR = 2;
14
15 my $app = Gtk2::UniqueApp->new(
16 "org.example.UnitTets", undef,
17 foo => $COMMAND_FOO,
18 bar => $COMMAND_BAR,
19 );
20 if ($app->is_running) {
21 # The application is already running, send it a message
22 $app->send_message_by_name('foo', text => "Hello world");
23 }
24 else {
25 my $window = Gtk2::Window->new();
26 my $label = Gtk2::Label->new("Waiting for a message");
27 $window->add($label);
28 $window->set_size_request(480, 120);
29 $window->show_all();
30
31 $window->signal_connect(delete_event => sub {
32 Gtk2->main_quit();
33 return TRUE;
34 });
35
36 # Watch the main window and register a handler that will be called each time
37 # that there's a new message.
38 $app->watch_window($window);
39 $app->signal_connect('message-received' => sub {
40 my ($app, $command, $message, $time) = @_;
41 $label->set_text($message->get_text);
42 return 'ok';
43 });
44
45 Gtk2->main();
46 }
47
49 Gtk2::UniqueApp is the base class for single instance applications. You
50 can either create an instance of UniqueApp via "Gtk2::UniqueApp->new()"
51 and "Gtk2::UniqueApp->_with_commands()"; or you can subclass
52 Gtk2::UniqueApp with your own application class.
53
54 A Gtk2::UniqueApp instance is guaranteed to either be the first running
55 at the time of creation or be able to send messages to the currently
56 running instance; there is no race possible between the creation of the
57 Gtk2::UniqueApp instance and the call to
58 "Gtk2::UniqueApp::is_running()".
59
60 The usual method for using the Gtk2::UniqueApp API is to create a new
61 instance, passing an application-dependent name as construction-only
62 property; the "Gtk2::UniqueApp:name" property is required, and should
63 be in the form of a domain name, like org.gnome.YourApplication.
64
65 After the creation, you should check whether an instance of your
66 application is already running, using "Gtk2::UniqueApp::is_running()";
67 if this method returns "FALSE" the usual application construction
68 sequence can continue; if it returns "TRUE" you can either exit or send
69 a message using Gtk2::UniqueMessageData and
70 "Gtk2::UniqueMessageData::send_message()".
71
72 You can define custom commands using "Gtk2::UniqueApp::add_command()":
73 you need to provide an arbitrary integer and a string for the command.
74
76 Glib::Object
77 +----Gtk2::UniqueApp
78
80 uniqueapp = Gtk2::UniqueApp->new ($name, $startup_id, ...)
81 • $name (string)
82
83 • $startup_id (string or undef)
84
85 • ... (list)
86
87 Creates a new Gtk2::UniqueApp instance for name passing a start-up
88 notification id startup_id. The name must be a unique identifier for
89 the application, and it must be in form of a domain name, like
90 org.gnome.YourApplication.
91
92 If startup_id is "undef" the DESKTOP_STARTUP_ID environment variable
93 will be check, and if that fails a "fake" startup notification id will
94 be created.
95
96 Once you have created a Gtk2::UniqueApp instance, you should check if
97 any other instance is running, using "Gtk2::UniqueApp::is_running()".
98 If another instance is running you can send a command to it, using the
99 "Gtk2::UniqueApp::send_message()" function; after that, the second
100 instance should quit. If no other instance is running, the usual logic
101 for creating the application can follow.
102
103 uniqueapp = Gtk2::UniqueApp->new_with_commands ($name, $startup_id, ...)
104 • $name (string)
105
106 • $startup_id (string or undef)
107
108 • ... (list)
109
110 An alias for "Gtk2::UniqueApp->new()".
111
112 $app->add_command ($command_name, $command_id)
113 • $command_name (string)
114
115 • $command_id (integer)
116
117 Adds command_name as a custom command that can be used by app. You must
118 call "Gtk2::UniqueApp::add_command()" before
119 "Gtk2::UniqueApp::send_message()" in order to use the newly added
120 command.
121
122 The command name is used internally: you need to use the command's
123 logical id in "Gtk2::UniqueApp::send_message()" and inside the message-
124 received signal.
125
126 boolean = $app->is_running
127 Checks whether another instance of app is running.
128
129 uniqueresponse = $app->send_message ($command, ...)
130 • $command (scalar)
131
132 • ... (list)
133
134 Same as "Gkt2::UniqueApp::send_message_by_name()", but uses a message
135 id instead of a name.
136
137 uniqueresponse = $app->send_message_by_name ($command, ...)
138 • $command (scalar)
139
140 • ... (list)
141
142 Sends command to a running instance of app. If you need to pass data to
143 the instance, you have to indicate the type of message that will be
144 passed. The accepted types are:
145
146 text
147 A plain text message
148
149 data
150 Rad data
151
152 filename
153 A file name
154
155 uris
156 URI, multiple values can be passed
157
158 The running application will receive a message-received signal and will
159 call the various signal handlers attach to it. If any handler returns a
160 "Gtk2::UniqueResponse" different than "ok", the emission will stop.
161
162 Usages:
163
164 $app->send_message_by_name(write => data => $data);
165 $app->send_message_by_name(greet => text => "Hello World!");
166 $app->send_message_by_name(open => uris =>
167 'http://search.cpan.org/',
168 'http://www.gnome.org/',
169 );
170
171 NOTE: If you prefer to use an ID instead of a message name then use the
172 function "Gkt2::UniqueApp::send_message()". The usage is the same as
173 this one.
174
175 $app->watch_window ($window)
176 • $window (Gtk2::Window)
177
178 Makes app "watch" a window. Every watched window will receive startup
179 notification changes automatically.
180
182 'is-running' (boolean : default false : readable / private / static-
183 nick / static-blurb)
184 Whether another instance is running
185
186 'name' (string : default undef : readable / writable / construct-only /
187 private / static-nick / static-blurb)
188 The unique name of the application
189
190 'screen' (Gtk2::Gdk::Screen : default undef : readable / writable /
191 construct / private / static-nick / static-blurb)
192 The GdkScreen of the application
193
194 'startup-id' (string : default undef : readable / writable / construct-
195 only / private / static-nick / static-blurb)
196 The startup notification id for the application
197
199 Gtk2::UniqueResponse = message-received (Gtk2::UniqueApp, integer,
200 Gtk2::UniqueMessageData, Glib::UInt)
201
203 enum Gtk2::UniqueResponse
204 • 'invalid' / 'UNIQUE_RESPONSE_INVALID'
205
206 • 'ok' / 'UNIQUE_RESPONSE_OK'
207
208 • 'cancel' / 'UNIQUE_RESPONSE_CANCEL'
209
210 • 'fail' / 'UNIQUE_RESPONSE_FAIL'
211
212 • 'passthrough' / 'UNIQUE_RESPONSE_PASSTHROUGH'
213
215 Gtk2::Unique, Glib::Object
216
218 Copyright (C) 2009-2017 by Emmanuel Rodriguez
219
220
221
222perl v5.36.0 2022-07-22 Gtk2::UniqueApp(3)