
nfigrity-core_2.9.0-1.0.10.2.source-code.Reader.scala Maven / Gradle / Ivy
The newest version!
/*
Copyright (C) 2011, Paradigmatic
This file is part of Configrity.
Configrity 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 3 of the License, or
(at your option) any later version.
Configrity 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 Configrity. If not, see .
*/
package org.streum.configrity
import converter.ValueConverter
/** Monadic Reader */
trait Reader[A] {
/** Produce a value from a Configuration */
def apply( c: Configuration ): A
def map[B]( f: A => B ) = {
val parent = this
new Reader[B] {
def apply( c: Configuration ) = f( parent(c) )
}
}
def flatMap[B]( f: A => Reader[B] ) = {
val parent = this
new Reader[B] {
def apply( c: Configuration ) = f( parent(c) )(c)
}
}
}
case class ConfigurationReader[A: ValueConverter](
key: String,
default: Option[A]
) extends Reader[A] {
def apply( c: Configuration ) = if( default.isDefined ) {
c.get[A](key).getOrElse( default.get )
} else {
c[A](key)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy