All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ciris.package.scala Maven / Gradle / Ivy

There is a newer version: 0.12.1
Show newest version
import ciris.api._

/**
  * The main namespace of Ciris is `ciris`, and the easiest way to
  * get started is to bring it into scope with an import.
* If you are looking for a getting started guide, with examples * and explanations, please refer to the [[https://cir.is/docs usage guide]]. */ package object ciris extends LoadConfigs with CirisPlatformSpecific { /** * Reads the environment variable with the specified key name, * and tries to convert the value to type `Value`, wrapping * the result in a [[ConfigEntry]].
*
* If you want the value returned in a context, that is not * [[api.Id]], you can use [[envF]] and explicitly specify * the context to use. * * @param key the name of the environment variable to read * @param decoder the decoder with which to decode the value * @tparam Value the type to convert the value to * @return a [[ConfigEntry]] with the result * @example {{{ * scala> ciris.env[Int]("key").toStringWithValues * res0: String = ConfigEntry(key, Environment, Left(MissingKey(key, Environment))) * }}} */ def env[Value](key: String)( implicit decoder: ConfigDecoder[String, Value] ): ConfigEntry[Id, String, String, Value] = { envF[Id, Value](key) } /** * Reads the environment variable with the specified key name, * and tries to convert the value to type `Value`, wrapping * the result in a [[ConfigEntry]] where the value has been * lifted into context `F`.
*
* If no context `F` is desired, [[api.Id]] can be used. There * is also [[env]] which can be used for the case when `F` is * [[api.Id]]. * * @param key the name of the environment variable to read * @param decoder the decoder with which to decode the value * @tparam F the context in which to lift the value * @tparam Value the type to convert the value to * @return a [[ConfigEntry]] with the result */ def envF[F[_]: Applicative, Value](key: String)( implicit decoder: ConfigDecoder[String, Value] ): ConfigEntry[F, String, String, Value] = { ConfigSource.Environment .read(key) .decodeValue[Value] .transformF[F] } /** * Reads the system property with the specified key name, * and tries to convert the value to type `Value`. Note * that system properties are mutable, so if you modify * them during runtime, this function is not pure.
*
* You might want to use [[propF]] to suspend the actual * reading in a context `F`, like `IO`. * * @param key the system property to read * @param decoder the decoder with which to decode the value * @tparam Value the type to convert the value to * @return a [[ConfigEntry]] with the result * @example {{{ * scala> ciris.prop[Int]("key").toStringWithValues * res0: String = ConfigEntry(key, Property, Left(MissingKey(key, Property))) * }}} */ def prop[Value](key: String)( implicit decoder: ConfigDecoder[String, Value] ): ConfigEntry[Id, String, String, Value] = { ConfigSource.Properties .read(key) .decodeValue[Value] } /** * Reads the system property with the specified key name, * but suspends the reading by wrapping the operation in * the specified context `F`, and then tries to convert * the value to type `Value`.
*
* Note that system properties are mutable. If you never * modify them during runtime, and you are sure that you * do not want to suspend the reading to a context `F`, * you can instead use [[prop]]. * * @param key the system property to read * @param decoder the decoder with which to decode the value * @tparam F the context in which to suspend the reading * @tparam Value the type to convert the value to * @return a [[ConfigEntry]] with the result */ def propF[F[_]: Sync, Value](key: String)( implicit decoder: ConfigDecoder[String, Value] ): ConfigEntry[F, String, String, Value] = { ConfigSource.Properties .suspendF[F] .read(key) .decodeValue[Value] } /** * Reads the command-line argument with the specified index, * and tries to convert the value to type `Value`, wrapping * the result in a [[ConfigEntry]].
*
* Note that the underlying arguments may be mutable. There * is also an alternative pure version [[argF]] with which * the reading is suspended into a context `F`. * * @param args the command-line arguments * @param index the index of the argument to read * @param decoder the decoder with which to decode the value * @tparam Value the type to convert the value to * @return a [[ConfigEntry]] with the result * @example {{{ * scala> ciris.arg[Int](Array("50"))(0).toStringWithValues * res0: String = ConfigEntry(0, Argument, Right(50)) * * scala> ciris.arg[Int](Array("50"))(1).toStringWithValues * res1: String = ConfigEntry(1, Argument, Left(MissingKey(1, Argument))) * * scala> ciris.arg[Int](Array("a"))(0).toStringWithValues * res2: String = ConfigEntry(0, Argument, Right(a), Left(WrongType(0, Argument, Right(a), a, Int, java.lang.NumberFormatException: For input string: "a"))) * }}} */ def arg[Value](args: IndexedSeq[String])(index: Int)( implicit decoder: ConfigDecoder[String, Value] ): ConfigEntry[Id, Int, String, Value] = { ConfigSource .byIndex(ConfigKeyType.Argument)(args) .read(index) .decodeValue[Value] } /** * Reads the command-line argument with the specified index, * and tries to convert the value to type `Value`. Note that * the underlying arguments may be mutable, so this function * suspends the reading into context `F`.
*
* If you're sure that the underlying arguments are never * modified at runtime, and do not want to suspend reading, * there is also [[arg]] which reads the argument directly. * * @param args the command-line arguments * @param index the index of the argument to read * @param decoder the decoder with which to decode the value * @tparam F the context in which to suspend the reading * @tparam Value the type to convert the value to * @return a [[ConfigEntry]] with the result */ def argF[F[_]: Sync, Value](args: IndexedSeq[String])(index: Int)( implicit decoder: ConfigDecoder[String, Value] ): ConfigEntry[F, Int, String, Value] = { ConfigSource .byIndex(ConfigKeyType.Argument)(args) .suspendF[F] .read(index) .decodeValue[Value] } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy