An open API service providing package, version and dependency metadata of many open source software ecosystems and registries.

relude

relude is an alternative prelude library. If you find the default Prelude unsatisfying, despite its advantages, consider using relude instead. Productivity. You can be more productive with a "non-standard" standard library, and relude helps you with writing safer and more efficient code faster. Total programming. Usage of partial functions can lead to unexpected bugs and runtime exceptions in pure code. The types of partial functions lie about their behaviour. And even if it is not always possible to rely only on total functions, relude strives to encourage best-practices and reduce the chances of introducing a bug. Type-safety. We use the "make invalid states unrepresentable" motto as one of our guiding principles. If it is possible, we express this concept through the types. Example: whenNotNull :: Applicative f => [a] -> (NonEmpty a -> f ()) -> f () Performance. We prefer Text over String, use space-leaks-free functions (e.g. our custom performant sum and product), introduce {-# INLINE #-} and {-# SPECIALIZE #-} pragmas where appropriate, and make efficient container types (e.g. Map, HashMap, Set) more accessible. Minimalism (low number of dependencies). We do not force users of relude to stick to any specific lens or text formatting or logging library. Where possible, relude depends only on boot libraries. The Dependency graph of relude can give you a clearer picture. Convenience. Despite minimalism, we want to bring commonly used types and functions into scope, and make available functions easier to use. Some examples of conveniences: No need to add containers, unordered-containers, text and bytestring to dependencies in your .cabal file to use the main API of these libraries No need to import types like NonEmpty, Text, Set, Reader[T], MVar, STM Functions like liftIO, fromMaybe, sortWith are available by default as well IO actions are lifted to MonadIO Excellent documentation. Tutorial Migration guide from Prelude Haddock for every function with examples tested by doctest. Documentation regarding internal module structure relude-specific HLint rules: .hlint.yaml User-friendliness. Anyone should be able to quickly migrate to relude. Only some basic familiarity with the common libraries like text and containers should be enough (but not necessary). Exploration. We have space to experiment with new ideas and proposals without introducing breaking changes. relude uses the approach with Extra.* modules which are not exported by default. The chosen approach makes it quite easy for us to provide new functionality without breaking anything and let the users decide to use it or not.

Ecosystem
hackage.haskell.org
Latest Release
0.5.0
almost 7 years ago
Versions
16
Downloads
19,570 total
Dependent Packages
50
Dependent Repos
120
Links
Registry hackage.haskell.org
Source Repository
JSON API View JSON
CodeMeta codemeta.json
Package Details
PURL pkg:hackage/relude
spec
License MIT
First Release over 7 years ago
Last Synced 20 days ago
Repository
Stars 727 on GitHub
Forks 81 on GitHub
Commits 644
Committers 70
Avg per Author 9.2
DDS 0.689
Rankings on hackage.haskell.org
Overall Top 4.1%
Downloads Top 9.1%
Dependent packages Top 0.6%
Dependent repos Top 5.2%
Forks Top 4.4%