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

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

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

Фронт: Ускорить токенайзер PostCSS

Для уверенных в себе, задача на неделю

В хороших парсерах разбор разбит на два шага: строка → токены и токены → дерево объектов. Первый шаг называется токенайзер.

Сейчас токенайзер возвращает [token_name, content, start_line, start_column, end_line, end_column]. Есть мнение, что можно сильно ускорить токенайзер, если:

  1. Возвращать Uint32Array(token_code, offset_start, offset_end, start_line, start_column, end_line, end_column). То есть, вместо строки с именем токена использовать цифровой код. А content парсер может взять сам из строки входящего CSS по offset_start и offset_end.
  2. Если токенайзер будет использовать один и тот же экземпляр Uint32Array. В итоге не будет постоянно создаваться больше объектов и вызываться сборщик мусора.

Польза: указать в резюме коммит в известный проект.

  1. Загрузить бенчмарк.
  2. Форкнуть PostCSS.
  3. Переключиться на ветку amy в PostCSS.
  4. Исправить код токенайзера и парсера.
  5. Вызвать gulp build в PostCSS и потом gulp tokenizers в бенчмарке.
  6. Вне зависимости от результата отправить PR с результатами бенчмарка.