Skip to content

Query git state to get information on a currently ongoing rebase when encountering conflict markers #955

@estebank

Description

@estebank

Proposal

The rustc parser currently identify patch conflict markers that are caused when trying to merge or rebase code in many different code-control systems, including git. git is the most common amongst our users, so our diagnostic does provide some additional context for them. I'm proposing invoking git to get its .git/rebase-merge directory, which holds the metadata needed by git to understand where it is in a rebase. We can use the same information to surface what the target branch name is, the origin branch name is, and differentiate between a merge conflict caused by git rebase branch-name and git pull. There are other sources of conflict markers in git (like git stash pop and git merge) and other VCSs that could also be supported.

An implementation is present at rust-lang/rust#150233.

Mentors or Reviewers

I'll mentor and review any additional work beyond the above PR.

Process

The main points of the Major Change Process are as follows:

  • File an issue describing the proposal.
  • A compiler team member who is knowledgeable in the area can second by writing @rustbot second or kickoff a team FCP with @rfcbot fcp $RESOLUTION.
  • Once an MCP is seconded, the Final Comment Period begins.
    • Final Comment Period lasts for 10 days after all outstanding concerns are solved.
    • Outstanding concerns will block the Final Comment Period from finishing. Once all concerns are resolved, the 10 day countdown is restarted.
    • If no concerns are raised after 10 days since the resolution of the last outstanding concern, the MCP is considered approved.

You can read more about Major Change Proposals on forge.

Caution

Concerns (1 active)

Managed by @rustbot—see help for details.

Metadata

Metadata

Assignees

No one assigned

    Labels

    T-compilerAdd this label so rfcbot knows to poll the compiler teamhas-concernsThere are active concernsmajor-changeA proposal to make a major change to rustcto-announceAnnounce this issue on triage meeting

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions