Бэкенд и «золотые молотки»

Привет, коллеги!

Мы анонсировали конференцию, посвященную Desktop UI & Business Application. В поддержку, чтобы посмотреть на настроения публики, была опубликована статья «WPF живее всех живых», которая оказалась дискуссионной и заставила нас в несколько другом свете взглянуть, на то, что и как мы хотим донести до широкой публики.

Как показали комментарии, не WPF единым живет десктоп разработка. Есть порты Qt для .NET, есть WinRT, если в эпсилон окрестности от дефолт-сити есть спецы по этим технологиям, которые хотят высказаться – у нас есть трибуна! Для этого все и задумано, чтобы показать различные варианты для ваших проектов.

Буквально вчера закончилась онлайн конференция dotNetConf 2015, которую, исходя из сообщений, Microsoft скорее возродила, нежели придумала заново. Конференция, судя по содержанию старается покрыть все основные области использования языка, это мультиплатформенность, веб, десктоп, доставка приложений, интеграция с Xamarin, будущее .NET, .NET Core, Roslyn Analyzer и другие темы. На мой взгляд, это генеральная репетиция перед конференцией //build, которая состоится в конце апреля-начале мая.

Подробнее

WPF живее всех живых

Я долгое время был разработчиком систем для десктопа. Сначала это был WinForms, потом более мощный и гибкий WPF. С тех пор прошло много времени и курсирует множество слухов и мнений о том, что WPF завершает свою жизнь, ведь сейчас столько разговоров о том, что можно писать настольные приложения на JS. А еще Microsoft усиленно двигает в массы платформу WinRT для разработки новых приложений. Это не могло меня и коллег оставить равнодушным.

Так почему же мы, команда GoSharp конференции (да, да, это о C#), решили сделать акцент на десктопной разработке в разрезе WPF? Далее я хочу показать какие светлые и темные моменты есть в существующем положении фреймворка и почему все же стоит в него вкладывать силы и время.

Существует мнение, что развитие десктопной разработки остановилось в своем развитии и для этого есть несколько предпосылок. Одна из них – остановка, или даже лучше сказать стагнация, в самой базе, в визуальном фреймворке WPF. Значительных обновлений для него не было вот уже лет 5, как может показаться. Официальный тулкит давно не обновлялся, точнее с февраля 2010 года, т.е. вот как раз те самые 5 лет. При этом компании, специализирующиеся на кастом-компонентах, как например DevExpress и Telerik успешно выпускают обновления и составляют планы на будущее относительно WPF. Даже если вы ориентированы на новинки, то компоненты для WinRT все равно используют концепции и общую структуру XAML, который никуда не уходит.
Далее мы хотим представить причины, по которым WPF некоторые считают неактуальным, и опровержение этих причин.

 

Причины для беспокойства

Причин для беспокойства можно выделить с дюжину. Но не все они реально так страшны и существенны. Пройдемся кратко по основным.

Блог команды WPF давно не обновлялся.

Так же, как и у любой другой команды, у команды WPF есть свой блог, в котором по идее должны быть описаны планы и достижения команды. К сожалению, в блоге давно нет новой информации. Это может натолкнуть на мысли, что всех разогнали или что писать не о чем. Однако, это не так и блог стал обновляться 4 месяца назад и последняя запись появилась 20 дней назад. Более того, появился генеральный план развития фреймворка, а также краткие описания новых фич доступных с последними CTP.

Подробнее

Интервью Гаэля и Скота Хансельмана

Всем привет! Я хочу анонсировать и пригласить резидентов Москвы и Питера посетить бесплатные вечера и мастер-классы с автором одного из наиболее мощных АОП фреймворков для .Net — Гаэлем Фрётэром.
Встречи пройдут 11-13 марта в Москве и 16-17 марта в Питере. Еще раз повторюсь мероприятие бесплатное, но необходимо зарегистрироваться. Более подробно агенда представлена здесь

Далее вы можете почитать весьма занимательное интервью, которое дал Гаэль Скоту, о том, как развивался и вставал на ноги продукт. Какие сложности были в развитии, какие непростые решения пришлось принимать во время перехода от опенсорс проекта к коммерческому.

HM

СКОТТ ХАНСЕЛЬМАН: Всем привет, это Скотт Хансельман (Scott Hanselman) и в эфире новый эпизод Hanselminutes. Сегодня, с помощью магии скайпа, с другого конца мира, мы поговорим с Гаэлем Фрётэром (Gael Fraiteur) из SharpCrafters, создателем PostSharp. Привет!
ГАЭЛЬ ФРЁТЭР: Привет!
СКОТТ ХАНСЕЛЬМАН: Я очень рад, что сегодня могу поговорить с тобой. Я твой поклонник и нам предстоит многое обсудить. Сегодняшняя беседа входит в цикл бесед о стартапах и ты как нельзя лучше подходишь для этого. Ты человек из мира открытого ПО, и создал программу которой я пользовался для своих открытых проектов, но теперь ты построил на этом целую компанию. И я хочу понять почему ты сделал это? Затем мы немного обсудим сам продукт и его будущее. Итак, ты можешь начать с рассказа что за программу ты создал.
ГАЭЛЬ ФРЁТЭР: Мы создали PostSharp – это дополнение к компилятору, которое запускается после сборки проекта или, другими словами Аспектно-Ориентированный фреймворк. Его задача заключается в том, чтобы вы, как программист, создавали меньше тупого повторяющегося кода. Для примера можем рассмотреть такую штуку как реализацию уведомления об изменении свойства. Каждый раз для её использования вам надо написать три строчки кода. Эти три строчки кода – мелочь, но мелочь, которая должна быть реализована для каждого свойства в каждом классе, и они превращаются в тысячи строк кода. Можно обнаружить, что вы пишите реализацию по определенному шаблону и это приводит к лучшей реализации INPC. Наш инструмент позволяет реализовать этот шаблон так, что код будет генерироваться автоматически и не загрязнять исходный код. Это суть подхода PostSharp и аспектно-ориентированного программирования (АОП).
СКОТТ ХАНСЕЛЬМАН: Хм, аспектно-ориентированное программирование. Я слышал про него в рамках решений для сквозного функционала. Можно сказать, что люди думают вертикально при объектно ориентированном подходе: это наследуется от этого, вон то от другого. Но АОП, как например логирование, не вписывается в такую вертикальную иерархию. Оно прошивает эти иерархии через всё приложение. Я в верном ключе описал АОП подход?

Подробнее