承接 pingiun/fix-composer-conflicts 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

pingiun/fix-composer-conflicts

最新稳定版本:0.1.1

Composer 安装命令:

composer create-project pingiun/fix-composer-conflicts

包简介

Fix composer conflicts with less thinking

README 文档

README

Fix composer conflicts with some help.

Installation

The easiest way to install is using composer global require.

composer global require pingiun/fix-composer-conflicts

Then you can find the tool in your composer home directory. Use this command to find out where it is:

composer global config home

You could add this directory (with /vendor/bin appended) to your PATH variable if you want to run it easily.

Bash single-liner if you're lazy:

echo 'export PATH="$PATH:$(composer global config home)/vendor/bin"' >> ~/.bashrc && source ~/.bashrc

Note, this tool requires PHP 8.3 or higher.

Usage

If you are doing a merge, rebase or cherry-pick and you get a git conflict in your composer.json file, you can use this tool to fix it. Run the following command in the root of your project:

fix-composer-conflicts

You will get an interactive prompt like this:

screenshot

If you need help with the single letter commands, you can type ? and hit enter for help.

How does it work?

After making your choices, the tool checks whether the ours version or the theirs version of the composer.json is closer to what you want.

Then it resets both the composer.json and composer.lock files to the ours version, and then applies any choices you made in the interactive prompt.

It applies the choices by literally just doing composer require commands in the background.

Afterwards it adds the composer.json and composer.lock files to the git index, so you can commit them right away.

Current limitations

The tool does not try to keep subdependencies locked as they were in the composer.lock file. This is because it works by just re-requiring the tools, at which point composer will resolve the dependencies again. This is something I will look into in the future, as it could lead to unexpected changes in the composer.lock file.

Another limitation is that every step is still manual, I'd like to have a way to automatically make choices. PRs are welcome for this!

统计信息

  • 总下载量: 4
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: EUPL-1.2
  • 更新时间: 2025-06-29