I meant how would the actor be written using the custom type approach that I proposed, if the way I wrote it before wasn’t quite right . I’m not really familiar with JSON-LD.
I don’t agree really. This seems to be some object-oriented way of thinking about it (inferring from the usage of the word “class”), but I don’t think it really fits. Since there can be multiple types for a single object, it is much less akin to the object-oriented class and much closer to the concept of a type class or trait as seen in languages like Haskell or Rust. Seen in that light, it is perfectly natural to consider the type
field to be a behavior-defining property.
Wouldn’t you need to know about FEP-1b12 in any case, even if you signified it through some other field, like constrainedBy? I mean you can’t get around the fact that you need some prior knowledge to understand a specific FEP.
I would define it through this FEP, which describes very usefully how I can expect that actor to behave.
I don’t see the problem in breaking it up into more specific behaviors - you just add more entries to the type
field. Translated to programming-language lingo, adding an entry is akin to implementing a trait for an object in Rust, i.e. adding a set of behaviors. Traits/type classes can be arbitrarily specific and broken up.