/hidden-args

Hide your accumulators from the public API

Primary LanguageScalaMIT LicenseMIT

Build Status Build status

Hidden Arguments

Description

A common pattern during development of tail-recursive functions is to introduce a helper function to hide the accumulator parameter.

Hidden Arguments is a project that provides a language feature (implemented in Scala using macros), which helps the developer to define such functions without the necessary boilerplate.

--

The definition of the function

@hiddenargs
def sum(xs: List[Int], @hidden acc: Int = 0): Int = 
  xs match {
    case hd :: tl => sum(tl, hd + acc)
    case _        => acc
  }

will be rewritten to hide the parameter acc:

def sum(xs: List[Int]): Int = {
  def sum_impl(xs: List[Int], acc: Int): Int =
    xs match {
      case hd :: tl => sum_impl(tl, hd + acc)
      case _        => acc
    }

  sum_impl(xs, 0)
}

--

The defined function, which should be rewritten, has to be marked with the annotation 'hiddenargs'. Every parameter of such function, which is marked with the 'hidden' annotation, will be hidden using a nested function. The default value of the hidden paramter is used to call the nested function.

Building the project

This project is built using sbt.

To build the project:

  • Install sbt
  • Clone this project
  • Open a terminal and cd into the root directory of the cloned repository
  • Run
    • sbt compile to build the project
    • sbt packageBin to publish the project locally
    • sbt test to run the unit tests

Usage

  • Add dependency on Scala compiler plugin Macro Paradise.
    • This can be done by adding addCompilerPlugin("org.scalamacros" % "paradise" % "2.1.0" cross CrossVersion.full) to the build settings in build.sbt.
    • An example project, which uses Macro Paradise can be found here.
  • Add the following resolver to your build.sbt:
resolvers += Resolver.jcenterRepo
  • Add the following dependency to your build.sbt:
libraryDependencies += "com.github.keddelzz.hidden-args" %% "hidden-args" % "0.0.1"
  • Define tail-recursive functions, mark them with 'hiddenargs' and let the compiler hide those arguments, which are marked as 'hidden'.

License

See the LICENSE file for license rights and limitations (MIT).