Comments 81
По мне, так этот товарищ — улучшатель из разряда тех самых эффективных менеджеров, особливо распространённых в наших госстуктурах, которые продвигают всякого рода сомнительные решения, очковтирательства ради. И хорошо, если эти решения в итоге бесполезны, потому как часто они бывают даже вредны.
Мне кажется, на первом же споре про архитектуру нужно было ответить что-то типа: "Если не нравится архитектура, то делай форк и делай архитектуру которая нравится. Общественность нас рассудит выбрав то что ей нравится." Думаю на этом конфликт был бы исчерпан.
Либо — предложить самому пофиксить свой тикет и сделать pull request (для тех тикетов, которые просто не хочется делать, но которые не ломают архитектуру).
Раздражение автора ведь началось с необходимости (хотя кто заставляет-то?) трудиться по тикетам, которые ему неинтересны. В коммерческой разработке вполне нормально принять тикет с низким приоритетом или делегировать задачу. Похоже, автор пока не умеет пользоваться этими механизмами, поэтому поставил себя в позицию "или я сейчас делаю фикс, или я нечестный парень". Дальше, конечно, конфликт неизбежен, особенно при таком неуважительном отношении собеседника.
люди обычно стараются договориться, в первую очередь ради пользователей
Я считаю что разработчик вправе придерживаться своей точки зрения по поводу своего проекта. Он не обязан доказывать свою правоту. Он разработал что-то и выложил в открытый доступ. Вы не обязаны этим пользоваться. А если уже пользуетесь – будьте благодарны, предлагайте изменения, поддерживайте проект, считаясь с мнением автора. А для несогласных
у нас есть разрешающие лицензии и кнопка «Форк»
Бывает критика объективная и субъективная. Если критика объективная — игнорировать ее глупо.
Если пользователь был в чем то прав и реально хотел помочь проекту, то мейнтайнер все таки поступил плохо.
Но судя по тикетам, которые создавал пользователь — он не совсем технически подкован, в частности, он предлагал выкинуть кавычки экранирующие названия таблиц и полей, что закономерно привело бы к проблеме, мотивируя это тем, что кавычки мешают читать SQL людям.
По поводу объективной/субъективной критики согласен, но не полностью. Поясню.
Могут быть логичные и объективные причины внести какие-то изменения в проект, которые не будут сочетаться с виденьем автора, его долгосрочными планами по поводу проекта и т.д. Например вы просите внедрить локальную фичу для какого-то редкого случая, а автор в это время планирует сделать какое-то глобальное изменение, которые поможет и в вашем случае и в других.
Но, в итоге, конечно больше всего влияет адекватность. Если и автор и комментатор адекватны, они найдут общее решение. В данной ситуации комментатор был, судя по всему, не очень адекватен.
Тут есть тонкость, что чтобы разобраться в критике, и тем более учесть ее, нужно потратить время — тот самый ограниченный ресурс, который opensource-разработчик вкладывает в проект. Имхо, у мейнтейнера есть право сказать "изини, у меня нет времени глубоко в это погружаться", хотя вряд ли он им будет пользоваться, если критика существенная (касается реальных проблем) и обоснованная.
И уж тем более у него может не быть времени разбираться пусть даже в честной критике всяких мелочей.
Этот опыт также показал, что сохранить право собственности может быть непросто в open-source.
Проще простого: я овнер и мне решать, будет так или нет. Не нравится? Пиши сам или форкай.
Автор просто не совсем уверен в себе и попав впервые в такую ситуацию — опешил.
Если код проекта опубликован под свободной лицензией, то принадлежит ли он своему создателю? Или он получил собственную жизнь, в которой его должны защищать пользователи как тот, с которым я встретился, даже если это означает отрезать создателя?
Зависит от цели автора, думаю: если цель — развить опен сорс проект, он, все же, принадлежит уже комьюнити, хотя, авторство остается за автором; а если цель — только найти и исправить ошибки, то только за автором, имхо.
«Кнопка Fork справа вверху»
Однако даже беглого изучения этих изменений хватило чтобы понять, что производительность вообще никак не меняется (ну это и не удивительно ведь автор хотел улучшить производительность, в основном, меня is_null на !== null).
После этого я довольно вежливо объяснил автору pull request'ов, что вообще ничего не поменялось, и мне больше не охото рассматривать его идеи. И предложил создать свой форк и развивать его как ему нравиться. Что он и сделал (я не особо слежу за форком, но бейджей там точно больше).
В общем, порой на Github'е встречаются довольно странные люди, поэтому нужно попытаться добиться от них конструктивной критики (т.е конкретных изменений, которые можно просто проверить), и на их основании делать выводы. Если выводы не утешительные, или диалог вообще не получается, то просто вежливо предлагаем сделать форк. Но тут все зависит от вас, так как на подобные вещи приходится тратить время…
И предложил создать свой форк и развивать его как ему нравиться.
Жму вашу руку. Это честно, и это как раз о том, ради чего опер-сорс создавался — ради развития, а не ради переделывания чего-то чужого под себя.
Тем более, уж если честно, на каждом уровне профессионализма хочется внести другие изменения — как в свои старые проекты, так и в чужие. И профессионализм еще и в том, чтобы понимать, что из этого стоит делать, а что — нет.
Потому что код-стайл — штука религиозная.
Непонятно, в чем суть претензий к оригинальному автору. Ну напишите друг другу письма, созвонитесь, обсудите тему (если кому-то так уж хочется). Но мейнтейнер проекта на то и мейнтейнер, что он ведет корабль проекта по бурным водам разработки. Если завтра в его ORM пришлют реквест для вывода сообщения политического содержания, то, что же, его принимать, потому что «свобода слова»?
И это они еще до суда не дошли, я так понимаю!
Я перестал отвечать на его тикеты. Иногда я удалял их (а если не мог, то нажимал «редактировать» и стирал весь текст). Иногда в негодовании спрашивал, кем он себя возомнил, когда приходит в трекер и требует от меня объяснений по тем аспектам моей библиотеки, с которыми он не согласен. В конце концов я забанил его на проекте.
Даже если человек открыто называет ваши архитектурные решения неправильными, это не повод так с ним себя вести. Кто-то потратил своё время, думая над тем, как сделать ваш проект лучше, не поленился зайти в трекер и написать об этом, а вы удаляете его сообщения. Даже если его предложения абсолютно и безкомпромисно противоречат вашему видению, так делать нельзя — вам следовало закрыть тикет с «wontfix» и оставить его в истории проекта. Лично я не увидел в предоставленной вами переписке абсолютно ничего такого, что могло бы оправдать ваш модераторский произвол.
Соглашусь: автор редиска и так вести себя не должен. Редактировать чужие сообщения — очень плохо и это и есть «модераторский произвол». Именно из-за таких людей сейчас и вошли в моду CODE CONDUCT'ы.
Выкладывание чего либо в Open Source — ответственность. Поддержка проекта требует времени, сил не только на код, но и на консультирование не всегда адекватных пользователей. И это нужно делать вежливо.
Ну это всё-таки перевод, мопед не автора)
Не это ли та причина, по которой у нас есть разрешающие лицензии и кнопка «Форк»?
Ух ты, до программистишек-любителей интересных проектов и прочего тупорылого гичья начинает доходить, от кого именно свободен их "свободный" код. Может, еще дойдет, кто получает те деньги, которых он реально стоит.
Я никогда никуда не выкладываю код проектов, которыми время от времени занимаюсь ради фана, поэтому у меня нет проблем, описанных в статье (и левые ушлые дяди денег на них тоже не сделают). Да, наивным глупым проповедникам "свободных" лицензий это не нравится, но как же это приятно — нагло вытирать ноги об убеждения апологетов неоплачиваемого труда и наслаждаться тем, что они ничего не могут сделать в ответ.
Я вас понимаю, мне тоже нравится проектировать системы. При этом я по вышеописанным причинам (да и просто из лени) не выкладываю ничего. Некоторые люди видят в последнем (и даже во мне лично тоже) проблему, с которой нужно бороться. Я не вижу. А вы?
наивным глупым проповедникам «свободных» лицензий это не нравитсяСкорее всего им просто наплевать. Хотите прятать свой код — прячьте, хотите тешить себя иллюзией, что о кого-то там «вытираете ноги».
Если не видите причин выкладывать свои работы, не выкладывайте.
Зачем столько пафоса?
Статья не будет хорошо смотреться без таких вот комментариев. Они, так сказать, дополняют картину :)
Никакого пафоса.
Это просто вшивые программки.
Я лишь троллю опенсорц-помешанных при случае, не более того.
Вы что же, зеленкой думаете меня вылечить?))
Однажды я пытался троллить яблочников в похожей манере.
Они, к моему, удивлению, спокойно и конструктивно объяснили мне, в чем я неправ.
С тех пор на мак пересел, между прочим.
А вы вот беситесь, ибо возразить по существу нечего.
Свободный код свободен, в первую очередь, от самих разработчиков, поэтому я не вижу рациональных причин выкладывать что-то в открытый доступ. Такой вывод напрямую следует и из статьи: автор выложил свой труд бесплатно и еще виноват оказался, перечитайте последнюю часть. Какие-то недостаточно(!) чистые были у него намерения, забыл раздать имущество окрестным бомжам и одеться в рубище, видимо.
Вы так говорите, будто свои проекты я вам задолжал, и я не имею права голоса без пары компиляторов С++ в портфолио.
Зачем столько пафоса?
А еще вы можете устроить благотворительный марафон, чтобы показать мне, насколько вам плевать. Или митинг у дома Столлмана. Чтобы все увидели, как вам все равно на мнение нехорошего человека в сети. Еще можете меня какой-нибудь зеленкой пообливать — ну, это чтобы показать мне, что вы не обращаете внимания. Какой вариант вам больше по душе?
Я никогда никуда не выкладываю код проектов… (и левые ушлые дяди денег на них тоже не сделают)… нагло вытирать ноги об убеждения апологетов неоплачиваемого труда
Может, стоит быть последовательным, и не выкладывать исходный код своих комментариев? Написал тихонечко в стол или в /dev/null
, писательский зуд удовлетворил. И нет таких проблем, что ушлые дяди заработают на твоих комментах лайки. Журналисты профессионально пишут статьи, и получают за это деньги! А ты, подобно апологетам неоплачиваемого труда, тратишь время на что? Чтобы кто-то за счёт твоих комментариев расшевелил аудиторию своего поста?
Самовыражение и творчество должно быть только приватным! Сделал фотографию — спрячь в архив, чтоб левые ушлые дяди в фотобанк не утащили. Решил программистскую задачу — ни с кем не делись кодом и статьями на богомерзких сайтиках для тупорылого гичья. Твиттер само собой должен быть приватным, какой смысл в его публикации, если денег за это не платят.
ты, подобно апологетам неоплачиваемого труда
Ты не поверишь, но я одумался, и теперь с твоей точкой зрения совершенно согласен.
Неплохо было бы заставлять всех программистов каждый день в свободное от основной работы время уделять несколько часов опенсорсным проектам, ибо польза от этого будет всем, а работы еще много. А еще неплохо было бы запретить высказываться публично против подобной практики, ибо это тормозит прогресс и заставляет компании тратить на зарплату деньги, которые могли бы пойти на исследования.
Да уж, непростая задача для разработчика — сформулировать, почему он написал код именно так, а не иначе! Вопрос, который задал ему коллаборатор, не несёт в себе и тени наезда. Нормальный рабочий вопрос, я такие на работе вижу и сам пишу не так уж и редко. Но автор реагирует на него именно как на наезд. Нужен определённый опыт, чтобы научиться отделять критику кода и критику личности автора кода. Если бы автор это умел делать, то и повода для статьи не возникло бы :)
Объяснить человеку, почему API реализован именно таким образом, какие у проекта есть требования и ограничения, всё же более конструктивно, чем воевать с ним. Эти объяснения могут помочь ему или другим людям сделать более качественный патч в следующий раз, их можно превратить в техническую документацию. А может оказаться и наоборот: что за конкретной формой API не лежит чёткого обоснования, он просто вышел так, как вышел. И это может быть поводом пересмотреть существующие представления о текущей архитектуре, чтобы она стала лучше.
В общем, если бы автор действительно использовал свой проект так, как он представляет:
этот проект стал своего рода промежуточным этапом; способом понять самого себя как разработчика, а оттуда — как человека
то данный конфликт — реальная возможность узнать о себе что-то новое и найти способ стать чуть совершеннее. Только не думаю, что путь к совершенству лежит через войны в Википедии.
Этикет не просто так придуман был хорошо вооруженными людьми.
Я неоднократно сталкивался с похожей проблемой как пользователь open source проектов.
Нужна мне какая-то функциональность. Зачем писать велосипед когда можно взять готовое. Я ищу готовое решение на GitHub и нахожу несколько проектов. Проекты крупные, популярные и на хабре их не раз упоминали. Но начинаю их изучать и пониаю что где-то реализация корявая, где-то не полная, где-то не удобные или не логичные мне архитектурные решения, где-то некорректная реализация архитектурных шаблонов, где-то мне нужно изменить поведение под мой проект, но я не могу его подменить в библиотеке потому что все захардкожено.
Вроде мелочь, а пользоваться нельзя. И PR не зделаешь, так как ломает BC и меняет архитектуру нельзя. Вот и приходится пилить свои велосипеды. А так не хочется этого делать. И не потому что это лишняя работа, а потому что, скорей всего, никто кроме меня не будет пользоваться моим решением. И не потому что оно хуже, а потому что оно не популярное.
Бывало и такое что я делаю PR, но после правок от ментейнера, он оказываются бесполезны для меня.
А что мешает написать свое решение и просто выложить его?
Иногда меня тоже не устраивают либы и я пишу дополнение к нему (с моими фиксами) которые выкладываю на гитхаб. У людей появляется выбор: использовать стандартный вариант и вариант с моими дополнениями.
А что мешает написать свое решение и просто выложить его?
@springimport я в результате так и делаю. Как я и сказал, пишу свой велосипеде и выкладываю его на GitHub. Но это не совсем правильно, о чем я уже написал.
Что хорошего в том что каждый будет писать свою реализацию функциональности и постить ее на GitHub?
Просто для примера, список реализаций CQRS на PHP.
Я просмотрел около 20 проектов из списка, не найдя удобно мне сделал свою реализацию и думаю выложить её на GitHub. Хорошо ли это? Не уверен.
If you think that these can be improved in anyway, please do suggest.
1. Мэйнтэйнер всегда прав.
2. Если код не нравится — не используй.
3. Если код содержит ошибки — исправь и приложи тесты и комментарии в PR
4. Если код содержит ошибки архитектуры — разработай свою, опубликуй и стань подобен Мэйнтэйнеру.
5. Единственный комментарий для PR — это он принят или отклонён.
6. Любые запросы на добавление функционала только через комментарии в платеже PayPal где сумма — число минут на разработку.
7. Cкачать стиль оформления кода можно <тут>
8. Не занимайте внимание мэйнтэйнера своими проблемами, он тратит время на работу, код, друзей, спорт и отдых — попробуйте сначала войти в одну из категорий
9. Мэйнтэйнер тоже человек и может ошибаться, но уже есть пункт 1 и пункт 3.
10. Аминь, да прибудет с тобой fork.
Продукт возможно предоставлять как есть. В таком варианте любые обращения от пользователей — клиентов по улучшениям могут как полностью игнорироваться, так и вызывать ответ «роботов», вежливое ничего не обещающее сообщение с благодарностью за внимание.
Продукт намерены развивать, ориентируясь на отзывы пользователей. В этом варианте обращения обрабатывают живые люди и с отдельными пользователями может завязываться переписка, в целях конкретизации проблем и пожеланий.
Для развития продукта или компании по продвижению продукта ищут партнеров. Вот тут могут возникать разнообразные переписки, в которых могут обсуждаться неожиданные для авторов — производителей вещи, что может потребовать пересмотреть свои взгляды на что-то или отказаться от самой идеи партнерства.
Автору элементарно не хватило жизненного опыта, что бы различить продуктивное общение от чего-то другого. Это не имеет отношения к душевным — моральным качествам. Опыт такого различения наживается сам собой.
А вот то, что автор отследил у себя мотивацию к некорректности ущемлением личного профессионального самолюбия, это хорошо, в следующий раз ему будет проще вежливо слить безграмотного деструктора.
Для справки, привычки, так или иначе реагировать на что-то неприятное, мы наживаем неосознанно, в детстве. Если кто научиться такое у себя отслеживать и менять, то это редкость и это очень хорошо, с чем автора и поздравляю.
Как и положено соц.сети есть свои тролли.
Бан, игнор хорошие инструменты.
Не кормите троллей.
FOSS подразумевает бесплатность использования кода, но не написания. Оригинальный автор мог бы ответить: Окей, вы хотите читаемый SQL, и вы его получите, но за деньгу. Да, вы уже прислали мне PR с изменениями, типа ну вот же, всё уже готово; но дело не в самом изменении, дело в том, что придётся поддерживать проект с вашими изменениями до скончания времён. Это усложняет жизнь, поэтому есть два варианта: "я не буду это делать" и "я сделаю это за вознаграждение".
По содержанию поста: на мейнтейнера ругались не без причины, т.к. задокументированный баг не перестаёт быть багом. Так или иначе, его отношение к подобным моментам контрпродуктивно и, как по мне, ошибочно. В чём вообще проблема поддержки проекта с вполне обоснованными изменениями до, как Вы говорите, скончания времён? Вот точно ведь лучше, чем иметь совершенно кривой код (зато свой!) и отклонять конструктивную критику.
В целом мораль очень простая: кто делает вещи — тот и прав. Если ты вкладываешь время и силы в проект, то этим ты доказываешь, что ты являешься одним из немногих людей, кому важна жизнь проекта, и тогда к твоему мнению лучше прислушатсья, и в случае конфликта тебе должны бы уступать. Особенно если ты мэйнтейнер и вкладываешь в том числе и кучу нервов, тебя лучше беречь.
Если ты форкаешь чужой проект с целью перехватить власть и направить его в другом направлении, то тем самым можешь доказать, что этот проект тебе важнее, чем текущим мэйнтейнерам. Успешный форк, который действительно в исторической перспективе жизнеспособнее исходного проекта, будет доказательством, что твои слова не были пустыми, и тогда хороший мэйнтейнер снимет шляпу и порадуется, что его дело стало ещё живее чем прежде, и что он ошибался в нужности своих вещей и идей.
Если ты ноешь, какой проект плохой и как разработчики его делают неправильно и руки растут у них не оттуда, пишешь об этом на багтрекер, на форумы, в рассылку, на википедию, в спортлото, или даже форкаешь но не рассчитываешь силы и забрасываешь форк — это никак не доказывает что тебе важна жизнь проекта, сколько бы ты ни утверждал обратное в этом процессе. Ну может чуть и важна, но твоё место гораздо скромнее, и в твоём положении надо сидеть тише и быть более благодарным за хотя бы то, что уже есть и делается, и твоё мнение не должно, вообще говоря, учитываться. Но может учитываться, если оно вдруг верное. Описанный человек (сейчас скорее обсуждаю статью и историю как описана в статье, но не пытаюсь судить что там было на самом деле) не понимает что имеет смысл только делиться и не имеет смысла требовать, и поэтому ведёт себя неадекватно.
Есть то, что есть. Причиной существования проекта являются люди, у людей есть принципы, благодаря которым и в соответствии с которым они этот проект делают. Если твой маленький патчик не принимают, потому что он не соответствует этим принципам этих людей, то увы: ведь если принципы будут нарушены, то у проекта станет меньше причин к существованию, люди будут вкладывать в него меньше времени и сил, а ты этого не хочешь, и это важнее для тебя, чем твой патчик. Или предложи сообществу себя как человека, вкладывающего силы, и свои принципы взамен, в равном количестве на примере форка или в меньшем на примере просто активного участия в имеющемся проекте. Почини чей-нибудь ещё патч, чтобы у мэйнтейнера было время починить твой, например.
Желание не достаточно просто выразить, его нужно доказывать делом, в том числе самому себе, чтобы не было случаев когда я что-то хочу, но на самом деле ничего для этого не делаю. Обманывать людей, заставляя их делать то, что тебе не так уж и важно на самом деле — нехорошо.
А если серьезно. Человека обложили на нескольких ресурсах за безвозмездный труд (не зависимо от востребованности построенного) и он заглянул на хабрахабр за переоценкой собственного отношения к произошедшему.
Люди несовершенны, прощать проще, а выводы можно делать из самых разных приоритетов.
Если замечания неприемлимы, то надо прямо так и говорить, реверансы здесь ни к чему. Но хамить и спорить на повышенных нельзя.
После чтения этого блог-поста и комментариев я немного успокоился. И скорей всего моя вина тоже присутствует. Неплохо бы с человеком обсудить, наверное, что ты хочешь делать. Но пока что я думаю так: если у меня будет большой опенсорсный проект, я постараюсь адекватно разбирать все issue и PR по модулю неадекватных личностей и троллей.
Я бы посоветовал, прежде чем делать большой PR, сначала обсудить его в issues с мейнтейнером. Это поможет избавиться от лишней работы и предвидеть правки PR. Хотя по моему опыту на PR мейнтейнеры реагируют активнее.
Pull Request — это продажа. Вы должны «продать» ~корову~ своё улучшение мэйнтейнеру или команде разработки. Так, чтобы они захотели его «купить».
Поэтому оформление PR — очень важно. Вы должны снабдить его понятным и подробным описанием решаемых проблем, почему это важно, с примерами, use case'ами и прочим. Прям вот на страничку где-то. Тогда шансы, что его примут, возрастают.
Сложно? Да. Затратно? Да. Долго? Да.
Вот один мой PR, описанием к которому я горжусь: https://github.com/rails/rails/pull/22911
У меня была такая же ситуация и даже могу дать ссылку на мой риквест: [RFC] Case Insensitivity Proof of Concept.
Его не приняли и желание дальше контрибьютить в Open Source и в ANTLR в частности поубавилось. Ну ничего — живем. Дальнейшие мои риквесты принимались, правда не с такими объемными фичами.
Насчёт сути конфликта: по-моему, выхода из него нет. Есть такие люди, которым нужно всех доставить. Делать ответвление и самостоятельно пилить код он бы не стал. Ему надо троллить.
Твоя идея — ерунда