Нам нужны твои мозги

Хотите расти как разработчик и найти крутую работу? Не протирайте штаны — займитесь Open Source проектами. Так легче всего попасть в лучшие команды разработчиков и положить себе в резюме настоящий проект, вместо нелепых «примеров кода». Но найти подходящий проект для участия сложно. Начинаются лень и отговорки, а за ними — отсутствие профессионального роста, критики по-настоящему крутых программистов, уныние и застой.

На Cult of Martians мы собираем интересные задачи для современных веб-программистов. Можно выбрать подходящую по сложности, продолжительности и специализации. Задачи не выдуманы «из воздуха» — каждая решает насущную проблему, и решить ее можно через создание нового Open Source проекта или улучшение существующего. Решайте задачи, прокачивайтесь, присылайте решение на оценку. Лучших могут пригласить к себе на работу компании, программистам которых понравится ваше решение.

Помощь запрашивалАндрей СитникАндрей Ситник Андрей Ситник

ПомогАяз ЗайнутдиновАяз Зайнутдинов Аяз Зайнутдинов

Фронт: Перевести токенайзер PostCSS с line, column на offset

Для новичков, задача на неделю

Сейчас PostCSS сохраняет строку и колонку каждого токена. Но команде Sass для совместимости нужна позиция в CSS-строке (offset) вместо строки и колонки. Можно перевести токенайзер на offset, а строку/колонку вычислять. Это упростит токенайзер и уменьшит расход памяти.

Польза: опыт работы с JavaScript в большом опенсорс-проекте, строка в резюме с PR в известный проект.

  1. Форкнуть postcss.
  2. Сделать новую ветку от ветки ose.
  3. Исправить lib/tokenize.js, чтобы он отдавал [type, content, offset] вместо [type, content, line, column].
  4. Исправить lib/parser.js, чтобы он работал с новыми токенами. Добавить Node#source.start.offset и Node#source.end.offset. Node#source.start.line, и так далее; расчитывать динамически с помощью line-column.
  5. Запустить бенчмарк, сравнив ose и вашу ветку. Убедиться, что изменения скорости незаметны. Если заметны, написать в issue.