-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Update README.md * Updated example in README.md * Update README.md * Update README.md * Update README.md
- Loading branch information
1 parent
1a5d59e
commit 0195720
Showing
1 changed file
with
32 additions
and
90 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,111 +1,53 @@ | ||
# co-log | ||
# co-log-core | ||
|
||
data:image/s3,"s3://crabby-images/c98ad/c98adc13bf816e05510fe54e623e27d352632023" alt="Co-logo" | ||
|
||
[data:image/s3,"s3://crabby-images/ba95f/ba95ff97ec8c9a85b7e92057a2dce42732cc0045" alt="GitHub CI"](https://github.com/kowainik/co-log/actions) | ||
[data:image/s3,"s3://crabby-images/61779/617797244be5afd4dae8f70366a5286d2266b7ae" alt="Build status"](https://travis-ci.org/kowainik/co-log) | ||
[data:image/s3,"s3://crabby-images/eb403/eb403028426928a951cc54f06fc32ce31be5d1cd" alt="Windows build"](https://ci.appveyor.com/project/kowainik/co-log) | ||
[data:image/s3,"s3://crabby-images/c62c7/c62c77e3ebf3783d539c2900b78939c158b8b654" alt="GitHub CI"](https://github.com/co-log/co-log-core/actions) | ||
[![Hackage][hk-img-core]][hk-core] | ||
[![Stackage LTS][lts-img-core]][lts-core] | ||
[data:image/s3,"s3://crabby-images/5fb6f/5fb6ffc88c88f597686410fa162b1b2ba45a4641" alt="MPL-2.0 license"](https://github.com/kowainik/co-log/blob/main/LICENSE) | ||
|
||
`co-log-core` is a lightweight package that provides core types and functions to | ||
work with the @LogAction@ data type which is both simple and powerful. | ||
|
||
| | | | | | ||
| :------------ | :--------------------------------- | :---------------------------------------- | :---------------------------------------------------- | | ||
| `co-log-core` | [![Hackage][hk-img-core]][hk-core] | [![Stackage LTS][lts-img-core]][lts-core] | [![Stackage Nightly][nightly-img-core]][nightly-core] | | ||
| `co-log` | [![Hackage][hk-img]][hk] | [![Stackage LTS][lts-img]][lts] | [![Stackage Nightly][nightly-img]][nightly] | | ||
| `co-log-polysemy` | [![Hackage][hk-img-ps]][hk-ps] | [![Stackage LTS][lts-img-ps]][lts-ps] | [![Stackage Nightly][nightly-img-ps]][nightly-ps] | | ||
## How to use | ||
|
||
`co-log` is a composable and configurable logging framework. It | ||
combines all the benefits of Haskell idioms to provide a reasonable | ||
and convenient interface. Though it uses some advanced concepts in its | ||
core, we are striving to provide beginner-friendly API. The library | ||
also contains complete documentation with a lot of beginner-friendly | ||
examples, explanations and tutorials to guide users. The combination | ||
of a pragmatic approach to logging and fundamental Haskell abstractions | ||
allows us to create a highly composable and configurable logging | ||
framework. | ||
`co-log-core` is compatible with the following GHC | ||
versions - [supported versions](https://matrix.hackage.haskell.org/#/package/co-log-core) | ||
|
||
If you're interested in how different Haskell typeclasses are used to | ||
implement core functions of `co-log`, you can read the following blog | ||
post which goes into detail about internal implementation specifics: | ||
In order to start using `co-log-core` in your project, you | ||
will need to set it up with these steps: | ||
|
||
* [co-log: Composable Contravariant Combinatorial Comonadic Configurable Convenient Logging](https://kowainik.github.io/posts/2018-09-25-co-log) | ||
1. Add the dependency on `co-log-core` in your project's | ||
`.cabal` file. For this, you should modify the `build-depends` | ||
section according to the below section: | ||
|
||
`co-log` is also modular on the level of packages. We care a lot about a | ||
low dependency footprint so you can build your logging only on top of | ||
the minimal required interface for your use-case. This repository contains | ||
the following packages: | ||
```haskell | ||
build-depends: base ^>= LATEST_SUPPORTED_BASE | ||
, co-log-core ^>= LATEST_VERSION | ||
``` | ||
|
||
* [`co-log-core`](co-log-core): lightweight package with basic data types and | ||
general idea which depends only on `base`. | ||
* [`co-log`](co-log): taggless final implementation of logging library based on | ||
`co-log-core`. | ||
* [`co-log-polysemy`](co-log-polysemy): implementation of logging library based | ||
on `co-log-core` and the [`polysemy`](http://hackage.haskell.org/package/polysemy) extensible effects library. | ||
* [`co-log-benchmark`](co-log-benchmark): benchmarks of the `co-log` library. | ||
2. To use this package, refer to the below example. | ||
|
||
To provide a more user-friendly introduction to the library, we've | ||
created the tutorial series which introduces the main concepts behind `co-log` | ||
smoothly: | ||
```haskell | ||
module Main (main) where | ||
|
||
* [Intro: Using `LogAction`](https://github.com/kowainik/co-log/blob/main/co-log/tutorials/1-intro/Intro.md) | ||
* [Using custom monad that stores `LogAction` inside its environment](https://github.com/kowainik/co-log/blob/main/co-log/tutorials/2-custom/Custom.md) | ||
import Prelude hiding (log) | ||
|
||
`co-log` also cares about concurrent logging. For this purpose we have the `concurrent-playground` | ||
executable where we experiment with different multithreading scenarios to test the library's behavior. | ||
You can find it here: | ||
import Colog.Core (LogAction, logStringStdout, (<&)) | ||
|
||
* [tutorials/Concurrent.hs](co-log/tutorials/Concurrent.hs) | ||
|
||
## Benchmarks | ||
app :: LogAction IO String -> IO () | ||
app log = do | ||
log <& "Starting app..." | ||
log <& "Finishing app..." | ||
|
||
`co-log` is compared with basic functions like `putStrLn`. Since IO overhead is | ||
big enough, every benchmark dumps 10K messages to output. If a benchmark's name | ||
doesn't contain `Message` then this benchmark simply dumps the string `"message"` | ||
to output, otherwise it works with the `Message` data type from the `co-log` | ||
library. | ||
|
||
To run benchmarks, use the following command: | ||
|
||
``` | ||
cabal v2-run co-log-bench | ||
``` | ||
|
||
| Benchmarks | Time for 10K messages | | ||
| :------------------------------------------------------ | :-------------------- | | ||
| `Prelude.putStrLn` | ` 5.117ms` | | ||
| `Text.putStrLn` | ` 9.220ms` | | ||
| `ByteString.putStrLn` | ` 2.971ms` | | ||
| `mempty` | ` 1.181ms` | | ||
| `logStringStdout` | ` 5.107ms` | | ||
| `logPrint` | ` 5.248ms` | | ||
| `logTextStdout` | ` 5.351ms` | | ||
| `logByteStringStdout` | ` 2.933ms` | | ||
| `logByteStringStderr` | ` 17.482ms` | | ||
| `ByteString > (stdout <> stderr)` | ` 17.715ms` | | ||
| `Message > format > stdout` | ` 9.188ms` | | ||
| `Message > format > ByteString > stdout` | ` 3.524ms` | | ||
| `Message{callstack} > format > stdout` | ` 9.139ms` | | ||
| `Message{callstack:5} > format > stdout` | ` 9.464ms` | | ||
| `Message{callstack:50} > format > stdout` | ` 9.439ms` | | ||
| `Message{Time,ThreadId} > format > stdout` | ` 54.160ms` | | ||
| `Message{Time,ThreadId} > format > ByteString > stdout` | ` 54.137ms` | | ||
|
||
|
||
[hk-img]: https://img.shields.io/hackage/v/co-log.svg?logo=haskell | ||
[hk-img-ps]: https://img.shields.io/hackage/v/co-log-polysemy.svg?logo=haskell | ||
main :: IO () | ||
main = app logStringStdout | ||
``` | ||
|
||
|
||
[hk-img-core]: https://img.shields.io/hackage/v/co-log-core.svg?logo=haskell | ||
[hk]: https://hackage.haskell.org/package/co-log | ||
[hk-ps]: https://hackage.haskell.org/package/co-log-polysemy | ||
[hk-core]: https://hackage.haskell.org/package/co-log-core | ||
[lts-img]: http://stackage.org/package/co-log/badge/lts | ||
[lts-img-ps]: http://stackage.org/package/co-log-polysemy/badge/lts | ||
[lts-img-core]: http://stackage.org/package/co-log-core/badge/lts | ||
[lts]: http://stackage.org/lts/package/co-log | ||
[lts-ps]: http://stackage.org/lts/package/co-log-polysemy | ||
[lts-core]: http://stackage.org/lts/package/co-log-core | ||
[nightly-img]: http://stackage.org/package/co-log/badge/nightly | ||
[nightly-img-ps]: http://stackage.org/package/co-log-polysemy/badge/nightly | ||
[nightly-img-core]: http://stackage.org/package/co-log-core/badge/nightly | ||
[nightly]: http://stackage.org/nightly/package/co-log | ||
[nightly-ps]: http://stackage.org/nightly/package/co-log-polysemy | ||
[nightly-core]: http://stackage.org/nightly/package/co-log-core |