Size: a a a

2020 June 18

A

Aleksandr Khristenko in PHP
Kirill Nesmeyanov
Атрибуты - это декларативная шляпа, так что конфликтовать с погашением ошибок не будут (располагаются в разных местах)
Может парсер усложняет?
источник

KN

Kirill Nesmeyanov in PHP
ну там и так кс грамматика вроде как
источник

KN

Kirill Nesmeyanov in PHP
ну т.е. не знаю как на счёт похапешного LALR, но в примитивных комбинаторах не усложняет ничего
источник

KN

Kirill Nesmeyanov in PHP
парсер сильно усложняет синтаксис << xxx >> - это да
источник

KN

Kirill Nesmeyanov in PHP
<< Attr(2 >> 4) >>
источник

KN

Kirill Nesmeyanov in PHP
хотя... не, вроде не усложняет
источник

AM

Artem Molotov in PHP
Anton Lakotka
хотя пхпшникам не привыкать нажимать на шифт для знаменитого $
так для < тоже надо шифт нажимать
источник

KN

Kirill Nesmeyanov in PHP
не, проблем с парсерами нет, даже с самыми примитивными
источник

KN

Kirill Nesmeyanov in PHP
источник

ВУ

Валентин Удальцов... in PHP
Наброшу, пожалуй))
источник

ВУ

Валентин Удальцов... in PHP
Однажды я услышал, что геттеры — это плохо.

И прошел все этапы реакции по Кюблер-Росс: отрицание, злость, торг, депрессию, принятие 😂
Надеюсь, этот пост поможет пропустить несколько стадий.

DTO. Если тело геттера return $this->privateProperty, заменяем его публичным свойством с аннотацией @psalm-readonly-allow-private-mutation или @psalm-readonly или объявляем весь класс @psalm-immutable. Так мы обеспечиваем инкапсуляцию да ещё и нанооптимизируем код (-N вызовов геттеров). Метод без каких-либо манипуляций не имеет смысла — это 4 строки визуального долга и 1 строка для покрытия тестами.

Кстати, я тут заметил, что геттер — это трюк. К существительному добавили глагол, чтобы удовлетворить фомуле subject.actionVerb(?object). Вот только get — это не предоставить, а получить. То есть мы не просим объект поделиться состоянием, мы его отбираем.

Value Object. Если метод представляет собой query по CQS и возвращает некоторое представление (проекцию) объекта, то его название не должно быть шаблонным, оно должно отражать семантику. Например, Birthday::format(string $format): string, Color::toHex(): string.

Entity. Стараемся применять принцип Tell-Don't-Ask. Попробую сформулировать по-своему. Объект — это состояние + поведение. Если мы программируем объектно-ориентированно, мы должны просить объект совершить действие над принадлежащим ему состоянием, а не отбирать у него состояние и выполнять действие за пределами этого объекта. Если программируем не объектно-ориентированно (что тоже ок), то объекты по определению не используем и геттеры, соответственно, тоже.

---

Итак, в DTO вместо геттеров используем публичные свойства. В Value Object — семантические query методы, и то, если не добавлять "на всякий случай", их будет немного. В моделях оставляем только command методы.

Как тогда вывести состояние модели? Рассудим логически. Для вывода состояния поведение не нужно, нужно только состояние. Значит и сама модель для этой задачи не нужна. Где хранится состояние модели? В хранилище. Вот из него напрямую и запросим. Утрированный GET API контроллер: echo json_encode($pdo->query('select x1, x2 from y where z = ?')->fetch()).
источник

A

Adel in PHP
Валентин Удальцов
Однажды я услышал, что геттеры — это плохо.

И прошел все этапы реакции по Кюблер-Росс: отрицание, злость, торг, депрессию, принятие 😂
Надеюсь, этот пост поможет пропустить несколько стадий.

DTO. Если тело геттера return $this->privateProperty, заменяем его публичным свойством с аннотацией @psalm-readonly-allow-private-mutation или @psalm-readonly или объявляем весь класс @psalm-immutable. Так мы обеспечиваем инкапсуляцию да ещё и нанооптимизируем код (-N вызовов геттеров). Метод без каких-либо манипуляций не имеет смысла — это 4 строки визуального долга и 1 строка для покрытия тестами.

Кстати, я тут заметил, что геттер — это трюк. К существительному добавили глагол, чтобы удовлетворить фомуле subject.actionVerb(?object). Вот только get — это не предоставить, а получить. То есть мы не просим объект поделиться состоянием, мы его отбираем.

Value Object. Если метод представляет собой query по CQS и возвращает некоторое представление (проекцию) объекта, то его название не должно быть шаблонным, оно должно отражать семантику. Например, Birthday::format(string $format): string, Color::toHex(): string.

Entity. Стараемся применять принцип Tell-Don't-Ask. Попробую сформулировать по-своему. Объект — это состояние + поведение. Если мы программируем объектно-ориентированно, мы должны просить объект совершить действие над принадлежащим ему состоянием, а не отбирать у него состояние и выполнять действие за пределами этого объекта. Если программируем не объектно-ориентированно (что тоже ок), то объекты по определению не используем и геттеры, соответственно, тоже.

---

Итак, в DTO вместо геттеров используем публичные свойства. В Value Object — семантические query методы, и то, если не добавлять "на всякий случай", их будет немного. В моделях оставляем только command методы.

Как тогда вывести состояние модели? Рассудим логически. Для вывода состояния поведение не нужно, нужно только состояние. Значит и сама модель для этой задачи не нужна. Где хранится состояние модели? В хранилище. Вот из него напрямую и запросим. Утрированный GET API контроллер: echo json_encode($pdo->query('select x1, x2 from y where z = ?')->fetch()).
это ты CQRS для себя открыл?
источник

ВУ

Валентин Удальцов... in PHP
Adel
это ты CQRS для себя открыл?
ну года два назад) но пост в первую очередь про то, что геттеры не нужны, а не про CQRS, хотя темы пересекаются
источник

A

Adel in PHP
рид модель иногда бывает сложнее чем просто "вывести состояние"
источник

ВУ

Валентин Удальцов... in PHP
Adel
рид модель иногда бывает сложнее чем просто "вывести состояние"
да, поэтому у нас EventSorcing и туча проекций. но это бы вышло за рамки поста
источник

A

Adel in PHP
просто последний абзац непонятный получился. т.е. как будто предлагается всё держать в полях базы данных...
источник

ВУ

Валентин Удальцов... in PHP
Adel
просто последний абзац непонятный получился. т.е. как будто предлагается всё держать в полях базы данных...
понимаю, о чем ты, согласен, спасибо. ща мб поправлю
источник

AK

Anton Karpov in PHP
ооо, яб читнул про проекции и рид-модельки... 😋
источник

ВУ

Валентин Удальцов... in PHP
Anton Karpov
ооо, яб читнул про проекции и рид-модельки... 😋
как-нибудь напишу)
источник

AK

Anton Karpov in PHP
источник