Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 52011
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T16:50:24+00:00 2026-05-10T16:50:24+00:00

Using Scala’s command line REPL: def foo(x: Int): Unit = {} def foo(x: String):

  • 0

Using Scala’s command line REPL:

def foo(x: Int): Unit = {} def foo(x: String): Unit = {println(foo(2))} 

gives

error: type mismatch; found: Int(2) required: String 

It seems that you can’t define overloaded recursive methods in the REPL. I thought this was a bug in the Scala REPL and filed it, but it was almost instantly closed with ‘wontfix: I don’t see any way this could be supported given the semantics of the interpreter, because these two methods must to be compiled together.’ He recommended putting the methods in an enclosing object.

Is there a JVM language implementation or Scala expert who could explain why? I can see it would be a problem if the methods called each other for instance, but in this case?

Or if this is too large a question and you think I need more prerequisite knowledge, does someone have any good links to books or sites about language implementations, especially on the JVM? (I know about John Rose’s blog, and the book Programming Language Pragmatics… but that’s about it. 🙂

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-10T16:50:25+00:00Added an answer on May 10, 2026 at 4:50 pm

    The issue is due to the fact that the interpreter most often has to replace existing elements with a given name, rather than overload them. For example, I will often be running through experimenting with something, often creating a method called test:

    def test(x: Int) = x + x 

    A little later on, let’s say that I’m running a different experiment and I create another method named test, unrelated to the first:

    def test(ls: List[Int]) = (0 /: ls) { _ + _ } 

    This isn’t an entirely unrealistic scenario. In fact, it’s precisely how most people use the interpreter, often without even realizing it. If the interpreter arbitrarily decided to keep both versions of test in scope, that could lead to confusing semantic differences in using test. For example, we might make a call to test, accidentally passing an Int rather than List[Int] (not the most unlikely accident in the world):

    test(1 :: Nil)  // => 1 test(2)         // => 4  (expecting 2) 

    Over time, the root scope of the interpreter would get incredibly cluttered with various versions of methods, fields, etc. I tend to leave my interpreter open for days at a time, but if overloading like this were allowed, we would be forced to ‘flush’ the interpreter every so often as things got to be too confusing.

    It’s not a limitation of the JVM or the Scala compiler, it’s a deliberate design decision. As mentioned in the bug, you can still overload if you’re within something other than the root scope. Enclosing your test methods within a class seems like the best solution to me.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 105k
  • Answers 106k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer If the reason you can't create the object is because… May 11, 2026 at 8:49 pm
  • Editorial Team
    Editorial Team added an answer I found the answer to my question upto a good… May 11, 2026 at 8:49 pm
  • Editorial Team
    Editorial Team added an answer MVVM is useful even if you have only one screen.… May 11, 2026 at 8:49 pm

Related Questions

Using Scala's command line REPL: def foo(x: Int): Unit = {} def foo(x: String):
Where do you seen using Scala for your project?
I want to write a function that works on any Scala type with a
I'm using IntelliJ IDEA with the Scala plugin. If I reference HashMap in code,
I needed a Low-Pass-Filter in one of my Scala projects and came up with

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.