ghc-tcplugin-api
An API for type-checker plugins.
https://github.com/sheaf/ghc-tcplugin-api
| Stackage Nightly 2025-10-22: | 0.18.1.0 | 
| Latest on Hackage: | 0.18.1.0 | 
ghc-tcplugin-api-0.18.1.0@sha256:289d8d3b6ed733a933aa518d483dd5fbbe96420e39da9a58862757a6faa476ca,5295Module documentation for 0.18.1.0
This library provides a streamlined monadic interface for writing GHC type-checking plugins.
Each stage in a type-checking plugin (initialisation, solving, rewriting, shutdown) has a corresponding monad, preventing operations that are only allowed in some stages to be used in the other stages. Operations that work across multiple stages are overloaded across monads using MTL-like typeclasses.
Some operations, like creating evidence for constraints or creating custom type error messages, are also simplified.
Please refer to the associated GitHub repository for example usage.
Changes
Version 0.18.1.0 (2025-10-09)
- Bugfix for v0.18.0.0: deal with constraints generated by unflattening
in splitTyConApp_upTo. Fixes #19.
Version 0.18.0.0 (2025-09-15)
- 
On GHC 9.0 and below, ghc-tcplugin-apiwill now automatically unflatten all Given constraints. That is, all flattening skolems[G] fsk ~ F tyswill be substituted away, both in Givens and in Wanteds/Deriveds.No change for GHC 9.2 and above, as GHC stopped producing flattening variables from 9.2 onwards. 
Version 0.17.2.0 (2025-09-08)
- Fix the package failing to build on GHC 9.6.1 through 9.6.6 and on GHC 9.8.1 through 9.8.3. GHC versions 9.6.7 and 9.8.4 are unaffected.
Version 0.17.1.0 (2025-08-27)
- Fix a regression, introduced in 0.17.0.0, in whichsplitTyConApp_upTowould fail to take into account equalities of the formtv1 ~ tv2.
Version 0.17.0.0 (2025-08-25)
- splitTyConApp_upTonow additionally returns a- [Coercion]for tracking Given dependencies (which should be passed to functions such as- mkPluginUnivCo,- mkPluginUnivEvTermand- mkTyFamAppReduction).
Version 0.16.2.0 (2025-08-22)
- splitTyConApp_upTonow correctly splits apart type families. This ensures it is a valid drop-in replacement for- splitTyConApp_maybe(fixes issue #13).
Version 0.16.1.0 (2025-07-18)
- Correctness fix for the GHC.TcPlugin.API.TyConSubstmodule: ensure that theTyConSubstdoes not mistake representational Given equalities for nominal equalities. For the time being, thesplitTyConApp_upTofunctionality only works at nominal role.
Version 0.16.0.0 (2025-07-18)
- 
Re-export tyConDataCons,tyConSingleDataCon_maybe,tyConSingleDataCon,dataConTyCon,isNewTyConandisNewDataConfrom GHC.
- 
The isWantedfunction now correctly returnsFalsefor derived constraints. This is only relevant for GHC 9.2 and below.
- 
Add GHC.TcPlugin.API.TyConSubstmodule, which implements logic for recognising when a type is aTyConAppup to Given constraints.
Version 0.15.0.0 (2025-06-03)
- 
Remove tcPluginIOin favour of newMonadIOinstance.
 To migrate, useliftIOinstead oftcPluginIO.
- 
Add lookupTHNamefunction, which allows looking up Template Haskell names in typechecker plugins. Useful in conjunction withTemplateHaskellQuotes.
- 
Helper functions to construct evidence terms have been adjusted to return values of type EvExpr, rather thanEvTerm. This makes the functions more composable, and allows typechecker plugin to provide evidence for quantified constraints more easily.Affected functions: evDFunApp,evDataConApp,evCast.To migrate, you will need to manually wrap evidence terms with the EvExprconstructor in places that expect anEvTerm.
- 
Added natKind,symbolKindandcharKindfor the kinds of type-levelNat,SymbolandChar.
- 
Added several re-exports from the ghclibrary:- isGiven&- isWanted.
- ctEvPred,- ctEvId,- ctEvExprand- ctEvLoc.
- className&- tyConName.
- isEqPred(unboxed equality) and- isEqClassPred(boxed equality).
- evId&- ctEvId.
- typeKind.
- nonDetCmpType.
 
- 
Removed re-exports of ctev_pred,ctev_loc,ctev_evar, andctev_dest.Migration: use ctEvPredinstead ofctev_predandctEvLocinstead ofctev_loc. Uses ofctev_evarandctev_destshould be covered byctEvEvIdand/orctEvExpr.
Version 0.14.0.0 (2024-11-28)
- Rename mkPrimEqPredRoletomkEqPredRole. This is a re-exported function from GHC, and the renaming adapts to the renaming in GHC-9.13.
Version 0.13.0.0 (2024-10-30)
- 
Update to changes in the type of GHC’s mkUnivCoin order to (properly) add support for GHC 9.12.
- 
Change mkPluginUnivCo,mkPluginUnivEvTermandmkTyFamAppReductionto take a[Coercion]rather than aDVarSetfor specifying dependencies.
- 
Stop re-exporting DVarSet,emptyDVarSet,extendDVarSet,unionDVarSet,unitDVarSet, andmkDVarSet.
- 
Update documentation to suggest using ctEvCoercionrather thanctEvIdto specify coercions that aUnivCodepends on.
- 
Re-export ctEvCoercion, and stop re-exportingctEvId.
Version 0.12.0.0 (2024-10-22)
- 
Add preliminary support for GHC 9.12. 
- 
mkPluginUnivCo,mkPluginUnivEvTermandmkTyFamAppReductionnow all take an additionalDVarSetargument which allows specifying evidence that we depend on. This stops evidence terms being floated out past used enclosing Givens (see GHC issue #23923).
- 
Re-export DVarSet,emptyDVarSet,extendDVarSet,unionDVarSet,unitDVarSet, andmkDVarSet, as well asctEvId, in order to facilitate construction and manipulation ofDVarSets.
- 
Re-export GHC.Types.Unique.Set,GHC.Types.Unique.DSet.
Version 0.11.0.0 (2023-08-29)
- 
Add support for GHC 9.8. 
- 
Re-export functionality relating to GHC’s constraint solving TcSmonad, such as{get,set}InertSet,{get,set}TcEvBindsMap.
- 
Re-export readTcRefandwriteTcRef.
Version 0.10.0.0 (2023-02-28)
- 
Introduce resolveImport, and makePkgQualopaque.
- 
Rename tcRewriterWantedstotcRewriterNewWanteds(bringing it in line with nomenclature in GHC 9.4).
Version 0.9.0.0 (2023-01-24)
- 
Add support for GHC 9.6 and transformers0.6.
- 
The OneandManypattern synonyms are nowOneTyandManyTy.
- 
Use mkInvisFunTy/mkInvisFunTysinstead ofmkInvisFunTyMany/mkInvisFunTysMany.
Version 0.8.3.0 (2022-10-05)
- Bugfix for the GHC 9.0 rewriter plugin compatibility shim: fix coercion orientations in family application cache
Version 0.8.2.0 (2022-10-05)
- Bugfix for the GHC 9.0 rewriter plugin compatibility shim: fix coercion orientations in family rewriting.
Version 0.8.1.0 (2022-10-05)
- Bugfix for the GHC 9.2 rewriter plugin compatibility shim: fix coercion orientations in family rewriting.
Version 0.8.0.0 (2022-07-07)
- 
Compatibility for GHC 9.4. 
- 
Change API for lookupImportedModuleto usePkgQualandUnitIdinstead ofMaybe FastString, with back-compatibility functionpkgQual_pkgfor use with older module lookup functions.
- 
Re-export splitAppTysandunpackFS.
Version 0.7.1.0 (2022-01-04)
- 
newWantednow always uses theCtLocinformation that it is provided with, as opposed to obtaining some information from the monadic environment. This means you no longer need to wrap calls tonewWantedinsetCtLocMto ensure that GHC reports the correct source span when reporting unsolved Wanteds in error messages.
- 
Remove the newDerivedfunction, as Derived constraints are going to be removed from GHC.
Version 0.7.0.0 (2021-12-31)
- 
Re-export functions for dealing with type-level literals, such as mkNumLitTyandisStrLitTy.
- 
Re-export functions for splitting apart type applications, such as splitAppTy_maybeandtyConAppTyCon_maybe.
- 
Redefine and re-export mkUncheckedIntExprfor GHC versions prior to 9.0.
- 
Re-export some basic types from GHC.Types.Basicsuch asArity,PromotionFlagandBoxity.
- 
Re-export GHC.Builtin.NamesandGHC.Builin.Types.Prim.
- 
Provide MonadThingsinstances forTcPluginMmonads.
Version 0.6.1.0 (2021-12-13)
- 
Re-export various useful types and functions to deal with type and coercion variables. 
- 
Re-export a few types and functions to deal with source locations. 
- 
Remove some re-exports for constructing function types, as not all functions make sense across all GHC versions supported by the library. 
- 
Re-export panicandpprPanic.
Version 0.6.0.0 (2021-12-13)
- 
Add support for GHC 8.8. 
- 
Re-export evDataConApp, which is useful for constructing typeclass dictionaries.
Version 0.5.1.0 (2021-08-31)
- Fix a bug in the type-family rewriting compatibility layer (GHC 8.10, 9.0, 9.2) by correctly downgrading the coercion used to cast the evidence, when necessary.
Version 0.5.0.0 (2021-08-30)
- Re-export some additional types and functions that are useful for inspecting
and constructing evidence terms, such as mkTyVar,newName,mkLocalId,lookupEvBind…
Version 0.4.1.0 (2021-08-24)
- Re-export a few GHC modules, such as GHC.Core.Make and GHC.Plugins. These re-exports might be changed to be more selective in the future to aid cross-version compatibility.
Version 0.4.0.0 (2021-08-24)
- 
Adapt to GHC 9.4 changes in the TcPluginSolveResultdatatype: are now able to solve and emit constraints even when reporting a contradiction. This can help with error messages. Unfortunately these extra constraints will be dropped in versions of GHC prior to 9.4.
- 
Add a utility module for name resolution using constrained traversals. 
- 
Add compatibility for GHC 8.10. 
Version 0.3.1.0 (2021-08-09)
Ensure that the coercions stored in Reductions are always
oriented left-to-right, by making the internal rewriting compatibility layer
also use left-to-right coercions.
Version 0.3.0.0 (2021-08-04)
Account for changes in rewriting in GHC 9.4:
- rewriter plugins can no longer emit new Wanted constraints if they don’t rewrite the type family application;
- coercions in the rewriter are now oriented left-to-right,
requiring mkTyFamAppReductionto be adapted.
Version 0.2.0.0 (2021-07-22)
Initial release on Hackage.
