metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-11-27 06:45 pm

Коньцепция

А вот скажите, существует ли где-нибудь в академических эмпиреях компутер сайенс такая вещь, как эволюционирующие типы?

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

Так вот, тут бы не помешала бы какая-нибудь жосткая проверка корректности этого дела, аналогичная статической типизации, но чтобы до часа Ч типы и функции был одни, а после - другие, да еще с обязательной проверкой что для всех данных уже существующих в системе есть корректные функции миграции.

[identity profile] theiced.livejournal.com 2009-11-28 09:13 am (UTC)(link)
Ну чо - мастер функа, которая в зависимости от фазы луны вызывает нужный вариант (грубо). Как реализовать - в зависимости от платформы. Будь то элегантное решение в лиспах или там жабские аспекты или кошмар с `class RasschetProvodokSTretjeyFazyLunyPoChetvertuju17800GodaEraOpezdola` с мастер классом.

С данными вот сложнее. Если идёт ввод `задним числом` то надо дёрнуть все последующие `конвертации`. Если данные непротиворечивы - то всё просто, а если противоречивы - то две копии хранить, хуле.

[identity profile] theiced.livejournal.com 2009-11-28 09:15 am (UTC)(link)
И да - счастье если юзеры спят по ночам. А вот если остановка системы на 5 минут == куча геммора и согласовний - то пиздец совсем.

[identity profile] metaclass.livejournal.com 2009-11-28 09:26 am (UTC)(link)
Да, с данными - нужно бранчи делать и мержить их, т.е. разницу в текущем периоде прокладывать.

[identity profile] sergiej.livejournal.com 2009-11-29 02:03 pm (UTC)(link)
Это как-то негибко. Если данные обрабатывались/должны обрабатываться разными методами, то признак конкретной версии метода лучше держать при самих данных.