[Haskell-cafe] The Good, the Bad and the GUI
Wojtek Narczyński
wojtek at power.com.pl
Tue Aug 12 22:44:18 UTC 2014
On 13.08.2014 00:26, Daniel Gorín wrote:
> On 12 Aug 2014, at 20:23, Wojciech Narczyński <wojtek at power.com.pl> wrote:
>
>> W dniu 2014-08-12 15:01, Daniel Gorín pisze:
>>> On 11 Aug 2014, at 23:16, Wojtek Narczyński <wojtek at power.com.pl> wrote:
>>>
>>>> If you declare Person class in Java, you automatically get a thingy that you can readily use in UI construction, because all the fields can temporarily be null, even the required ones. In Haskell you'd need two data types: the usual proper Haskell data type, and another which wraps every field in Maybe, facilitates editing, validation, etc. Perhaps it would be possible to generate one data type from the other, or generate both from a common specification.
>>> At least this part you can achieve rather easily by parametrizing each field in your record by a functor. E.g.:
>>>
>>> data Person f
>>> = Person {
>>> firstName :: f String
>>> ,lastName :: f String
>>> ,birthDate :: f Date
>>> ,height :: f Int
>>> }
>>>
>>> Then you get:
>>>
>>> - "Person Id" is a person with every field set in stone.
>>>
>>> - "Person Maybe" is a person with missing information.
>>>
>>> - Other functors can be easily defined (and then composed) to represent things such as Mandatory/Optional, Valid/Invalid, etc.
>>>
>>>
>>>
>> I saw in the presentation submitted in another post that a similar thing has been done in Vinyl. But this won't work so well, because in the "rigid" type some fields are still supposed to remain wrapped in Maybe.
> That’s not necessary a problem. If you add a field:
>
> ,favoriteNumber :: f (Maybe Int)
>
> Then, in Person Maybe, a value of Nothing in favoriteNumber would mean “not entered” while Just Nothing would be “none”. Maybe you have some specific problem in mind?
>
There is such a distinction in certain DBMSes: null vs "". It is
confusing even to developers, not to mention users.
More information about the Haskell-Cafe
mailing list