
is there some module out there than provides a template haskell function that do the same thing but generating simple accessor functions instead of lenses? Or can I configure the parameters of makeFieldsWith to generate simple functions instead of
lenses? There are none that I am aware of. I certainly don't think Control.Lens supports this. Another related question: if I use makeFields
in more than one module, and different records have fields with the same name, the generated typeclasses will have the same name but will be different, because declared twice in different modules, am I right?
I believe this is correct. Is there a way to use a unique
typeclass in the whole project for every generated field of the same name?
If the typeclass already exists in the module, then it won't be generated. So if you are working on module B, and you import module A which exports the class in question, then I believe module B will just use the class from module A instead of creating its own. There are various helper functions in Control.Lens.TH, such as "makeClassyFor", which are meant to help with this. However, I don't think your use case is covered well by these helper functions. If you get in touch with the lens devs (file an issue in their github tracker, or chat with them on irc), I'm sure they can help you accomplish what you desire. n.b. lenses aren't all that scary. It is quite simple to retrieve the "simple accessor" from a lens. Just use "view". import Control.Lens.Getter (view) -- given this typeclass operation fooLens :: HasFoo a => Lens' a Foo -- just use view on it to extract the getter portion of the lens foo :: HasFoo a => a -> Foo foo = view fooLens -- Dan Burton On Sat, Oct 4, 2014 at 11:02 AM, Andrew Gibiansky < andrew.gibiansky@gmail.com> wrote:
Nicola,
Could you be looking for the OverloadedRecordFields[0] extension? This is an extension that I *think* is slated to be in 7.10, and might do what you want (though won't help you now).
If you declare two data types with the same field name (e.g. data A = A { hello :: Int} and data B = B { hello :: Int }), the extension will generate some typeclasses and type families so that you can use `hello` on both data types.
(I haven't used this myself, but have been looking forward to it, so if anyone wants to correct me on anything I've said please do so.)
[0] https://ghc.haskell.org/trac/ghc/wiki/Records/OverloadedRecordFields
On Sat, Oct 4, 2014 at 6:53 AM, Brandon Allbery
wrote: On Sat, Oct 4, 2014 at 5:57 AM, Nicola Gigante
wrote: However, it generates lenses, which at this time I don’t use in my little project. I'll learn to use them well sooner or later, I promise! In the meantime, is there some module out there than provides a template haskell function that do the same thing but generating simple accessor functions instead of lenses?
Anything that does this creates lenses. That does not mean that they all create Control.Lens, though; a lens is a general abstraction, not a trademark. The simplest version, focused solely on this use case, is probably the fclabels package.
Note that the reason they do what you need is that they are lenses. Simple accessors will conflict as you described. fclabels is still useful if you're only interested in lenses for record field accessors, though, since the full lens package is rather heavyweight in that case --- and as a bonus, you'll be getting a head start on the more general concept, without getting dropped into the deep end of the pool.
-- brandon s allbery kf8nh sine nomine associates allbery.b@gmail.com ballbery@sinenomine.net unix, openafs, kerberos, infrastructure, xmonad http://sinenomine.net
_______________________________________________ Haskell-Cafe mailing list Haskell-Cafe@haskell.org http://www.haskell.org/mailman/listinfo/haskell-cafe
_______________________________________________ Haskell-Cafe mailing list Haskell-Cafe@haskell.org http://www.haskell.org/mailman/listinfo/haskell-cafe