A free, once-weekly Scala news flash. Easy to unsubscribe. Goes out every Thursday.
January 31st, 2019, ISSUE 259

READING

State of Scala compilation time in 2018

The data collected thanks to the survey indicate that in the best case the time lost because of compilation is around 25 to 30 minutes a day.
Mirco Dotta (@mircodotta)
Low-memory symbol indexing with bloom filters

Thanks to bloom filters, the three new indexes added in the last release of Metal use only a few megabytes of memory even for large projects with >500k lines of code.
Ólafur Páll Geirsson (@olafurpg)
Building a Big Data Machine Learning Spark Application for Flight Delay Prediction

In this tutorial, I explain how to develop a Spark application that allows creating a machine learning model for a real-world problem, using real-world data: Predicting the arrival delay of commercial flights.
Pedro Costa
Logging in Spark with Log4j. How to customize a driver and executors for YARN cluster mode

In this article, I’m going to describe several configurations for logging in Spark.
Oleksandr Tarasenko
Finally: Top-level Definitions

One of Scala 2’s small but persistently annoying warts is that many declarations can’t happen on their own.
Mark "Justin" Waks (@jducoeur)
Why you should think about functional programming

Writing code in a functional language gives you the opportunity to look at the issue from another aspect, where the development of your solution may be more effective.
Roman Taluyev
Toward a polyglot James server…

In our simple example, we replaced 127 lines of java code with 46 lines of Scala code.
Benoit Tellier (@TellierBenoit)
The Known Unknown: Working with Option and Nullable Types

There’s always a wild discussion between the followers of the two approaches about which concept is better, more concise or more functional and which not.
Benedikt Jerat (@benedikt_j42)
Reduce the domain of your types with Refined

Refined simply let us enforce our business rules into our types without all the boilerplate of defining classes and unsafe validations for each.
Methrat0n
From Kentucky Mule to faster Scala compiler - project brief

An ambitious project aiming to create a completely new and blazing fast compiler.
Grzegorz Kossakowski (@gkossakowski)

PRESENTATIONS

Homegrown Scala Collections - Part 23 - Extracting Trees from Sets

In this video we will notice that our Sets are actually a mixture of Sets and Trees so we will invest some time into a heavy refactoring.
DevInsideYou (@DevInsideYou)

EVENTS

Scalar, Warsaw, Poland April 5-6, 2019

Join the next edition of the largest Scala conference in central Europe!
SoftwareMill (@softwaremill)
Lambda Days, Kraków, Poland, February 21-22, 2019

Use promo code SCALArlz10 for a 10% discount for our readers!
LambdaDays (@LambdaDays)
flatMap(Oslo), May 8-9, 2019

Use promo code SCALATIMES for a discount for our readers!
flatMap(Oslo) (@flatmaposlo)

RELEASES

Metals v0.4.0

Metals is a language server for Scala that works with VS Code, Atom, Vim, Sublime Text and Emacs.
Metals contributors
Slinky 0.5.2

Slinky is a framework for writing React apps in Scala with an experience just like using ES6.
Shadaj Laddad (@ShadajL)
clear-config 1.2.2

A type-safe, FP, Scala config library.
David Barri (@japgolly)
scalajs-react 1.4.0

React 16.6 & 16.7 support, VDOM modernisation and many other changes.
scalajs-react contributors

VARIA

Scala Times banners?

Want one? Click here
THE INTERNET
Scala Times stickers?

Want one? Let us know or tweet @scalatimes.
THE INTERNET





  1. Scala Times Issue #283

    Python vs. Scala: a comparison of the basic commands. Keep your projects up-to-date with Scala Steward. My favorite new features of Scala 2.13 standard library. Implementing a server for the Language Server Protocol. Homegrown Scala Collections: Testing Streams.


  2. Scala Times Issue #282

    Read Pure functional HTTP APIs in Scala | Leanpub. Combining ZIO and Akka to enable distributed FP in Scala. Rethinking Streaming Workloads with Akka Streams: Part II. ES/CQRS the Akka way - Krunoslav Uzelac - Medium. Tour of Akka Typed: Protocols and Behaviors.


  3. Scala Times Issue #281

    Abstracting Over Effect Types. Reusable pre-commit hooks in Scala projects. Functional Highlighting for Functional Programming. Top Link of June: The Evolution of a Scala Programmer. Lambda World, Cádiz, Spain, October 17th - 18th.


  4. Scala Times Issue #280

    Comonads for Life. TypeSafe journey using Scala. Scala programming language wins SIGPLAN award. Shapeless' HLists and how to traverse them. How to work with JSON in Scala.


  5. Scala Times Issue #279

    Thread shifting in cats-effect and ZIO. How to work with HTTP JSON APIs in Scala. ZIO with http4s and doobie. Optimizing CI build times for Scala projects. The False Hope of Tagless-Final in Scala.


  6. Scala Times Issue #278

    Counting to infinity at compile time. Vectos - A functional ecosystem. Scala 2.13.0 for the Akka family. The place of applicative style in today's Scala. This Month We've Learned - May’19 .


  7. Scala Times Issue #277

    Final Free Structures with Subtyping. Exploring the STM functionality in ZIO. The Evolution of a Scala Programmer. How to work with Files in Scala. Top Link Of May: The little gems of Scala standard library.


  8. Scala Times Issue #276

    Small & fast Docker images using GraalVM’s native-image. SystemFw FP blog. IO monad: which, why and how. Counting at compile time. Why I'm Stepping Back from Scalaz.


  9. Scala Times Issue #275

    Tagless unions in scala 2.12. Combine IntelliJ IDEA with Hydra for the fastest Scala development experience. TMWL April’19  - qubits, scripting Google Apps & Scala tricks. Performant Functional Programming to the max with ZIO.


  10. Scala Times Issue #274

    AST playground: recursion schemes and recursive data. Rethinking Streaming Workloads with Akka Streams: Part I. Sharing is Caring!. A Scala tutorial for Java developers. Scala: Useful User Information + Why you should consider the Language.


  11. Scala Times Issue #273

    Community and Communication. Futures Made Easy with Scala. Scala: Useful User Information + Why you should consider the Language. Using 47 Degree's Fetch library with ZIO. Scala Compilation Got 5x Faster With Triplequote Hydra.


  12. Scala Times Issue #272

    The little gems of Scala standard library. Practical fiber safety (and how Concurrent implies Parallel). Typelevel Sustainability Program Announcement. Homegrown #Scala Collections - ScalaCheck / ScalaTest Integration. Alphabet Soup: Lensing, for free.


  13. Scala Times Issue #271

    ZIO & Cats Effect: A Match Made in Heaven. Concurrency is complicated. An introduction to Law Testing in Scala. Celebrating 10 Years of Akka. Alphabet Soup: Type-level transformations.


  14. Scala Times Issue #270

    Akka 2.6 roadmap. Extending MapR Database Queries Using Scala Polymorphic Types. Marvels of functional programming: Composing effects with monads. Traverse your HLists for fun and profit. Did Functional Programming get it wrong?.


  15. Scala Times Issue #269

    Scalar 2019 whiteboard voting. 38 lines of code towards better data validation in Scala. Scala: Internals and Intermediates. Hacker News API Part 5. Scala Ordering Crash Course.


  16. Scala Times Issue #268

    Functional Hangman with ZIO. Scala or Go: Tastes Great or Less Filling?. An Example of Free Monads and Optimization. Homegrown Scala Collections - Part 29 - Are Views Typeclasses?. Scalar, Warsaw, Poland April 5th - 6th.


  17. Scala Times Issue #267

    Bloop’s compiler performance is ~29% faster than SBT. Fourth batch of Scala 3 SIPs. Functional Hangman with ZIO. Scala: Understanding Variance. Fun with mutually-recursive typeclass resolution.


  18. Scala Times Issue #266

    The RedMonk Programming Language Rankings: January 2019. A monad is not a burrito. Joins in Apache Spark - Part 3. Scala sbt Project Directory Structure. Scala Snippets #1: Instantiable Implicits.


  19. Scala Times Issue #265

    Testing Incrementally with ZIO Environment. Finally Tagless - Not Quite Dead Yet. Functional Testing with Tagless-Final. Monad Transformers aren’t hard!. The Functional Scala Concurrency Challenge.


  20. Scala Times Issue #264

    Final Tagless seen alive. Effectful Episode with John de Goes. State vs Stateful Actor. Phil Bagwell Nominations. Introduction to Akka Streams.


  21. Scala Times Issue #263

    Describe, then interpret: HTTP endpoints using tapir. Vue.js with Playframework. Mu-RPC: defining messages and services. Validate Service Configuration in Scala. Modern Systems Programming And Scala Native With Richard Whaling.


  22. Scala Times Issue #262

    Is your Scala object always a singleton?. Freer doesn’t come for free. Maintaining Binary Compatibility in Scala. Anatomy of functors and category theory. A little Scala 'sed' class.


  23. Scala Times Issue #261: from Scala with love

    Aecor — Purely functional event sourcing in Scala. Part 5. Homegrown #Scala Collections - Foldable Maps. Kubernetes Liveness and Readiness Probes Revisited. Streams and Resource Safety | Akka. Assemble messages from Akka Actors.


  24. Scala Times Issue #260

    Cats Ecosystem Community Survey 2018 Results. Thread Pool Best Practices with ZIO. Purely functional parallelism in Scala. Finatra meets Ammonite. Typed Supervision: why the changes?.


  25. Scala Times Issue #259

    State of Scala compilation time in 2018. Low-memory symbol indexing with bloom filters. Finally: Top-level Definitions. Why you should think about functional programming. Toward a polyglot James server….


Organizing an event?
Promote it with
Scala Times.
The Scala Times reader?
Get a banner!
Got a tip? Send it in!
Follow us on Twitter.
Curated by SoftwareMill.
We are hiring.
And taking on projects.