Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

type constructor escape its scope #3381

Closed
vicuna opened this issue Jun 7, 2002 · 3 comments
Closed

type constructor escape its scope #3381

vicuna opened this issue Jun 7, 2002 · 3 comments
Labels

Comments

@vicuna
Copy link

vicuna commented Jun 7, 2002

Original bug ID: 1189
Reporter: administrator
Status: closed
Resolution: fixed
Priority: normal
Severity: minor
Category: ~DO NOT USE (was: OCaml general)

Bug description

Bonjour,

ceci est sans doute plus un problème d'affichage du type qu'un bug, mais
il n'empêche que le type renvoyé n'est pas satisfaisant

    Objective Caml version 3.04+13 (2002-06-05)

let f x =

let module M = struct type t = [ A | B] let z : t = x end in
M.z
;;
val f : t -> M.t =

@vicuna
Copy link
Author

vicuna commented Jun 7, 2002

Comment author: administrator

ceci est sans doute plus un problème d'affichage du type qu'un bug, mais
il n'empêche que le type renvoyé n'est pas satisfaisant

let f x =

let module M = struct type t = [ A | B] let z : t = x end in M.z;;
val f : t -> M.t =

En effet, c'est louche, même si je n'ai pas encore trouvé un exemple
de cette forme qui "casserait" le typage.

Pour les développeurs Caml qui connaissent le typeur: j'ai
l'impression qu'il faudrait utiliser Ctype.nondep_type au lieu d'une
unification sous préfixe. Mais est-ce que Ctype.nondep_type est
applicable à un type simple?

  • Xavier Leroy

@vicuna
Copy link
Author

vicuna commented Jun 8, 2002

Comment author: administrator

From: lvibert@irisa.fr

ceci est sans doute plus un probleme d'affichage du type qu'un bug, mais
il n'empeche que le type renvoye n'est pas satisfaisant

let f x =

let module M = struct type t = [ A | B] let z : t = x end in M.z ;;
val f : t -> M.t =

En effet, c'est lie' aau tracage des noms de variants, destine' a`
l'affichage.

From: xavier.leroy@inria.fr

Pour les developpeurs Caml qui connaissent le typeur: j'ai
l'impression qu'il faudrait utiliser Ctype.nondep_type au lieu d'une
unification sous prefixe. Mais est-ce que Ctype.nondep_type est
applicable a un type simple?

Non, l'unification appelle update_level, qui est cense' faire le
boulot.
Le probleme est que update_level oubliait d'eliminer les abbreviations
destinees a` l'affichage. C'est sans danger, mais incorrect.

Un autre exemle utilisant les objets:

let f x = let module M= struct class type c = object method m : int end let g x = (x :> c) end in M.g;;

val f : 'a -> #M.c -> < m : int > =

Tout ca est maintenant corrige'.

 Jacques

@vicuna
Copy link
Author

vicuna commented Jun 10, 2002

Comment author: administrator

Fixed by Jacques on 2002-06-08.

@vicuna vicuna closed this as completed Jun 10, 2002
@vicuna vicuna added the bug label Mar 19, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant