FFmpeg: различия между версиями
Нет описания правки |
Нет описания правки |
||
Строка 1: | Строка 1: | ||
== Особенности пакета == | == Особенности пакета == | ||
# Поддержка всех encoder’ов и decoder’ов из стандартно распространяемых в исходниках ffmpeg. | # Поддержка всех encoder’ов и decoder’ов из стандартно распространяемых в исходниках ffmpeg. | ||
# Поддержка linamrnb/linamrwb через dlopen для проигрывания 3gp (patch branch '''amr''') | # Поддержка linamrnb/linamrwb через dlopen для проигрывания 3gp (patch branch '''amr''') (obsoleted через libopencore) | ||
# Поддержка xvmc для карт via openchrome (в версиях 11199-alt3 <= ffmpeg <= 16869-alt1). | # Поддержка xvmc для карт via openchrome (в версиях 11199-alt3 <= ffmpeg <= 16869-alt1). | ||
Строка 9: | Строка 9: | ||
# git-svn вытягивает trunk проекта libswscale в refs/remotes/libswscale. Этому remote бранчу соответствует бранч libswscale-trunk. | # git-svn вытягивает trunk проекта libswscale в refs/remotes/libswscale. Этому remote бранчу соответствует бранч libswscale-trunk. | ||
# Бранчи ffmpeg-trunk и libswscale-trunk мержатся в бранч upstream, причем libswscale-trunk является subtree для бранча upstream. Этим достигается наличие вложенной истории libswscale относительно ffmpeg. | # Бранчи ffmpeg-trunk и libswscale-trunk мержатся в бранч upstream, причем libswscale-trunk является subtree для бранча upstream. Этим достигается наличие вложенной истории libswscale относительно ffmpeg. | ||
# В любой момент времени существует несколько feature/patch бранчей для более удобной поддержки того или иного патчсета, будь то alt-specific исправления или поддержка дополнительных кодеков. В данный момент таких бранчей два: '''alt''', содержащий alt-specific исправления | # В любой момент времени существует несколько feature/patch бранчей для более удобной поддержки того или иного патчсета, будь то alt-specific исправления или поддержка дополнительных кодеков. В данный момент таких бранчей два: '''alt''', содержащий alt-specific исправления. Бранчи amr и xvmc считаются устаревшим. | ||
# Для каждого из feature/patch бранчей делается pull из «низлежащего» бранча. Отправная точка — бранч upstream, из него надо придти в бранч master. В данный момент схема merge’й такова: | # Для каждого из feature/patch бранчей делается pull из «низлежащего» бранча. Отправная точка — бранч upstream, из него надо придти в бранч master. В данный момент схема merge’й такова: | ||
#: upstream{{==)}}alt | #: upstream{{==)}}alt{{==)}}master, то есть все feature-патчи проходят мержи в алфавитном порядке. | ||
# В бранче master относительно последнего feature-бранча содержатся только spec-файл и правила для gear. Любые другие исправления должны попадать в feature/patch бранчи. | # В бранче master относительно последнего feature-бранча содержатся только spec-файл и правила для gear. Любые другие исправления должны попадать в feature/patch бранчи. | ||
# В данный момент в Сизифе поддерживается версия 0.5, всё вышеперечисленное применимо к бранчам с суффиксом {{term|-0.5}}. | # В данный момент в Сизифе поддерживается версия 0.5, всё вышеперечисленное применимо к бранчам с суффиксом {{term|-0.5}}. |
Версия от 09:20, 18 февраля 2010
Особенности пакета
- Поддержка всех encoder’ов и decoder’ов из стандартно распространяемых в исходниках ffmpeg.
- Поддержка linamrnb/linamrwb через dlopen для проигрывания 3gp (patch branch amr) (obsoleted через libopencore)
- Поддержка xvmc для карт via openchrome (в версиях 11199-alt3 <= ffmpeg <= 16869-alt1).
Особенности сборки
Сборка ведётся из git при помощи git-svn.
- git-svn вытягивает trunk и бранч 0.5 в refs/remotes/ffmpeg/trunk и refs/remotes/ffmpeg/0.5 соответственно. Этим remote бранчам соответствуют локальные ffmpeg-trunk и ffmpeg-0.5
- git-svn вытягивает trunk проекта libswscale в refs/remotes/libswscale. Этому remote бранчу соответствует бранч libswscale-trunk.
- Бранчи ffmpeg-trunk и libswscale-trunk мержатся в бранч upstream, причем libswscale-trunk является subtree для бранча upstream. Этим достигается наличие вложенной истории libswscale относительно ffmpeg.
- В любой момент времени существует несколько feature/patch бранчей для более удобной поддержки того или иного патчсета, будь то alt-specific исправления или поддержка дополнительных кодеков. В данный момент таких бранчей два: alt, содержащий alt-specific исправления. Бранчи amr и xvmc считаются устаревшим.
- Для каждого из feature/patch бранчей делается pull из «низлежащего» бранча. Отправная точка — бранч upstream, из него надо придти в бранч master. В данный момент схема merge’й такова:
- upstream ⇒ alt ⇒ master, то есть все feature-патчи проходят мержи в алфавитном порядке.
- В бранче master относительно последнего feature-бранча содержатся только spec-файл и правила для gear. Любые другие исправления должны попадать в feature/patch бранчи.
- В данный момент в Сизифе поддерживается версия 0.5, всё вышеперечисленное применимо к бранчам с суффиксом -0.5.
- Сборка unstable trunk ffmpeg предназначена для power users и для подготовки девелоперских версий зависимого софта. Никакой поддержки по сборкам из trunk не оказывается.
Работа с ffmpeg svn
$ git svn fetch ffmpeg $ git svn fetch libswscale $ git checkout -f ffmpeg-trunk && git pull . refs/remotes/ffmpeg/trunk $ git checkout -f libswscale-trunk && git pull . refs/remotes/libswscale $ git checkout -f upstream $ git pull . refs/heads/ffmpeg-trunk $ git pull -s subtree . refs/heads/libswscale-trunk $ git checkout -f <feature branch> $ git pull . upstream $ ... $ git checkout -f master $ git pull . <latest feature branch> $ ... $ PROFIT