Skip to content

Functional programming library for Go including a lazy list implementation and some of the most usual functions.

Notifications You must be signed in to change notification settings

tcard/functional

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 

Repository files navigation

functional

A functional programming library including a lazy list implementation and some of the most usual functions.

import FP "github.com/tcard/functional"

Installing

go get github.com/tcard/functional

Tested on Go 1.

Build Status

Examples

The Fibonacci sequence, infinite stream:

var fibo *FP.Thunk
fibo = FP.Link(1, FP.DelayedLink(1, func() *FP.Thunk {
	return FP.MapN(func(xs ...FP.I) FP.I {
		ret := 0
		for _, v := range xs {
			ret += v.(int)
		}
		return ret
	}, fibo, fibo.Tail())
}))

Which is an uglier, slower version of the famous Lisp-like:

(define fibo
	(cons 1
		(cons 1
			(map + fibo (cdr fibo)))))		

For showing some "real" utility, this would retrieve the third page of a blog:

var posts *FP.Thunk	= ...
page := 3
postsPerPage := 10
_ = posts.Drop((page - 1) * postsPerPage).Take(postsPerPage).Map(func (post FP.I) FP.I {
	blog.showPost(post.(Post))
	return post
})

See documentation and tests for detailed usage.

To Do

  • Better memoization.
  • Ability to skip lists and work directly with slices, although lack of generics would make it clumsy anyway.
  • Some optimizations.

About

Functional programming library for Go including a lazy list implementation and some of the most usual functions.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages