Незадолго до выхода Kohana 3.0RC1 «великодушный пожизненный диктатор» Shadowhand предложил коммьюнити сделать выбор между двумя путями развития:
1. Ветки 3.0 и 2.4 будут развиваться параллельно (релизы примерно в начале сентября), причем 2.4 будет предполагать небольшие изменения по сравнению с 2.3.x (изменится Database и i18n).
2. Ветка 2.4 будет закрыта, все силы перебросят на 3.0. При этом для 2.3.x будет продолжена поддержка в виде выпуска bug-fix‘ов.
Судя по всему, ситуация с разделением девелоперских ресурсов стала основным лейтмотивом данного заявления. Конечно, второй вариант получил большинство голосов от рядовых пользователей, но был ряд серьезных возражений от «отцов» 2.4, в том числе с намеками на возможный форк. Поэтому в итоге было принято Соломоново решение:
1. Обе ветки (2.4 и 3.0) будут выпущены.
2. Будет произведен ряд корректив, направленных на максимальную совместимость данных веток. В частности, средства интернационализации (i18n) и классы Kohana_Config и Kohana_Log будут иметь одинаковый синтаксис. Для Kohana 2.4 создается автолоадер для загрузки модулей из Ko3.
3. Модули Database и ORM будут импортированы из 3.0 в 2.4, и буду загружаться с помощью упомянутого выше нового автолоадера.
Таким образом, при минимуме производимых изменений, переход от 2.3.4 к 2.4 будет достаточно легким (основные изменения коснутся модуля Database). В свою очередь, 2.4 и 3.0 также будут иметь сходные API. Новые разрабатываемые модули будут ориентированы на третью ветку (соответственно они будут доступны и из 2.4).
Спасибо Вам, за освещение материалов по Kohana 3!
Не могли бы Вы, как профессионал, описать работу (настройку) роутинга в Kohane3. Не совсем понятно, как его (роутинг) настраивать, когда в директории classes/controller находятся еще директории с контроллерами..
Что ж, вполне разумно и уважительно для всех.
Хотя свои следующие проекты после окончания текущего надеюсь делать на KO3
@Max
На самом деле все довольно просто. Есть специальный параметр ‘directory’, который определяет наличие поддиректорий при роутинге:
@BIakaVeron
Большое человеческое Спасибо!
А всем нравится структура директорий коханы3???
Мне не нравится, что все подряд смешивается в общей папке classes. Кохана 2 интуитивней с точки зрения структуры директорий, имхо.
Вот думаю, переделать ручками 3 версию, по структуре ближе ко второй.
Почему смешивается? Контроллеры и модели разделены по соответствующим директориям. В корне остаются только хэлперы и библиотеки.
BIakaVeron
С контроллерами и моделями — согласен. Интересно, почему бы для хэлперов и библиотек не сделать отдельные директории, как в Кохане2, интуитивнее ведь и меньше путаницы. Или я ошибаюсь? Интересно у слушать мнение…
Имхо конечно, но мне кажется разработчики Коханы изучали ЗендФреймворк, отдаленно, но кахана3 начинает чем-то напоминать его.
1. Как таковых хэлперов и библиотек в Кохана3 нет. Они хранятся вместе. Например, хэлпер valid и библиотека Validation теперь объединены в один класс Validate, который может быть использован как статический хэлпер (методы email() и прочие) или как класс для валидации данных.
2. Согласен, после Ко2 наступает культурный шок от структуры папок и файлов (и не только, теперь ведь вместо суффикса ‘_Controller’ надо писать префикс ‘Controller_’, все время путаюсь), но это дело наживное, как мне кажется.
3. Изучали, конечно. Например, в документации есть отдельный пункт (в vendors) о подключении классов именно ZF, а очередные изменения в структуре папок Ко3 (тогда еще не было отдельной папки kohana в classes) Shadowhand объяснил именно как переход к Zend-style. Главное, чтобы Кохана перенимала только лучшее
BIakaVeron
Спасибо за информацию!
Работаю php-программистом. К сожалению, руководство запрещает нам пользоваться сторонними фреймворками и даже ихними исходниками. Вся разработка ведется на фреймворке, который предоставила фирма — он ужасен.
Чтобы не терять квалификацию, в свободные время ковыряю популярные php-фреймворки (их код). Изучая код Кохана2 и Коханы3, заметил эволюцию в сторону Зендовского фреймворка.
До сих пор структура директорий Коханы2 больше нравится, но и впечатляет легкость,скорость и качество кода Коханы3.
Поэтому собираюсь собрать нечто среднее между Коханой2 и Коханой3)))
BIakaVeron, а Вы не в курсе, существует ли хоть какой-то манул на Кохану3???
Есть заготовка для будущей документации, но там по сути присутствуют только примеры для Database.
Смотрите исходники, да еще тут.
PS. Я собираюсь в ближайшее время написать статью с описанием RC1, если есть конкретные вопросы, напишите мне на почту, постараюсь описать все актуальные проблемы.
Что касается хэлперов и библиотек — на мой взгляд, как раз интуитивнее не проводить такого разделения, потому что смысл у них очень похожий, в начале я немного путался