caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: Andreas Rossberg <rossberg@ps.uni-sb.de>
To: caml-list@inria.fr
Subject: Re: [Caml-list] choosing modules at runtime
Date: Tue, 24 Sep 2002 11:36:29 +0200	[thread overview]
Message-ID: <3D90321D.DEFBF3AA@ps.uni-sb.de> (raw)
In-Reply-To: <Pine.LNX.4.44.0209241034550.15455-100000@lcavpc41.epfl.ch>

Henri Dubois-Ferriere wrote:
> 
> let run_algo =
>   if (use algorithm 1) then
>   M_1.run_algo
>   else if (use algorithm 2) then
>   M_2.run_algo ...
> 
> and then simply call run_algo from then on. (But this needs to be done for
> every function/value that the signature M exports).

It's not too bad, just do:

 let (algoA, algoB, algoC) =
   if (use algorithm 1) then
   (M_1.algoA, M_1.algoB, M_1.algoC)
   else if (use algorithm 2) then
   (M_2.algoA, M_2,algoB, M_2.algoC) ...

But admittedly it still is somewhat annoying.

> Am I missing something obvious here? Of course what I would conceptually
> like to do would be something like
> 
> let Mod = if (use algorithm 1) then M_1 else if (use alg 2) then M_2 ..
> 
> and then be able to call Mod.run_algo(), but that probably belies that I
> am still thinking in an OO manner...

No, you are right. Unfortunately, this either requires 1st-class
modules, or if-then-else on the module level. (The latter can be
partially faked by heroic use of higher-order functors, but you don't
want to see that and it most likely does not apply to your particular
problem, since the condition itself had to be expressible in the module
language). Both is not (yet?) available in OCaml, and in very few other
languages, for that matter (Moscow ML currently being the only MLish
exception). Such a feature is not impossible to add, but represents a
significant complication of the language that may not be considered
worthwhile.

	- Andreas

-- 
Andreas Rossberg, rossberg@ps.uni-sb.de

"Computer games don't affect kids; I mean if Pac Man affected us
 as kids, we would all be running around in darkened rooms, munching
 magic pills, and listening to repetitive electronic music."
 - Kristian Wilson, Nintendo Inc.
-------------------
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-09-24  9:51 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2002-09-24  8:48 Henri Dubois-Ferriere
2002-09-24  9:36 ` Andreas Rossberg [this message]
2002-09-24 10:37   ` Markus Mottl
2002-09-24 10:08 ` Markus Mottl
2002-09-24 10:18 ` Olivier Andrieu
2002-09-24 17:24   ` Sven LUTHER
2002-09-24 10:42 ` Yamagata Yoriyuki
2002-09-24 12:43 ` Alessandro Baretta
2002-09-24 12:55   ` Maxence Guesdon
2002-09-24 10:40 Sebastien.deMentendeHorne
2002-09-24 11:00 ` Markus Mottl
2002-09-24 11:09 Sebastien.deMentendeHorne
2002-09-24 11:41 ` Markus Mottl
2002-09-30  7:28   ` John Max Skaller
2002-10-02 13:04     ` Alessandro Baretta
2002-10-02 13:28       ` Dave Mason
2002-10-02 20:57         ` Chris Hecker

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=3D90321D.DEFBF3AA@ps.uni-sb.de \
    --to=rossberg@ps.uni-sb.de \
    --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).