From 241f21aba6e91d59c4ca86fb78d848b91b38e716 Mon Sep 17 00:00:00 2001 From: Diego Elio Pettenò Date: Fri, 9 Feb 2007 04:47:59 +0000 Subject: Add a patch to (optionally) use xcb instead of libX11 for xine's output, requiring the 1.1.4-r1 patched xine, with xcb useflag enabled. Please note that although this experimental ebuild has xcb as optional, next 0.8.4 release will only support XCB (unless upstream changes idea). (Portage version: 2.1.2-r9) --- media-video/kaffeine/ChangeLog | 11 +- .../kaffeine/files/digest-kaffeine-0.8.3-r1 | 3 + .../kaffeine/files/kaffeine-0.8.3-xcb.patch | 249 +++++++++++++++++++++ media-video/kaffeine/kaffeine-0.8.3-r1.ebuild | 69 ++++++ 4 files changed, 331 insertions(+), 1 deletion(-) create mode 100644 media-video/kaffeine/files/digest-kaffeine-0.8.3-r1 create mode 100644 media-video/kaffeine/files/kaffeine-0.8.3-xcb.patch create mode 100644 media-video/kaffeine/kaffeine-0.8.3-r1.ebuild (limited to 'media-video/kaffeine') diff --git a/media-video/kaffeine/ChangeLog b/media-video/kaffeine/ChangeLog index 8671eea69ee4..62e9db6f4c85 100644 --- a/media-video/kaffeine/ChangeLog +++ b/media-video/kaffeine/ChangeLog @@ -1,6 +1,15 @@ # ChangeLog for media-video/kaffeine # Copyright 2000-2007 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-video/kaffeine/ChangeLog,v 1.68 2007/02/08 17:28:04 opfer Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/kaffeine/ChangeLog,v 1.69 2007/02/09 04:47:59 flameeyes Exp $ + +*kaffeine-0.8.3-r1 (09 Feb 2007) + + 09 Feb 2007; Diego Pettenò + +files/kaffeine-0.8.3-xcb.patch, +kaffeine-0.8.3-r1.ebuild: + Add a patch to (optionally) use xcb instead of libX11 for xine's output, + requiring the 1.1.4-r1 patched xine, with xcb useflag enabled. Please note + that although this experimental ebuild has xcb as optional, next 0.8.4 + release will only support XCB (unless upstream changes idea). 08 Feb 2007; Christian Faulhammer kaffeine-0.8.3.ebuild: diff --git a/media-video/kaffeine/files/digest-kaffeine-0.8.3-r1 b/media-video/kaffeine/files/digest-kaffeine-0.8.3-r1 new file mode 100644 index 000000000000..04b39d433e2b --- /dev/null +++ b/media-video/kaffeine/files/digest-kaffeine-0.8.3-r1 @@ -0,0 +1,3 @@ +MD5 667dd56cf02f1343b3a466a685afdf24 kaffeine-0.8.3.tar.bz2 2940941 +RMD160 f22a971481e8fd1a96063fef66d156d119c1e596 kaffeine-0.8.3.tar.bz2 2940941 +SHA256 42719f4eab6a27a06ec247369424f5a9d796fca74672573c467d024983a861b2 kaffeine-0.8.3.tar.bz2 2940941 diff --git a/media-video/kaffeine/files/kaffeine-0.8.3-xcb.patch b/media-video/kaffeine/files/kaffeine-0.8.3-xcb.patch new file mode 100644 index 000000000000..babe90baa2dc --- /dev/null +++ b/media-video/kaffeine/files/kaffeine-0.8.3-xcb.patch @@ -0,0 +1,249 @@ +Index: kaffeine-0.8.3/kaffeine/src/main.cpp +=================================================================== +--- kaffeine-0.8.3.orig/kaffeine/src/main.cpp ++++ kaffeine-0.8.3/kaffeine/src/main.cpp +@@ -30,8 +30,6 @@ + #include "kaffeine.h" + #include "version.h" + +-#include +- + class KaffeineApp : public KUniqueApplication + { + public: +@@ -91,23 +89,6 @@ int main(int argc, char *argv[]) + if (!KaffeineApp::start()) + return 0; + +- /* +- * XInitThreads() should the first call to xlib in multithreaded X programs - +- * but because of a bug in some xfree versions that can freeze at startup, +- * we also call XInitThreads() in kxinewidget.cpp +- * +- * kaffeinepart & konqueror: We call XInitThreads() in kxinewidget.cpp, so the part is +- * not stable with buggy X implementations. +- * +- * FIXME: deadline for this workaround is 2007-03-16 --pfister +- */ +- +-#ifndef XINIT_WKRND /* configure flag --with-xinit-workaround not set */ +- flush(kdDebug() << "if kaffeine hangs here run 'configure --with-xinit-workaround' and recompile / reinstall ..."); +- XInitThreads(); +- kdDebug() << " ok\n"; +-#endif +- + KaffeineApp a; + return a.exec(); + } +Index: kaffeine-0.8.3/kaffeine/src/player-parts/xine-part/kxinewidget.cpp +=================================================================== +--- kaffeine-0.8.3.orig/kaffeine/src/player-parts/xine-part/kxinewidget.cpp ++++ kaffeine-0.8.3/kaffeine/src/player-parts/xine-part/kxinewidget.cpp +@@ -38,10 +38,6 @@ + + #include "kxinewidget.h" + +-#ifdef HAVE_XINERAMA +-#include +-#endif +- + #ifndef USE_QT_ONLY + #include "kxinewidget.moc" + #include +@@ -68,7 +64,7 @@ KXineWidget::KXineWidget(QWidget* parent + bool startManual, bool verbose) + : QWidget(parent,name), m_startXineManual(startManual), m_xineReady(false), + m_logoFile(pathToLogoFile), m_preferedAudio(audioDriver), m_preferedVideo(videoDriver), m_xineVerbose(verbose), +- m_xineEngine(NULL), m_audioDriver(NULL), m_videoDriver(NULL), m_xineStream(NULL), m_xineDisplay(NULL), ++ m_xineEngine(NULL), m_audioDriver(NULL), m_videoDriver(NULL), m_xineStream(NULL), connection(NULL), + m_eventQueue(NULL), m_osd(NULL), m_osdUnscaled(false), m_osdShow(false), m_osdSize(0), m_osdFont(NULL), + m_audioChoices(NULL), m_audioInfo(NULL), m_videoChoices(NULL), m_videoInfo(NULL), m_mixerInfo(NULL), + m_osdShowInfo(NULL), +@@ -239,12 +235,12 @@ KXineWidget::~KXineWidget() + delete [] m_audioChoices; + } + +- if (m_xineDisplay) ++ if (connection) + { + debugOut("Close xine display"); +- XCloseDisplay(m_xineDisplay); /* close xine display */ ++ xcb_disconnect(connection); /* close xine display */ + } +- m_xineDisplay = NULL; ++ connection = NULL; + + debugOut("xine closed"); + } +@@ -831,7 +827,7 @@ void KXineWidget::videoDriverChangedCall + xine_close_video_driver(vw->m_xineEngine, oldVideoDriver); + + vw->m_videoDriver = xine_open_video_driver(vw->m_xineEngine, +- entry->enum_values[entry->num_value], XINE_VISUAL_TYPE_X11, ++ entry->enum_values[entry->num_value], XINE_VISUAL_TYPE_XCB, + (void *) &(vw->m_x11Visual)); + + if (!vw->m_videoDriver) +@@ -840,7 +836,7 @@ void KXineWidget::videoDriverChangedCall + QApplication::postEvent(vw, new QTimerEvent( TIMER_EVENT_NEW_XINE_ERROR)); + playing = false; + vw->m_videoDriver = xine_open_video_driver(vw->m_xineEngine, +- vw->m_videoDriverName.ascii(), XINE_VISUAL_TYPE_X11, ++ vw->m_videoDriverName.ascii(), XINE_VISUAL_TYPE_XCB, + (void *) &(vw->m_x11Visual)); + } + else +@@ -1012,14 +1008,18 @@ void KXineWidget::fontForOSDMessagesChan + * EVENT LOOP + *********************************************/ + +-bool KXineWidget::x11Event(XEvent *event) ++void KXineWidget::paintEvent(QPaintEvent *event) + { +- if (isXineReady()) +- if (event->type == Expose) +- if (event->xexpose.count == 0) +- xine_port_send_gui_data(m_videoDriver, XINE_GUI_SEND_EXPOSE_EVENT, event); ++ if (isXineReady()) { ++ xcb_expose_event_t xcb_event; ++ memset(&xcb_event, 0, sizeof(xcb_event)); + +- return false; ++ xcb_event.count = 0; ++ ++ xine_port_send_gui_data(m_videoDriver, XINE_GUI_SEND_EXPOSE_EVENT, &xcb_event); ++ } ++ ++ QWidget::paintEvent(event); + } + + /********************************************************** +@@ -1044,39 +1044,17 @@ bool KXineWidget::initXine() + + /**** INIT XINE DISPLAY ****/ + +- XInitThreads(); +- +- m_xineDisplay = XOpenDisplay( getenv("DISPLAY") ); ++ connection = xcb_connect(NULL, NULL); + +- if (!m_xineDisplay) ++ if (!connection) + { + emit signalXineFatal(i18n("Failed to connect to X-Server!")); + return false; + } + +- int m_xineScreen = DefaultScreen(m_xineDisplay); +- Window m_xineWindow = winId(); ++ int m_xineWindow = winId(); + +- /* determine display aspect ratio */ +- double resHor = ((double) DisplayWidth(m_xineDisplay, m_xineScreen)) / DisplayWidthMM(m_xineDisplay, m_xineScreen); +- double resVer = ((double) DisplayHeight(m_xineDisplay, m_xineScreen)) / DisplayHeightMM(m_xineDisplay, m_xineScreen); +- +- m_displayRatio = resVer / resHor; +- +-#ifdef HAVE_XINERAMA +- int dummy_event, dummy_error; +- +- if (XineramaQueryExtension(m_xineDisplay, &dummy_event, &dummy_error)) +- { +- int count = 1; +- debugOut("Xinerama extension present"); +- XineramaQueryScreens(m_xineDisplay, &count); +- debugOut(QString("%1 screens detected").arg(count)); +- if (count > 1) +- /* multihead -> assuming square pixels */ +- m_displayRatio = 1.0; +- } +-#endif ++ m_displayRatio = 1.0; + + debugOut(QString("Display aspect ratio (v/h): %1").arg(m_displayRatio)); + +@@ -1188,15 +1166,15 @@ bool KXineWidget::initXine() + /* init video driver */ + debugOut("Init video driver"); + +- m_x11Visual.display = m_xineDisplay; +- m_x11Visual.screen = m_xineScreen; +- m_x11Visual.d = m_xineWindow; ++ m_x11Visual.connection = connection; ++ m_x11Visual.screen = xcb_setup_roots_iterator(xcb_get_setup(connection)).data; ++ m_x11Visual.window = m_xineWindow; + m_x11Visual.dest_size_cb = &KXineWidget::destSizeCallback; + m_x11Visual.frame_output_cb = &KXineWidget::frameOutputCallback; + m_x11Visual.user_data = (void*)this; + + m_videoDriver = xine_open_video_driver(m_xineEngine, +- m_videoDriverName.ascii(), XINE_VISUAL_TYPE_X11, ++ m_videoDriverName.ascii(), XINE_VISUAL_TYPE_XCB, + (void *) &(m_x11Visual)); + + if (!m_videoDriver && m_videoDriverName != "auto") +@@ -1204,7 +1182,7 @@ bool KXineWidget::initXine() + emit signalXineError(i18n("Can't init Video Driver '%1' - trying 'auto'...").arg(m_videoDriverName)); + m_videoDriverName = "auto"; + m_videoDriver = xine_open_video_driver(m_xineEngine, +- m_videoDriverName.ascii(), XINE_VISUAL_TYPE_X11, ++ m_videoDriverName.ascii(), XINE_VISUAL_TYPE_XCB, + (void *) &(m_x11Visual)); + } + +Index: kaffeine-0.8.3/kaffeine/src/player-parts/xine-part/kxinewidget.h +=================================================================== +--- kaffeine-0.8.3.orig/kaffeine/src/player-parts/xine-part/kxinewidget.h ++++ kaffeine-0.8.3/kaffeine/src/player-parts/xine-part/kxinewidget.h +@@ -48,7 +48,6 @@ class QTime; + + #include + #include +-#include + #include + + #ifndef USE_QT_ONLY +@@ -57,6 +56,8 @@ class QTime; + typedef int PostFilter; /* dummy type */ + #endif + ++#include ++ + #define SUPPORTED_PROTOCOLS "file,http,mms,mmst,rtsp,rtp,tcp,pnm,cdda,vcd,vcdo,dvd,dvb,pvr,v4l,net,vdr,smb" + + #define DEFAULT_TVTIME_CONFIG "tvtime:method=LinearBlend,enabled=1,pulldown=none,framerate_mode=half_top,judder_correction=0,use_progressive_frame_flag=1,chroma_filter=0,cheap_mode=1" +@@ -308,7 +309,7 @@ protected: + void initOSD(); + + private: +- bool x11Event(XEvent *); ++ void paintEvent(QPaintEvent *); + + /********* callbacks and threads ************/ + static void destSizeCallback(void* p, int video_width, int video_height, double video_aspect, +@@ -363,10 +364,10 @@ protected: + QStringList m_videoDriverList; + + /*x11*/ +- Display* m_xineDisplay; ++ xcb_connection_t* connection; + + /*xine*/ +- x11_visual_t m_x11Visual; ++ xcb_visual_t m_x11Visual; + xine_t* m_xineEngine; + xine_audio_port_t* m_audioDriver; + xine_video_port_t* m_videoDriver; +Index: kaffeine-0.8.3/kaffeine/src/player-parts/xine-part/Makefile.am +=================================================================== +--- kaffeine-0.8.3.orig/kaffeine/src/player-parts/xine-part/Makefile.am ++++ kaffeine-0.8.3/kaffeine/src/player-parts/xine-part/Makefile.am +@@ -13,7 +13,7 @@ noinst_HEADERS = xine_part_iface.h kxin + libxinepart_la_SOURCES = xine_part.cpp kxinewidget.cpp postfilter.cpp deinterlacequality.cpp \ + videosettings.cpp filterdialog.cpp screenshotpreview.cpp xineconfig.cpp positionslider.cpp \ + equalizer.cpp xine_part_iface.skel +-libxinepart_la_LIBADD = $(LIB_XINERAMA) $(LIB_XINE) ../kaffeine-part/libkaffeinepart.la ++libxinepart_la_LIBADD = $(LIB_XINERAMA) $(LIB_XINE) ../kaffeine-part/libkaffeinepart.la -lxcb + libxinepart_la_LDFLAGS = -module $(KDE_PLUGIN) $(all_libraries) -avoid-version -no-undefined + + diff --git a/media-video/kaffeine/kaffeine-0.8.3-r1.ebuild b/media-video/kaffeine/kaffeine-0.8.3-r1.ebuild new file mode 100644 index 000000000000..0493d4e4fc2e --- /dev/null +++ b/media-video/kaffeine/kaffeine-0.8.3-r1.ebuild @@ -0,0 +1,69 @@ +# Copyright 1999-2007 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-video/kaffeine/kaffeine-0.8.3-r1.ebuild,v 1.1 2007/02/09 04:47:59 flameeyes Exp $ + +inherit eutils kde flag-o-matic + +DESCRIPTION="Media player for KDE using xine and gstreamer backends." +HOMEPAGE="http://kaffeine.sourceforge.net/" +SRC_URI="mirror://sourceforge/kaffeine/${P}.tar.bz2" +LICENSE="GPL-2" + +SLOT="0" +KEYWORDS="~amd64 ~ppc ~ppc64 ~sparc ~x86 ~x86-fbsd" +IUSE="dvb gstreamer xinerama vorbis encode kdehiddenvisibility xcb" + +RDEPEND=">=media-libs/xine-lib-1 + xcb? ( >=x11-libs/libxcb-1.0 + >=media-libs/xine-lib-1.1.4-r1 ) + gstreamer? ( =media-libs/gstreamer-0.8* + =media-libs/gst-plugins-0.8* + =media-plugins/gst-plugins-xvideo-0.8* ) + media-sound/cdparanoia + encode? ( media-sound/lame ) + vorbis? ( media-libs/libvorbis ) + x11-libs/libXtst" + +DEPEND="${RDEPEND} + dvb? ( media-tv/linuxtv-dvb-headers )" + +PATCHES="${FILESDIR}/${P}-build.patch" + +need-kde 3.5.4 + +pkg_setup() { + if use xcb && ! built_with_use --missing false media-libs/xine-lib xcb; then + eerror "To enable the xcb useflag on this package you need" + eerror "the useflag xcb enabled on media-libs/xine-lib." + eerror "Please emerge media-libs/xine-lib again with the xcb useflag" + eerror "enabled." + die "Missing xcb useflag on media-libs/xine-lib." + fi +} + +src_unpack() { + kde_src_unpack + + use xcb && epatch "${FILESDIR}/${P}-xcb.patch" +} + +src_compile() { + # see bug #143168 + replace-flags -O3 -O2 + + local myconf="${myconf} + $(use_with xinerama) + $(use_with dvb) + $(use_with gstreamer) + $(use_with vorbis oggvorbis) + $(use_with encode lame)" + + kde_src_compile +} + +src_install() { + kde_src_install + + # Remove this, as kdelibs 3.5.4 provides it + rm -f "${D}/usr/share/mimelnk/application/x-mplayer2.desktop" +} -- cgit v1.2.3-65-gdbad