куратора. Если куратор примет данную заплату (что вряд ли), то почти гарантированно удалит данный комментарий. Если разработчик хочет добиться доверия, то ему следует включить диапазон исправлений для таких файлов проекта, как NEWS
или HISTORY
. В таком случае принятие заплаты куратором более вероятно. Ниже приведен пример хорошего комментария.
/*
* Необходимо защитить этот переход, так чтобы в crunch_data()
* никогда не передавался NULL-указатель.
*/
Данный комментарий показывает, что вы понимаете не только код куратора, но и ту информацию, которая ему необходима для того, чтобы быть уверенным в ваших изменениях. Такой вид комментария
19.2.1.9. Не огорчайтесь, если заплата отклонена
Существует множество причин отклонения заплат, которые никак не связаны с их создателями. Нельзя забывать, что большинство кураторов крайне ограничены во времени и должны быть консервативными в вопросе приема заплат, чтобы не нарушить код проекта. Иногда повторная подача с уточнениями помогает, иногда нет. Такова жизнь.
19.2.2. Хорошая практика наименования проектов и архивов
По мере роста нагрузки на кураторов архивов, подобных ibiblio, SourceForge и CPAN, возрастает тенденция к обработке заявок частично или полностью программным путем (вместо полной их проверки вручную).
В связи с этим возрастает важность подчинения имен проектов и архивов обычным шаблонам, которые могут анализироваться и распознаваться программами.
19.2.2.1. Используйте GNU-стиль названий с именной частью и номерами (основной.второстепенный.заплата)
Будет хорошо, если архивные файлы проекта будут иметь GNU-подобные названия — именной префикс, состоящий из строчных алфавитно-цифровых символов, дефис, номер версии, расширение и другие суффиксы.
Хорошая общая форма названия содержит следующие части в указанном порядке.
1. Префикс проекта.
2. Дефис.
3. Номер версии.
4. Точка.
5. 'src' или 'bin' (не обязательно).
6. Точка или дефис (точка предпочтительнее).
7. Тип бинарных файлов и параметры (не обязательно).
8. Расширения архивирования и компрессии.
Именная часть в данном стиле может содержать дефис или подчеркивание для разделения составляющих слов; в настоящее время использование дефисов предпочтительнее. Хорошей практикой является группировка связанных проектов путем включения в именные части общего префикса, ограниченного дефисом.
Предположим, существует проект, который называется 'foobar', основной номер версии (major version) 1, второстепенный номер версии (minor version) или выпуска 2, уровень исправлений (patchlevel) 3. Ниже представлены примеры названий для проекта, содержащего только один архив (предположительно исходный код).
foobar-1.2.3.tar.gz
Архив исходного кода.
foobar.lsm
LSM-файл (для публикации в ibiblio).
foobar123.tar.gz
Многие программы распознают такое имя как архив для проекта, который называется 'foobar123' без номера версии.
foobar1.2.3.tar.gz
Многие программы распознают такое имя как архив для проекта, который называется 'foobar1' версии 2.3.
foobar-v1.2.3.tar.gz
Многие программы распознают такое имя как проект, который называется 'foobar-v1'.
foo_bar-1.2.3.tar.gz
Подчеркивание плохо передается в устной речи, его неудобно вводить и запоминать.
FooBar-1.2.3.tar.gz
Если только разработчик
Если необходимо дифференцировать архивы исходного кода и бинарных файлов или различные виды бинарных файлов, либо выразить в имени файла некоторые параметры компиляции, то данную информацию следует интерпретировать как расширение файла, следующее
foobar-1.2.3.src.tar.gz
Исходный код.
foobar-1.2.3.bin.tar.gz
Бинарные файлы без указания типа.
foobar-1.2.3.bin.i386.tar.gz
Бинарные файлы для архитектуры i386.
foobar-1.2.3.bin.i386.static.tar.gz
Статически связанные бинарные файлы для архитектуры i386.
foobar-1.2.3.bin.SPARC.tar.gz
Бинарный код для архитектуры SPARC.
Соглашение о различиях основной и второстепенной нумерации версий весьма простое: уровень заплат увеличивается на единицу для исправлений или внесения незначительных функций, второстепенный номер версии — для совместимых новых функций, а основной номер версии увеличивается, когда сделаны несовместимые изменения.