meld linux что это

Обзор инструментов для визуального сравнения и разрешения конфликтов слияния

На хабре уже было много статей о распределенных системах управления версиями (DVCS), их сравнений, а также сравнений GUI-клиентов для них. Также были обсуждения плагинов к IDE для работы с git и mercurial. Но практически не было информации об инструментах визуального сравнения и разрешения конфликтов слияния.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это
Недавно я «перескочил» с mercurial (который до сих пор считаю более удобным и логичным) на git, потому что, подавляющее большинство проектов, которые мне интересны, используют git и хостятся на github. В связи с этим, встал вопрос о пересмотре арсенала инструментов, в частности вопрос выбора инструмента визуального сравнения и слияния (diff and merge). Дабы восполнить недостаток информации на хабре, я решил написать этот мини-обзор. Как говориться — по горячим следам.

Под катом Вы также найдете примеры настроек Git для использования с DiffMerge и WinMerge под Windows. Думаю многим сэкономит время.

KDiff3

[скриншот]

DiffMerge

WinMerge

Diffuse

TKDiff

SmartSynchronize

BeyondCompare

Araxis Merge

Git и DiffMerge

1) Добавим в директорию c:/Git/libexec/git-core/mergetools/
файл diffmerge следующего содержания:

2) Теперь добавим в файл c:/Users/swipe/.gitconfig
следующие строки:

3) Создадим конфликт и вызовем DiffMerge для его разрешения

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Выводится сообщение о конфликте слияния, чего мы и добивались.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

В среднем окне, приведем файл к требуемому состоянию и сохраним изменения.
Конфликт разрешен.
Настройку DiffMegre подсмотрел тут:
http://twobitlabs.com/2011/08/install-diffmerge-git-mac-os-x/

Git и WinMerge

1) Добавим в директорию c:/Git/libexec/git-core/mergetools/
файл winmerge следующего содержания:

Когда Git не может автоматически объединить изменения, происходит конфликт слияния и в конфликтующий файл добавляются маркеры слияния ( >>>>>>). Они необходимы для разрешения конфликта с помощью сторонних инструментов.
Рассмотрим файл readme.txt который образуется в результате выполнения слияния веток master и new в приведенном выше примере:

Мы можем открыть файл конфликтов с помощью программы WinMerge для разрешения конфликта.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

После этого откроется средство двухстороннего слияния:

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Исходя из описанной логики перепишем команду слияния merge_cmd следующим образом:

По сути, оба приведенных варианта эквивалентны.

2) Отредактируем .gitconfig

последняя строчка отменяет сохранение backup-файлов в директории репозитория.

3) Создадим конфликт при слиянии двух веток (см. пример с использованием DiffMerge).

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Для разрешения конфликта при слиянии веток, воспользуемся командой

Источник

Сравнение файлов с помощью приложения Meld в Linux для начинающих

Оригинал: A beginner’s guide to comparing files using visual diff/merge tool Meld on Linux
Автор: Himanshu Arora
Дата публикации: 19 января 2017 г.
Перевод: А.Панин
Дата перевода: 8 марта 2017 г.

После того, как мы рассмотрели несколько инструментов с интерфейсом командной строки, предназначенных для сравнения и объединения файлов в Linux, логично было бы описать некоторые аналогичные инструменты с графическим интерфейсом. Это следует сделать еще и потому, что не все привыкли работать с интерфейсом командной строки системы и/или инструментами с интерфейсом командной строки для сравнения файлов, которые могут оказаться более сложными в освоении для неопытных пользователей.

По этой причине мы посвятим эту новую серию статей рассмотрению возможностей приложения под названием Meld.

Но перед тем, как перейти к рассмотрению вопросов установки и использования упомянутого приложения, следует упомянуть о том, что все инструкции и примеры, представленные в данной статье, были протестированы в системе Ubuntu 14.04 с Meld версии 3.14.2.

Пара слов о Meld

Meld является инструментом для визуального сравнения и объединения файлов, предназначенным в первую очередь для разработчиков программного обеспечения (однако, вам стоит иметь в виду, что мы будем рассматривать данный инструмент, ориентируясь на потребности конечных пользователей). Данный инструмент позволяет осуществлять сравнение как двух, так и трех файлов, причем он может сравнивать не только содержимое этих файлов, но и содержимое директорий, а также проектов, разрабатываемых с использованием некоторых систем контроля версий.

На официальном сайте проекта говорится: «Приложение Meld упрощает обзор модификаций кода, а также разбор патчей. Оно может помочь вам даже в выяснении последствий внесения модификаций, которых вы старались избегать. Код проекта распространяется в соответствии с условиями лицензии GPL v2.»

Установка Meld

Если вы используете Ubuntu или любой дистрибутив на основе Debian, вы можете загрузить и установить пакет программного обеспечения Meld с помощью следующей команды:

Также вы можете использовать ваш менеджер пакетов программного обеспечения для установки данного приложения. Например, в Ubuntu вы можете использовать менеджер пакетов программного обеспечения под названием Центр приложений Ubuntu или Ubuntu Software, заменивший первый менеджер пакетов программного обеспечения в версии 16.04.

Вам стоит знать, что для корректной работы Meld требуются следующие программные компоненты:

Использование Meld

После запуска приложения вы должны будете увидеть окно, аналогичное приведенному на иллюстрации ниже.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Таким образом, у вас имеется три варианта действий: Сравнение файлов ( File Comparsion ), Сравнение каталогов ( Directory comparsion ) и Просмотр контроля версий ( Version control view ).

Нажмите на кнопку Сравнение файлов ( File comparsion ), после чего вам будет предложено выбрать файлы для сравнения.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Как становится ясно после рассмотрения приведенного выше снимка окна приложения, Meld позволяет также осуществлять сравнение трех файлов, но в данной серии статей мы будем сравнивать два файла, так как на практике эта операция осуществляется гораздо чаще.

После этого следует выбрать файлы для сравнения и нажать на кнопку Сравнить ( Compare ). В результате вы увидите, как приложение откроет оба файла и отметит отличающиеся строки (а также их отличающиеся фрагменты).

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Очевидно, что в исследуемых файлах отличается лишь вторая строка, причем различие заключается в дополнительном символе «3» во второй строке файла с именем file2. Эти черные стрелки, которые несложно заметить, используются для осуществления операции объединения/модификации файлов. Правая стрелка в данном случае позволяет заменить вторую строку файла с именем file2 на соответствующую строку из файла с именем file1. Левая стрелка позволяет осуществить противоположную операцию.

После внесения изменений вы можете воспользоваться комбинацией клавиш Ctrl+S для их сохранения.

Это был простой пример, демонстрирующий принцип работы приложения Meld. Давайте рассмотрим пример более сложного сравнения файлов.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Перед обсуждением изменений стоит обратить внимание на то, что интерфейс приложения Meld содержит специальные области, указывающие позиции отличающихся фрагментов исследуемых файлов. Если говорить конкретно, то речь идет о вертикальных полосах в левой и правой сторонах окна. Например, вы можете увидеть одну из таких полос на следующей иллюстрации.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Если вы посмотрите на иллюстрацию внимательнее, то без труда обнаружите, что полоса содержит цветные блоки. Эти блоки позволяют оценить все различия между двумя исследуемыми файлами. В официальной документации дается следующее описание данных блоков: «Каждый цветной блок представляет фрагмент файла, который был добавлен, удален, изменен или является причиной конфликта между вашими файлами в зависимости от используемого цвета».

Теперь давайте вернемся к рассмотрению нашего примера. Из следующих иллюстраций становится очевидной простота выявления изменений файлов (а также их объединения) в случае использования Meld:

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

До этого момента мы пролистывали содержимое файлов от одного отличия к другому. Однако, бывают случаи, когда исследуемые файлы имеют очень большой объем, что затрудняет процесс поиска отличий. В таких случаях могут использоваться кнопки с оранжевыми стрелками на панели инструментов, которая расположена над областью редактирования.

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Также Meld позволяет выполнять следующие базовые операции: вы можете использовать стандартную комбинацию клавиш Ctrl+F для поиска произвольного текста в области редактирования, клавишу F11 для перевода приложения в полноэкранный режим, комбинацию клавиш Ctrl+R для обновления содержимого области редактирования (обычно используется когда один или оба исследуемых файла подверглись внешнему изменению в процессе исследования).

А это список ключевых функций приложения, приведенный на официальном сайте проекта Meld:

Учтите, что приведенный выше список возможностей приложения не является исчерпывающим. Веб-сайт проекта содержит отдельную страницу с исчерпывающим описанием возможностей Meld. На этой странице все возможности приложения разделены на секции в зависимости от того, используется ли приложение для сравнения файлов, сравнения директорий, сравнения данных проектов под управлением систем контроля версий или объединения файлов.

Как и любой другой программный продукт, Meld не может выполнять некоторые операции. На официальном веб-сайте проекта упомянута по крайней мере одна такая операция: «При отображении различий между файлами осуществляется вывод содержимого этих файлов таким же образом, как это мог бы сделать обычный текстовый редактор. Приложение не вставляет в файлы дополнительные строки для того, чтобы привести определенные измененные фрагменты файлов слева и справа к одинаковому размеру. Также не существует параметра, позволяющего активировать данный режим.».

Заключение

В данной статье были рассмотрены самые очевидные приемы использования приложения Meld, которое обладает достаточно богатым функционалом. Но для начала этой информации будет вполне достаточно, ведь это лишь первая статья серии. Для того, чтобы заинтересовать вас, следует упомянуть о том, что в круг дополнительных возможностей Meld входит функция игнорирования определенных типов отличий файлов, функции перемещения, копирования и удаления отдельных отличий файлов, кроме того, имеется много нюансов, связанных с запуском приложения из командной строки. Мы обсудим эти функции и нюансы в следующих статьях серии.

Источник

Национальная библиотека им. Н. Э. Баумана
Bauman National Library

Персональные инструменты

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

НазваниеОсобенностиПлатформа
С этим инструментом скорее всего сталкивались как пользователи git, так и пользователи системы mercurial, тем не менее пару строк не помешает.

Примечание: устанавливается вместе с TortoiseHg.

Windows, Mac OS X, Linux
Создатели:Стивен Кеннеди,
Кай Вилладсен
Выпущена:май 2002 [1]
Постоянный выпуск:3.14.1 / 4 октября 2015 [2]
Написана на:Python
Операционная система:Linux,
Mac OS X [3]
UNIX-подобные,
Windows [4]
Linux
Платформа:Windows, Mac OS X, Linux
Локализация:русский и др.
Лицензия:GNU GPL
Веб-сайтhttp://meldmerge.org/

Содержание

Оценка программы MELD

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Несмотря на поддержку нескольких платформ, приложение далеко не стабильно функционирует в Windows. Скажем, вкладки и окна не всегда открываются и закрываются корректно. Возможно, проблемы связаны с библиотекой PyGTK, входящей в инсталлятор. Запустить программу получилось не сразу и только от имени администратора. Ошибки возникают постоянно, в подтверждение — перечень текущих проблем.В процессе сравнения файлов можно задействовать текстовый фильтр или поиск (поддерживается синтаксис regex). Предусмотрены подсветка синтаксиса (используется библиотека gtksourceview), нумерация строк, учет пробелов и другие опции, которые нужно активировать через настройки, так как по умолчанию они отключены. Вставки, изменения и конфликты в документе подсвечиваются, возможна быстрая навигация по списку изменений и экспорт в формате diff. Связь между файлами легко отследить с помощью соединительных линий и одним кликом произвести слияние нужных участков.

Сканирование файлов директорий работает очень медленно. Это связано с тем, что сравнение осуществляется по содержимому, а не по размеру и временной отметке. Проблема решается установкой флажка напротив соответствующей опции в настройках. Набор доступных колонок весьма ограничен: размер, дата модификации и разрешения. Хотя и можно воспользоваться файловым фильтром, просмотр длинного списка файлов все равно превращается в рутинный процесс: нельзя мгновенно остановить сканирование, свернуть дерево файлов, быстро переместиться к нужным элементам. Разработчикам будет интересен третий режим работы приложения — Version Control View. Meld поддерживает интерфейс командной строки, поэтому предусмотрена интеграция со средами Git, Bazaar, Mercurial, Subversion и многим другими.Meld представлен для большинства Linux дистрибутивов (Ubuntu, Suse, Fedora и др.), и присутствует в их основных репозиториях.

Плюсы и минусы программы Meld

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Резюме

Программа Meld зарекомендовала себя с хорошей стороны в среде Linux, чего нельзя сказать о функционировании в Windows. Нестабильная работа и неудобный интерфейс, отсутствие сессий, недостаточная гибкость настройки. С другой стороны, инструментарий программы неплох, а качественная адаптация Meld для Windows, возможно, лишь вопрос времени. [Источник 2]

Обзор Meld

Функции программы Meld

Принцип работы программы Meld

Итак начнём с diff-а. Первое что стоит сделать это посмотреть документацию у meld: «meld –help», из которой узнаём, что достаточно передать ему, в качестве параметров, 2 пути к сравниваемым файлам или директориям. Теперь разберёмся с git, опять пойдём в документацию и вытащим из неё вот такие пару строк для git config:

Ну или для Windows вот так:

Всё, теперь можно посмотреть например разницу между локальными изменениями и версиями файлов в HEAD, запустив:

Чуть улучшить результат можно вот так:

Теперь meld будет открывать не каждый файл по очереди, а покажет сразу все изменения, которые мы запросили в виде сравнения двух директорий. Что бы не писать такую большую команду каждый раз, git даёт нам возможность настроить алиасы:

Теперь разницу между мастером и branch1, можно посмотреть вот так:

Для мержа всё не сильно сложнее, опять смотрим справку по meld, там пишут что нужно в качестве параметров указать 3 файла и в параметре «–output» указать какой из них использовать для сохранения результата. Для git тоже обратимся к документации и получим вот это:

з незнакомых опций тут следующие:

Ну и запуск, с учётом алиасов, выглядит вот так:

Git в ответ будет последовательно открывать meld для каждого конфликта в режиме 3-х стороннего мёржа. [Источник 4] Всё вместе это выглядит вот так:

Как сравнить файлы и папки

Установка Meld в Windows

2) GTK+ All-in-one bundle:

3) Python gnome bindings:

7) Download meld source code:

8) Add this to your Path:

Теперь, если запустить python, указав путь к Meld’у (c:\dev\meld\meld-1.3.1\meld) в качестве параметра, должно открыться окно Meld’а. [Источник 5]

Источник

Чем сравнить две директории в Linux? С помощью Diff и Meld Tools

Для тех пользователей линукс мира, у кого как и у меня, время от времени возникает необходимость сравнения файлов и директорий, решил написать эту небольшую статью, о двух прекрасных, на мой взгляд, утилитах — утилита командной строки diff и утилита с графическим Meld Tools. Опережая реакцию неосиляторов и не желающих разбираться самостоятельно, ответственно заявляю, эта статья лишь ознакомительная, и не претендует на роль мануала, посему не буду подробно расписывать как сравнивать файлы и директории в Diff и Meld, тем более они имеют, на мой взгляд, интуитивно понятный интерфейс, разобраться в котором сможет даже бабушка, ну или дедушка. К слову сказать, в настоящее время у меня есть очень явный пример того, что линукс в целом и информационные технологии, в частности, всем возрастам покорны. В Manjaro группе в телеграмме, есть у нас товарищ, ему 61 год, с компьютером он познакомился в 55 лет, ныне пенсионер и всю жизнь проработал шахтёром. Так вот от него вопросов по настройке и помощи в линуксе слышно меньше, чем от 20-25 летних юнцов.

Что-то я ушёл от темы. Итак, обычно для того, чтобы сравнить два файла в Linux, я использую

. Если честно пользуюсь ей я ни потому, что я прям вот обожаю до ужаса этот волшебный мир консоли хотя да, он великолепен, а потому что diff есть «из коробки»в большинстве, если во всех дистрибутивах Linux, и если возникает необходимость сравнения файлов на чужом компьютере, то легче всего открыть терминал и использовать diff.

Так выглядит её интерфейс
meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Как я написал выше, разберется в нём и стар и млад, учиться никогда не поздно. Благо в линуксе каждый найдёт для себя то, что ему нравится, кто-то фанатеет от консольки и работает только в ней, кто-то любит графические интерфейсы. Если у кого то возникнут вопросы, не стесняйтесь спрашивайте в комментариях всегда открыт к диалогу.

Источник

Сравнение файлов в Linux

Иногда возникает необходимость сравнить несколько файлов между собой. Это может понадобиться при анализе разницы между несколькими версиями конфигурационного файла или просто для сравнения различных файлов. В Linux для этого есть несколько утилит, как для работы через терминал, так и в графическом интерфейсе.

В этой статье мы рассмотрим как выполняется сравнение файлов Linux. Разберем самые полезные способы, как для терминала, так и в графическом режиме. Сначала рассмотрим как выполнять сравнение файла linux с помощью утилиты diff.

Сравнение файлов diff

$ diff опции файл1 файл2

Можно передать больше двух файлов, если это нужно. Перед тем как перейти к примерам, давайте рассмотрим опции утилиты:

Это были основные опции утилиты, теперь давайте рассмотрим как сравнить файлы Linux. В выводе утилиты кроме, непосредственно, отображения изменений, выводит строку в которой указывается в какой строчке и что было сделано. Для этого используются такие символы:

Вот содержимое наших тестовых файлов:

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Теперь давайте выполним сравнение файлов diff:

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

В результате мы получим строчку: 2,3c2,4. Она означает, что строки 2 и 3 были изменены. Вы можете использовать опции для игнорирования регистра:

Можно сделать вывод в две колонки:

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Для удобства, вы можете перенаправить вывод утилиты сразу в файл:

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Как видите, все очень просто. Но не очень удобно. Более приятно использовать графические инструменты.

Сравнение файлов Linux с помощью GUI

Существует несколько отличных инструментов для сравнения файлов в linux в графическом интерфейсе. Вы без труда разберетесь как их использовать. Давайте рассмотрим несколько из них:

1. Kompare

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

2. Meld

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Это легкий инструмент для сравнения и объединения файлов. Он позволяет сравнивать файлы, каталоги, а также выполнять функции системы контроля версий. Программа создана для разработчиков и позволяет сравнивать до трёх файлов. Можно сравнивать каталоги и автоматически объединять сравниваемые файлы. Кроме того поддерживаются такие системы контроля версий, как Git.

3. Diffuse

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

4. KDiff3

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

5. TkDiff

meld linux что это. Смотреть фото meld linux что это. Смотреть картинку meld linux что это. Картинка про meld linux что это. Фото meld linux что это

Это очень простая утилита для сравнения файлов написанная на основе библиотеки tk. Она позволяет сравнивать только два файла, поддерживает поиск и редактирование сравниваемых файлов.

Выводы

В этой статье мы рассмотрели как выполняется сравнение файлов linux с помощью терминала, как создавать патчи, а также сделали небольшой обзор лучших графических утилит для сравнения файлов. А какие инструменты для сравнения используете вы? Напишите в комментариях!

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *