94131b43f662dd345f17d1d8b5f0df2b263361a9
[aquarium] / src / main / scala / gr / grnet / aquarium / util / yaml / YAMLListNode.scala
1 /*
2  * Copyright 2011-2012 GRNET S.A. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or
5  * without modification, are permitted provided that the following
6  * conditions are met:
7  *
8  *   1. Redistributions of source code must retain the above
9  *      copyright notice, this list of conditions and the following
10  *      disclaimer.
11  *
12  *   2. Redistributions in binary form must reproduce the above
13  *      copyright notice, this list of conditions and the following
14  *      disclaimer in the documentation and/or other materials
15  *      provided with the distribution.
16  *
17  * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
18  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
21  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
24  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
25  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
27  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28  * POSSIBILITY OF SUCH DAMAGE.
29  *
30  * The views and conclusions contained in the software and
31  * documentation are those of the authors and should not be
32  * interpreted as representing official policies, either expressed
33  * or implied, of GRNET S.A.
34  */
35
36 package gr.grnet.aquarium.util.yaml
37
38 /**
39  * 
40  * @author Christos KK Loverdos <loverdos@gmail.com>.
41  */
42 case class YAMLListNode(path: String,  list: List[YAMLNode]) extends YAMLNode {
43   def /(childName: String) = YAMLEmptyNode
44
45   override def listValue = list
46   override def isList = true
47
48   def head = list match {
49     case Nil    => YAMLEmptyNode
50     case h :: _ => h
51   }
52   def tail = YAMLListNode(path + "::tail", list.tail)
53
54   override def isEmpty = list.isEmpty
55
56   override def foreach[T](f: (YAMLNode) => T) = {
57     for(node <- listValue) {
58       f(node)
59     }
60   }
61
62   def withPath(newPath: String) = this.copy(path = newPath)
63 }