mirror of
https://gitdl.cn/https://github.com/chakralinux/gtk.git
synced 2025-01-24 01:42:13 +08:00
firefox-kde added
This commit is contained in:
parent
f96e96c0e6
commit
d0926d3de1
210
firefox-i18n/PKGBUILD
Normal file
210
firefox-i18n/PKGBUILD
Normal file
@ -0,0 +1,210 @@
|
||||
pkgname=firefox-i18n
|
||||
pkgver=20.0.1
|
||||
pkgrel=1
|
||||
pkgdesc="Language pack for Firefox"
|
||||
arch=('any')
|
||||
url="http://www.mozilla.com/"
|
||||
license=('MPL' 'GPL')
|
||||
pkgdesc="Language pack for Firefox"
|
||||
|
||||
_languages=(
|
||||
'ach "Acoli"'
|
||||
'af "Afrikaans"'
|
||||
'ak "Akan"'
|
||||
'ar "Arabic"'
|
||||
'as "Assamese"'
|
||||
'ast "Asturian"'
|
||||
'be "Belarusian"'
|
||||
'bg "Bulgarian"'
|
||||
'bn-BD "Bengali (Bangladesh)"'
|
||||
'bn-IN "Bengali (India)"'
|
||||
'br "Breton"'
|
||||
'bs "Bosnian"'
|
||||
'ca "Catalan"'
|
||||
'cs "Czech"'
|
||||
'csb "Kashubian"'
|
||||
'cy "Welsh"'
|
||||
'da "Danish"'
|
||||
'de "German"'
|
||||
'el "Greek"'
|
||||
'en-GB "English (United Kingdom)"'
|
||||
'en-US "English (United States)"'
|
||||
'en-ZA "English (South Africa)"'
|
||||
'eo "Esperanto"'
|
||||
'es-AR "Spanish (Argentina)"'
|
||||
'es-CL "Spanish (Chile)"'
|
||||
'es-ES "Spanish (Spain)"'
|
||||
'es-MX "Spanish (Mexico)"'
|
||||
'et "Estonian"'
|
||||
'eu "Basque"'
|
||||
'fa "Persian"'
|
||||
'ff "Fula"'
|
||||
'fi "Finnish"'
|
||||
'fr "French"'
|
||||
'fy-NL "Frisian (Netherlands)"'
|
||||
'ga-IE "Irish"'
|
||||
'gd "Gaelic"'
|
||||
'gl "Galician"'
|
||||
'gu-IN "Gujarati (India)"'
|
||||
'he "Hebrew"'
|
||||
'hi-IN "Hindi (India)"'
|
||||
'hr "Croatian"'
|
||||
'hu "Hungarian"'
|
||||
'hy-AM "Armenian"'
|
||||
'id "Indonesian"'
|
||||
'is "Icelandic"'
|
||||
'it "Italian"'
|
||||
'ja "Japanese"'
|
||||
'kk "Kazakh"'
|
||||
'km "Khmer"'
|
||||
'kn "Kannada"'
|
||||
'ko "Korean"'
|
||||
'ku "Kurdish"'
|
||||
'lg "Ganda"'
|
||||
'lij "Ligurian"'
|
||||
'lt "Lithuanian"'
|
||||
'lv "Latvian"'
|
||||
'mai "Maithili"'
|
||||
'mk "Macedonian"'
|
||||
'ml "Malayalam"'
|
||||
'mr "Marathi"'
|
||||
'nb-NO "Norwegian (Bokmal)"'
|
||||
'nl "Dutch"'
|
||||
'nn-NO "Norwegian (Nynorsk)"'
|
||||
'nso "Northern Sotho (Sesotho sa lebowa)"'
|
||||
'or "Oriya"'
|
||||
'pa-IN "Punjabi"'
|
||||
'pl "Polish"'
|
||||
'pt-BR "Brazilian Portuguese"'
|
||||
'pt-PT "Portuguese"'
|
||||
'rm "Romansh"'
|
||||
'ro "Romanian"'
|
||||
'ru "Russian"'
|
||||
'si "Sinhalese"'
|
||||
'sk "Slovak"'
|
||||
'sl "Slovenian"'
|
||||
'son "Songhai"'
|
||||
'sq "Albanian"'
|
||||
'sr "Serbian"'
|
||||
'sv-SE "Swedish"'
|
||||
'ta-LK "Tamil (Sri Lanka)"'
|
||||
'ta "Tamil"'
|
||||
'te "Telugu"'
|
||||
'th "Thai"'
|
||||
'tr "Turkish"'
|
||||
'uk "Ukrainian"'
|
||||
'vi "Vietnamese"'
|
||||
'zh-CN "Chinese (simplified)"'
|
||||
'zh-TW "Chinese (traditional)"'
|
||||
'zu "Zulu"'
|
||||
)
|
||||
|
||||
source=()
|
||||
_url=http://download.cdn.mozilla.net/pub/mozilla.org/firefox/releases/$pkgver/linux-i686/xpi
|
||||
|
||||
for _lang in "${_languages[@]}"; do
|
||||
_locale=${_lang%% *}
|
||||
|
||||
source+=("firefox-i18n-$pkgver-$_locale.xpi::$_url/$_locale.xpi")
|
||||
done
|
||||
|
||||
# Don't extract anything
|
||||
noextract=(${source[@]%%::*})
|
||||
|
||||
package() {
|
||||
for _lang in "${_languages[@]}"; do
|
||||
_locale=${_lang%% *}
|
||||
install -Dm644 firefox-i18n-$pkgver-${_locale}.xpi \
|
||||
"$pkgdir/opt/firefox/extensions/langpack-${_locale}@firefox.mozilla.org.xpi"
|
||||
done
|
||||
}
|
||||
|
||||
md5sums=('597e3ef4a20841b5bec461634bb46a6d'
|
||||
'0b89340b7cab8803fe5f86c627d52770'
|
||||
'c2a3a0fe444fa389f61339ad5d189fdc'
|
||||
'f32fb82611adb9422cb88599f1c0eb56'
|
||||
'9372776226c93de0115e3cef93477f7a'
|
||||
'1148ca8998b7a13ec415328da3ec311b'
|
||||
'0bf3d930144ce0649a7c42f29316092e'
|
||||
'2e89e7fceca13697bb2f434913b2975a'
|
||||
'7a35eb4ec90cc6dd0ea3fe83f92304dc'
|
||||
'3a3d215e72bf6dea35f8da0a0dca6fc5'
|
||||
'085cc2de9c4bbb541d29ddc5aeb4fbb5'
|
||||
'dbd5046c3d3dab6c4fefef999fe50781'
|
||||
'c38a2f030b88f65681610f3bf60b96c9'
|
||||
'82d0b81be13d1e584a5d92709529440c'
|
||||
'8e5f36b655ac2a1ef63d57bca9b492eb'
|
||||
'aece86a38b9f6d20352426f1ccdfa1fb'
|
||||
'0a0f93a504fb87ff26afffa8c84aa12e'
|
||||
'd9e685e55d32caf84f419f72a1c468ec'
|
||||
'50b88fdc3782f106ef86fe87ebdeac8c'
|
||||
'553f17d16fa89063675ffcef806feb89'
|
||||
'2b2eb97db05c4b7b6fc0d42c57f4e27a'
|
||||
'9739ad4f2a26d964d20d95c0e6e89236'
|
||||
'86a3fd95c1f3217300ee0e289a834030'
|
||||
'3d175fbe1b1970e70b3f62af3b900525'
|
||||
'cb35fbc928fe465a3bc934b1f6bb745f'
|
||||
'50437c49670acab136604b505b404b20'
|
||||
'cf7ddc9b121746963c937199a33d92d7'
|
||||
'7faf0ba42b4233a103a37899afabe2ae'
|
||||
'aaaf844852925aa7071233c6f09ab91a'
|
||||
'06c41a72518f06bf93eae67584a6485d'
|
||||
'935f2c53f26e3a353db73cf29307f569'
|
||||
'aecf7230cb90ca550370c578238ce5a4'
|
||||
'f2de7bfe152ad2797fba831c197d388c'
|
||||
'a68ad8ca8569beb99f680239986db0cf'
|
||||
'94e8e358b0f092618c3acf57b1d0906f'
|
||||
'14f889b49e889293d51721337c33a4d2'
|
||||
'44b618e828a07d7446b095934c56d5e9'
|
||||
'd53b4f6a29ded966b9d187ffd05e4b70'
|
||||
'de0ac2693ed958604ded2f23636effbf'
|
||||
'1618522eb50f173acec7f092c7c96f39'
|
||||
'26db544175c2bcbce4ce30d160cedc87'
|
||||
'b99c07102adab6c7e5fa5f1cb15c5f76'
|
||||
'8e0396a4f6474a35c4918de2784c5221'
|
||||
'4b74f98a3342db51c2ec77ed16b8556b'
|
||||
'a91b96f872177553e7690f244bff7462'
|
||||
'11ed58204ca499e790d192d0bd25b2b3'
|
||||
'97605ae1cfee9bbd73ef64502fcf74c0'
|
||||
'a5e0b54c1b62e8230e68f9e08885d60b'
|
||||
'04fc0ec71cb3737ac22fbca8972836ba'
|
||||
'ce7057480c8e8c6cb4628881aa282935'
|
||||
'1c67943a68874b8bbd1247c2b182c392'
|
||||
'5ff652376c9f8b8cebf35289691d4ea4'
|
||||
'969767e3b6f854678d7a14540b06dfd0'
|
||||
'f12c9f983d359de24e81dc6537272bee'
|
||||
'4d1612c3479b8425fd0d59d7f6f8c62f'
|
||||
'1438937613d33972e169c73e4c623dab'
|
||||
'f43bb1be2f6010ae2aca60d1f4afc41d'
|
||||
'1834a840381523dfe342e16f8ff981cd'
|
||||
'4cef624804aedc2a1e03b59fe4e240ae'
|
||||
'8b8c116f33b2a2c2339b6d7086b613e4'
|
||||
'c5014cc33ffa8f6fb77deb99f44ee7c5'
|
||||
'd1063014c0c76e8c859f8344cba32c70'
|
||||
'3cf5a45579f12400518dc71347e673c1'
|
||||
'd2915e7ac4fabada4c3724e784171320'
|
||||
'c959f7257ba9ffc8b5c7f6a356ae23cc'
|
||||
'5c8f905eebdc01706474711024787e37'
|
||||
'959e327c760433883fa99391983c1d92'
|
||||
'289c26f04aac9162f97cfcf119e047a1'
|
||||
'baa58c0da97b9f00c40b7fac5649917e'
|
||||
'1c73ed43e67724374a6d63ded286853b'
|
||||
'2ff6dba5d558be87f55685ce5847f237'
|
||||
'bbde96f321c72b9e36ba4858152e0abc'
|
||||
'41223f817c308106b4d6cd36472971bd'
|
||||
'874fd27d3497ce8861f59898d4ca071e'
|
||||
'591270d06d4465ca12e4f0af8e877e04'
|
||||
'5ca701859cccf06e76a57a0f058844cd'
|
||||
'5ac2747d887a0d45a30679664dd36af5'
|
||||
'2599b9f22a873a69bf4fc1d8df35b1a8'
|
||||
'ac9b4e003bbcbff1fffade3dac13cda1'
|
||||
'83c02b0e4a0632a585fc604a5034e2b7'
|
||||
'ecb95562b073024cb51d179e1b28417e'
|
||||
'cbce947435041ff404b7b127429a66ab'
|
||||
'52a316fd6f158ff05350aba2f3c8ddda'
|
||||
'579c897bd19c133d26c3a9bb99db25a7'
|
||||
'd9cfd223fd70df09c6f9d5e479ab76b6'
|
||||
'9c4a74f244eeb96bafc2f10f9eb71e6d'
|
||||
'b3cd3bf0724be59bdc35e0e8fe87536c'
|
||||
'e837b3b7f94de1d980b786d115f99e5c'
|
||||
'a89fbe66af0b56518e94471b32517a5d')
|
114
firefox-kde/PKGBUILD
Normal file
114
firefox-kde/PKGBUILD
Normal file
@ -0,0 +1,114 @@
|
||||
# Contributor: Weng Xuetian <wengxt@gmail.com>
|
||||
|
||||
pkgname=firefox-kde
|
||||
pkgver=20.0.1
|
||||
pkgrel=1
|
||||
pkgdesc="Standalone web browser from mozilla.org with OpenSUSE patch, integrate better with KDE"
|
||||
url='http://www.mozilla.org/projects/firefox'
|
||||
arch=('x86_64')
|
||||
license=('MPL' 'GPL' 'LGPL')
|
||||
depends=('gtk2' 'libnotify' 'alsa-lib' 'gstreamer0.10' 'gstreamer0.10-base' 'libxt' 'firefox-i18n' 'dbus-glib')
|
||||
makedepends=('zip' 'pkg-config' 'diffutils' 'python2' 'wireless_tools' 'unzip' 'autoconf2.13' 'mesa' 'yasm')
|
||||
screenshot="http://img864.imageshack.us/img864/5116/firefoxm.png"
|
||||
|
||||
provides=("firefox=${pkgver}")
|
||||
conflicts=('firefox')
|
||||
install=firefox.install
|
||||
url="http://www.mozilla.org/projects/firefox"
|
||||
#source=(http://releases.mozilla.org/pub/mozilla.org/firefox/releases/${pkgver}/source/firefox-${pkgver}.source.tar.bz2
|
||||
#patch http://www.rosenauer.org/hg/mozilla/
|
||||
#patch https://build.opensuse.org/package/show?package=MozillaFirefox&project=mozilla%3AFactory
|
||||
source=(ftp://ftp.mozilla.org/pub/mozilla.org/firefox/releases/${pkgver}/source/firefox-${pkgver}.source.tar.bz2
|
||||
mozconfig
|
||||
firefox.desktop
|
||||
firefox-install-dir.patch
|
||||
vendor.js
|
||||
kde.js
|
||||
firefox-kde.patch
|
||||
mozilla-nongnome-proxies.patch
|
||||
mozilla-kde.patch
|
||||
mozilla-gstreamer-760140.patch
|
||||
firefox-712763.patch
|
||||
duckduckgo.xml
|
||||
)
|
||||
md5sums=('b822ff4b2348410587dec563235d9320'
|
||||
'55864e6a1b7f165efe272472217934d3'
|
||||
'af37777ea15a693e837a5be36e0de3ca'
|
||||
'150ac0fb3ac7b2114c8e8851a9e0516c'
|
||||
'b1b1ad060b411a4abee7dcc63927aa02'
|
||||
'75df0f88cc7a7fa7d522459e4ff82cc5'
|
||||
'194da028eba1fbc316cf37dd586c4112'
|
||||
'79f113b56057e17ca2466cd0ac578bb3'
|
||||
'8e833c5abff5ddd3d20bc81eb9bfc028'
|
||||
'9f4e6467284a5c82fbba0c0afe862f31'
|
||||
'7303a96e92e600a46dd6a2cf9af5ada5'
|
||||
'f6e2a6759b8711b445dbc9d35cbd275f')
|
||||
|
||||
|
||||
build() {
|
||||
cd "mozilla-release"
|
||||
patch -Np1 -i "../firefox-install-dir.patch"
|
||||
|
||||
# modify the patch to make it work in bundle
|
||||
cp ../mozilla-kde.patch ../mozilla-kde-mod.patch
|
||||
sed -i 's|\(\+\#define KMOZILLAHELPER "\)/usr/lib/mozilla/kmozillahelper\("\)|\1kmozillahelper\2|' ../mozilla-kde-mod.patch
|
||||
sed -i 's|\(\+ \)execv\(( KMOZILLAHELPER, args )\)|\1execvp\2|' ../mozilla-kde-mod.patch
|
||||
|
||||
# remove the new file, to make life easier with call makepkg multiple times
|
||||
rm -f content/media/gstreamer/nsGStreamerFormatHelper.cpp \
|
||||
content/media/gstreamer/GStreamerFormatHelper.cpp \
|
||||
content/media/gstreamer/nsGStreamerFormatHelper.h \
|
||||
content/media/gstreamer/GStreamerFormatHelper.h
|
||||
rm -f browser/components/shell/src/nsKDEShellService.cpp \
|
||||
browser/components/shell/src/nsKDEShellService.h \
|
||||
browser/components/shell/src/nsUnixShellService.cpp \
|
||||
browser/components/shell/src/nsUnixShellService.h \
|
||||
browser/base/content/browser-kde.xul
|
||||
rm -f toolkit/xre/nsKDEUtils.cpp \
|
||||
toolkit/xre/nsKDEUtils.h \
|
||||
uriloader/exthandler/unix/nsCommonRegistry.cpp \
|
||||
uriloader/exthandler/unix/nsCommonRegistry.h \
|
||||
uriloader/exthandler/unix/nsKDERegistry.cpp \
|
||||
uriloader/exthandler/unix/nsKDERegistry.h \
|
||||
toolkit/content/widgets/dialog-kde.xml \
|
||||
toolkit/content/widgets/preferences-kde.xml
|
||||
|
||||
msg "apply mozilla-gstreamer-760140.patch"
|
||||
patch -Np1 -i "../mozilla-gstreamer-760140.patch" || return 1
|
||||
msg "apply firefox-712763.patch"
|
||||
patch -Np1 -i "../firefox-712763.patch" || return 1
|
||||
msg "apply mozilla-nongnome-proxies.patch"
|
||||
patch -Np1 -i "../mozilla-nongnome-proxies.patch" || return 1
|
||||
msg "apply mozilla-kde.patch"
|
||||
patch -Np1 -i "../mozilla-kde-mod.patch" || return 1
|
||||
msg "apply firefox-kde.patch"
|
||||
patch -Np1 -i "../firefox-kde.patch" || return 1
|
||||
|
||||
cp "../mozconfig" .mozconfig
|
||||
|
||||
# Fix PRE_RELEASE_SUFFIX
|
||||
sed -i '/^PRE_RELEASE_SUFFIX := ""/s/ ""//' \
|
||||
browser/base/Makefile.in
|
||||
|
||||
export LDFLAGS="$LDFLAGS"
|
||||
export PYTHON="/usr/bin/python2"
|
||||
|
||||
make -j1 -f client.mk build MOZ_MAKE_FLAGS="${MAKEFLAGS}"
|
||||
|
||||
}
|
||||
|
||||
package() {
|
||||
cd mozilla-release
|
||||
make -j1 -f client.mk MOZ_PKG_FATAL_WARNINGS=0 package
|
||||
mkdir -p $pkgdir/opt
|
||||
tar -C $pkgdir/opt -xf obj-ff/dist/firefox-$pkgver.en-US.linux-${CARCH}.tar.bz2
|
||||
|
||||
install -Dm644 ../vendor.js "$pkgdir/opt/firefox/defaults/preferences/vendor.js"
|
||||
install -Dm644 ../kde.js "$pkgdir/opt/firefox/defaults/preferences/kde.js"
|
||||
install -Dm644 ../duckduckgo.xml "$pkgdir/opt/firefox/searchplugins/duckduckgo.xml"
|
||||
|
||||
# Use system-provided dictionaries
|
||||
rm -rf "$pkgdir"/opt/firefox/{dictionaries,hyphenation}
|
||||
ln -s /usr/share/hunspell "$pkgdir/opt/firefox/dictionaries"
|
||||
ln -s /usr/share/hyphen "$pkgdir/opt/firefox/hyphenation"
|
||||
}
|
14
firefox-kde/PKGINFO
Normal file
14
firefox-kde/PKGINFO
Normal file
@ -0,0 +1,14 @@
|
||||
name=firefox
|
||||
version=20.0.1
|
||||
description=The Mozilla Web-Browser
|
||||
icon=firefox.png
|
||||
desktop=firefox.desktop
|
||||
screenshot=http://www.ghacks.net/wp-content/uploads/2008/11/firefox_default_header1-500x338.jpg
|
||||
url=http://www.mozilla.com
|
||||
type=Launcher
|
||||
config=external
|
||||
pkgz=flashplugin kmozillahelper firefox alsa-lib glib2 atk cairo dbus-core dbus-glib expat fontconfig freetype2 gcc-libs gdk-pixbuf2 gstreamer0.10 gstreamer0.10-base gtk2 libffi libice libpng libsm libx11 libxau libxcb libxcomposite libxcursor libxdamage libxdmcp libxext libxfixes libxi libxinerama libxml2 libxrandr libxrender libxt orc pango pixman startup-notification xcb-util zlib pcre yasm firefox-i18n
|
||||
build=alsa-lib atk cairo dbus-core dbus-glib glib2 expat fontconfig freetype2 gcc-libs gdk-pixbuf2 gstreamer0.10 gstreamer0.10-base gtk2 libffi libice libpng libsm libx11 libxau libxcb libxcomposite libxcursor libxdamage libxdmcp libxext libxfixes libxi libxinerama libxml2 libxrandr libxrender libxt orc pango pixman startup-notification xcb-util zlib python2 wireless_tools autoconf2.13 mesa pcre yasm flashplugin kmozillahelper firefox-i18n @firefox
|
||||
env==LD_LIBRARY_PATH=$ORIGIN/lib:$ORIGIN/usr/lib:$ORIGIN/usr/lib/gtk-2.0,,,MOZ_PLUGIN_PATH=$ORIGIN/usr/lib/mozilla/plugins,,,PATH=$ORIGIN/usr/lib/mozilla/:$PATH,,,_BUNDLE_FIREFOX_DESKTOP=firefox-20.0.1-1-x86_64.desktop
|
||||
binary=/opt/firefox/firefox /opt/firefox/libxul.so
|
||||
exec=/firefox_launcher.sh
|
10
firefox-kde/duckduckgo.xml
Normal file
10
firefox-kde/duckduckgo.xml
Normal file
@ -0,0 +1,10 @@
|
||||
<SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/" xmlns:os="http://a9.com/-/spec/opensearch/1.1/">
|
||||
<os:ShortName>DuckDuckGo</os:ShortName>
|
||||
<os:Description>DuckDuckGo</os:Description>
|
||||
<os:InputEncoding>UTF-8</os:InputEncoding>
|
||||
<os:Image width="16" height="16"></os:Image>
|
||||
<os:Url type="text/html" method="GET" template="http://duckduckgo.com/">
|
||||
<Param name="t" value="chakra"/>
|
||||
<Param name="q" value="{searchTerms}"/>
|
||||
</os:Url>
|
||||
</SearchPlugin>
|
95
firefox-kde/firefox-712763.patch
Normal file
95
firefox-kde/firefox-712763.patch
Normal file
@ -0,0 +1,95 @@
|
||||
# HG changeset patch
|
||||
# User Tim Taubert <ttaubert@mozilla.com>
|
||||
# Date 1358185823 -3600
|
||||
# Node ID f7a2af238d06c17d10c49c94ef860434d5b76758
|
||||
Bug 712763 - Backout changes from bug 669272 to keep original window order when restoring a session
|
||||
|
||||
diff --git a/browser/components/sessionstore/src/SessionStore.jsm b/browser/components/sessionstore/src/SessionStore.jsm
|
||||
--- a/browser/components/sessionstore/src/SessionStore.jsm
|
||||
+++ b/browser/components/sessionstore/src/SessionStore.jsm
|
||||
@@ -1757,23 +1757,16 @@ let SessionStoreInternal = {
|
||||
|
||||
// We want to re-use the last opened window instead of opening a new one in
|
||||
// the case where it's "empty" and not associated with a window in the session.
|
||||
// We will do more processing via _prepWindowToRestoreInto if we need to use
|
||||
// the lastWindow.
|
||||
let lastWindow = this._getMostRecentBrowserWindow();
|
||||
let canUseLastWindow = lastWindow &&
|
||||
!lastWindow.__SS_lastSessionWindowID;
|
||||
- let lastSessionFocusedWindow = null;
|
||||
- this.windowToFocus = lastWindow;
|
||||
-
|
||||
- // move the last focused window to the start of the array so that we
|
||||
- // minimize window movement (see bug 669272)
|
||||
- lastSessionState.windows.unshift(
|
||||
- lastSessionState.windows.splice(lastSessionState.selectedWindow - 1, 1)[0]);
|
||||
|
||||
// Restore into windows or open new ones as needed.
|
||||
for (let i = 0; i < lastSessionState.windows.length; i++) {
|
||||
let winState = lastSessionState.windows[i];
|
||||
let lastSessionWindowID = winState.__lastSessionWindowID;
|
||||
// delete lastSessionWindowID so we don't add that to the window again
|
||||
delete winState.__lastSessionWindowID;
|
||||
|
||||
@@ -1801,28 +1794,19 @@ let SessionStoreInternal = {
|
||||
// Restore into that window - pretend it's a followup since we'll already
|
||||
// have a focused window.
|
||||
//XXXzpao This is going to merge extData together (taking what was in
|
||||
// winState over what is in the window already. The hack we have
|
||||
// in _preWindowToRestoreInto will prevent most (all?) Panorama
|
||||
// weirdness but we will still merge other extData.
|
||||
// Bug 588217 should make this go away by merging the group data.
|
||||
this.restoreWindow(windowToUse, { windows: [winState] }, canOverwriteTabs, true);
|
||||
- if (i == 0)
|
||||
- lastSessionFocusedWindow = windowToUse;
|
||||
-
|
||||
- // if we overwrote the tabs for our last focused window, we should
|
||||
- // give focus to the window that had it in the previous session
|
||||
- if (canOverwriteTabs && windowToUse == lastWindow)
|
||||
- this.windowToFocus = lastSessionFocusedWindow;
|
||||
}
|
||||
else {
|
||||
- let win = this._openWindowWithState({ windows: [winState] });
|
||||
- if (i == 0)
|
||||
- lastSessionFocusedWindow = win;
|
||||
+ this._openWindowWithState({ windows: [winState] });
|
||||
}
|
||||
}
|
||||
|
||||
// Merge closed windows from this session with ones from last session
|
||||
if (lastSessionState._closedWindows) {
|
||||
this._closedWindows = this._closedWindows.concat(lastSessionState._closedWindows);
|
||||
this._capClosedWindows();
|
||||
}
|
||||
@@ -2735,27 +2719,27 @@ let SessionStoreInternal = {
|
||||
this._setWindowStateBusy(aWindow);
|
||||
|
||||
if (root._closedWindows)
|
||||
this._closedWindows = root._closedWindows;
|
||||
|
||||
var winData;
|
||||
if (!root.selectedWindow || root.selectedWindow > root.windows.length) {
|
||||
root.selectedWindow = 0;
|
||||
- } else {
|
||||
- // put the selected window at the beginning of the array to ensure that
|
||||
- // it gets restored first
|
||||
- root.windows.unshift(root.windows.splice(root.selectedWindow - 1, 1)[0]);
|
||||
}
|
||||
+
|
||||
// open new windows for all further window entries of a multi-window session
|
||||
// (unless they don't contain any tab data)
|
||||
for (var w = 1; w < root.windows.length; w++) {
|
||||
winData = root.windows[w];
|
||||
if (winData && winData.tabs && winData.tabs[0]) {
|
||||
var window = this._openWindowWithState({ windows: [winData] });
|
||||
+ if (w == root.selectedWindow - 1) {
|
||||
+ this.windowToFocus = window;
|
||||
+ }
|
||||
}
|
||||
}
|
||||
winData = root.windows[0];
|
||||
if (!winData.tabs) {
|
||||
winData.tabs = [];
|
||||
}
|
||||
// don't restore a single blank tab when we've had an external
|
||||
// URL passed in for loading at startup (cf. bug 357419)
|
30
firefox-kde/firefox-install-dir.patch
Normal file
30
firefox-kde/firefox-install-dir.patch
Normal file
@ -0,0 +1,30 @@
|
||||
diff -Nur mozilla-release.orig/config/baseconfig.mk mozilla-release/config/baseconfig.mk
|
||||
--- mozilla-release.orig/config/baseconfig.mk 2012-10-09 07:34:41.762092280 +0000
|
||||
+++ mozilla-release/config/baseconfig.mk 2012-10-09 07:40:53.052771576 +0000
|
||||
@@ -1,9 +1,9 @@
|
||||
INCLUDED_AUTOCONF_MK = 1
|
||||
|
||||
-includedir := $(includedir)/$(MOZ_APP_NAME)-$(MOZ_APP_VERSION)
|
||||
-idldir = $(datadir)/idl/$(MOZ_APP_NAME)-$(MOZ_APP_VERSION)
|
||||
-installdir = $(libdir)/$(MOZ_APP_NAME)-$(MOZ_APP_VERSION)
|
||||
-sdkdir = $(libdir)/$(MOZ_APP_NAME)-devel-$(MOZ_APP_VERSION)
|
||||
+includedir := $(includedir)/$(MOZ_APP_NAME)
|
||||
+idldir = $(datadir)/idl/$(MOZ_APP_NAME)
|
||||
+installdir = $(libdir)/$(MOZ_APP_NAME)
|
||||
+sdkdir = $(libdir)/$(MOZ_APP_NAME)-devel
|
||||
DIST = $(DEPTH)/dist
|
||||
|
||||
# We do magic with OBJ_SUFFIX in config.mk, the following ensures we don't
|
||||
diff -Nur mozilla-release.orig/js/src/config/baseconfig.mk mozilla-release/js/src/config/baseconfig.mk
|
||||
--- mozilla-release.orig/js/src/config/baseconfig.mk 2012-10-09 07:34:58.411973276 +0000
|
||||
+++ mozilla-release/js/src/config/baseconfig.mk 2012-10-09 07:39:55.143186168 +0000
|
||||
@@ -1,7 +1,7 @@
|
||||
INCLUDED_AUTOCONF_MK = 1
|
||||
|
||||
-installdir = $(libdir)/$(MOZ_APP_NAME)-$(MOZ_APP_VERSION)
|
||||
-sdkdir = $(libdir)/$(MOZ_APP_NAME)-devel-$(MOZ_APP_VERSION)
|
||||
+installdir = $(libdir)/$(MOZ_APP_NAME)
|
||||
+sdkdir = $(libdir)/$(MOZ_APP_NAME)-devel
|
||||
|
||||
ifneq (,$(filter /%,$(TOP_DIST)))
|
||||
DIST = $(TOP_DIST)
|
1818
firefox-kde/firefox-kde.patch
Normal file
1818
firefox-kde/firefox-kde.patch
Normal file
File diff suppressed because it is too large
Load Diff
84
firefox-kde/firefox.desktop
Executable file
84
firefox-kde/firefox.desktop
Executable file
@ -0,0 +1,84 @@
|
||||
#!/usr/bin/env xdg-open
|
||||
[Desktop Entry]
|
||||
Name=Firefox
|
||||
Name[bn]=ফায়ারফক্স
|
||||
Name[eo]=Fajrovulpo
|
||||
Name[fi]=Firefox
|
||||
Name[pa]=ਫਾਇਰਫੋਕਸ
|
||||
Name[tg]=Рӯбоҳи оташин
|
||||
GenericName=Web Browser
|
||||
GenericName[af]=Web Blaaier
|
||||
GenericName[ar]=متصفح ويب
|
||||
GenericName[az]=Veb Səyyahı
|
||||
GenericName[bg]=Браузър
|
||||
GenericName[bn]=ওয়েব ব্রাউজার
|
||||
GenericName[br]=Furcher ar Gwiad
|
||||
GenericName[bs]=WWW Preglednik
|
||||
GenericName[ca]=Fullejador web
|
||||
GenericName[cs]=WWW prohlížeč
|
||||
GenericName[cy]=Porydd Gwe
|
||||
GenericName[da]=Browser
|
||||
GenericName[de]=Web-Browser
|
||||
GenericName[el]=Περιηγητής Ιστού
|
||||
GenericName[eo]=TTT-legilo
|
||||
GenericName[es]=Navegador web
|
||||
GenericName[et]=Veebilehitseja
|
||||
GenericName[eu]=Web arakatzailea
|
||||
GenericName[fa]=مرورگر وب
|
||||
GenericName[fi]=WWW-selain
|
||||
GenericName[fo]=Alnótsfar
|
||||
GenericName[fr]=Navigateur web
|
||||
GenericName[gl]=Navegador Web
|
||||
GenericName[he]=דפדפן אינטרנט
|
||||
GenericName[hi]=वेब ब्राउज़र
|
||||
GenericName[hr]=Web preglednik
|
||||
GenericName[hu]=Webböngésző
|
||||
GenericName[is]=Vafri
|
||||
GenericName[it]=Browser Web
|
||||
GenericName[ja]=ウェブブラウザ
|
||||
GenericName[ko]=웹 브라우저
|
||||
GenericName[lo]=ເວັບບຣາວເຊີ
|
||||
GenericName[lt]=Žiniatinklio naršyklė
|
||||
GenericName[lv]=Web Pārlūks
|
||||
GenericName[mk]=Прелистувач на Интернет
|
||||
GenericName[mn]=Веб-Хөтөч
|
||||
GenericName[nb]=Nettleser
|
||||
GenericName[nds]=Nettkieker
|
||||
GenericName[nl]=Webbrowser
|
||||
GenericName[nn]=Nettlesar
|
||||
GenericName[nso]=Seinyakisi sa Web
|
||||
GenericName[pa]=ਵੈਬ ਝਲਕਾਰਾ
|
||||
GenericName[pl]=Przeglądarka WWW
|
||||
GenericName[pt]=Navegador Web
|
||||
GenericName[pt_BR]=Navegador Web
|
||||
GenericName[ro]=Navigator de web
|
||||
GenericName[ru]=Веб-браузер
|
||||
GenericName[se]=Fierpmádatlogan
|
||||
GenericName[sk]=Webový prehliadač
|
||||
GenericName[sl]=Spletni brskalnik
|
||||
GenericName[sr]=Веб претраживач
|
||||
GenericName[sr@Latn]=Veb pretraživač
|
||||
GenericName[ss]=Ibrawuza yeWeb
|
||||
GenericName[sv]=Webbläsare
|
||||
GenericName[ta]=வலை உலாவி
|
||||
GenericName[tg]=Тафсиргари вэб
|
||||
GenericName[th]=เว็บบราวเซอร์
|
||||
GenericName[tr]=Web Tarayıcı
|
||||
GenericName[uk]=Навігатор Тенет
|
||||
GenericName[uz]=Веб-браузер
|
||||
GenericName[ven]=Buronza ya Webu
|
||||
GenericName[vi]=Trình duyệt Web
|
||||
GenericName[wa]=Betchteu waibe
|
||||
GenericName[xh]=Umkhangeli zincwadi we Web
|
||||
GenericName[zh_CN]=网页浏览器
|
||||
GenericName[zh_TW]=網頁瀏覽器
|
||||
GenericName[zu]=Umcingi we-Web
|
||||
Exec=firefox %u
|
||||
Icon=firefox.png
|
||||
Terminal=false
|
||||
Type=Application
|
||||
MimeType=text/html;text/xml;application/xhtml+xml;application/vnd.mozilla.xul+xml;text/mml;x-scheme-handler/http;x-scheme-handler/https;
|
||||
StartupNotify=false
|
||||
Categories=Network;WebBrowser;
|
||||
Comment=Firefox web-browser bundle, including all language packs and flash plugin
|
||||
|
12
firefox-kde/firefox.install
Normal file
12
firefox-kde/firefox.install
Normal file
@ -0,0 +1,12 @@
|
||||
post_install() {
|
||||
update-desktop-database -q
|
||||
}
|
||||
|
||||
post_upgrade() {
|
||||
post_install $1
|
||||
}
|
||||
|
||||
post_remove() {
|
||||
update-desktop-database -q
|
||||
}
|
||||
|
BIN
firefox-kde/firefox.png
Normal file
BIN
firefox-kde/firefox.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.0 KiB |
8
firefox-kde/firefox_launcher.sh
Executable file
8
firefox-kde/firefox_launcher.sh
Executable file
@ -0,0 +1,8 @@
|
||||
#!/bin/sh
|
||||
|
||||
export GTK_PATH=${PWD}/usr/lib/gtk-2.0/
|
||||
|
||||
${PWD}/usr/bin/gtk-query-immodules-2.0 > /tmp/firefox.gtk.immodules
|
||||
export GTK_IM_MODULE_FILE=/tmp/firefox.gtk.immodules
|
||||
|
||||
exec ${PWD}/opt/firefox/firefox "$@"
|
1
firefox-kde/kde.js
Normal file
1
firefox-kde/kde.js
Normal file
@ -0,0 +1 @@
|
||||
pref("browser.preferences.instantApply", false);
|
42
firefox-kde/mozconfig
Normal file
42
firefox-kde/mozconfig
Normal file
@ -0,0 +1,42 @@
|
||||
. $topsrcdir/browser/config/mozconfig
|
||||
|
||||
# System libraries
|
||||
ac_add_options --without-system-nspr
|
||||
ac_add_options --without-system-nss
|
||||
ac_add_options --without-system-jpeg
|
||||
ac_add_options --without-system-zlib
|
||||
ac_add_options --without-system-bz2
|
||||
ac_add_options --without-system-png
|
||||
ac_add_options --without-system-libevent
|
||||
ac_add_options --without-system-libvpx
|
||||
#ac_add_options --enable-system-hunspell
|
||||
#ac_add_options --enable-system-sqlite
|
||||
#ac_add_options --enable-system-ffi
|
||||
#ac_add_options --enable-system-pixman
|
||||
ac_add_options --enable-gstreamer
|
||||
ac_add_options --disable-libproxy
|
||||
ac_add_options --with-pthreads
|
||||
|
||||
# Features
|
||||
ac_add_options --enable-official-branding
|
||||
ac_add_options --enable-safe-browsing
|
||||
ac_add_options --enable-startup-notification
|
||||
|
||||
ac_add_options --disable-gio
|
||||
ac_add_options --disable-gconf
|
||||
ac_add_options --disable-gnomevfs
|
||||
ac_add_options --disable-crashreporter
|
||||
ac_add_options --disable-updater
|
||||
ac_add_options --disable-tests
|
||||
ac_add_options --disable-mochitest
|
||||
ac_add_options --disable-installer
|
||||
|
||||
# Optimization
|
||||
ac_add_options --enable-optimize
|
||||
|
||||
mk_add_options MOZ_OBJDIR=@TOPSRCDIR@/obj-ff
|
||||
|
||||
export BUILD_OFFICIAL=1
|
||||
export MOZILLA_OFFICIAL=1
|
||||
mk_add_options BUILD_OFFICIAL=1
|
||||
mk_add_options MOZILLA_OFFICIAL=1
|
542
firefox-kde/mozilla-gstreamer-760140.patch
Normal file
542
firefox-kde/mozilla-gstreamer-760140.patch
Normal file
@ -0,0 +1,542 @@
|
||||
# HG changeset patch
|
||||
# Parent 9fe99f8a584f2369a88bfb5281fd6bc95eb2593c
|
||||
Bug 760140 - Query the GstRegistry for the required demuxers/decoders from canPlayType
|
||||
|
||||
|
||||
diff --git a/content/media/DecoderTraits.cpp b/content/media/DecoderTraits.cpp
|
||||
--- a/content/media/DecoderTraits.cpp
|
||||
+++ b/content/media/DecoderTraits.cpp
|
||||
@@ -7,16 +7,18 @@
|
||||
#include "DecoderTraits.h"
|
||||
#include "MediaDecoder.h"
|
||||
#include "nsCharSeparatedTokenizer.h"
|
||||
#ifdef MOZ_MEDIA_PLUGINS
|
||||
#include "MediaPluginHost.h"
|
||||
#endif
|
||||
#ifdef MOZ_GSTREAMER
|
||||
#include "mozilla/Preferences.h"
|
||||
+#include "GStreamerDecoder.h"
|
||||
+#include "nsXPCOMStrings.h"
|
||||
#endif
|
||||
#ifdef MOZ_WMF
|
||||
#include "WMFDecoder.h"
|
||||
#endif
|
||||
|
||||
namespace mozilla
|
||||
{
|
||||
|
||||
@@ -137,48 +139,35 @@
|
||||
return false;
|
||||
}
|
||||
|
||||
return CodecListContains(gWebMTypes, aType);
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_GSTREAMER
|
||||
-static const char* const gH264Types[4] = {
|
||||
- "video/mp4",
|
||||
- "video/3gpp",
|
||||
- "video/quicktime",
|
||||
- nullptr
|
||||
-};
|
||||
-
|
||||
bool
|
||||
DecoderTraits::IsGStreamerSupportedType(const nsACString& aMimeType)
|
||||
{
|
||||
if (!MediaDecoder::IsGStreamerEnabled())
|
||||
return false;
|
||||
- if (IsH264Type(aMimeType))
|
||||
+ if (GStreamerDecoder::CanHandleMediaType(aMimeType, nullptr))
|
||||
return true;
|
||||
if (!Preferences::GetBool("media.prefer-gstreamer", false))
|
||||
return false;
|
||||
#ifdef MOZ_WEBM
|
||||
if (IsWebMType(aMimeType))
|
||||
return true;
|
||||
#endif
|
||||
#ifdef MOZ_OGG
|
||||
if (IsOggType(aMimeType))
|
||||
return true;
|
||||
#endif
|
||||
return false;
|
||||
}
|
||||
-
|
||||
-bool
|
||||
-DecoderTraits::IsH264Type(const nsACString& aType)
|
||||
-{
|
||||
- return CodecListContains(gH264Types, aType);
|
||||
-}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WIDGET_GONK
|
||||
static const char* const gOmxTypes[6] = {
|
||||
"audio/mpeg",
|
||||
"audio/mp4",
|
||||
"video/mp4",
|
||||
"video/3gpp",
|
||||
@@ -190,19 +179,17 @@
|
||||
DecoderTraits::IsOmxSupportedType(const nsACString& aType)
|
||||
{
|
||||
if (!MediaDecoder::IsOmxEnabled()) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return CodecListContains(gOmxTypes, aType);
|
||||
}
|
||||
-#endif
|
||||
|
||||
-#if defined(MOZ_GSTREAMER) || defined(MOZ_WIDGET_GONK)
|
||||
static char const *const gH264Codecs[9] = {
|
||||
"avc1.42E01E", // H.264 Constrained Baseline Profile Level 3.0
|
||||
"avc1.42001E", // H.264 Baseline Profile Level 3.0
|
||||
"avc1.58A01E", // H.264 Extended Profile Level 3.0
|
||||
"avc1.4D401E", // H.264 Main Profile Level 3.0
|
||||
"avc1.64001E", // H.264 High Profile Level 3.0
|
||||
"avc1.64001F", // H.264 High Profile Level 3.1
|
||||
"mp4v.20.3", // 3GPP
|
||||
@@ -303,19 +290,19 @@
|
||||
#ifdef MOZ_DASH
|
||||
if (IsDASHMPDType(nsDependentCString(aMIMEType))) {
|
||||
// DASH manifest uses WebM codecs only.
|
||||
codecList = gWebMCodecs;
|
||||
result = CANPLAY_YES;
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_GSTREAMER
|
||||
- if (IsH264Type(nsDependentCString(aMIMEType))) {
|
||||
- codecList = gH264Codecs;
|
||||
- result = CANPLAY_MAYBE;
|
||||
+ if (GStreamerDecoder::CanHandleMediaType(nsDependentCString(aMIMEType),
|
||||
+ aHaveRequestedCodecs ? &aRequestedCodecs : nullptr)) {
|
||||
+ return CANPLAY_YES;
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_WIDGET_GONK
|
||||
if (IsOmxSupportedType(nsDependentCString(aMIMEType))) {
|
||||
codecList = gH264Codecs;
|
||||
result = CANPLAY_MAYBE;
|
||||
}
|
||||
#endif
|
||||
@@ -324,17 +311,17 @@
|
||||
result = CANPLAY_MAYBE;
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_MEDIA_PLUGINS
|
||||
if (MediaDecoder::IsMediaPluginsEnabled() &&
|
||||
GetMediaPluginHost()->FindDecoder(nsDependentCString(aMIMEType), &codecList))
|
||||
result = CANPLAY_MAYBE;
|
||||
#endif
|
||||
- if (result == CANPLAY_NO || !aHaveRequestedCodecs) {
|
||||
+ if (result == CANPLAY_NO || !aHaveRequestedCodecs || !codecList) {
|
||||
return result;
|
||||
}
|
||||
|
||||
// See http://www.rfc-editor.org/rfc/rfc4281.txt for the description
|
||||
// of the 'codecs' parameter
|
||||
nsCharSeparatedTokenizer tokenizer(aRequestedCodecs, ',');
|
||||
bool expectMoreTokens = false;
|
||||
while (tokenizer.hasMoreTokens()) {
|
||||
diff --git a/content/media/DecoderTraits.h b/content/media/DecoderTraits.h
|
||||
--- a/content/media/DecoderTraits.h
|
||||
+++ b/content/media/DecoderTraits.h
|
||||
@@ -49,17 +49,16 @@
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WEBM
|
||||
static bool IsWebMType(const nsACString& aType);
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_GSTREAMER
|
||||
static bool IsGStreamerSupportedType(const nsACString& aType);
|
||||
- static bool IsH264Type(const nsACString& aType);
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WIDGET_GONK
|
||||
static bool IsOmxSupportedType(const nsACString& aType);
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_MEDIA_PLUGINS
|
||||
static bool IsMediaPluginsType(const nsACString& aType);
|
||||
diff --git a/content/media/gstreamer/GStreamerDecoder.cpp b/content/media/gstreamer/GStreamerDecoder.cpp
|
||||
--- a/content/media/gstreamer/GStreamerDecoder.cpp
|
||||
+++ b/content/media/gstreamer/GStreamerDecoder.cpp
|
||||
@@ -2,18 +2,26 @@
|
||||
/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
#include "MediaDecoderStateMachine.h"
|
||||
#include "GStreamerReader.h"
|
||||
#include "GStreamerDecoder.h"
|
||||
+#include "GStreamerFormatHelper.h"
|
||||
|
||||
namespace mozilla {
|
||||
|
||||
MediaDecoderStateMachine* GStreamerDecoder::CreateStateMachine()
|
||||
{
|
||||
return new MediaDecoderStateMachine(this, new GStreamerReader(this));
|
||||
}
|
||||
|
||||
+bool
|
||||
+GStreamerDecoder::CanHandleMediaType(const nsACString& aMIMEType,
|
||||
+ const nsAString* aCodecs)
|
||||
+{
|
||||
+ return GStreamerFormatHelper::Instance()->CanHandleMediaType(aMIMEType, aCodecs);
|
||||
+}
|
||||
+
|
||||
} // namespace mozilla
|
||||
|
||||
diff --git a/content/media/gstreamer/GStreamerDecoder.h b/content/media/gstreamer/GStreamerDecoder.h
|
||||
--- a/content/media/gstreamer/GStreamerDecoder.h
|
||||
+++ b/content/media/gstreamer/GStreamerDecoder.h
|
||||
@@ -3,21 +3,23 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
#if !defined(GStreamerDecoder_h_)
|
||||
#define GStreamerDecoder_h_
|
||||
|
||||
#include "MediaDecoder.h"
|
||||
+#include "nsXPCOMStrings.h"
|
||||
|
||||
namespace mozilla {
|
||||
|
||||
class GStreamerDecoder : public MediaDecoder
|
||||
{
|
||||
public:
|
||||
virtual MediaDecoder* Clone() { return new GStreamerDecoder(); }
|
||||
virtual MediaDecoderStateMachine* CreateStateMachine();
|
||||
+ static bool CanHandleMediaType(const nsACString& aMIMEType, const nsAString* aCodecs);
|
||||
};
|
||||
|
||||
} // namespace mozilla
|
||||
|
||||
#endif
|
||||
diff --git a/content/media/gstreamer/GStreamerFormatHelper.cpp b/content/media/gstreamer/GStreamerFormatHelper.cpp
|
||||
new file mode 100644
|
||||
--- /dev/null
|
||||
+++ b/content/media/gstreamer/GStreamerFormatHelper.cpp
|
||||
@@ -0,0 +1,159 @@
|
||||
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
||||
+/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
||||
+/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
+ * License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||
+ * You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
+
|
||||
+#include "GStreamerFormatHelper.h"
|
||||
+#include "nsCharSeparatedTokenizer.h"
|
||||
+#include "nsXPCOMStrings.h"
|
||||
+
|
||||
+#define ENTRY_FORMAT(entry) entry[0]
|
||||
+#define ENTRY_CAPS(entry) entry[1]
|
||||
+
|
||||
+GStreamerFormatHelper* GStreamerFormatHelper::gInstance = nullptr;
|
||||
+
|
||||
+GStreamerFormatHelper* GStreamerFormatHelper::Instance() {
|
||||
+ if (!gInstance) {
|
||||
+ gst_init(nullptr, nullptr);
|
||||
+ gInstance = new GStreamerFormatHelper();
|
||||
+ }
|
||||
+
|
||||
+ return gInstance;
|
||||
+}
|
||||
+
|
||||
+void GStreamerFormatHelper::Shutdown() {
|
||||
+ if (gInstance) {
|
||||
+ delete gInstance;
|
||||
+ gInstance = nullptr;
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+char const *const GStreamerFormatHelper::mContainers[4][2] = {
|
||||
+ {"video/mp4", "video/quicktime"},
|
||||
+ {"video/quicktime", "video/quicktime"},
|
||||
+ {"audio/mp4", "audio/mpeg, mpegversion=(int)4"},
|
||||
+ {"audio/mpeg", "audio/mpeg, mpegversion=(int)1"},
|
||||
+};
|
||||
+
|
||||
+char const *const GStreamerFormatHelper::mCodecs[8][2] = {
|
||||
+ {"avc1.42E01E", "video/x-h264"},
|
||||
+ {"avc1.42001E", "video/x-h264"},
|
||||
+ {"avc1.58A01E", "video/x-h264"},
|
||||
+ {"avc1.4D401E", "video/x-h264"},
|
||||
+ {"avc1.64001E", "video/x-h264"},
|
||||
+ {"avc1.64001F", "video/x-h264"},
|
||||
+ {"mp4v.20.3", "video/3gpp"},
|
||||
+ {"mp4a.40.2", "audio/mpeg, mpegversion=(int)4"},
|
||||
+};
|
||||
+
|
||||
+GStreamerFormatHelper::GStreamerFormatHelper()
|
||||
+ : mFactories(nullptr),
|
||||
+ mCookie(static_cast<uint32_t>(-1))
|
||||
+{
|
||||
+}
|
||||
+
|
||||
+GStreamerFormatHelper::~GStreamerFormatHelper() {
|
||||
+ if (mFactories)
|
||||
+ g_list_free(mFactories);
|
||||
+}
|
||||
+
|
||||
+bool GStreamerFormatHelper::CanHandleMediaType(const nsACString& aMIMEType,
|
||||
+ const nsAString* aCodecs) {
|
||||
+ const char *type;
|
||||
+ NS_CStringGetData(aMIMEType, &type, NULL);
|
||||
+
|
||||
+ GstCaps* caps = ConvertFormatsToCaps(type, aCodecs);
|
||||
+ if (!caps) {
|
||||
+ return false;
|
||||
+ }
|
||||
+
|
||||
+ bool ret = HaveElementsToProcessCaps(caps);
|
||||
+ gst_caps_unref(caps);
|
||||
+
|
||||
+ return ret;
|
||||
+}
|
||||
+
|
||||
+GstCaps* GStreamerFormatHelper::ConvertFormatsToCaps(const char* aMIMEType,
|
||||
+ const nsAString* aCodecs) {
|
||||
+ unsigned int i;
|
||||
+
|
||||
+ /* convert aMIMEType to gst container caps */
|
||||
+ const char* capsString = nullptr;
|
||||
+ for (i = 0; i < G_N_ELEMENTS(mContainers); i++) {
|
||||
+ if (!strcmp(ENTRY_FORMAT(mContainers[i]), aMIMEType)) {
|
||||
+ capsString = ENTRY_CAPS(mContainers[i]);
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ if (!capsString) {
|
||||
+ /* we couldn't find any matching caps */
|
||||
+ return nullptr;
|
||||
+ }
|
||||
+
|
||||
+ GstCaps* caps = gst_caps_from_string(capsString);
|
||||
+ /* container only */
|
||||
+ if (!aCodecs) {
|
||||
+ return caps;
|
||||
+ }
|
||||
+
|
||||
+ nsCharSeparatedTokenizer tokenizer(*aCodecs, ',');
|
||||
+ while (tokenizer.hasMoreTokens()) {
|
||||
+ const nsSubstring& codec = tokenizer.nextToken();
|
||||
+ capsString = nullptr;
|
||||
+
|
||||
+ for (i = 0; i < G_N_ELEMENTS(mCodecs); i++) {
|
||||
+ if (codec.EqualsASCII(ENTRY_FORMAT(mCodecs[i]))) {
|
||||
+ capsString = ENTRY_CAPS(mCodecs[i]);
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ if (!capsString) {
|
||||
+ gst_caps_unref(caps);
|
||||
+ return nullptr;
|
||||
+ }
|
||||
+
|
||||
+ GstCaps* tmp = gst_caps_from_string(capsString);
|
||||
+ /* appends and frees tmp */
|
||||
+ gst_caps_append(caps, tmp);
|
||||
+ }
|
||||
+
|
||||
+ return caps;
|
||||
+}
|
||||
+
|
||||
+bool GStreamerFormatHelper::HaveElementsToProcessCaps(GstCaps* aCaps) {
|
||||
+
|
||||
+ GList* factories = GetFactories();
|
||||
+
|
||||
+ GList* list;
|
||||
+ /* here aCaps contains [containerCaps, [codecCaps1, [codecCaps2, ...]]] so process
|
||||
+ * caps structures individually as we want one element for _each_
|
||||
+ * structure */
|
||||
+ for (unsigned int i = 0; i < gst_caps_get_size(aCaps); i++) {
|
||||
+ GstStructure* s = gst_caps_get_structure(aCaps, i);
|
||||
+ GstCaps* caps = gst_caps_new_full(gst_structure_copy(s), nullptr);
|
||||
+ list = gst_element_factory_list_filter (factories, caps, GST_PAD_SINK, FALSE);
|
||||
+ gst_caps_unref(caps);
|
||||
+ if (!list) {
|
||||
+ return false;
|
||||
+ }
|
||||
+ g_list_free(list);
|
||||
+ }
|
||||
+
|
||||
+ return true;
|
||||
+}
|
||||
+
|
||||
+GList* GStreamerFormatHelper::GetFactories() {
|
||||
+ uint32_t cookie = gst_default_registry_get_feature_list_cookie ();
|
||||
+ if (cookie != mCookie) {
|
||||
+ g_list_free(mFactories);
|
||||
+ mFactories = gst_element_factory_list_get_elements
|
||||
+ (GST_ELEMENT_FACTORY_TYPE_DEMUXER | GST_ELEMENT_FACTORY_TYPE_DECODER,
|
||||
+ GST_RANK_MARGINAL);
|
||||
+ mCookie = cookie;
|
||||
+ }
|
||||
+
|
||||
+ return mFactories;
|
||||
+}
|
||||
diff --git a/content/media/gstreamer/GStreamerFormatHelper.h b/content/media/gstreamer/GStreamerFormatHelper.h
|
||||
new file mode 100644
|
||||
--- /dev/null
|
||||
+++ b/content/media/gstreamer/GStreamerFormatHelper.h
|
||||
@@ -0,0 +1,60 @@
|
||||
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
||||
+/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
||||
+/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
+ * License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||
+ * You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
+
|
||||
+#if !defined(GStreamerFormatHelper_h_)
|
||||
+#define GStreamerFormatHelper_h_
|
||||
+
|
||||
+#include <gst/gst.h>
|
||||
+#include <mozilla/Types.h>
|
||||
+#include "nsXPCOMStrings.h"
|
||||
+
|
||||
+class GStreamerFormatHelper {
|
||||
+ /* This class can be used to query the GStreamer registry for the required
|
||||
+ * demuxers/decoders from nsHTMLMediaElement::CanPlayType.
|
||||
+ * It implements looking at the GstRegistry to check if elements to
|
||||
+ * demux/decode the formats passed to CanPlayType() are actually installed.
|
||||
+ */
|
||||
+ public:
|
||||
+ static GStreamerFormatHelper* Instance();
|
||||
+ ~GStreamerFormatHelper();
|
||||
+
|
||||
+ bool CanHandleMediaType(const nsACString& aMIMEType,
|
||||
+ const nsAString* aCodecs);
|
||||
+
|
||||
+ static void Shutdown();
|
||||
+
|
||||
+ private:
|
||||
+ GStreamerFormatHelper();
|
||||
+ GstCaps* ConvertFormatsToCaps(const char* aMIMEType,
|
||||
+ const nsAString* aCodecs);
|
||||
+ char* const *CodecListFromCaps(GstCaps* aCaps);
|
||||
+ bool HaveElementsToProcessCaps(GstCaps* aCaps);
|
||||
+ GList* GetFactories();
|
||||
+
|
||||
+ static GStreamerFormatHelper* gInstance;
|
||||
+
|
||||
+ /* table to convert from container MIME types to GStreamer elements */
|
||||
+ static char const *const mContainers[4][2];
|
||||
+
|
||||
+ /* table to convert from codec MIME types to GStreamer elements */
|
||||
+ static char const *const mCodecs[8][2];
|
||||
+
|
||||
+ /* list of GStreamer element factories
|
||||
+ * Element factories are the basic types retrieved from the GStreamer
|
||||
+ * registry, they describe all plugins and elements that GStreamer can
|
||||
+ * create.
|
||||
+ * This means that element factories are useful for automated element
|
||||
+ * instancing, such as what autopluggers do,
|
||||
+ * and for creating lists of available elements. */
|
||||
+ GList* mFactories;
|
||||
+
|
||||
+ /* Storage for the default registrys feature list cookie.
|
||||
+ * It changes every time a feature is added to or removed from the
|
||||
+ * GStreamer registry. */
|
||||
+ uint32_t mCookie;
|
||||
+};
|
||||
+
|
||||
+#endif
|
||||
diff --git a/content/media/gstreamer/Makefile.in b/content/media/gstreamer/Makefile.in
|
||||
--- a/content/media/gstreamer/Makefile.in
|
||||
+++ b/content/media/gstreamer/Makefile.in
|
||||
@@ -13,21 +13,23 @@
|
||||
MODULE = content
|
||||
LIBRARY_NAME = gkcongstreamer_s
|
||||
LIBXUL_LIBRARY = 1
|
||||
|
||||
|
||||
EXPORTS += \
|
||||
GStreamerDecoder.h \
|
||||
GStreamerReader.h \
|
||||
+ GStreamerFormatHelper.h \
|
||||
$(NULL)
|
||||
|
||||
CPPSRCS = \
|
||||
GStreamerReader.cpp \
|
||||
GStreamerDecoder.cpp \
|
||||
+ GStreamerFormatHelper.cpp \
|
||||
$(NULL)
|
||||
|
||||
FORCE_STATIC_LIB = 1
|
||||
|
||||
include $(topsrcdir)/config/rules.mk
|
||||
|
||||
CFLAGS += $(GSTREAMER_CFLAGS)
|
||||
CXXFLAGS += $(GSTREAMER_CFLAGS)
|
||||
diff --git a/layout/build/Makefile.in b/layout/build/Makefile.in
|
||||
--- a/layout/build/Makefile.in
|
||||
+++ b/layout/build/Makefile.in
|
||||
@@ -316,16 +316,20 @@
|
||||
-I$(topsrcdir)/js/xpconnect/loader \
|
||||
-I$(topsrcdir)/caps/include \
|
||||
-I$(topsrcdir)/netwerk/base/src \
|
||||
-I$(topsrcdir)/content/svg/content/src \
|
||||
-I$(topsrcdir)/extensions/cookie \
|
||||
-I$(topsrcdir)/netwerk/cookie \
|
||||
$(NULL)
|
||||
|
||||
+ifdef MOZ_GSTREAMER
|
||||
+LOCAL_INCLUDES += $(GSTREAMER_CFLAGS)
|
||||
+endif
|
||||
+
|
||||
ifdef MOZ_B2G_RIL #{
|
||||
LOCAL_INCLUDES += -I$(topsrcdir)/dom/system/gonk
|
||||
endif #}
|
||||
|
||||
ifdef MOZ_B2G_FM #{
|
||||
LOCAL_INCLUDES += -I$(topsrcdir)/dom/fm
|
||||
endif #}
|
||||
|
||||
diff --git a/layout/build/nsLayoutStatics.cpp b/layout/build/nsLayoutStatics.cpp
|
||||
--- a/layout/build/nsLayoutStatics.cpp
|
||||
+++ b/layout/build/nsLayoutStatics.cpp
|
||||
@@ -78,16 +78,20 @@
|
||||
#ifdef MOZ_MEDIA_PLUGINS
|
||||
#include "MediaPluginHost.h"
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WMF
|
||||
#include "WMFDecoder.h"
|
||||
#endif
|
||||
|
||||
+#ifdef MOZ_GSTREAMER
|
||||
+#include "GStreamerFormatHelper.h"
|
||||
+#endif
|
||||
+
|
||||
#ifdef MOZ_SYDNEYAUDIO
|
||||
#include "AudioStream.h"
|
||||
#endif
|
||||
|
||||
#include "nsError.h"
|
||||
|
||||
#include "nsCycleCollector.h"
|
||||
#include "nsJSEnvironment.h"
|
||||
@@ -336,16 +340,20 @@
|
||||
nsXBLService::Shutdown();
|
||||
nsAutoCopyListener::Shutdown();
|
||||
FrameLayerBuilder::Shutdown();
|
||||
|
||||
#ifdef MOZ_MEDIA_PLUGINS
|
||||
MediaPluginHost::Shutdown();
|
||||
#endif
|
||||
|
||||
+#ifdef MOZ_GSTREAMER
|
||||
+ GStreamerFormatHelper::Shutdown();
|
||||
+#endif
|
||||
+
|
||||
#ifdef MOZ_SYDNEYAUDIO
|
||||
AudioStream::ShutdownLibrary();
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WMF
|
||||
WMFDecoder::UnloadDLLs();
|
||||
#endif
|
||||
|
293
firefox-kde/mozilla-gstreamer-803287.patch
Normal file
293
firefox-kde/mozilla-gstreamer-803287.patch
Normal file
@ -0,0 +1,293 @@
|
||||
# HG changeset patch
|
||||
# Parent 09328afa274e7cf6354f446ae37735218b796e7f
|
||||
# User Wolfgang Rosenauer <wr@rosenauer.org>
|
||||
Bug 803287 - Don't use GStreamer (when enabled) for Ogg/WebM if builtin backends present. (TM: 19)
|
||||
|
||||
diff --git a/content/base/src/nsContentUtils.cpp b/content/base/src/nsContentUtils.cpp
|
||||
--- a/content/base/src/nsContentUtils.cpp
|
||||
+++ b/content/base/src/nsContentUtils.cpp
|
||||
@@ -6676,71 +6676,55 @@ nsContentUtils::FindInternalContentViewe
|
||||
else
|
||||
*aLoaderType = TYPE_UNKNOWN;
|
||||
}
|
||||
return docFactory.forget();
|
||||
}
|
||||
|
||||
#ifdef MOZ_MEDIA
|
||||
#ifdef MOZ_OGG
|
||||
- if (nsHTMLMediaElement::IsOggEnabled()) {
|
||||
- for (unsigned int i = 0; i < ArrayLength(nsHTMLMediaElement::gOggTypes); ++i) {
|
||||
- const char* type = nsHTMLMediaElement::gOggTypes[i];
|
||||
- if (!strcmp(aType, type)) {
|
||||
- docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
- if (docFactory && aLoaderType) {
|
||||
- *aLoaderType = TYPE_CONTENT;
|
||||
- }
|
||||
- return docFactory.forget();
|
||||
- }
|
||||
+ if (nsHTMLMediaElement::IsOggType(nsDependentCString(aType))) {
|
||||
+ docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
+ if (docFactory && aLoaderType) {
|
||||
+ *aLoaderType = TYPE_CONTENT;
|
||||
}
|
||||
+ return docFactory.forget();
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WEBM
|
||||
- if (nsHTMLMediaElement::IsWebMEnabled()) {
|
||||
- for (unsigned int i = 0; i < ArrayLength(nsHTMLMediaElement::gWebMTypes); ++i) {
|
||||
- const char* type = nsHTMLMediaElement::gWebMTypes[i];
|
||||
- if (!strcmp(aType, type)) {
|
||||
- docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
- if (docFactory && aLoaderType) {
|
||||
- *aLoaderType = TYPE_CONTENT;
|
||||
- }
|
||||
- return docFactory.forget();
|
||||
- }
|
||||
+ if (nsHTMLMediaElement::IsWebMType(nsDependentCString(aType))) {
|
||||
+ docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
+ if (docFactory && aLoaderType) {
|
||||
+ *aLoaderType = TYPE_CONTENT;
|
||||
}
|
||||
+ return docFactory.forget();
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_GSTREAMER
|
||||
- if (nsHTMLMediaElement::IsH264Enabled()) {
|
||||
- for (unsigned int i = 0; i < ArrayLength(nsHTMLMediaElement::gH264Types); ++i) {
|
||||
- const char* type = nsHTMLMediaElement::gH264Types[i];
|
||||
- if (!strcmp(aType, type)) {
|
||||
- docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
- if (docFactory && aLoaderType) {
|
||||
- *aLoaderType = TYPE_CONTENT;
|
||||
- }
|
||||
- return docFactory.forget();
|
||||
- }
|
||||
+ if (nsHTMLMediaElement::IsGStreamerSupportedType(nsDependentCString(aType))) {
|
||||
+ docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
+ if (docFactory && aLoaderType) {
|
||||
+ *aLoaderType = TYPE_CONTENT;
|
||||
}
|
||||
+ return docFactory.forget();
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_MEDIA_PLUGINS
|
||||
if (nsHTMLMediaElement::IsMediaPluginsEnabled() &&
|
||||
nsHTMLMediaElement::IsMediaPluginsType(nsDependentCString(aType))) {
|
||||
docFactory = do_GetService("@mozilla.org/content/document-loader-factory;1");
|
||||
if (docFactory && aLoaderType) {
|
||||
*aLoaderType = TYPE_CONTENT;
|
||||
}
|
||||
return docFactory.forget();
|
||||
}
|
||||
#endif // MOZ_MEDIA_PLUGINS
|
||||
-
|
||||
#endif // MOZ_MEDIA
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// static
|
||||
bool
|
||||
nsContentUtils::IsPatternMatching(nsAString& aValue, nsAString& aPattern,
|
||||
diff --git a/content/html/content/public/nsHTMLMediaElement.h b/content/html/content/public/nsHTMLMediaElement.h
|
||||
--- a/content/html/content/public/nsHTMLMediaElement.h
|
||||
+++ b/content/html/content/public/nsHTMLMediaElement.h
|
||||
@@ -303,17 +303,18 @@ public:
|
||||
#ifdef MOZ_WEBM
|
||||
static bool IsWebMEnabled();
|
||||
static bool IsWebMType(const nsACString& aType);
|
||||
static const char gWebMTypes[2][11];
|
||||
static char const *const gWebMCodecs[4];
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_GSTREAMER
|
||||
- static bool IsH264Enabled();
|
||||
+ static bool IsGStreamerEnabled();
|
||||
+ static bool IsGStreamerSupportedType(const nsACString& aType);
|
||||
static bool IsH264Type(const nsACString& aType);
|
||||
static const char gH264Types[3][16];
|
||||
static char const *const gH264Codecs[7];
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WIDGET_GONK
|
||||
static bool IsOmxEnabled();
|
||||
static bool IsOmxSupportedType(const nsACString& aType);
|
||||
diff --git a/content/html/content/src/nsHTMLMediaElement.cpp b/content/html/content/src/nsHTMLMediaElement.cpp
|
||||
--- a/content/html/content/src/nsHTMLMediaElement.cpp
|
||||
+++ b/content/html/content/src/nsHTMLMediaElement.cpp
|
||||
@@ -2148,34 +2148,29 @@ char const *const nsHTMLMediaElement::gH
|
||||
#ifdef MOZ_GSTREAMER
|
||||
const char nsHTMLMediaElement::gH264Types[3][16] = {
|
||||
"video/mp4",
|
||||
"video/3gpp",
|
||||
"video/quicktime",
|
||||
};
|
||||
|
||||
bool
|
||||
-nsHTMLMediaElement::IsH264Enabled()
|
||||
+nsHTMLMediaElement::IsGStreamerEnabled()
|
||||
{
|
||||
- return Preferences::GetBool("media.h264.enabled");
|
||||
+ return Preferences::GetBool("media.gstreamer.enabled");
|
||||
}
|
||||
|
||||
bool
|
||||
nsHTMLMediaElement::IsH264Type(const nsACString& aType)
|
||||
{
|
||||
- if (!IsH264Enabled()) {
|
||||
- return false;
|
||||
- }
|
||||
-
|
||||
for (uint32_t i = 0; i < ArrayLength(gH264Types); ++i) {
|
||||
if (aType.EqualsASCII(gH264Types[i])) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
-
|
||||
return false;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_WIDGET_GONK
|
||||
const char nsHTMLMediaElement::gOmxTypes[5][16] = {
|
||||
"audio/mpeg",
|
||||
"audio/mp4",
|
||||
@@ -2424,34 +2419,63 @@ nsHTMLMediaElement::CanPlayType(const ns
|
||||
default:
|
||||
case CANPLAY_MAYBE:
|
||||
aResult.AssignLiteral("maybe");
|
||||
break;
|
||||
}
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
+#ifdef MOZ_GSTREAMER
|
||||
+bool
|
||||
+nsHTMLMediaElement::IsGStreamerSupportedType(const nsACString& aMimeType)
|
||||
+{
|
||||
+ if (!IsGStreamerEnabled())
|
||||
+ return false;
|
||||
+ if (IsH264Type(aMimeType))
|
||||
+ return true;
|
||||
+ if (!Preferences::GetBool("media.prefer-gstreamer", false))
|
||||
+ return false;
|
||||
+#ifdef MOZ_WEBM
|
||||
+ if (IsWebMType(aMimeType))
|
||||
+ return true;
|
||||
+#endif
|
||||
+#ifdef MOZ_OGG
|
||||
+ if (IsOggType(aMimeType))
|
||||
+ return true;
|
||||
+#endif
|
||||
+ return false;
|
||||
+}
|
||||
+#endif
|
||||
+
|
||||
already_AddRefed<nsMediaDecoder>
|
||||
nsHTMLMediaElement::CreateDecoder(const nsACString& aType)
|
||||
{
|
||||
+#ifdef MOZ_GSTREAMER
|
||||
+ // When enabled, use GStreamer for H.264, but not for codecs handled by our
|
||||
+ // bundled decoders, unless the "media.prefer-gstreamer" pref is set.
|
||||
+ if (IsGStreamerSupportedType(aType)) {
|
||||
+ nsRefPtr<nsGStreamerDecoder> decoder = new nsGStreamerDecoder();
|
||||
+ if (decoder->Init(this)) {
|
||||
+ return decoder.forget();
|
||||
+ }
|
||||
+ }
|
||||
+#endif
|
||||
+
|
||||
#ifdef MOZ_RAW
|
||||
if (IsRawType(aType)) {
|
||||
nsRefPtr<nsRawDecoder> decoder = new nsRawDecoder();
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_OGG
|
||||
if (IsOggType(aType)) {
|
||||
-#ifdef MOZ_GSTREAMER
|
||||
- nsRefPtr<nsGStreamerDecoder> decoder = new nsGStreamerDecoder();
|
||||
-#else
|
||||
nsRefPtr<nsOggDecoder> decoder = new nsOggDecoder();
|
||||
-#endif
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_WAVE
|
||||
if (IsWaveType(aType)) {
|
||||
nsRefPtr<nsWaveDecoder> decoder = new nsWaveDecoder();
|
||||
@@ -2473,44 +2497,32 @@ nsHTMLMediaElement::CreateDecoder(const
|
||||
nsRefPtr<nsMediaPluginDecoder> decoder = new nsMediaPluginDecoder(aType);
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_WEBM
|
||||
if (IsWebMType(aType)) {
|
||||
-#ifdef MOZ_GSTREAMER
|
||||
- nsRefPtr<nsGStreamerDecoder> decoder = new nsGStreamerDecoder();
|
||||
-#else
|
||||
nsRefPtr<nsWebMDecoder> decoder = new nsWebMDecoder();
|
||||
-#endif
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_DASH
|
||||
if (IsDASHMPDType(aType)) {
|
||||
nsRefPtr<nsDASHDecoder> decoder = new nsDASHDecoder();
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
-#ifdef MOZ_GSTREAMER
|
||||
- if (IsH264Type(aType)) {
|
||||
- nsRefPtr<nsGStreamerDecoder> decoder = new nsGStreamerDecoder();
|
||||
- if (decoder->Init(this)) {
|
||||
- return decoder.forget();
|
||||
- }
|
||||
- }
|
||||
-#endif
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
nsresult nsHTMLMediaElement::InitializeDecoderAsClone(nsMediaDecoder* aOriginal)
|
||||
{
|
||||
NS_ASSERTION(mLoadingSrc, "mLoadingSrc must already be set");
|
||||
NS_ASSERTION(mDecoder == nullptr, "Shouldn't have a decoder");
|
||||
|
||||
diff --git a/modules/libpref/src/init/all.js b/modules/libpref/src/init/all.js
|
||||
--- a/modules/libpref/src/init/all.js
|
||||
+++ b/modules/libpref/src/init/all.js
|
||||
@@ -164,17 +164,17 @@ pref("media.wave.enabled", true);
|
||||
#endif
|
||||
#ifdef MOZ_WEBM
|
||||
pref("media.webm.enabled", true);
|
||||
#endif
|
||||
#ifdef MOZ_DASH
|
||||
pref("media.dash.enabled", true);
|
||||
#endif
|
||||
#ifdef MOZ_GSTREAMER
|
||||
-pref("media.h264.enabled", true);
|
||||
+pref("media.gstreamer.enabled", true);
|
||||
#endif
|
||||
#ifdef MOZ_WEBRTC
|
||||
pref("media.navigator.enabled", false);
|
||||
pref("media.peerconnection.enabled", false);
|
||||
pref("media.navigator.permission.disabled", false);
|
||||
#else
|
||||
#ifdef ANDROID
|
||||
pref("media.navigator.enabled", true);
|
52
firefox-kde/mozilla-gstreamer.patch
Normal file
52
firefox-kde/mozilla-gstreamer.patch
Normal file
@ -0,0 +1,52 @@
|
||||
# HG changeset patch
|
||||
# Parent e4b87e710b1a5f0bb7db058911bc163b4bf30227
|
||||
# User Wolfgang Rosenauer <wr@rosenauer.org>
|
||||
No Bug - use GStreamer _only_ for MP4 (not WebM/OGG)
|
||||
|
||||
diff --git a/content/html/content/src/nsHTMLMediaElement.cpp b/content/html/content/src/nsHTMLMediaElement.cpp
|
||||
--- a/content/html/content/src/nsHTMLMediaElement.cpp
|
||||
+++ b/content/html/content/src/nsHTMLMediaElement.cpp
|
||||
@@ -2277,21 +2277,17 @@ nsHTMLMediaElement::CreateDecoder(const
|
||||
nsRefPtr<nsRawDecoder> decoder = new nsRawDecoder();
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_OGG
|
||||
if (IsOggType(aType)) {
|
||||
-#ifdef MOZ_GSTREAMER
|
||||
- nsRefPtr<nsGStreamerDecoder> decoder = new nsGStreamerDecoder();
|
||||
-#else
|
||||
nsRefPtr<nsOggDecoder> decoder = new nsOggDecoder();
|
||||
-#endif
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_WAVE
|
||||
if (IsWaveType(aType)) {
|
||||
nsRefPtr<nsWaveDecoder> decoder = new nsWaveDecoder();
|
||||
@@ -2305,21 +2301,17 @@ nsHTMLMediaElement::CreateDecoder(const
|
||||
nsRefPtr<nsMediaPluginDecoder> decoder = new nsMediaPluginDecoder(aType);
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef MOZ_WEBM
|
||||
if (IsWebMType(aType)) {
|
||||
-#ifdef MOZ_GSTREAMER
|
||||
- nsRefPtr<nsGStreamerDecoder> decoder = new nsGStreamerDecoder();
|
||||
-#else
|
||||
nsRefPtr<nsWebMDecoder> decoder = new nsWebMDecoder();
|
||||
-#endif
|
||||
if (decoder->Init(this)) {
|
||||
return decoder.forget();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MOZ_GSTREAMER
|
||||
if (IsH264Type(aType)) {
|
3675
firefox-kde/mozilla-kde.patch
Normal file
3675
firefox-kde/mozilla-kde.patch
Normal file
File diff suppressed because it is too large
Load Diff
46
firefox-kde/mozilla-nongnome-proxies.patch
Normal file
46
firefox-kde/mozilla-nongnome-proxies.patch
Normal file
@ -0,0 +1,46 @@
|
||||
From: Wolfgang Rosenauer
|
||||
Subject: Do not use gconf for proxy settings if not running within Gnome
|
||||
|
||||
Index: toolkit/system/unixproxy/nsUnixSystemProxySettings.cpp
|
||||
===================================================================
|
||||
RCS file: /cvsroot/mozilla/toolkit/system/unixproxy/nsUnixSystemProxySettings.cpp,v
|
||||
retrieving revision 1.1
|
||||
|
||||
diff --git a/toolkit/system/unixproxy/nsUnixSystemProxySettings.cpp b/toolkit/system/unixproxy/nsUnixSystemProxySettings.cpp
|
||||
--- a/toolkit/system/unixproxy/nsUnixSystemProxySettings.cpp
|
||||
+++ b/toolkit/system/unixproxy/nsUnixSystemProxySettings.cpp
|
||||
@@ -50,22 +50,28 @@ nsUnixSystemProxySettings::GetMainThread
|
||||
// dbus prevents us from being threadsafe, but this routine should not block anyhow
|
||||
*aMainThreadOnly = true;
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
nsresult
|
||||
nsUnixSystemProxySettings::Init()
|
||||
{
|
||||
- mSchemeProxySettings.Init(5);
|
||||
- mGConf = do_GetService(NS_GCONFSERVICE_CONTRACTID);
|
||||
- mGSettings = do_GetService(NS_GSETTINGSSERVICE_CONTRACTID);
|
||||
- if (mGSettings) {
|
||||
- mGSettings->GetCollectionForSchema(NS_LITERAL_CSTRING("org.gnome.system.proxy"),
|
||||
- getter_AddRefs(mProxySettings));
|
||||
+ // If this is a GNOME session, load gconf and try to use its preferences.
|
||||
+ // If gconf is not available (which would be stupid) we'll proceed as if
|
||||
+ // this was not a GNOME session, using *_PROXY environment variables.
|
||||
+ const char* sessionType = PR_GetEnv("DESKTOP_SESSION");
|
||||
+ if (sessionType && !strcmp(sessionType, "gnome")) {
|
||||
+ mSchemeProxySettings.Init(5);
|
||||
+ mGConf = do_GetService(NS_GCONFSERVICE_CONTRACTID);
|
||||
+ mGSettings = do_GetService(NS_GSETTINGSSERVICE_CONTRACTID);
|
||||
+ if (mGSettings) {
|
||||
+ mGSettings->GetCollectionForSchema(NS_LITERAL_CSTRING("org.gnome.system.proxy"),
|
||||
+ getter_AddRefs(mProxySettings));
|
||||
+ }
|
||||
}
|
||||
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
bool
|
||||
nsUnixSystemProxySettings::IsProxyMode(const char* aMode)
|
||||
{
|
40
firefox-kde/package
Normal file
40
firefox-kde/package
Normal file
@ -0,0 +1,40 @@
|
||||
alsa-lib
|
||||
atk
|
||||
cairo
|
||||
dbus-core
|
||||
dbus-glib
|
||||
expat
|
||||
fontconfig
|
||||
freetype2
|
||||
gcc-libs
|
||||
gdk-pixbuf2
|
||||
glib2
|
||||
gstreamer0.10
|
||||
gstreamer0.10-base
|
||||
gtk2
|
||||
libffi
|
||||
libice
|
||||
libpng
|
||||
libsm
|
||||
libx11
|
||||
libxau
|
||||
libxcb
|
||||
libxcomposite
|
||||
libxcursor
|
||||
libxdamage
|
||||
libxdmcp
|
||||
libxext
|
||||
libxfixes
|
||||
libxi
|
||||
libxinerama
|
||||
libxml2
|
||||
libxrandr
|
||||
libxrender
|
||||
libxt
|
||||
orc
|
||||
pango
|
||||
pixman
|
||||
startup-notification
|
||||
util-linux
|
||||
xcb-util
|
||||
zlib
|
10
firefox-kde/vendor.js
Normal file
10
firefox-kde/vendor.js
Normal file
@ -0,0 +1,10 @@
|
||||
// Use LANG environment variable to choose locale
|
||||
pref("intl.locale.matchOS", true);
|
||||
|
||||
// Disable default browser checking.
|
||||
pref("browser.shell.checkDefaultBrowser", true);
|
||||
pref("browser.search.defaultenginename", "DuckDuckGo");
|
||||
|
||||
// Don't disable our bundled extensions in the application directory
|
||||
pref("extensions.autoDisableScopes", 11);
|
||||
pref("extensions.shownSelectionUI", true);
|
Loading…
Reference in New Issue
Block a user