Some additional thoughts
I was thinking a lot about this context-based resolution idea and I think that it is possible to go a little further (not immediately, mind you, it is the idea for the future). I am leaving this global context G
everywhere in my schemes and it does not play any important role because it usually is empty. But in fact it could provide a lot of opportunities.
File level context
G
is basically resolved to file which does not have any type of its own. But if there was a way to bind a context or a set of contexts to the file itself (not proposing any syntax solution, but it should be quite easy). Then everywhere in my schemes above we will just replace G
with G, F1, F2
. Meaning that all classes and functions in this file will have additional implicit contexts, just like type-classes. Of-course, it means that F
s could only be singletons in this case.
Extension classes and interfaces
We consider a class or interface to be top-level non-empty context. It seems to be not so hard to add a set of external contexts to the class context. It could look like class [T1,T2].MyClass{}
. In this case the instance of this class could be created only in context bound to both T1
and T2
and all members of this class will have additional implicit contexts, meaning member of MyClass
will be able to call members of T1
without additional declarations. From the implementation point of view, the instances of T1
and T2
could be class constructor implicit parameters (or a single map parameter, which is probably better), it should not violate anything, even Java compatibility (you will have to pass instances of contexts to create class instance). The interfaces could work the same way, just provide synthetic (invisible) property which holds the Map<KClass, Any>
of actual receiver.
Note: There will be some problem with class type parameter syntax here since unlike functions, type parameters in classes are declared after class name, but probably it could be solved.
This second proposal is in fact much more flexible than first one since we can use non-singleton contexts and define them explicitly on class creation. Also, both ideas probably could cover most of type-classes use-cases.