forwards compatability in enumerations in .cabal files

Duncan Coutts duncan.coutts at worc.ox.ac.uk
Tue Mar 18 09:21:42 EDT 2008


I'm looking for some advice...

I think lots of bits of the current parser need another look. All the
enumeration fields are very brittle and do not allow for any forwards
compatibility. Cabal's current response to adding a new compiler,
license, build-type, language extension or whatever is to just fail with
a "parse error in field 'foo' on line N".

All uses of parseReadS really have to go.

One idea is to add an extra catch-all onto these enums, like:

data CompilerFlavour =
    ...
  | UnknownCompiler String

then we check for such unknown values and warn about them and do not
allow them to be uploaded to hackage. When we add new enum values, older
Cabal versions will treat the value as other/unknown and where possible
carry on with just a warning. Where it's not possible to carry on with
an unknown value it can fail with a more helpful error message.

Another alternative is to keep only known values in the enumeration but
do something more generic in the parser to represent unknown or failed
values. However that still leaves the problem of what to do when we
encounter unknown values. How they're handled really depends on the
type. New compilers or OSs mentioned in configurations are ok, where as
new build-types cannot be handled.

Any other suggestions?

One way or another I think the plan for Cabal 1.4 should be to make the
parser for these things more liberal but not to accept any new values so
that we do not break older Cabal versions by adding .cabal files to
hackage that older Cabal cannot parse. When enough time has passed and
the current Cabal-1.4 and later are the norm, it'll be possible to add
new enum values without causing major breakage.

Duncan



More information about the cabal-devel mailing list