Alternative to Scala REPL breakIf in 2.10

2020-05-18 05:11发布

I was reading here about using the breakIf method in the REPL code for interactive debugging, but then I found this post saying that break and breakIf were removed from ILoop in Scala 2.10. Unfortunately, that post doesn't explain why the code was removed.

I'm assuming that these functions were removed because there's a better way of doing this. If that's the case, could someone please enlighten me?

1条回答
▲ chillily
2楼-- · 2020-05-18 05:36

Perhaps the idea is that you should just work with the ILoop directly? As far as I can tell, it shouldn't be much more complex than:

// insert the code below wherever you want a REPL
val repl = new ILoop
repl.settings = new Settings
repl.in = SimpleReader()
repl.createInterpreter()

// bind any local variables that you want to have access to
repl.intp.bind("i", "Int", i)
repl.intp.bind("e", "Exception", e)

// start the interpreter and then close it after you :quit
repl.loop()
repl.closeInterpreter()

Compared to the old breakIf API, this approach gets rid of an additional level of indirection for both the if condition (which was wrapped into a => Boolean) and the DebugParam/NamedParam (which were temporary wrappers used only to fill in the bind arguments).

This approach also allows you to specify your Settings as needed. For example, some REPL bugs can be worked around with -Yrepl-sync but break gave you no way of specifying that.

查看更多
登录 后发表回答