- 
                Notifications
    You must be signed in to change notification settings 
- Fork 30
StrMap.fromRecord #127
base: master
Are you sure you want to change the base?
StrMap.fromRecord #127
Conversation
| My only concern is that the runtime representation of these two types might not necessarily coincide in other backends. | 
| @hdgarrood  | 
| Perhaps the solution is to add a level of indirection before the  | 
| How would a level of indirection help? Currently I think alternate backend maintainers have been forking the core libraries and translating the FFI code; just because there's only JS FFI stuff here, I don't think that means that we can ignore the issue of alternate backends. I think I'd prefer to address #118 before merging this. Other than that, though, this seems great. See also #125 | 
034c9fe    to
    6e066ed      
    Compare
  
    | @hdgarrood I've made a change, above, that I think should address the concern by moving the coercion to FFI code. Happy to wait for resolution to #118 . | 
| Ohh, I see what you mean now. Yeah, that does seem like it should address that concern. Do you think you can work out how to make the linter happy? | 
6e066ed    to
    f1ef4a7      
    Compare
  
    | The linter loves me now. | 
| Great! Before merging I'd like to get approval from someone else, as I'm not sure I'm fully aware of the implications of adding this function. I'd also like to wait until 0.12 to merge this, because changing dependencies of core libraries is generally something that we need to take a bit of care with and has potential to break things, and so it's probably best to wait until we're breaking everything anyway. | 
        
          
                src/Data/StrMap.purs
              
                Outdated
          
        
      | pure s) | ||
|  | ||
| -- | Create a map from a homogeneous record (all attributes have the same type). | ||
| foreign import fromRecord :: forall r t. Homogeneous r t => Record r -> StrMap t | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it's a good idea for foreign functions to take constraints. It's better to declare an "unsafe" impl function for internal use, and add a constraint to the PS wrapper. Honestly, I wish PS altogether disallowed constraint syntax in foreign imports.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks. Will fix.
create a StrMap from a homogeneous record
f1ef4a7    to
    9697436      
    Compare
  
    
create a
StrMapfrom a homogeneous record