[Functional Programming ADT] Debug a Functional JavaScript composeK Flow
When using ADTs in our code base, it can be difficult to use common debugging tools like watches and breakpoints. This is mainly due to the common pattern of using compositions and other ways of manipulating how functions are called. This can cause us to have to revert to using console logs at the different points in our flow, to peek at how our data is changing over time. When using ADTs this gets even further complicated by the fact that we typically need ways to lift our logging functions into the type.
To get a handle on one way to approach debugging, we’ll look at a logAfter
function that is a must in any Functional Programmer’s toolkit. Using logAfter
we’ll hunt down a bug currently in our code base and once located, squash that bug out of existence.
// logAfter :: (a -> State s b) -> a -> State s b export const logAfter = fn => composeK(liftState(tap(console.log)),fn)
How to use:
// validateAnswer :: String -> State AppState Boolean const validateAnswer = converge( liftA2(equals), logAfter(getHint), logAfter(cardToHint) )
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2018-02-08 [ReactVR] Render Custom 3D Objects Using the Model Component in React VR
2018-02-08 [ReactVR] Add Lighting Using Light Components in React VR
2018-02-08 [ReactVR] Add Shapes Using 3D Primitives in React VR
2017-02-08 [NPM] Add comments to your npm scripts
2017-02-08 [NPM] List available npm scripts and support tab completion
2017-02-08 [NPM] Make npm scripts cross-environment friendly
2017-02-08 [Ramda] Count Words in a String with Ramda's countBy and invert