DiscoverRock the Code
Rock the Code
Claim Ownership

Rock the Code

Author: Daniel Ciocirlan

Subscribed: 0Played: 0
Share

Description

A podcast about interesting programming topics for the curious software engineer. You will learn about programming languages, tools, libraries, and combinations thereof, from the best in the field.
12 Episodes
Reverse
Jon Gjengset is a long-time Rust programmer and educator and the author of Rust for Rustaceans, a book on idiomatic Rust programming for experienced developers. You can find Jon and his work at https://thesquareplanet.com/ --- 0:00 Intro 1:00 Vibe coding in Rust: safer or more dangerous? 3:54 Jon's two-week LLM immersion experiment 6:55 When LLMs save time vs. waste it 10:10 Avro IDL transpiler: a perfect LLM task 14:30 Building a Touch Portal plugin with LLM help 16:10 Developing an intuition for LLM delegation 17:18 Unlearning OOP habits in Rust 22:20 Rust's opinionated design and error messages 26:02 Common anti-patterns from newcomers to Rust 28:40 Traits, type classes, and why not OOP 32:47 Unsafe Rust: hygiene, MIRI, and Loom 39:43 Polonius: the next borrow checker 46:31 Rust's narrow standard library — intentional restraint 52:46 Origin of Rust for Rustaceans 57:58 Writing dense, timeless technical prose 1:02:23 Teaching Rust in 10 hours 1:07:32 Rust as a first programming language 1:10:48 Comments as the most important code 1:18:57 Writing comments before the code 1:23:31 Getting unstuck live on stream 1:28:46 Impl Rust vs. Crust of Rust vs. Decrusted 1:30:45 Languages Jon would explore if not Rust 1:32:15 Advice for Scala developers on trying Rust 1:34:10 Recommended books for programmers
José Valim is the creator of the Elixir programming language and cofounder of Dashbit, where he focuses on growing the Elixir ecosystem, the Tidewave web AI agent, and Livebook, a Jupyter-style notebook for Elixir. Before creating Elixir, he cofounded Plataformatec (acquired by Nubank) and was a core Ruby contributor. Elixir language: https://elixir-lang.org/ Dashbit: https://dashbit.co/ Tidewave AI: https://tidewave.ai Livebook: https://livebook.dev --- 0:00 Intro 1:32 Elixir 1.20 type inference: what's new 9:15 Gradual typing vs TypeScript's approach 15:03 Typing existing Elixir code without breaking it 19:35 Set-theoretic types vs Hindley-Milner 25:06 Developer happiness: tooling and documentation 34:48 Elixir adoption: growth and decentralization 39:21 Origins: falling in love with the BEAM 45:09 Dashbit: small team, big ecosystem impact 49:18 Enabling open-source contributors 57:11 José's planning and productivity habits 1:00:20 Open source sustainability and burnout 1:08:04 NX and Elixir for machine learning 1:17:16 Elixir vs Python in the age of AI agents 1:23:28 Marketing Elixir to developers 1:29:29 Teaching as a core skill 1:34:05 BEAM vs JVM: concurrency and fault tolerance 1:43:33 Akka, virtual threads, and the BEAM scheduler 1:50:54 Where to start with Elixir
Richard Feldman is a software engineer with more than 20 years of experience, a frequent conference speaker, teacher and author of Elm in Action. He's the author of the Roc programming language and is currently working on Zed, the AI-enabled code editor. Zed: https://zed.dev/ Roc: https://www.roc-lang.org/ --- 0:00 Intro 1:38 Why Rust's borrow checker didn't help Roc's compiler 6:02 Zig vs Rust for Roc: trade-offs in practice 8:29 Why Richard built Roc 13:11 Roc vs Go for web servers 18:02 Roc's error handling: anonymous sum types 19:44 How Roc measures success 23:22 Roc adoption: the startup pathway 29:54 Platforms and applications: Roc's core design 40:33 Security by design: sandboxing dependencies 55:00 Avoiding monads: Richard's FP philosophy 1:02:36 Empathy as a design principle 1:05:04 Teaching FP: don't start with types 1:09:32 Writing Elm in Action: lessons and regrets 1:17:35 Career decisions: startups and red flags 1:30:08 Fundamentals: API design and OOP skepticism 1:40:14 Roc in the age of AI 1:47:24 Vibe coding and software quality 1:54:51 AI agents for bug reproduction in Roc 2:08:09 What drives Richard: people and products
Haoyi Li is a software engineer and a core contributor to the Scala ecosystem. He's built a whole suite of Scala libraries under the com.lihaoyi banner, focusing on simplicity and productivity, as well as the Mill build tool, which he has since expanded beyond Scala to support other JVM tools like Java and Kotlin and experimental support for other things like TypeScript and Android, and promises better performance and user friendliness than Gradle and Maven can ever match. He's also the author of the book Hands-on Scala Programming, which focuses on getting things done with Scala. You can find Mill at https://mill-build.org/ My own course, Scala Projects, uses Haoyi's book examples as starting points for full-fledged, shippable projects that you can use for yourself or turn into products: https://rockthejvm.com/courses/scala-projects --- 0:00 Intro 1:14 The 45-conference sabbatical tour 4:55 In-person feedback vs. shouting into the void 8:38 Mill's current development process 11:00 Mill beyond Scala: targeting Java and Kotlin 14:05 Why build tools terrify developers 17:07 Mill's YAML config format 22:24 Scala at Databricks: using one language everywhere 26:17 Fast Scala onboarding: no Akka, no CATS, no ZIO 29:04 Scala vs Kotlin, TypeScript, and Go today 30:12 What Scala actually needs: IDE support and a simpler stack 35:56 The async obsession Scala needs to drop 43:10 IC to manager and back: the cost of remote leadership 50:26 From EverQuest XML mods to Scala 1:02:24 Maintaining a library ecosystem without burning out 1:03:30 Open-sourcing Hands-on Scala Programming 1:07:45 Self-publishing the book: pipeline, printing, and margins 1:13:09 Rewriting the book: dropping Quill, evolving Ammonite 1:15:33 Vibe-coding contributions to the Scala compiler 1:22:17 Moving up the stack: engineers in the AI era 1:27:12 The fun of wrangling half-baked code 1:31:38 Haoyi's message to Scala developers
Grady Booch is one of the pioneers of modern software architecture as a distinct discipline of software engineering. He has 50+ years of experience and has developed software for every conceivable domain, has authored 7 books and is the co-creator of the UML design language. His latest ongoing work is a documentary called Computing - The Human Experience: https://computingthehumanexperience.com/ --- 0:00 Intro 1:25 Computing: The Human Experience documentary 4:58 Why computing history matters today 10:00 AI fear-mongering: then vs. now 15:00 Computing as a tool for subjugation 17:12 Grady's influences: Sagan, Feynman, Campbell 20:39 Debate class to keynote stage: Amarillo origins 24:30 Grady's writing and lecture process 34:54 Gang of Four patterns: warranted criticism 39:40 Developing good architectural taste 43:00 Reading great code: MacPaint, Photoshop, Linux 48:00 Idioms, patterns, and architectural styles 53:00 Where formal methods actually matter 57:00 Python and JavaScript in production systems 59:37 LLM-generated code: security holes and fragility 1:05:00 AI overhype and the FOMO trap 1:16:27 LLMs as statistical systems, not truth machines 1:18:12 Human truth vs. LLM statistics 1:24:46 Optimism for software engineers in the AI era 1:25:40 Clear and present dangers: bias automation
John De Goes is a software engineer recognized in the Scala ecosystem for the ZIO effect system. He's the founder of multiple companies, including Ziverge and Golem Cloud, and the producer of the show The Ultimate Coder. He's also a frequent conference speaker, writer and mentor. --- 0:00 Intro 1:45 The Ultimate Coder: humans vs AI in API design 6:26 Judging criteria: expressiveness, type safety, developer joy 12:04 Why TypeScript over Scala 15:00 Making programming entertaining 19:00 AI killing developer education 25:20 Uncle Bob's abstraction argument vs AI 30:15 AI as a new programming abstraction layer 42:09 How John uses AI: test generation and boilerplate 49:00 Adapting education and MCP servers for AI-first devs 57:04 Skills worth doubling down on in the AI era 1:06:18 Vibe coders vs senior engineers: the kill order 1:16:18 Retaining top engineers as a founder 1:25:43 Leverage and synergy across open source, companies, and talks 1:34:30 Zio's origin: eating the pain of async, concurrency, and errors 1:41:53 Internal complexity and rewrites in Zio Streams 1:46:25 Effect system proliferation: Zio, Cats Effect, Kyo, Effect TS 1:50:30 The three legs of Zio: async, concurrency, error management 1:58:53 Will effect systems ever go mainstream? 2:06:34 AI favoring typed, structured code 2:13:00 John's process for crafting conference talks 2:15:14 Education, inspiration, and entertainment in talks 2:17:54 How to become a more fluent speaker
Robert Martin aka "Uncle Bob" is a software engineer for more than 50 years, and the author of many influential programming books, including Clean Code and Clean Architecture, and one of the founders of the Agile methodology. He teaches principles of software craftsmanship at https://cleancoders.com/ --- 0:00 Intro 1:04 Uncle Bob's journey into Clojure 5:05 Why Uncle Bob prefers Clojure over Java 8:30 Dynamic vs. static typing 13:08 How TDD replaces type checkers 20:10 Dijkstra's failed dream of provable software 30:20 AI as a co-pilot: the danger of blind trust 43:00 Will AI replace programmers? 56:00 Clean Code principles in the age of AI 1:04:00 Clean Code 2nd edition: what changed 1:13:20 Osterhout's critique of Clean Code 1:17:51 The only way to go fast: craftsmanship 1:21:16 Filtering the churn: spotting old news 1:28:08 Essential books every programmer should read 1:35:54 Don't fear the future 1:37:11 How Uncle Bob developed as a teacher
Jonas Bonér is the founder and CTO of Akka Inc. and creator of the Akka project and the Reactive Manifesto. He's also a Java Champion. You can find Jonas at http://jonasboner.com --- 0:00 Intro 2:30 Akka's origin story: 2009 consultancy to open source 9:30 The actor model: message passing, isolation, and fault tolerance 24:10 Supervision hierarchies and location transparency 37:00 Akka modules: Streams, Clustering, and Sharding 51:00 CRDTs, Alpakka, gRPC, and brokerless PubSub 1:03:00 Akka Edge: extending actors to Rust and devices 1:09:30 The Akka platform SDK: from months to days 1:20:30 Event sourcing and CQRS in the Akka SDK 1:27:00 Serverless, bring-your-own-cloud, and self-hosted deploys 1:38:00 BSL license change: survival over ideology 1:46:00 Open-source sustainability and the tragedy of the commons 1:53:00 Agentic AI and the actor model as its backbone 1:58:00 Distributed systems: what engineers still get wrong
Rúnar Bjarnason is a cofounder of Unison Computing, a programming language and environment for distributed systems and applications on the cloud. He's also a coauthor of the famous "red book", aka Functional Programming in Scala (and more recently in Kotlin as well). --- 0:00 Intro 1:26 Unison's origin and the content-addressed code idea 5:03 Why a new language instead of a Scala framework 8:28 Unison vs. Spark: deployment without infra 13:54 Scaling and remote.fork in Unison Cloud 18:54 Real-world Unison use cases 22:39 Why Haskell for the runtime (and ditching the JVM) 39:19 Dependency management without the hell 49:02 Runar's path: Java refugee to functional programming 59:59 Renaming types without breaking code 1:05:51 Concepts that transfer from Scala to Unison 1:12:21 Why Haskell isn't mainstream 1:21:24 LLMs and Unison: vibe coding vs. intelligent autocomplete 1:25:01 Books, taste, and advice for aspiring programmers
Paul Snively is a software architect and engineer with 40 years of programming experience. He's worked professionally with a variety of languages, tools and mental models, including Lisp, C, Java, Scala and Haskell, and has held various positions at Apple, Intel, VMWare, Verizon and others. He is also a frequent conference speaker, talking about type systems, functional programming, formal logic and reliable software. You can find Paul at https://paul-snively.github.io/ --- 0:00 Intro 6:30 Language proliferation: Go, Rust, Scala, and corporate bets 10:00 Scala in production: Twitter, Spark, and Databricks 12:10 Go's appeal: consistency over abstraction ceiling 16:10 Runar Bjarnason, Funnel, and the Verizon Labs team 21:50 Kleisli arrows and HTTP4S explained 30:25 Why purely functional programming: expressions all the way down 36:05 Where correctness matters most: finance, avionics, smart contracts 47:45 TypeScript's success: syntax, ecosystem fit, and .d.ts files 58:55 Scala's adoption problem and the abstraction ceiling 1:03:40 Direct style, Ox, Kyo, and lowering the FP on-ramp 1:11:50 How to develop taste and intuition in software 1:20:00 Apprenticeship, stupid questions, and the monad epiphany 1:33:00 Shipping System 7.0 with 1,500 known bugs: Apple and business tradeoffs 1:41:30 OCaml: governance, stability, and Jane Street 1:53:50 ReasonML and language recommendations for beginners 1:57:00 Paradigms over languages: Smalltalk, Prolog, Haskell, C
James Ward is a professional software developer since 1997, with much of that time spent helping developers build software that doesn't suck. He describes himself as a typed pure functional programming zealot who often compromises on his ideals to just get stuff done. He is the author of several programming books, the latest being Effect Oriented Programming. James hosts the Happy Path Programming podcast and is a frequent conference speaker around the world, and he's been recognized as a Java Champion in 2021. He is currently a Developer Advocate for AWS. --- 0:00 Intro 1:38 Why James wrote Effect Oriented Programming 5:30 From Scala 3 book to Zio book to effects 14:08 What effects actually are 27:02 Typed errors, dependencies, and retry superpowers 40:56 Refactorability, testability, and concurrency with effects 42:56 Zio streams as a quick win 43:56 Career mindset shifts: types and functional programming 52:49 Scala vs Kotlin vs Java type systems 1:01:21 Fringe languages: Unison, Rock, WASM 1:02:04 Algebraic data types + exhaustive pattern matching in Scala 3 1:07:11 EasyRacer: learning concurrency through experiments 1:12:48 Using AI and LLMs for learning unfamiliar languages 1:16:45 The FFT benchmark story: agent vs. profiler 1:23:57 LLMs as copy-paste at scale: the abstractions problem 1:31:17 MCP: what it is and what it could become 1:45:21 Are we at peak AI hype? 1:51:42 Agentic loops, interaction models, and type inference gaps 1:55:57 Skills that still matter: understanding code you didn't write 1:57:31 Formal verification and deriving code from specs 2:02:44 How James finds time to explore so many technologies 2:05:41 CFP submissions as a forcing function for learning
A long-form conversation with Martin Odersky about everything Scala: the evolution of the language, the future, learning, teaching, good library and code design, and more. --- 0:00 Intro 2:30 Teaching Scala to kids and beginners 6:55 Why recursion trips up new programmers 11:51 Scala as a first language: the evidence from Lund University 13:38 How Martin's students at EPFL learn debugging via the scientific method 16:36 Inside the Scala compiler: phases, tests, and community builds 24:03 The SIP process: from Discord proposal to stable feature 29:03 Scala 3 vs Scala 2: implicits, givens, and extension methods 48:03 Scala's strengths: safety, convenience, and low ceremony 54:30 The complexity trap: effect systems, HTTP4S, and simple Scala 1:03:00 Capabilities: Scala's answer to Rust's borrow checker 1:32:27 Gears: direct-style concurrency with capabilities 1:34:58 Scala's path to mainstream: network effects and the next Spark 1:43:03 Learning Lean and what Martin would steal for Scala
Comments