1Glib::BookmarkFile(3) User Contributed Perl DocumentationGlib::BookmarkFile(3)
2
3
4
6 Glib::BookmarkFile - Parser for bookmark files
7
9 use Glib;
10
11 $date .= $_ while (<DATA>);
12
13 $b = Glib::BookmarkFile->new;
14 $b->load_from_data($data);
15 $uri = 'file:///some/path/to/a/file.txt';
16 if ($b->has_item($uri)) {
17 $title = $b->get_title($uri);
18 $desc = $b->get_description($uri);
19
20 print "Bookmark for `$uri' ($title):\n";
21 print " $desc\n";
22 }
23 0;
24
25 __DATA__
26 <?xml version="1.0" encoding="UTF-8"?>
27 <xbel version="1.0"
28 xmlns:bookmark="http://www.freedesktop.org/standards/desktop-bookmarks"
29 xmlns:mime="http://www.freedesktop.org/standards/shared-mime-info">
30 <bookmark href="file:///tmp/test-file.txt" added="2006-03-22T18:54:00Z" modified="2006-03-22T18:54:00Z" visited="2006-03-22T18:54:00Z">
31 <title>Test File</title>
32 <desc>Some test file</desc>
33 <info>
34 <metadata owner="http://freedesktop.org">
35 <mime:mime-type type="text/plain"/>
36 <bookmark:applications>
37 <bookmark:application name="Gedit" exec="gedit %u" timestamp="1143053640" count="1"/>
38 </bookmark:applications>
39 </metadata>
40 </info>
41 </bookmark>
42 </xbel>
43
45 Glib::BookmarkFile lets you parse, edit or create files containing
46 lists of bookmarks to resources pointed to by URIs, with some meta-data
47 bound to them, following the Desktop Bookmark Specification. The
48 recent files support inside GTK+ uses this type of files to store the
49 list of recently used files.
50
51 The syntax of bookmark files is described in detail in the Desktop
52 Bookmarks Specification, here is a quick summary: bookmark files use a
53 subclass of the XML Bookmark Exchange Language (XBEL) document format,
54 defining meta-data such as the MIME type of the resource pointed by a
55 bookmark, the list of applications that have registered the same URI
56 and the visibility of the bookmark.
57
59 bookmarkfile = Glib::BookmarkFile->new
60 $bookmark_file->add_application ($uri, $name, $exec)
61 · $uri (string)
62
63 · $name (string or undef)
64
65 · $exec (string or undef)
66
67 Adds the application with $name and $exec to the list of applications
68 that have registered a bookmark for $uri into $bookmark_file.
69
70 Every bookmark inside a "Glib::BookmarkFile" must have at least an
71 application registered. Each application must provide a name, a
72 command line useful for launching the bookmark, the number of times the
73 bookmark has been registered by the application and the last time the
74 application registered this bookmark.
75
76 If $name is undef, the name of the application will be the same
77 returned by Glib::get_application_name(); if $exec is undef, the
78 command line will be a composition of the program name as returned by
79 Glib::get_prgname() and the "%u" modifier, which will be expanded to
80 the bookmark's URI.
81
82 This function will automatically take care of updating the
83 registrations count and timestamping in case an application with the
84 same $name had already registered a bookmark for $uri inside the
85 bookmark file. If no bookmark for $uri is found one is created.
86
87 $bookmark_file->add_group ($uri, $group)
88 · $uri (string)
89
90 · $group (string)
91
92 Adds $group to the list of groups to which the bookmark for $uri
93 belongs to. If no bookmark for $uri is found one is created.
94
95 unix timestamp = $bookmark_file->get_added ($uri)
96 · $uri (string)
97
98 $bookmark_file->set_added ($uri, $value)
99 · $uri (string)
100
101 · $value (unix timestamp)
102
103 Sets the time the bookmark for $uri was added. If no bookmark for $uri
104 is found one is created.
105
106 ($exec, $count, $stamp) = $bookmark_file->get_app_info ($uri, $name)
107 · $uri (string)
108
109 · $name (string)
110
111 Gets the registration information of $name for the bookmark for $uri.
112 See Glib::BookmarkFile::set_app_info() for more information about the
113 returned data.
114
115 May croak with a Glib::Error in $@ on failure.
116
117 $bookmark_file->set_app_info ($uri, $name, $exec, $count, $stamp)
118 · $uri (string)
119
120 · $name (string)
121
122 · $exec (string)
123
124 · $count (integer)
125
126 · $stamp (unix timestamp)
127
128 Sets the meta-data of application $name inside the list of applications
129 that have registered a bookmark for $uri inside $bookmark_file.
130
131 You should rarely use this method; use
132 Glib::BookmarkFile::add_application() and
133 Glib::BookmarkFile::remove_application() instead.
134
135 $name can be any UTF-8 encoded string used to identify an application.
136 $exec can have one of these two modifiers: "%f", which will be expanded
137 as the local file name retrieved from the bookmark's URI; "%u", which
138 will be expanded as the bookmark's URI. The expansion is done
139 automatically when retrieving the stored command line using the
140 Glib::BookmarkFile::get_app_info() method. $count is the number of
141 times the application has registered the bookmark; if it is < 0, the
142 current registration count will be increased by one, if it is 0, the
143 application with $name will be removed from the list of registered
144 applications. $stamp is the Unix time of the last registration, as
145 returned by time(); if it is -1, the current time will be used.
146
147 If you try to remove an application by setting its registration count
148 to zero, and no bookmark for $uri is found, %FALSE is returned and an
149 exception is fired.
150
151 May croak with a Glib::Error in $@ on failure.
152
153 list = $bookmark_file->get_applications ($uri)
154 · $uri (string)
155
156 Retrieves the names of the applications that have registered the
157 bookmark for $uri.
158
159 May croak with a Glib::Error in $@ on failure.
160
161 $bookmark_file->get_description ($uri)
162 · $uri (string)
163
164 Gets the description of the bookmark for $uri.
165
166 May croak with a Glib::Error in $@ on failure.
167
168 $bookmark_file->set_description ($uri, $description)
169 · $uri (string)
170
171 · $description (string)
172
173 Sets the description of the bookmark for $uri. If no bookmark for $uri
174 is found one is created.
175
176 list = $bookmark_file->get_groups ($uri)
177 · $uri (string)
178
179 Retrieves the list of group names of the bookmark for $uri.
180
181 May croak with a Glib::Error in $@ on failure.
182
183 $bookmark_file->set_groups ($uri, ...)
184 · $uri (string)
185
186 · ... (list) one or more group names
187
188 Sets a list of group names for the item with URI $uri. Each previously
189 set group name list is removed. If no bookmark for $uri is found one
190 is created.
191
192 boolean = $bookmark_file->has_application ($uri, $name)
193 · $uri (string)
194
195 · $name (string)
196
197 Checks whether the bookmark for $uri inside $bookmark_file has been
198 registered by application $name.
199
200 May croak with a Glib::Error in $@ on failure.
201
202 boolean = $bookmark_file->has_group ($uri, $group)
203 · $uri (string)
204
205 · $group (string)
206
207 Checks whether $group appears in the list of groups to which the
208 bookmark for $uri belongs to.
209
210 May croak with a Glib::Error in $@ on failure.
211
212 boolean = $bookmark_file->has_item ($uri)
213 · $uri (string)
214
215 Looks whether the bookmark file has a bookmark for $uri.
216
217 ($href, $mime_type) = $bookmark_file->get_icon ($uri)
218 · $uri (string)
219
220 Gets the icon of the bookmark for $uri.
221
222 May croak with a Glib::Error in $@ on failure.
223
224 $bookmark_file->set_icon ($uri, $href, $mime_type)
225 · $uri (string)
226
227 · $href (string or undef)
228
229 · $mime_type (string or undef)
230
231 Sets the icon for the bookmark for $uri. If $href is undef, unsets the
232 currently set icon.
233
234 boolean = $bookmark_file->get_is_private ($uri)
235 · $uri (string)
236
237 May croak with a Glib::Error in $@ on failure.
238
239 $bookmark_file->set_is_private ($uri, $is_private)
240 · $uri (string)
241
242 · $is_private (boolean)
243
244 $bookmark_file->load_from_data ($buf)
245 · $buf (scalar)
246
247 Parses a string containing a bookmark file structure.
248
249 May croak with a Glib::Error in $@ on failure.
250
251 ($full_path) = $bookmark_file->load_from_data_dirs ($file)
252 · $file (localized file name)
253
254 Parses a bookmark file, searching for it inside the data directories.
255 If a file is found, it returns the full path.
256
257 May croak with a Glib::Error in $@ on failure.
258
259 $bookmark_file->load_from_file ($file)
260 · $file (localized file name)
261
262 Parses a bookmark file.
263
264 May croak with a Glib::Error in $@ on failure.
265
266 string = $bookmark_file->get_mime_type ($uri)
267 · $uri (string)
268
269 Gets the MIME type of the bookmark for $uri.
270
271 May croak with a Glib::Error in $@ on failure.
272
273 $bookmark_file->set_mime_type ($uri, $mime_type)
274 · $uri (string)
275
276 · $mime_type (string)
277
278 Sets the MIME type of the bookmark for $uri. If no bookmark for $uri
279 is found one is created.
280
281 unix timestamp = $bookmark_file->get_modified ($uri)
282 · $uri (string)
283
284 $bookmark_file->set_modified ($uri, $value)
285 · $uri (string)
286
287 · $value (unix timestamp)
288
289 Sets the time the bookmark for $uri was last modified. If no bookmark
290 for $uri is found one is created.
291
292 $bookmark_file->move_item ($old_uri, $new_uri)
293 · $old_uri (string)
294
295 · $new_uri (string or undef)
296
297 Changes the URI of a bookmark item from $old_uri to $new_uri. Any
298 existing bookmark for $new_uri will be overwritten. If $new_uri is
299 undef, then the bookmark is removed.
300
301 May croak with a Glib::Error in $@ on failure.
302
303 $bookmark_file->remove_application ($uri, $name)
304 · $uri (string)
305
306 · $name (string)
307
308 Removes application registered with $name from the list of applications
309 that have registered a bookmark for $uri inside $bookmark_file.
310
311 May croak with a Glib::Error in $@ on failure.
312
313 $bookmark_file->remove_group ($uri, $group)
314 · $uri (string)
315
316 · $group (string)
317
318 Removes $group from the list of groups to which the bookmark for $uri
319 belongs to.
320
321 May croak with a Glib::Error in $@ on failure.
322
323 $bookmark_file->remove_item ($uri)
324 · $uri (string)
325
326 Removes the bookmark for $uri from the bookmark file.
327
328 May croak with a Glib::Error in $@ on failure.
329
330 integer = $bookmark_file->get_size
331 Gets the number of bookmarks inside the bookmark file.
332
333 $bookmark_file->get_title ($uri, $title)
334 · $uri (string)
335
336 Gets the title of the bookmark for $uri.
337
338 May croak with a Glib::Error in $@ on failure.
339
340 $bookmark_file->set_title ($uri, $title)
341 · $uri (string)
342
343 · $title (string)
344
345 Sets the title of the bookmark for $uri. If no bookmark for $uri is
346 found one is created.
347
348 string = $bookmark_file->to_data
349 Returns the bookmark file as a string.
350
351 May croak with a Glib::Error in $@ on failure.
352
353 $bookmark_file->to_file ($file)
354 · $file (localized file name)
355
356 Saves the contents of a bookmark file into a file. The write operation
357 is guaranteed to be atomic by writing the contents of the bookmark file
358 to a temporary file and then moving the file to the target file.
359
360 May croak with a Glib::Error in $@ on failure.
361
362 list = $bookmark_file->get_uris
363 Returns the URI of all the bookmarks in the bookmark file.
364
365 unix timestamp = $bookmark_file->get_visited ($uri)
366 · $uri (string)
367
368 $bookmark_file->set_visited ($uri, $value)
369 · $uri (string)
370
371 · $value (unix timestamp)
372
373 Sets the time the bookmark for $uri was last visited. If no bookmark
374 for $uri is found one is created.
375
377 Glib
378
380 Copyright (C) 2003-2011 by the gtk2-perl team.
381
382 This software is licensed under the LGPL. See Glib for a full notice.
383
384
385
386perl v5.30.0 2019-07-29 Glib::BookmarkFile(3)