On 2019/02/27 10:59, Hendrik Boom wrote: > > On Tue, Feb 26, 2019 at 03:39:24PM +0900, Jacques Garrigue wrote: >> >> 2019/02/26 15:23, Hendrik Boom >: >>> >>> I have a (broken) function definition starting: >>> >>> let mixfix : 'token1 'phrase1. >>> ('token1, 'phrase1, ('token1, 'phrase1) Phrasestream.phrasestream) grammar >>> -> ('token1, 'phrase1) parser >>> = fun gram -> ( >>> ... >>> >>> It goes o for a hundred-odd lines. >>> The type-parameterized types Phrasestream.phrasestream, grammar, and parser >>> have been previously defined, and there are also operations defined on these >>> types. >>> >>> The problem I'm having is that the OCaml type-checker ends up identifying >>> the type parameters 'token1 an 'phrase1 because of type errors I've made in >>> the body of the mixfix function. Somewhere I ended up using an >>> operator that's supposed to work on values of type 'token1 >>> on a value of type 'phrase1 instead, and identification of 'token1 and >>> 'phrase1 is the natural result. >>> >>> Is there some way of forcing the type checker to treat 'token1 and >>> 'phrase1 as different types so that I can get meaningful type errors >>> at the point were they occur? >> >> You can use locally abstract types, which are often used with GADTs but are not >> restricted to them: >> let mixfix : type token1 phrase1. >> (token1, phrase1, (token1, phrase1) Phrasestream.phrasestream) grammar >> -> (token1, phrase1) parser >> = fun gram -> ( > > Thus *with* the type keyword, but *without* the apostrophes on token1 > and phrase1? Exactly. This means that in the body of your function their are abstract types, and you cannot unify them. Aside of that the behavior is the same as what we had written first. Jacques