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 7542959
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 30, 20262026-05-30T08:18:15+00:00 2026-05-30T08:18:15+00:00

Given this definition: class Foo(var x: String) {} object Helper { def model[T](get: ⇒

  • 0

Given this definition:

class Foo(var x: String) {}

object Helper {
  def model[T](get: ⇒ T, set: T ⇒ Unit) : Model[T] = new Model[T] {
    override def getObject(): T = get

    override def setObject(obj: T) { set(obj) }
  }
}

I try to call model like this:

val f = new Foo("initial")
val stringModel = model(f.x, f.x = _)

But that doesn’t work, the compiler gives me this, complaining about the underscore:

missing parameter type for expanded function ((x$1) => f.x = x$1)

If I change the definition of model to use two parameter lists like this:

def model[T](get: ⇒ T)(set: T ⇒ Unit) // rest is unchanged

Then I can call it like this:

model(f.x)(f.x = _)

Which I find nice and concise. I don’t really mind doing it like this, though it makes method overloading harder. I would like to understand, however, why the second variant works and the first one doesn’t?

  • 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. Editorial Team
    Editorial Team
    2026-05-30T08:18:16+00:00Added an answer on May 30, 2026 at 8:18 am

    The second variant works because Scala refines its types parameter-block by parameter-block. If you don’t specify the type of your input parameter for the function, it’s possible that it would change the type T that it has inferred based on the first parameter. If you push it to a separate parameter block, Scala’s already decided what T must be by the time it hits that block, so it fills in the only possible value for the function argument type.

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

Sidebar

Related Questions

Given the following Model, public class A { public string Name { get; set;
Given this definition: [UniqueId(Ident)] public class MyClass : MyBase { public int Ident{ get;
given the following class definition: public class Order { public IProduct Product {get;set;} }
In C#, given a class definition like this: public class SomeObject { public String
given this class definition: public class Frame { IFrameStream CapturedFrom; } I want implement
Given this class class Foo { // Want to find _bar with reflection [SomeAttribute]
Given this data set: ID Name City Birthyear 1 Egon Spengler New York 1957
I have a class set up like this: class Foo { Foo(); private: Bar
Given a generic class definition BaseClass<T> , is it possible to test this condition?
I have this definition in a WinForm: private BindingList<String> rollbackLog = new BindingList<String>(); I

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.