MyException - 我的异常网
当前位置:我的异常网» Linux/Unix » 幽雅地乱玩Linux-5-GitMerge工具Meld

幽雅地乱玩Linux-5-GitMerge工具Meld

www.MyException.Cn  网友分享于:2013-09-12  浏览:0次
优雅地乱玩Linux-5-GitMerge工具Meld

文章最初发表于szhshp的第三边境研究所 
转载请注明

你真的不需要一个Git Merge Tool?

Git的命令行来查看diff有些时候也是很鸡肋的。

Screenshot from 2017-07-01 23-04-17.png

Windows习惯使用TortoiseGit进行各种Merge操作,到了Linux也应该准备一个。

安装

一行代码解决所有问题

sudo apt-get install meld

使用

正常情况下输入meld会开启一个empty view

当然如果后面加一个repo路径的话就可以查看对应的diff了

Step1: 设置Git默认difftool为meld

设置meld为默认difftool

git config --global diff.tool meld

另外如果之后想换其他工具只要改一下meld就行

之后在运行:

git difftool

就会对当前repo进行diff查看,当然meld可以同时进行merge操作

Screenshot from 2017-07-01 23-04-39.png

Step2: 取消difftool的验证弹框/diff without prompt

查看所有difftool参数的命令

man git-difftool

OPTIONS
   -y, --no-prompt
   Do not prompt before launching a diff tool.

简单易懂,后面加个-y参数即可

git difftool -y

Step3: 使用Meld对整个repo进行Diff/Merge

但是依然很麻烦因为对应多个文件meld会依次弹出来,于是我又搜一下如何一次性diff整个文件夹

答案也很简单

Starting with git v1.7.11, you can use git difftool –dir-diff to perform a directory diff.

The answer that follows applies to git installations older than v1.7.11.

于是最终diff命令变成了:

git difftool -y --dir

Step Extra: 简化命令

这命令太麻烦了居然还有三个参数完全记不住怎么办

ZSH: (:з」∠)呵呵

打开ZSH的配置文件:

gedit ~/.zshrc

然后在alias下面加一行:

# Example aliases
# alias ohmyzsh="mate ~/.oh-my-zsh"
alias jkl='jekyll s'
alias subl='LD_PRELOAD=./libsublime-imfix.so subl'
alias gdiff="git difftool -y --dir"

当然这里的别名可以随便换,修改后保存重开Terminal就可以使用gdiff对当前repo进行diff和merge了

Screenshot from 2017-07-01 23-07-49.png

参考文献

  • https://stackoverflow.com/questions/4955752/set-git-diff-to-a-default-value
  • https://stackoverflow.com/questions/34119866/setting-up-and-using-meld-as-your-git-difftool-and-mergetool
  • https://stackoverflow.com/questions/7897517/why-does-git-difftool-not-open-the-tool-directly
  • https://stackoverflow.com/questions/1220309/git-difftool-open-all-diff-files-immediately-not-in-serial

文章评论

科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
我是如何打败拖延症的
我是如何打败拖延症的
那些争议最大的编程观点
那些争议最大的编程观点
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
老程序员的下场
老程序员的下场
编程语言是女人
编程语言是女人
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
旅行,写作,编程
旅行,写作,编程
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
 程序员的样子
程序员的样子
代码女神横空出世
代码女神横空出世
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
程序员应该关注的一些事儿
程序员应该关注的一些事儿
程序员和编码员之间的区别
程序员和编码员之间的区别
每天工作4小时的程序员
每天工作4小时的程序员
程序员必看的十大电影
程序员必看的十大电影
Google伦敦新总部 犹如星级庄园
Google伦敦新总部 犹如星级庄园
中美印日四国程序员比较
中美印日四国程序员比较
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
鲜为人知的编程真相
鲜为人知的编程真相
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
Java程序员必看电影
Java程序员必看电影
漫画:程序员的工作
漫画:程序员的工作
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
程序员的鄙视链
程序员的鄙视链
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
我的丈夫是个程序员
我的丈夫是个程序员
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
如何成为一名黑客
如何成为一名黑客
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
程序员都该阅读的书
程序员都该阅读的书
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
为什么程序员都是夜猫子
为什么程序员都是夜猫子
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有