caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: tim@fungible.com (Tim Freeman)
To: caml-list@inria.fr
Subject: [Caml-list] Polymorphic variants as type parameters
Date: Fri, 30 Aug 2002 08:34:25 -0700	[thread overview]
Message-ID: <20020830155016.90B527F63@lobus.fungible.com> (raw)

Here's some code that I'd like to be able to compile:

   type eventtype = [`VECTOR | `SCALAR | `UNIT]
   type +'a eventid
   constraint 'a = [> eventtype ]
   type scalar_eventid = [`SCALAR] eventid

Unfortunately it gives me an error:

   Characters 124-133:
        type scalar_eventid = [`SCALAR] eventid
                              ^^^^^^^^^
   This type [ `SCALAR] should be an instance of type
     [> eventtype] = [> `SCALAR | `UNIT | `VECTOR]
   The first variant type does not allow tag(s) `UNIT, `VECTOR

This feels like a bug to me: I said the type variable was covariant,
and the type I'm substituting for the type variable is more specific
than the old one, so I had expected it to be happy with that.

The present workaround I'm using is to leave out the type constraint
on the type argument to eventid:

   type eventtype = [`VECTOR | `SCALAR | `UNIT]
   type +'a eventid
   type scalar_eventid = [`SCALAR] eventid

This doesn't say what I want because it only makes sense for the type
argument to eventid to be some subset of the set {`VECTOR, `SCALAR, `UNIT}.

Another approach to getting the code to compile is to give
scalar_eventid a type parameter.  This compiles but it doesn't say
what I want to say because scalar_eventid shouldn't have a type
parameter; that would force my code to grow useless extra type
variables in lots of places.

   type eventtype = [`VECTOR | `SCALAR | `UNIT]
   type +'a eventid
   constraint 'a = [> eventtype ]
   type 'a scalar_eventid = 'a eventid
   constraint 'a = [> `SCALAR ]

Is there any way to say what I want to say in OCAML?  Is this as a
bug?

-- 
Tim Freeman       
tim@fungible.com
GPG public key fingerprint ECDF 46F8 3B80 BB9E 575D  7180 76DF FE00 34B1 5C78 
-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners


             reply	other threads:[~2002-08-30 15:50 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2002-08-30 15:34 Tim Freeman [this message]
2002-08-30 16:27 ` John Prevost
2002-08-30 17:08   ` Tim Freeman

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20020830155016.90B527F63@lobus.fungible.com \
    --to=tim@fungible.com \
    --cc=caml-list@inria.fr \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).