diff options
| author | Manuel M T Chakravarty <chak@cse.unsw.edu.au> | 2006-09-20 16:56:10 +0000 | 
|---|---|---|
| committer | Manuel M T Chakravarty <chak@cse.unsw.edu.au> | 2006-09-20 16:56:10 +0000 | 
| commit | 5c71a3bc3e9acfe3bee384a7948696aa5ac71646 (patch) | |
| tree | 037a7e9a675e95fd8dcbacf3ce792e78876a0b41 | |
| parent | d937e740b0c861a40243a83ac119de76775bd880 (diff) | |
| download | haskell-5c71a3bc3e9acfe3bee384a7948696aa5ac71646.tar.gz | |
..and a bit more
Mon Sep 18 14:30:11 EDT 2006  Manuel M T Chakravarty <chak@cse.unsw.edu.au>
  * ..and a bit more
  Sat Aug  5 21:23:16 EDT 2006  Manuel M T Chakravarty <chak@cse.unsw.edu.au>
    * ..and a bit more
    Fri Jul  7 10:40:40 EDT 2006  simonpj@microsoft.com
| -rw-r--r-- | compiler/typecheck/TcInstDcls.lhs | 38 | 
1 files changed, 0 insertions, 38 deletions
| diff --git a/compiler/typecheck/TcInstDcls.lhs b/compiler/typecheck/TcInstDcls.lhs index 6ff97e36af..b05b551942 100644 --- a/compiler/typecheck/TcInstDcls.lhs +++ b/compiler/typecheck/TcInstDcls.lhs @@ -551,44 +551,6 @@ tcMethods origin clas inst_tyvars' dfun_theta' inst_tys'      mapM tc_method_bind meth_infos		`thenM` \ meth_binds_s ->      returnM (meth_ids, unionManyBags meth_binds_s) -v v v v v v v -************* - - --- Derived newtype instances -tcMethods origin clas inst_tyvars' dfun_theta' inst_tys'  -	  avail_insts op_items (NewTypeDerived maybe_co rep_tys) -  = getInstLoc origin				`thenM` \ inst_loc -> -    mapAndUnzip3M (do_one inst_loc) op_items	`thenM` \ (meth_ids, meth_binds, rhs_insts) -> -     -    tcSimplifyCheck -	 (ptext SLIT("newtype derived instance")) -	 inst_tyvars' avail_insts rhs_insts	`thenM` \ lie_binds -> - -	-- I don't think we have to do the checkSigTyVars thing - -    returnM (meth_ids, lie_binds `unionBags` listToBag meth_binds) - -  where -    do_one inst_loc (sel_id, _) -	= -- The binding is like "op @ NewTy = op @ RepTy" -		-- Make the *binder*, like in mkMethodBind -	  tcInstClassOp inst_loc sel_id inst_tys'	`thenM` \ meth_inst -> - -		-- Make the *occurrence on the rhs* -	  tcInstClassOp inst_loc sel_id rep_tys'	`thenM` \ rhs_inst -> -	  let -	     meth_id = instToId meth_inst -	  in -	  return (meth_id, noLoc (VarBind meth_id (nlHsVar (instToId rhs_inst))), rhs_inst) - -	-- Instantiate rep_tys with the relevant type variables -	-- This looks a bit odd, because inst_tyvars' are the skolemised version -	-- of the type variables in the instance declaration; but rep_tys doesn't -	-- have the skolemised version, so we substitute them in here -    rep_tys' = substTys subst rep_tys -    subst    = zipOpenTvSubst inst_tyvars' (mkTyVarTys inst_tyvars') -^ ^ ^ ^ ^ ^ ^  \end{code} | 
