Mailing list for all users of the OCaml language and system.
 help / color / mirror / Atom feed
* null values and sentinels
@ 1999-01-12 15:50 Jerry Jackson
  1999-01-17 11:13 ` Xavier Leroy
  1999-01-18 10:05 ` Anton Moscal
  0 siblings, 2 replies; 3+ messages in thread
From: Jerry Jackson @ 1999-01-12 15:50 UTC (permalink / raw)
  To: 'caml-list@inria.fr'

Hello,

I'd like to know what the recommended solution to the following 
situation is...

I'd like to create a type like:

# type foo = {xxx: int; mutable yyy: foo};;

so that I can add nodes by mutating the "yyy" slots.  Unfortunately,
it seems that I must create a sentinel value of type "foo" to stand
for a null pointer.  This works but I'd like to be able to use pattern
matching on the value of yyy so as to get compile-time warnings if I
forget to check for null.

So, I tried this:

# type foo2 = {xxx: int; mutable yyy: bar} and bar = Empty | Pointer of
foo2;;

This works (i.e.  I can match on yyy in the way that I want), but
it _seems_ like this will create an extra indirection object in the
yyy slot.  Whether it does or not seems to be a compiler question to
me...  "Pointer of foo2" could be collapsed into foo2 by the
compiler.  Is it?  How should I approach this situation?

Thanks for any help,

Jerry Jackson




^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~1999-01-18 11:10 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
1999-01-12 15:50 null values and sentinels Jerry Jackson
1999-01-17 11:13 ` Xavier Leroy
1999-01-18 10:05 ` Anton Moscal

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox