metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-06-13 10:16 am

Еще одна юниксо-холиварная идея

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

Вот к примеру: я пишу некий софт, и массово использую для него сервисы предоставляемые другими прогами. В особо безумных случаях - вообще софт может представлять собой эти проги с обвязкой из скриптов. Если софт сложный - то он еще и несколько различных интерпретаторов скриптов может за собой притащить. Но главное то, что это софт чужой. И если во взаимодействии между разными софтам что-то ломается - самостоятельно исправлять чужой софт, по идее, не положено - положено зарепортить баг, если это баг, или наделать костылей, если это by design так. И у юзера в итоге будет то же самое - что-то ломается во взаимодействии, а участвует в этом десяток прог разных авторов. Куды бежать - неясно.

В монолитной виндовой проприетарщине же если что-то ломается - очевидно, первым этапом можно пойти поиметь мозг автору. А тому, в общем-то, и проще все исправить, т.к. код у него под контролем, а если автор еще и вменяем, то от сторонних сервисов у него вообще ничего не зависит. "Не принято вносить зависимости". И т.к. участвует одна единица "автор" или "контора-разработчик", исправление внести проще, чем когда это дело сначала надо обсудить со всем комьюнити в мейл-листах, поцеловать иконы столлмана и торвальдса в спину, сделать сначала патч, потом внести его куда-нибудь в основную ветку, долждаться пока выйдет очередная стабильная версия, а потом пару лет отвечать юзерам "обновите такое-то софтино версию 2.x.y на 2.x.z, если у вас при откручивании гайки из пупка жопа отваливается".

Конечно, когда проприетарный софт такой стоит массово у юзеров - там возникают те же проблемы, типа как у винды с обновлениями и рунтаймами от VS. Хотя для прикладного софта проблемы в основном вызывает только второе(если на VS писать), с обновлениями он хоть и конфликтует но не часто.

В общем, идея в том, чтобы не плодить множество зависимостей и разных версий - тогда получится, что если проблема в какой-то версии есть - она есть у всех и у всех ее можно однообразно исправить, а не разбираться, не поломается ли от исправления все остальное.

[identity profile] max-posedon.livejournal.com 2009-06-13 09:39 am (UTC)(link)
в теории на практике будет тоже самое что в теории, на практике получается иначе

Т.е. Идея конечно интересная, и вроде правильная, но вкорне расходится с суровой действительностью.

[identity profile] metaclass.livejournal.com 2009-06-13 09:47 am (UTC)(link)
Расходится с реальностью, видимо, потому, что имеется определенная категория лиц, что среди пропритарщиков, что среди опен-сорсников, которым болт положить на клиентов и качество продукта, а живут они за счет пол-кабана в холодильнике и колбасы, пальцем пханой из дзяроуни :)

[identity profile] dmzlj.livejournal.com 2009-06-13 11:06 am (UTC)(link)
Как показывает практика, болт на клиента положить почти всем. Т.е. в меньшей степени положить тем, кто разрабатывает на заказ и подписывает контракт на поддержку, еще меньше положить тем, кто несет финансовую ответственность за дефекты. Но таких мало. А вот на пользователей массового софта по моему, плевать абсолютно всем, даже мелкие шароварщики довольно мало парятся.