File: example-root-container-vala.vala

package info (click to toggle)
rygel 45.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 8,732 kB
  • sloc: xml: 1,756; ansic: 1,081; python: 226; sh: 64; makefile: 24
file content (55 lines) | stat: -rw-r--r-- 2,272 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
 * Copyright (C) 2012 Intel Corporation
 *
 * This file is part of Rygel.
 *
 * Rygel is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * Rygel is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 */

/**
 * Our derived MediaContainer.
 * In this example, we just derive from the SimpleContainer,
 * but a real-world server plugin might need something more sophisticated.
 */
public class Rygel.Example.RootContainerVala : Rygel.SimpleContainer {
    public RootContainerVala (string title) {
        base.root (title);

        /*
         * Add media items to be served from this container via UPnP,
         * using the standard AudioItem, ImageItem, MusicItem and 
         * VideoItem classes, with URIs.
         * A real server plugin would probably want to populate the container
         * dynamically, for instance by monitoring a directory on the file system.
         *
         * Plugins may alternatively derive their own item classes, overriding 
         * create_stream_source(). For instance, this could allow the plugin
         * to server content from a database rather than from the file system.
         */
        var item = new MusicItem ("test 1", this, "Test 1");
        item.add_uri ("file:///home/murrayc/Music/Madness/05_Baggy_Trousers.mp3");
        item.mime_type = "audio/mpeg";
        item.add_engine_resources.begin ();
        this.add_child_item(item);

        item = new MusicItem ("test 2", this, "Test 2");
        item.add_uri ("file:///home/murrayc/Music/08%20Busload%20of%20Faith.mp3");
        item.mime_type = "audio/mpeg";
        item.add_engine_resources.begin ();
        this.add_child_item(item);
    }
}