Skip to content

First draft of the cabal-proposals process #11006

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

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 19 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -307,6 +307,25 @@ you push a fix of a whitespace violation, please do so in a _separate commit_. F
#endif
```
## Proposal Process
For larger changes which require additional discussion or consensus building,
the [proposal process](proposals.md) can be used. Proposals are discussed in
the [`cabal-proposals`](http://github.com/haskell/cabal-proposals) repository.
When does a change require a proposal?
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Very much appreciated that a reasonable approach to proposals is suggested here, unlike the bureaucratic processes for GHC and base...

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @andreasabel 👍

* Bug fixes or small improvements do not require proposals.
* Improving features which already see wide agreement does not require
proposals (for example, migrating existing commands from v1- to v2-).
* Larger features should be first discussed on a proposal (for example, a new
command, Hooks, private dependencies).
* Significant changes to existing behaviour should be discussed on proposals.
In general, most changes do not require proposals, developers are trusted to
use their judgement about when seeking a broader consensus is necessary.
Comment on lines +325 to +326
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For contributors it would also be useful to know that they can still create a proposal for something that has been rejected ad-hoc by e.g. a single developer... as a means of forcing the democratic process as a last resort.

## GitHub Ticket Conventions
Each major `Cabal`/`cabal-install` release (e.g. 3.4, 3.6, etc.) has a
Expand Down
10 changes: 10 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,16 @@ This Cabal Git repository contains the following main packages:
The canonical upstream repository is located at
https://github.com/haskell/cabal.

Proposals for the Cabal project
-------------------------------

The [proposals process](proposals.md) is the mechanism which developers can gain
the necessary consensus to make larger changes to the Cabal ecosystem.

* It is light-weight, a PR is opened and discussed on [cabal-proposals](https://github.com/haskell/cabal-proposals/) repo with a fixed discussion period.
* It is developer-led, final decisions are made by developers at the Cabal developers meeting.
* It is flexible, there is no formal voting procedure, decisions are made by [rough consensus](https://datatracker.ietf.org/doc/html/rfc7282).

Ways to get the `cabal-install` binary
--------------------------------

Expand Down
160 changes: 160 additions & 0 deletions proposals.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,160 @@
# Cabal Proposals Process

## Motivation

The Cabal project's codebase is large, complex, and has evolved over many years. No single
person fully understands how all its parts interact. As a result, maintainers
and contributors often hesitate to make significant changes, unsure whether they
are safe or whether they align with the project's long-term direction. This
has led to a delayed decision making process and a tendency to avoid
making significant decisions. One example is the removal of legacy v1- commands: although most developers agree they should be deprecated and eventually removed, no one feels confident in making that change without a clearer mandate or process.

To address this, we propose a
lightweight, developer-led process for making and recording significant
decisions about the future of Cabal and cabal-install. The goal is to enable
contributors to move the project forward with greater confidence and
shared understanding.

The process is designed to make developers feel empowered to make decisions.

* It is light-weight, a PR is opened and discussed on a repo with a fixed discussion period.
* It is developer-led, final decisions are made by developers at the Cabal developers meeting.
* It is flexible, there is no formal voting procedure, decisions are made by [rough consensus](https://datatracker.ietf.org/doc/html/rfc7282).

Overall, we hope that this will allow developers to move the cabal project forward.

This process is an experiment. We will review it over time to ensure that it continues to serve the Cabal project well.

## Principles

- The process exists to support active contributors, not to control them.
- The decision-making power remains with those who contribute code and maintain the project.
- The process is deliberately kept lightweight to avoid burdening contributors.
If contributors do not want to use the process then it should be modified.
- The developers meeting will assess consensus to make a final decisions.
- Transparency and documentation make it easier for all contributors to follow significant decisions.


## Scope

This process applies to:

- Changes to the `Cabal` library.
- Changes to the `cabal-install` tool.
- Significant process or tooling changes for the Cabal project itself.

This process does **not** apply to:

- The broader Haskell ecosystem.
- Community-wide standards.
- Individual packages not maintained in the Cabal project.

Routine or small changes do not require a formal proposal; they can continue to be discussed and merged via the normal PR process.

### Examples

* Bug fixes or small improvements do not require proposals.
* Improving features which already see wide agreement does not require proposals (for example, migrating existing commands from v1- to v2-).
* Larger features should be first discussed on a proposal (for example, a new command, Hooks, private dependencies).
* Significant changes to existing behaviour should be discussed on proposals.

In general, most changes do not require proposals, developers are trusted to use their judgement about when seeking a broader consensus is necessary.

## Process

### 1. Proposal Submission

- Proposals are submitted as **pull requests** to the [`cabal-proposals`](https://github.com/haskell/cabal-proposals) repository.
- The proposal must follow the [proposal template](#proposal-template).
- Anyone can submit a proposal. However, proposals without the support of active contributors are unlikely to be accepted.
- There is a general expectation that authors of proposals will take the lead on their implementation. If proposals remain unimplemented for an extended period, it may affect how future proposals from the same author are received.

### 2. Discussion

- Discussion happens on the pull request.
- There is a **minimum comment period** of 2 weeks, or until the next Cabal developers meeting (whichever is longer). Extensions may be granted for more complex topics.
- All community members are welcome to comment. Maintainers and active contributors are especially encouraged to provide feedback.
- After the minimum comment period, the author can request for the proposal to be decided on at
the Cabal developers meeting.

### 3. Decision Meeting

- The Cabal developers meeting is the forum for making decisions on proposals.
- The developers present at the meeting should reflect on the comments on a proposal and determine the [rough consensus](https://datatracker.ietf.org/doc/html/rfc7282) of the community.
The opinion of knowledgeable contributors regarding a particular subsystem is especially
important for the meeting to reach a decision.
- It is not necessarily expected that the participants of the meeting will offer a technical opinion. The discussion on the issue should provide enough context for a decision to be made.
- There is a quorum of three developers at the meeting.
- If quorum is not reached for 4 consecutive meetings (8 weeks) whilst a proposal is due to be discussed, the proposal process is suspended and reviewed.

## 4. The Decision

- A proposal is **accepted** if there is general agreement among active maintainers and contributors present at the meeting.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Who are the active maintainers who partake in the decision? Are they written down somewhere? How to become an active maintainer?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You become an active maintainer by participating in issues, making PRs, commenting on proposals and so on, like normal, the currency of an open source project is the contribution.

At the core of the proposed process is the idea that it is the developers who are most actively engaged in the day-to-day work are those with the ability to make impactful decisions.

Copy link
Collaborator

@phadej phadej Jun 30, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I faced a problem that I was engaged in day-to-day work, but I explicitly didn't want to make impactful decisions, but would rather preferred someone else to take the burden of responsibility of decision making.

I feel that current Cabal team actually lacks people who could write their name on the list "we make the decisions, we'll respond to any positive or negative feedback". In other words, leadership.

I kind of want to see the list of names. I want to know there are people who eventually will (and must?) make a decision.

  • If quorum is not reached for 4 consecutive meetings (8 weeks) whilst a proposal is due to be discussed, the proposal process is suspended and reviewed.

The process can be stuck. There is no way to force progress on difficult issues.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I dropped in the suggestion of a quorum in part to address this, and in fact my version included a strong suggestion to list such people. I'm not sure why @mpickering dropped that part; like you, I feel it is quite important. (For example, were @grayjay and I authorized to make decisions of this nature a few weeks ago when we were the only ones who showed up at the meeting?)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(For example, were @grayjay and I authorized to make decisions of this nature a few weeks ago when we were the only ones who showed up at the meeting?)

Yes, you were. You were also authorized to postpone the decision if you were not sure about the wider consensus or for any other reason. If you misjudged any of this, you'd have opportunity to revert. Our processes are not supposed to guarantee infallibility nor immutability. Just best good faith effort.

I want to know there are people who eventually will (and must?) make a decision.

This is asking a lot of volunteer developers. Since contributing to cabal management is my part-time day job, I'm the last resort if all community processes fail, but in that case I rather sound an alarm and temporarily plug the worst holes, not become a one person orchestra. But just as with volunteers, where any commitment is "unless real live intervenes", mine is "as long as there's funding and maybe a short while longer, unless real live intervenes".

We could try a process where people are publicly nominated, publicly commit, etc., but that's raising the bar quite a lot for all concerned. This is partially orthogonal to this proposal, I think.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is very disempowering to be told by higher forces what you can and can't do, especially when most contributors are volunteers, why would you bother?

I'm a bit confused about this statement.

Isn't that exactly what the "inner circle" of cabal devs now is going to do with "collaborators" who are not part of the inner circle?

They are all volunteers.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think another way to put it, is that I agree with the GHCup philosophy about decision making in projects: "I do not believe in people making decisions over projects they are barely involved in.".

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isn't that exactly what the "inner circle" of cabal devs now is going to do with "collaborators" who are not part of the inner circle?

No, I think you are misunderstanding the process here. I have explained in this comment - #11006 (comment)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think another way to put it, is that I agree with the GHCup philosophy about decision making in projects: "I do not believe in people making decisions over projects they are barely involved in.".

GHCup follows a BDFL governance model, not an open governance model.

What model does cabal follow?


And I still don't understand what contributors get out of the proposal process. So far it seems to only serve cabal developers, is that right? If that's the case, then that's fair, but it's important to know for the discussion.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@geekosaur I added a quorum clause based on your suggestion, did you intend for me to write something different?

I said I wanted a quorum of people authorized to make decisions on behalf of Cabal, and those people would need to be chosen on the Cabal devs side. This is one reason I also said at the time that we currently run things just a little too loosely for the proposal to work as is.

- A proposal is **rejected** if consensus cannot be reached or the developers do not wish to
pursue the direction of the proposal.
- A proposal is **deferred** if the developers generally agree with the direction of the proposal
but have specific and actionable points which require improvement before acceptance.
For example, the opinion of a certain expert may be additionally sought or they may wish for more consideration into the backwards compatibility story.
- The meeting chair is responsible for recording the outcome on the proposal PR.


### 5. Outcome and Implementation

- **Accepted** proposals are merged into the `cabal-proposals` repository and tagged as "Accepted".
- **Rejected** proposals are closed with a clear rationale.
- **Deferred** proposals may be left open with an explicit milestone for revisiting.

Acceptance of a proposal does not automatically result in implementation. The proposer is expected to implement the change or coordinate with others to do so.

### Example Timeline

* A proposal is opened.
* A two weeks discussion period follows.
* After at least two weeks, the author may ask cabal developers to consider their proposal.
* The cabal developers may decide about the proposal at the next developers' meeting or a cabal developer may ask for a longer discussion period.
* The proposal is accepted: the proposal author implements the feature.
* The proposal is rejected: the PR is closed.
* The proposal is deferred: the decision period is extended and a concrete
reason for deferral is named. Once the concern has been addressed then the
proposal is reviewed again at the meeting.


## Proposal Template

Each proposal should include the following sections:

```markdown
# Title

## Summary

A short, high-level summary of the proposed change.

## Motivation

Why is this change needed? What problem does it solve?

## Proposed Change

Describe the change in detail.

## Alternatives Considered

What other approaches were considered? Why was this one chosen?

## Backwards Compatibility / Migration

Does this change affect backwards compatibility? What migration path is needed?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
## Interested parties
Who are the interested parties in the broader Haskell community? Have you contacted them?

## Implementation Notes

Are you willing to implement this yourself? What is the expected timeline?

## Open Questions

Are there any unresolved questions or areas needing further input?

## References

Links to related issues, discussions, or previous work.
```
Loading