WinMerge — маленькая утилита, с помощью которой можно сравнивать файлы и быстро находить различия между ними.
Скачать для Windows
Скачайте последнюю версию WinMerge 2.16.26 с помощью MultiSetup или по прямой ссылке. Программа совместима с операционными системами Windows 11, 10, 8, 7 разрядностью 32/64-bit, размер установочного файла — 7.9 Мб. Данный программный продукт разработан WinMerge Development Team и распространяется бесплатно. Также вы можете скачать программу с официального сайта.
Описание программы
С помощью программы можно быстро сравнить два текстовых файла и найти между ними разницу. Например, она позволяет сравнить исходный код двух разных версий и найти отличия между ними. Кроме того, WinMerge можно использовать в качестве текстового редактора.
При сравнении документов можно применять различные фильтры. Например, программу легко настроить таким образом, чтобы во время сравнения она игнорировала знаки пунктуации, табуляцию, нумерацию строк и так далее. Удобна программа и по той причине, что с ее помощью можно сравнивать большое количество документов в разных папках или архивах. По умолчанию WinMerge работает с ZIP-архивами, для всех остальных следует устанавливать плагины.
How to Use WinMerge
Программа работает со всеми распространенными кодировками, интегрируется в контекстное меню, сохраняет отчеты в удобном формате. WinMerge также имеет все необходимые инструменты для редактирования текстовых документов.
Преимущества и недостатки
- Дополнительные плагины
- Малый размер и быстрая установка
- Высокая точность определения различий
- Удобный текстовый редактор
- Можно сравнивать только два документа
- Работает не со всеми архивами
Источник: ktonasoft.ru
WinMerge Portable 2.16.30 (32-64 bit) скачать бесплатно
WinMerge Portable — это портативная программа для поиска различий в документах и быстрого их редактирования. Сравнивает и визуально показывает изменения в документах разного формата. Является Open Source инструментом сравнения и слияния для Windows. Может сравнивать как файлы, так и папки, отображая различия в визуальной текстовой форме. Которые легко найти, понять и обработать.
WinMerge Portable является весьма полезной для определения мест, которые изменились между версиями проекта, а затем она позволяет объединять изменения между версиями. Можно использовать в качестве внешнего инструмента определения разностей/слияния, или как автономное приложение.
WinMerge Portable является проектом с открытым исходным кодом.
Основные возможности WinMerge Portable:
- Сравнение файлов
- Визуальная подсветка изменений и слияния текстовых файлов.
- Удобный редактор с подсветкой синтаксиса, нумерацией строк и переносом строк.
- Подсветка изменений внутри строки.
- Панель различий показывает различия текущего файла в двух вертикальных панелях.
- Бокова панель расположения отображает карту сравниваемых файлов.
- Обнаружение перемещенных строк.
- Фильтрация файлов, основанная на регулярных выражениях, позволяет включать и исключать элементы из выборки.
- Быстрое сравнение которое учитывает размер файлов и даты.
- Сравнение как одного каталога, так и сравнение включая подкаталоги.
- Может отображать результат сравнения папок в виде дерева.
- Создает файлы патчей (Normal-, Context- и Unified форматы).
- Разрешает конфликты файлов.
- Начальная поддержка интеграции с Visual SourceSafe и Rational ClearCase.
Название: WinMerge Portable
Cистема: Windows 2000, Windows XP, Windows 2003, Windows Vista, Windows 7, Windows 8, Windows 8.1, Windows 10 и Windows 11 (32-64bit)
Официальный сайт: https://winmerge.org
Язык: Многоязычный, в том числе и Русский язык
Размер файла: 11.58 Мб
WinMerge Portable 2.16.30 (32-64 bit) скачать бесплатно
С официального сайта скачать Отдельно или 32 или 64 битная версия. Не портативная версия.
Если у вас есть сомнения по поводу этого файла, после скачивания просканируйте его на портале VirusTotal.
WinMerge Portable, можно скачать бесплатно, но можно и отблагодарить.
ОТБЛАГОДАРИТЬ
Источник: portable-rus.ru
Статический анализ исходного кода на примере WinMerge
Сегодня я хочу посвятить пост тематике, почему инструменты анализа исходного кода полезны вне зависимости от уровня знаний и опыта программиста. А польза такого анализа будет продемонстрирована на примере инструмента, который известен всем программистам — WinMerge.
Чем раньше ошибка в коде приложения будет обнаружена, тем дешевле стоит ее исправление. Отсюда следует вывод, что наиболее дешево и просто ошибка может быть устранена в процессе написания кода. А еще лучше, если ошибка вовсе не будет написана. Вот только захотел сделать ошибку, так сразу хлоп себя по рукам и код написан уже правильно. Но так как-то не получается.
Подход «надо писать без ошибок» все равно не работает.
Даже высококвалифицированный программист, который никуда не торопится, совершает ошибки, начиная от простейших опечаток и кончая логическими ошибками в алгоритмах. Здесь срабатывает закон больших чисел. Вот вроде в каждом конкретном операторе «if» сделать ошибку невозможно. А написал 200 сравнений, и один раз, да ошибся.
Про это интересно рассказывает Андрей Уразов в своем докладе «Программирование, ориентированное на качество» на конференции CodeFest 2010 (посмотреть запись выступления). Кратко я хочу привести следующую его мысль. Как бы ни были опытны разработчики, ошибки все равно появляются в коде. Эти ошибки невозможно прекратить делать. Но со многими из них можно успешно бороться на гораздо более раннем этапе, чем это делается обычно.
Обычно самым первым уровнем обороны от ошибок является создание юнит-тестов на вновь написанный код. Иногда тесты пишутся еще до кода, который они будут проверять. Однако у юнит-тестов есть свой ряд недостатков, которые я не буду подробно рассматривать, так как они и так известны программистам.
Не всегда легко создать юнит-тест для функции, которая требует большой предварительной подготовки данных. Юнит-тесты становятся обузой, если требования к проекту быстро меняются. Тесты отнимают много времени на написание и сопровождение. Тестами не всегда просто покрыть все ветвления.
А еще вы можете получить в подарок монолитный проект, в котором юнит-тестов просто не существует и не планировалось. Не отрицая огромной пользы юнит-тестов, я считаю, что хотя это хороший оборонительный рубеж, его можно и стоит существенно укрепить.
Часто программисты пренебрегают еще более ранним уровнем обороны — статическим анализом кода. Многие используют возможности анализа кода, не выходя за рамки диагностических предупреждений выдаваемых компиляторами. А между тем существует целый класс инструментов, позволяющих выявить на этапе кодирования значительный процент логических ошибок и простых опечаток. Эти инструменты осуществляют более высокоуровневую проверку кода, опираясь на знание некоторых паттернов кодирования, используют эвристические алгоритмы, имеют гибкую систему настройки.
У статического анализа, конечно тоже, есть недостатки. Многие виды ошибок он просто не в состоянии обнаружить. Анализаторы дают ложные срабатывания и заставляют вносить в код такие вправки, чтобы этот код им понравился и был затем оценен как безопасный.
Но есть и огромные преимущества. Анализ покрывает все ветвления программы, в не зависимости от частоты их использования. Анализ не зависит от этапа исполнения. Вы имеете возможность проверить даже недописанный код. Вы можете проверить большой объем кода, доставшийся вам по наследству.
Статический анализ быстр и хорошо масштабируется в отличие от инструментов динамической проверки.
Прозвучало много слов о статическом анализе исходного кода. Теперь пришло время уделить внимание практике. Я возьму одно приложение, написанное на Си++, и попробую найти в нем ошибки.
Я хотел выбрать что-то небольшое и общеизвестное. Поскольку я использую не так много инструментов, то листая список программ в меню «Пуск», мой выбор остановился на WinMerge. Программа WinMerge доступна в исходных кодах, невелика (около 186000 строк). Программа достаточна качественная.
Говорю на основании того, что я пользуюсь ей без нареканий, и что 25% исходного кода занимают комментарии (хороший признак). В общем, оптимальный выбор.
Была скачена последняя доступная версия 2.13.20 (от 20.10.2010). Для анализа я воспользовался разрабатываемым нами прототипом анализатора общего назначения. Остановлюсь на этом чуть подробнее.
Сейчас в состав статического анализатора PVS-Studio входит два набора правил. Один предназначен для выявления 64-битных дефектов, а другой предназначен для проверки OpenMP программ. В настоящее время мы занимаемся разработкой набора правил общего назначения. Пока не доступна даже beta-версия, но уже что-то работает и мне очень хочется хоть немного реальной войны с ошибками.
Мы планируем сделать новый набор правил бесплатным, так что просьба не писать про саморекламу. Общественности мы представим новый инструмент через 1-2 месяца в рамках PVS-Studio 4.00.
Итак, вот некоторые интересные моменты, которые я обнаружил в исходном коде WinMerge-2.13.20 в течение получаса (15 минут проверка, 15 минут просмотр результатов). Есть и другие подозрительные места, но разобраться, есть ли там действительно ошибка или нет — требует усилий. Сейчас у меня нет задачи найти как можно больше дефектов в одном проекте. Хочется изящно показать, чем полезен статический анализ и как даже беглым изучением можно быстро выявить ряд ошибок.
Пример первый. Анализатор указал мне на несколько ошибок «V530 — The return value of function ‘Foo’ is required to be utilized». Обычно эти предупреждения возникают в связи с неверным использованием функций. Рассмотрим фрагмент кода:
Функция должна вернуть в определенной ситуации две пустых строки. Однако по невнимательности вместо std::string::clear() вызываются функции std::string::empty(). Это, кстати, не такая редкая ошибка, как может показаться. Я встречал ее во многих других проектах. В том числе она есть и в другой функции WinMerge:
Здесь опять не происходит ожидаемой очистки строки.
А вот сработало предупреждение «V501 — There are identical sub-expressions to the left and to the right of the ‘||’ operator»:
BUFFERTYPE m_nBufferType[2]; . // Handle unnamed buffers if ((m_nBufferType[nBuffer] == BUFFER_UNNAMED) || (m_nBufferType[nBuffer] == BUFFER_UNNAMED)) nSaveErrorCode = SAVE_NO_FILENAME;
Если посмотреть код рядом, то по аналогии здесь должно быть написано:
(m_nBufferType[0] == BUFFER_UNNAMED) || (m_nBufferType[1] == BUFFER_UNNAMED)
А если и не так, то все равно имеется какая-то ошибка.
При возникновении различных аварийных ситуаций WinMerge попробует сообщить об ошибках, но во многих случаях у него это плохо получится. Это кстати хороший пример, как анализатор кода может выявлять ошики в редко используемых участках программы. В коде имеется несколько ошибок, о которых PVS-Studio сообщает так: «V510 — The ‘Format’ function is not expected to receive class-type variable as ‘N’ actual argument». Пример кода:
String GetSysError(int nerr); . CString msg; msg.Format( _T(«Failed to open registry key HKCU/%s:nt%d : %s»), f_RegDir, retVal, GetSysError(retVal));
На первый взгляд все хорошо. Вот только тип «String» есть не что иное как «std::wstring». А следовательно, в лучшем случае мы распечатаем абракадабру, а в худшем произойдет ошибка доступа к памяти (Access Violation). Вместо указателя на строку в стек помещается объект типа «std::wstring». Подробнее данную ситуацию я описывал в заметке «Большой брат помогает тебе». Корректный код должен содержать вызов c_str():
msg.Format( _T(«Failed to open registry key HKCU/%s:nt%d : %s»), f_RegDir, retVal, GetSysError(retVal).c_str());
Пойдем дальше. Вот обнаружен весьма подозрительный код. Есть здесь ошибка или нет, я не знаю. Но странно, что две ветки оператора «if» содержат полностью идентичный код. Анализатор предупредил об этой ситуации диагностическим сообщением «V532 — The ‘then’ statement is equivalent to the ‘else’ statement». Вот он этот подозрительный код:
if (max < INT_MAX) < for (i = min; i < max; i++) < if (eptr >= md->end_subject || IS_NEWLINE(eptr)) break; eptr++; while (eptr < md->end_subject (*eptr > > else < for (i = min; i < max; i++) < if (eptr >= md->end_subject || IS_NEWLINE(eptr)) break; eptr++; while (eptr < md->end_subject (*eptr > > >
Вот чувствую что здесь: «Это ж-ж-ж неспроста».
Ну и еще один пример и завершим, пожалуй. Анализатор нашел подозрительный цикл: «V534 — It is likely that a wrong variable is being compared inside the ‘for’ operator. Consider reviewing ‘i’.» Исходный код:
// Get length of translated array of bytes from text. int Text2BinTranslator::iLengthOfTransToBin( char* src, int srclen ) < . for (k=i; i’) break; > . >
Этот код предрасположен к Access Violation. Цикл должен продолжаться пока не найдется символ ‘>’ или не закончится строка длиной в ‘srclen’ символов. Вот только случайно для сравнения использована переменная ‘i’, а не ‘k’. Если символ ‘>’ найден не будет, то все вероятно закончится печально.
Заключение
Не забывайте про статический анализ. Он нередко может найти интересные вещи даже в хорошем коде. А еще приходите попозже на наш сайт, чтобы попробовать бесплатный анализатор общего назначения, когда он будет готов.
- статический анализ
- WinMerge
- ошибки программистов
- си плюс плюс
- pvs-studio
- программирование
Источник: habr.com