From: Walter Cazzola <cazzola@dico.unimi.it>
To: OCaML Mailing List <caml-list@inria.fr>
Subject: [Caml-list] still silly issues on polymorphic types
Date: Tue, 27 Sep 2011 13:46:02 +0200 (CEST) [thread overview]
Message-ID: <alpine.LFD.2.00.1109271335550.8918@surtur.dico.unimi.it> (raw)
[-- Attachment #1: Type: TEXT/PLAIN, Size: 1350 bytes --]
Dear all,
I'm still playing around with functors, modules and polymorphism but
I've some problems with this last concept.
In the attached files I have tried to implement a sort of function with
a variable number of arguments (based on continuation) and to generalize
the approach I've used a functor (OpVarADT) where I defined the
operation of type 'a -> 'b -> 'c but seems that it is not general enough
to contain int->int->int or 'a -> 'a list -> 'a list
This is the functor instantiation with the errors I get:
# module M0 = Continuation(StringConcat) ;;
Error: Signature mismatch:
Modules do not match:
sig val op : 'a -> 'a list -> 'a list val init : 'a list end
is not included in
OpVarADT.OpVarADT
Values do not match:
val op : 'a -> 'a list -> 'a list
is not included in
val op : 'a -> 'b -> 'c
# module M1 = Continuation(Sum) ;;
Error: Signature mismatch:
Modules do not match:
sig val op : int -> int -> int val init : int end
is not included in
OpVarADT.OpVarADT
Values do not match:
val op : int -> int -> int
is not included in
val op : 'a -> 'b -> 'c
I'm sure I'm doing something wrong but I can't see what, any help is
welcome
TIA
Walter
--
[-- Attachment #2: Type: TEXT/PLAIN, Size: 75 bytes --]
module Sum = struct
let op = fun x y -> x+y ;;
let init = 0 ;;
end
[-- Attachment #3: Type: TEXT/PLAIN, Size: 82 bytes --]
module type OpVarADT =
sig
val op: 'a -> 'b -> 'c
val init : 'c
end
[-- Attachment #4: Type: TEXT/PLAIN, Size: 182 bytes --]
module Continuation (OP : OpVarADT.OpVarADT) =
struct
let arg x = fun y continuation -> continuation (OP.op x y) ;;
let stop x = x;;
let f g = g OP.init;;
end
[-- Attachment #5: Type: TEXT/PLAIN, Size: 89 bytes --]
module StringConcat = struct
let op = fun x y -> y @ [x] ;;
let init = [] ;;
end
next reply other threads:[~2011-09-27 11:46 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-09-27 11:46 Walter Cazzola [this message]
2011-09-27 12:57 ` Christophe Papazian
2011-09-27 13:49 ` Walter Cazzola
2011-09-27 15:26 ` Christophe Papazian
2011-09-27 18:43 ` Walter Cazzola
2011-09-27 19:25 ` Thibault Suzanne
2011-09-27 13:16 ` Jacques Garrigue
2011-09-27 13:58 ` Walter Cazzola
2011-09-27 19:45 ` Pierre Chopin
2011-09-27 20:22 ` Walter Cazzola
2011-09-27 23:58 ` Jacques Garrigue
[not found] ` <266E7048-C3BB-4B9E-9760-9D52993A1C86@math.nagoya-u.ac.jp>
2011-09-29 10:27 ` Walter Cazzola
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=alpine.LFD.2.00.1109271335550.8918@surtur.dico.unimi.it \
--to=cazzola@dico.unimi.it \
--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