readonlylist.vala 2.19 KB
Newer Older
1 2
/* readonlylist.vala
 *
3
 * Copyright (C) 2007-2008  Jürg Billeter
4 5 6 7
 *
 * This library 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
8
 * version 2.1 of the License, or (at your option) any later version.
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27

 * This library 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
 *
 * Author:
 * 	Jürg Billeter <j@bitron.ch>
 */

using GLib;

/**
 * Represents a read-only collection of items in a well-defined order.
 */
28
public class Gee.ReadOnlyList<G> : Object, Iterable<G>, Collection<G>, List<G> {
29 30 31 32 33 34 35 36 37 38 39 40 41
	public int size {
		get { return _list.size; }
	}

	public List<G> list {
		set { _list = value; }
	}

	private List<G> _list;

	public ReadOnlyList (construct List<G> list = null) {
	}

42 43 44 45
	public Type get_element_type () {
		return typeof (G);
	}

46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
	public Gee.Iterator<G> iterator () {
		if (_list == null) {
			return new Iterator<G> ();
		}

		return _list.iterator ();
	}

	public bool contains (G item) {
		if (_list == null) {
			return false;
		}

		return _list.contains (item);
	}

	public int index_of (G item) {
		if (_list == null) {
			return -1;
		}

		return _list.index_of (item);
	}

	public bool add (G item) {
		assert_not_reached ();
	}

	public bool remove (G item) {
		assert_not_reached ();
	}

	public void insert (int index, G item) {
		assert_not_reached ();
	}

	public void remove_at (int index) {
		assert_not_reached ();
	}

	public G get (int index) {
		if (_list == null) {
			return null;
		}

		return _list.get (index);
	}

	public void set (int index, G o) {
		assert_not_reached ();
	}

	public void clear () {
		assert_not_reached ();
	}

102
	class Iterator<G> : Object, Gee.Iterator<G> {
103 104 105 106 107 108 109 110 111 112
		public bool next () {
			return false;
		}

		public G get () {
			return null;
		}
	}
}