diff options
author | Mike Frysinger <vapier@gentoo.org> | 2006-05-26 05:26:45 +0000 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2006-05-26 05:26:45 +0000 |
commit | 24c76abadfe2e125a1626ab6ba10b63f259a5aac (patch) | |
tree | f37122321eb770f44b841237632cb3a0d73ab349 /media-libs/libsdl | |
parent | dont bother duplicating the nobuggy-x patch (diff) | |
download | gentoo-2-24c76abadfe2e125a1626ab6ba10b63f259a5aac.tar.gz gentoo-2-24c76abadfe2e125a1626ab6ba10b63f259a5aac.tar.bz2 gentoo-2-24c76abadfe2e125a1626ab6ba10b63f259a5aac.zip |
Version bump #133754 by Stephan.
(Portage version: 2.1_rc2-r1)
Diffstat (limited to 'media-libs/libsdl')
-rw-r--r-- | media-libs/libsdl/ChangeLog | 10 | ||||
-rw-r--r-- | media-libs/libsdl/files/digest-libsdl-1.2.10 | 3 | ||||
-rw-r--r-- | media-libs/libsdl/files/libsdl-1.2.10-PIC-hidden-symbols.patch | 168 | ||||
-rw-r--r-- | media-libs/libsdl/files/libsdl-1.2.10-libcaca.patch | 592 | ||||
-rw-r--r-- | media-libs/libsdl/files/libsdl-1.2.10-sdl-config.patch | 20 | ||||
-rw-r--r-- | media-libs/libsdl/libsdl-1.2.10.ebuild | 150 |
6 files changed, 942 insertions, 1 deletions
diff --git a/media-libs/libsdl/ChangeLog b/media-libs/libsdl/ChangeLog index a6909efcbf7f..8838c301e734 100644 --- a/media-libs/libsdl/ChangeLog +++ b/media-libs/libsdl/ChangeLog @@ -1,6 +1,14 @@ # ChangeLog for media-libs/libsdl # Copyright 1999-2006 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-libs/libsdl/ChangeLog,v 1.100 2006/05/07 23:35:04 vapier Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-libs/libsdl/ChangeLog,v 1.101 2006/05/26 05:26:45 vapier Exp $ + +*libsdl-1.2.10 (26 May 2006) + + 26 May 2006; Mike Frysinger <vapier@gentoo.org> + +files/libsdl-1.2.10-PIC-hidden-symbols.patch, + +files/libsdl-1.2.10-libcaca.patch, +files/libsdl-1.2.10-sdl-config.patch, + +libsdl-1.2.10.ebuild: + Version bump #133754 by Stephan. 07 May 2006; Mike Frysinger <vapier@gentoo.org> files/libsdl-1.2.9-DirectFB-updates.patch: diff --git a/media-libs/libsdl/files/digest-libsdl-1.2.10 b/media-libs/libsdl/files/digest-libsdl-1.2.10 new file mode 100644 index 000000000000..dc8e2bfb28c2 --- /dev/null +++ b/media-libs/libsdl/files/digest-libsdl-1.2.10 @@ -0,0 +1,3 @@ +MD5 b7b46a866b8bf32df8c041a00e567c7d SDL-1.2.10.tar.gz 2792344 +RMD160 e2e73a580638ab29d4b000152ed80999545e9fb5 SDL-1.2.10.tar.gz 2792344 +SHA256 f4d384266a3174770234d40829c767ff7090f3e1a9c9fc9fd5e130f51ddf7a70 SDL-1.2.10.tar.gz 2792344 diff --git a/media-libs/libsdl/files/libsdl-1.2.10-PIC-hidden-symbols.patch b/media-libs/libsdl/files/libsdl-1.2.10-PIC-hidden-symbols.patch new file mode 100644 index 000000000000..857fc6591aa3 --- /dev/null +++ b/media-libs/libsdl/files/libsdl-1.2.10-PIC-hidden-symbols.patch @@ -0,0 +1,168 @@ +kill off textrels by hiding internal symbols + +http://bugzilla.libsdl.org/show_bug.cgi?id=157 +http://www.libsdl.org/pipermail/sdl/2006-March/073618.html + +--- configure.in ++++ configure.in +@@ -591,10 +591,13 @@ CheckNASM() + , enable_nasm=yes) + if test x$enable_video = xyes -a x$enable_assembly = xyes -a x$enable_nasm = xyes; then +- AC_PATH_PROG(NASM, nasm) +- if test x$NASM != x -a x$NASM != x'"$NASM"'; then ++ AC_PATH_PROG(NASM, yasm) ++ if test "x$NASM" = x -o "x$NASM" = x'"$NASM"'; then ++ AC_PATH_PROG(NASM, nasm) ++ fi ++ if test "x$NASM" != x -a "x$NASM" != x'"$NASM"'; then + AC_DEFINE(SDL_HERMES_BLITTERS) + SOURCES="$SOURCES $srcdir/src/hermes/*.asm" +- if test x$NASMFLAGS = x; then ++ if test x"$NASMFLAGS" = x; then + case $ARCH in + win32) + NASMFLAGS="-f win32" +@@ -607,6 +610,15 @@ AC_HELP_STRING([--enable-nasm], [use nas + ;; + esac + fi ++ NASMFLAGS="$NASMFLAGS -i $srcdir/src/hermes/" ++ ++ dnl See if hidden visibility is supported ++ echo 'GLOBAL _bar:function hidden' > nasm_vis.asm ++ if $NASM $NASMFLAGS nasm_vis.asm -o nasm_vis.o >&AS_MESSAGE_LOG_FD ; then ++ NASMFLAGS="$NASMFLAGS -DHIDDEN_VISIBILITY" ++ fi ++ rm -f nasm_vis.asm nasm_vis.o ++ + AC_SUBST(NASM) + AC_SUBST(NASMFLAGS) + +--- src/hermes/mmx_main.asm ++++ src/hermes/mmx_main.asm +@@ -9,8 +9,10 @@ + + BITS 32 + +-GLOBAL _ConvertMMX +-GLOBAL _mmxreturn ++%include "common.asm" ++ ++SDL_FUNC _ConvertMMX ++SDL_FUNC _mmxreturn + + SECTION .text + +--- src/hermes/mmxp2_32.asm ++++ src/hermes/mmxp2_32.asm +@@ -20,12 +20,13 @@ + + BITS 32 + ++%include "common.asm" + +-GLOBAL _ConvertMMXpII32_24RGB888 +-GLOBAL _ConvertMMXpII32_16RGB565 +-GLOBAL _ConvertMMXpII32_16BGR565 +-GLOBAL _ConvertMMXpII32_16RGB555 +-GLOBAL _ConvertMMXpII32_16BGR555 ++SDL_FUNC _ConvertMMXpII32_24RGB888 ++SDL_FUNC _ConvertMMXpII32_16RGB565 ++SDL_FUNC _ConvertMMXpII32_16BGR565 ++SDL_FUNC _ConvertMMXpII32_16RGB555 ++SDL_FUNC _ConvertMMXpII32_16BGR555 + + EXTERN _mmxreturn + +--- src/hermes/x86_main.asm ++++ src/hermes/x86_main.asm +@@ -11,10 +11,12 @@ + + BITS 32 + +-GLOBAL _ConvertX86 +-GLOBAL _x86return ++%include "common.asm" ++ ++SDL_FUNC _ConvertX86 ++SDL_FUNC _x86return + +-GLOBAL _Hermes_X86_CPU ++SDL_FUNC _Hermes_X86_CPU + + SECTION .text + +--- src/hermes/x86p_16.asm ++++ src/hermes/x86p_16.asm +@@ -10,19 +10,14 @@ + ; Used with permission. + ; + +- + BITS 32 + +-GLOBAL _ConvertX86p16_32RGB888 +-GLOBAL _ConvertX86p16_32BGR888 +-GLOBAL _ConvertX86p16_32RGBA888 +-GLOBAL _ConvertX86p16_32BGRA888 +-GLOBAL _ConvertX86p16_24RGB888 +-GLOBAL _ConvertX86p16_24BGR888 +-GLOBAL _ConvertX86p16_16BGR565 +-GLOBAL _ConvertX86p16_16RGB555 +-GLOBAL _ConvertX86p16_16BGR555 +-GLOBAL _ConvertX86p16_8RGB332 ++%include "common.asm" ++ ++SDL_FUNC _ConvertX86p16_16BGR565 ++SDL_FUNC _ConvertX86p16_16RGB555 ++SDL_FUNC _ConvertX86p16_16BGR555 ++SDL_FUNC _ConvertX86p16_8RGB332 + + EXTERN _ConvertX86 + EXTERN _x86return +--- src/hermes/x86p_32.asm ++++ src/hermes/x86p_32.asm +@@ -9,19 +9,20 @@ + ; Most routines are (c) Glenn Fiedler (ptc@gaffer.org), used with permission + ; + +- + BITS 32 + +-GLOBAL _ConvertX86p32_32BGR888 +-GLOBAL _ConvertX86p32_32RGBA888 +-GLOBAL _ConvertX86p32_32BGRA888 +-GLOBAL _ConvertX86p32_24RGB888 +-GLOBAL _ConvertX86p32_24BGR888 +-GLOBAL _ConvertX86p32_16RGB565 +-GLOBAL _ConvertX86p32_16BGR565 +-GLOBAL _ConvertX86p32_16RGB555 +-GLOBAL _ConvertX86p32_16BGR555 +-GLOBAL _ConvertX86p32_8RGB332 ++%include "common.asm" ++ ++SDL_FUNC _ConvertX86p32_32BGR888 ++SDL_FUNC _ConvertX86p32_32RGBA888 ++SDL_FUNC _ConvertX86p32_32BGRA888 ++SDL_FUNC _ConvertX86p32_24RGB888 ++SDL_FUNC _ConvertX86p32_24BGR888 ++SDL_FUNC _ConvertX86p32_16RGB565 ++SDL_FUNC _ConvertX86p32_16BGR565 ++SDL_FUNC _ConvertX86p32_16RGB555 ++SDL_FUNC _ConvertX86p32_16BGR555 ++SDL_FUNC _ConvertX86p32_8RGB332 + + EXTERN _x86return + +--- src/hermes/common.asm ++++ src/hermes/common.asm +@@ -0,0 +1,9 @@ ++; Some common macros for hermes nasm code ++ ++%macro SDL_FUNC 1 ++%ifdef HIDDEN_VISIBILITY ++GLOBAL %1:function hidden ++%else ++GLOBAL %1:function ++%endif ++%endmacro diff --git a/media-libs/libsdl/files/libsdl-1.2.10-libcaca.patch b/media-libs/libsdl/files/libsdl-1.2.10-libcaca.patch new file mode 100644 index 000000000000..d5ec96dd6adf --- /dev/null +++ b/media-libs/libsdl/files/libsdl-1.2.10-libcaca.patch @@ -0,0 +1,592 @@ +--- SDL-1.2.10/configure.in ++++ SDL-1.2.10/configure.in +@@ -1316,6 +1316,38 @@ AC_HELP_STRING([--enable-video-aalib], [ + fi + } + ++dnl Find the libcaca includes ++CheckCaca() ++{ ++ AC_ARG_ENABLE(video-caca, ++AC_HELP_STRING([--enable-video-caca], [use libcaca video driver [[default=no]]]), ++ , enable_video_caca=no) ++ if test x$enable_video = xyes -a x$enable_video_caca = xyes; then ++ video_caca=no ++ AC_PATH_PROG(CACACONFIG, caca-config, no) ++ if test x$CACACONFIG != xno; then ++ AC_MSG_CHECKING(for libcaca support) ++ CACA_CFLAGS=`$CACACONFIG --cflags` ++ CACA_LDFLAGS=`$CACACONFIG --libs` ++ save_CFLAGS="$CFLAGS" ++ AC_TRY_COMPILE([ ++ #include <caca.h> ++ ],[ ++ ],[ ++ video_caca=yes ++ ]) ++ CFLAGS="$save_CFLAGS" ++ AC_MSG_RESULT($video_caca) ++ if test x$video_caca = xyes; then ++ AC_DEFINE(SDL_VIDEO_DRIVER_CACA) ++ EXTRA_CFLAGS="$EXTRA_CFLAGS $CACA_CFLAGS" ++ EXTRA_LDFLAGS="$EXTRA_LDFLAGS $CACA_LDFLAGS" ++ SOURCES="$SOURCES $srcdir/src/video/caca/*.c" ++ fi ++ fi ++ fi ++} ++ + dnl Set up the QTopia video driver if enabled + CheckQtopia() + { +@@ -2130,6 +2162,7 @@ case "$host" in + CheckVGL + CheckWscons + CheckAAlib ++ CheckCaca + CheckQtopia + CheckPicoGUI + CheckOpenGLX11 +--- SDL-1.2.10/src/video/caca/SDL_cacaevents.c ++++ SDL-1.2.10/src/video/caca/SDL_cacaevents.c +@@ -0,0 +1,98 @@ ++/* ++ SDL - Simple DirectMedia Layer ++ Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 Sam Lantinga ++ ++ This library is free software; you can redistribute it and/or ++ modify it under the terms of the GNU Library General Public ++ License as published by the Free Software Foundation; either ++ version 2 of the License, or (at your option) any later version. ++ ++ This library is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ Library General Public License for more details. ++ ++ You should have received a copy of the GNU Library General Public ++ License along with this library; if not, write to the Free ++ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ++ ++ Sam Lantinga ++ slouken@libsdl.org ++*/ ++ ++#ifdef SAVE_RCSID ++static char rcsid = ++ "@(#) $Id: libsdl-1.2.10-libcaca.patch,v 1.1 2006/05/26 05:26:45 vapier Exp $"; ++#endif ++ ++#include <stdio.h> ++ ++#include <caca.h> ++ ++#include "SDL.h" ++#include "../../events/SDL_sysevents.h" ++#include "../../events/SDL_events_c.h" ++#include "SDL_cacavideo.h" ++#include "SDL_cacaevents_c.h" ++ ++void Caca_PumpEvents(_THIS) ++{ ++ int posted = 0; ++ int event; ++ SDL_keysym keysym; ++ ++ if( ! this->screen ) /* Wait till we got the screen initialised */ ++ return; ++ ++ do { ++ posted = 0; ++ ++ /* Get libcaca event */ ++ SDL_mutexP(Caca_mutex); ++ event = caca_get_event(CACA_EVENT_ANY); ++ SDL_mutexV(Caca_mutex); ++ ++ if ( event & (CACA_EVENT_KEY_PRESS | CACA_EVENT_KEY_RELEASE)) { ++ int key; ++ switch ( event & 0xffffff ) ++ { ++ case CACA_KEY_LEFT: key = SDLK_LEFT; break; ++ case CACA_KEY_RIGHT: key = SDLK_RIGHT; break; ++ case CACA_KEY_UP: key = SDLK_UP; break; ++ case CACA_KEY_DOWN: key = SDLK_DOWN; break; ++ default: key = event & 0xff; break; ++ } ++ /* Key pressed */ ++/* printf("Key pressed: %d (%c)\n", key, key); */ ++ keysym.scancode = key; ++ keysym.sym = key; ++ keysym.mod = KMOD_NONE; ++ keysym.unicode = 0; ++ if ( SDL_TranslateUNICODE ) { ++ keysym.unicode = key; ++ } ++ posted += SDL_PrivateKeyboard((event & CACA_EVENT_KEY_PRESS) ? SDL_PRESSED : SDL_RELEASED, &keysym); ++ } ++ else if ( event & (CACA_EVENT_MOUSE_PRESS | CACA_EVENT_MOUSE_RELEASE) ) { ++ /* FIXME: we currently ignore the button type! */ ++ int button = event & 0x00ffffff; ++ if ( button > 3 ) { ++ button = 1; ++ } ++ posted += SDL_PrivateMouseButton((event & CACA_EVENT_MOUSE_PRESS) ? SDL_PRESSED : SDL_RELEASED, button, 0, 0); ++ } ++ else if ( event & CACA_EVENT_MOUSE_MOTION ) { ++ int new_x = 0, new_y = 0; ++ new_x = ((event & 0x00fff000) >> 12) * Caca_w / caca_get_width(); ++ new_y = ((event & 0x00000fff) >> 0) * Caca_h / caca_get_height(); ++ posted += SDL_PrivateMouseMotion(0, 0, new_x, new_y); ++ } ++ } while ( posted ); ++} ++ ++void Caca_InitOSKeymap(_THIS) ++{ ++ return; ++} ++ ++ +--- SDL-1.2.10/src/video/caca/SDL_cacaevents_c.h ++++ SDL-1.2.10/src/video/caca/SDL_cacaevents_c.h +@@ -0,0 +1,35 @@ ++/* ++ SDL - Simple DirectMedia Layer ++ Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 Sam Lantinga ++ ++ This library is free software; you can redistribute it and/or ++ modify it under the terms of the GNU Library General Public ++ License as published by the Free Software Foundation; either ++ version 2 of the License, or (at your option) any later version. ++ ++ This library is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ Library General Public License for more details. ++ ++ You should have received a copy of the GNU Library General Public ++ License along with this library; if not, write to the Free ++ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ++ ++ Sam Lantinga ++ slouken@libsdl.org ++*/ ++ ++#ifdef SAVE_RCSID ++static char rcsid = ++ "@(#) $Id: libsdl-1.2.10-libcaca.patch,v 1.1 2006/05/26 05:26:45 vapier Exp $"; ++#endif ++ ++#include "SDL_cacavideo.h" ++ ++/* Variables and functions exported by SDL_sysevents.c to other parts. ++ of the native video subsystem (SDL_sysvideo.c) ++*/ ++extern void Caca_PumpEvents(_THIS); ++extern void Caca_InitOSKeymap(_THIS); ++ +--- SDL-1.2.10/src/video/caca/SDL_cacavideo.c ++++ SDL-1.2.10/src/video/caca/SDL_cacavideo.c +@@ -0,0 +1,301 @@ ++/* ++ SDL - Simple DirectMedia Layer ++ Copyright (C) 2003 Sam Hocevar ++ ++ This library is free software; you can redistribute it and/or ++ modify it under the terms of the GNU Library General Public ++ License as published by the Free Software Foundation; either ++ version 2 of the License, or (at your option) any later version. ++ ++ This library is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ Library General Public License for more details. ++ ++ You should have received a copy of the GNU Library General Public ++ License along with this library; if not, write to the Free ++ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ++ ++ Sam Hocevar ++ sam@zoy.org ++*/ ++ ++#ifdef SAVE_RCSID ++static char rcsid = ++ "@(#) $Id: libsdl-1.2.10-libcaca.patch,v 1.1 2006/05/26 05:26:45 vapier Exp $"; ++#endif ++ ++/* libcaca based SDL video driver implementation. ++*/ ++ ++#include <stdlib.h> ++#include <stdio.h> ++#include <string.h> ++#include <unistd.h> ++#include <sys/stat.h> ++ ++ ++#include "SDL.h" ++#include "SDL_error.h" ++#include "SDL_video.h" ++#include "SDL_mouse.h" ++#include "../SDL_sysvideo.h" ++#include "../SDL_pixels_c.h" ++#include "../../events/SDL_events_c.h" ++ ++#include "SDL_cacavideo.h" ++#include "SDL_cacaevents_c.h" ++ ++#include <caca.h> ++ ++/* Initialization/Query functions */ ++static int Caca_VideoInit(_THIS, SDL_PixelFormat *vformat); ++static SDL_Rect **Caca_ListModes(_THIS, SDL_PixelFormat *format, Uint32 flags); ++static SDL_Surface *Caca_SetVideoMode(_THIS, SDL_Surface *current, int width, int height, int bpp, Uint32 flags); ++static void Caca_VideoQuit(_THIS); ++ ++/* Hardware surface functions */ ++static int Caca_AllocHWSurface(_THIS, SDL_Surface *surface); ++static int Caca_LockHWSurface(_THIS, SDL_Surface *surface); ++static int Caca_FlipHWSurface(_THIS, SDL_Surface *surface); ++static void Caca_UnlockHWSurface(_THIS, SDL_Surface *surface); ++static void Caca_FreeHWSurface(_THIS, SDL_Surface *surface); ++ ++/* Cache the VideoDevice struct */ ++static struct SDL_VideoDevice *local_this; ++ ++/* libcaca driver bootstrap functions */ ++ ++static int Caca_Available(void) ++{ ++ return 1; /* Always available ! */ ++} ++ ++static void Caca_DeleteDevice(SDL_VideoDevice *device) ++{ ++ free(device->hidden); ++ free(device); ++} ++static SDL_VideoDevice *Caca_CreateDevice(int devindex) ++{ ++ SDL_VideoDevice *device; ++ ++ /* Initialize all variables that we clean on shutdown */ ++ device = (SDL_VideoDevice *)malloc(sizeof(SDL_VideoDevice)); ++ if ( device ) { ++ memset(device, 0, (sizeof *device)); ++ device->hidden = (struct SDL_PrivateVideoData *) ++ malloc((sizeof *device->hidden)); ++ } ++ if ( (device == NULL) || (device->hidden == NULL) ) { ++ SDL_OutOfMemory(); ++ if ( device ) { ++ free(device); ++ } ++ return(0); ++ } ++ memset(device->hidden, 0, (sizeof *device->hidden)); ++ ++ /* Set the function pointers */ ++ device->VideoInit = Caca_VideoInit; ++ device->ListModes = Caca_ListModes; ++ device->SetVideoMode = Caca_SetVideoMode; ++ device->CreateYUVOverlay = NULL; ++ device->SetColors = NULL; ++ device->UpdateRects = NULL; ++ device->VideoQuit = Caca_VideoQuit; ++ device->AllocHWSurface = Caca_AllocHWSurface; ++ device->CheckHWBlit = NULL; ++ device->FillHWRect = NULL; ++ device->SetHWColorKey = NULL; ++ device->SetHWAlpha = NULL; ++ device->LockHWSurface = Caca_LockHWSurface; ++ device->UnlockHWSurface = Caca_UnlockHWSurface; ++ device->FlipHWSurface = NULL; ++ device->FreeHWSurface = Caca_FreeHWSurface; ++ device->SetCaption = NULL; ++ device->SetIcon = NULL; ++ device->IconifyWindow = NULL; ++ device->GrabInput = NULL; ++ device->GetWMInfo = NULL; ++ device->InitOSKeymap = Caca_InitOSKeymap; ++ device->PumpEvents = Caca_PumpEvents; ++ ++ device->free = Caca_DeleteDevice; ++ ++ return device; ++} ++ ++VideoBootStrap Caca_bootstrap = { ++ "caca", "Color ASCII Art Library", ++ Caca_Available, Caca_CreateDevice ++}; ++ ++int Caca_VideoInit(_THIS, SDL_PixelFormat *vformat) ++{ ++ int i; ++ ++ /* Initialize all variables that we clean on shutdown */ ++ for ( i=0; i<SDL_NUMMODES; ++i ) { ++ SDL_modelist[i] = malloc(sizeof(SDL_Rect)); ++ SDL_modelist[i]->x = SDL_modelist[i]->y = 0; ++ } ++ /* Modes sorted largest to smallest */ ++ SDL_modelist[0]->w = 1024; SDL_modelist[0]->h = 768; ++ SDL_modelist[1]->w = 800; SDL_modelist[1]->h = 600; ++ SDL_modelist[2]->w = 640; SDL_modelist[2]->h = 480; ++ SDL_modelist[3]->w = 320; SDL_modelist[3]->h = 400; ++ SDL_modelist[4]->w = 320; SDL_modelist[4]->h = 240; ++ SDL_modelist[5]->w = 320; SDL_modelist[5]->h = 200; ++ SDL_modelist[6] = NULL; ++ ++ Caca_mutex = SDL_CreateMutex(); ++ ++ /* Initialize the library */ ++ if ( caca_init() != 0 ) { ++ SDL_SetError("Unable to initialize libcaca"); ++ return(-1); ++ } ++ ++ /* Initialize private variables */ ++ Caca_lastkey = 0; ++ Caca_bitmap = NULL; ++ Caca_buffer = NULL; ++ ++ local_this = this; ++ ++ /* Determine the screen depth (use default 8-bit depth) */ ++ vformat->BitsPerPixel = 8; ++ vformat->BytesPerPixel = 1; ++ ++ /* We're done! */ ++ return(0); ++} ++ ++SDL_Rect **Caca_ListModes(_THIS, SDL_PixelFormat *format, Uint32 flags) ++{ ++ if(format->BitsPerPixel != 8) ++ return NULL; ++ ++ if ( flags & SDL_FULLSCREEN ) { ++ return SDL_modelist; ++ } else { ++ return (SDL_Rect **) -1; ++ } ++} ++ ++/* Various screen update functions available */ ++static void Caca_DirectUpdate(_THIS, int numrects, SDL_Rect *rects); ++ ++SDL_Surface *Caca_SetVideoMode(_THIS, SDL_Surface *current, ++ int width, int height, int bpp, Uint32 flags) ++{ ++ if ( Caca_buffer ) { ++ free( Caca_buffer ); ++ Caca_buffer = NULL; ++ } ++ ++ if ( Caca_bitmap ) { ++ caca_free_bitmap( Caca_bitmap ); ++ Caca_bitmap = NULL; ++ } ++ ++ Caca_buffer = malloc(2 * ((width + 15) & ~15) * height); ++ if ( ! Caca_buffer ) { ++ SDL_SetError("Couldn't allocate buffer for requested mode"); ++ return(NULL); ++ } ++ ++ memset(Caca_buffer, 0, 2 * ((width + 15) & ~15) * height); ++ ++ /* Allocate the new pixel format for the screen */ ++ if ( ! SDL_ReallocFormat(current, 16, 0xf800, 0x07e0, 0x001f, 0) ) { ++ return(NULL); ++ } ++ ++ /* Set up the new mode framebuffer */ ++ current->flags = SDL_FULLSCREEN; ++ Caca_w = current->w = width; ++ Caca_h = current->h = height; ++ current->pitch = 2 * ((width + 15) & ~15); ++ current->pixels = Caca_buffer; ++ ++ /* Create the libcaca bitmap */ ++ Caca_bitmap = caca_create_bitmap( 16, width, height, current->pitch, 0xf800, 0x07e0, 0x001f, 0x0000 ); ++ if ( ! Caca_bitmap ) { ++ SDL_SetError("Couldn't allocate libcaca bitmap"); ++ return(NULL); ++ } ++ ++ /* Set the blit function */ ++ this->UpdateRects = Caca_DirectUpdate; ++ ++ /* We're done */ ++ return(current); ++} ++ ++/* We don't actually allow hardware surfaces other than the main one */ ++static int Caca_AllocHWSurface(_THIS, SDL_Surface *surface) ++{ ++ return(-1); ++} ++static void Caca_FreeHWSurface(_THIS, SDL_Surface *surface) ++{ ++ return; ++} ++ ++/* We need to wait for vertical retrace on page flipped displays */ ++static int Caca_LockHWSurface(_THIS, SDL_Surface *surface) ++{ ++ /* TODO ? */ ++ return(0); ++} ++static void Caca_UnlockHWSurface(_THIS, SDL_Surface *surface) ++{ ++ return; ++} ++ ++/* FIXME: How is this done with libcaca? */ ++static int Caca_FlipHWSurface(_THIS, SDL_Surface *surface) ++{ ++ SDL_mutexP(Caca_mutex); ++ caca_refresh(); ++ SDL_mutexV(Caca_mutex); ++ return(0); ++} ++ ++static void Caca_DirectUpdate(_THIS, int numrects, SDL_Rect *rects) ++{ ++ SDL_mutexP(Caca_mutex); ++ caca_draw_bitmap( 0, 0, caca_get_width() - 1, caca_get_height() - 1, ++ Caca_bitmap, Caca_buffer ); ++ caca_refresh(); ++ SDL_mutexV(Caca_mutex); ++ return; ++} ++ ++/* Note: If we are terminated, this could be called in the middle of ++ another SDL video routine -- notably UpdateRects. ++*/ ++void Caca_VideoQuit(_THIS) ++{ ++ int i; ++ ++ /* Free video mode lists */ ++ for ( i=0; i<SDL_NUMMODES; ++i ) { ++ if ( SDL_modelist[i] != NULL ) { ++ free(SDL_modelist[i]); ++ SDL_modelist[i] = NULL; ++ } ++ } ++ ++ if ( Caca_bitmap ) { ++ caca_free_bitmap( Caca_bitmap ); ++ Caca_bitmap = NULL; ++ } ++ ++ caca_end(); ++ ++ SDL_DestroyMutex(Caca_mutex); ++} ++ +--- SDL-1.2.10/src/video/caca/SDL_cacavideo.h ++++ SDL-1.2.10/src/video/caca/SDL_cacavideo.h +@@ -0,0 +1,73 @@ ++/* ++ SDL - Simple DirectMedia Layer ++ Copyright (C) 2003 Sam Hocevar ++ ++ This library is free software; you can redistribute it and/or ++ modify it under the terms of the GNU Library General Public ++ License as published by the Free Software Foundation; either ++ version 2 of the License, or (at your option) any later version. ++ ++ This library is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ Library General Public License for more details. ++ ++ You should have received a copy of the GNU Library General Public ++ License along with this library; if not, write to the Free ++ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ++ ++ Sam Hocevar ++ sam@zoy.org ++*/ ++ ++#ifdef SAVE_RCSID ++static char rcsid = ++ "@(#) $Id: libsdl-1.2.10-libcaca.patch,v 1.1 2006/05/26 05:26:45 vapier Exp $"; ++#endif ++ ++#ifndef _SDL_cacavideo_h ++#define _SDL_cacavideo_h ++ ++#include "SDL_mouse.h" ++#include "../SDL_sysvideo.h" ++#include "SDL_mutex.h" ++ ++#include <sys/time.h> ++#include <time.h> ++ ++#include <caca.h> ++ ++/* Hidden "this" pointer for the video functions */ ++#define _THIS SDL_VideoDevice *this ++ ++#define SDL_NUMMODES 6 ++ ++/* Private display data */ ++struct SDL_PrivateVideoData { ++ SDL_Rect *SDL_modelist[SDL_NUMMODES+1]; ++ SDL_mutex *mutex; ++ ++ struct caca_bitmap *bitmap; ++ void *buffer; ++ int w, h; ++ ++ int lastkey; ++ struct timeval lasttime; ++}; ++ ++/* Old variable names */ ++#define SDL_modelist (this->hidden->SDL_modelist) ++#define Caca_palette (this->hidden->palette) ++#define Caca_bitmap (this->hidden->bitmap) ++#define Caca_buffer (this->hidden->buffer) ++ ++#define Caca_w (this->hidden->w) ++#define Caca_h (this->hidden->h) ++ ++#define Caca_lastkey (this->hidden->lastkey) ++#define Caca_lasttime (this->hidden->lasttime) ++ ++#define Caca_mutex (this->hidden->mutex) ++ ++#endif /* _SDL_cacavideo_h */ ++ +--- SDL-1.2.10/src/video/SDL_sysvideo.h ++++ SDL-1.2.10/src/video/SDL_sysvideo.h +@@ -404,6 +404,9 @@ extern VideoBootStrap OS2FSLib_bootstrap + #if SDL_VIDEO_DRIVER_AALIB + extern VideoBootStrap AALIB_bootstrap; + #endif ++#if SDL_VIDEO_DRIVER_CACA ++extern VideoBootStrap CACA_bootstrap; ++#endif + #if SDL_VIDEO_DRIVER_DUMMY + extern VideoBootStrap DUMMY_bootstrap; + #endif +--- SDL-1.2.10/src/video/SDL_video.c ++++ SDL-1.2.10/src/video/SDL_video.c +@@ -120,6 +120,9 @@ static VideoBootStrap *bootstrap[] = { + #if SDL_VIDEO_DRIVER_AALIB + &AALIB_bootstrap, + #endif ++#if SDL_VIDEO_DRIVER_CACA ++ &CACA_bootstrap, ++#endif + #if SDL_VIDEO_DRIVER_DUMMY + &DUMMY_bootstrap, + #endif diff --git a/media-libs/libsdl/files/libsdl-1.2.10-sdl-config.patch b/media-libs/libsdl/files/libsdl-1.2.10-sdl-config.patch new file mode 100644 index 000000000000..f430428e6e90 --- /dev/null +++ b/media-libs/libsdl/files/libsdl-1.2.10-sdl-config.patch @@ -0,0 +1,20 @@ +Only output -L -rpath cruft if using a non-standard install location. + +Makes ABI / cross-compiling easier on the soul. + +--- sdl-config.in ++++ sdl-config.in +@@ -44,7 +44,12 @@ + echo -I@includedir@/SDL @SDL_CFLAGS@ + ;; + @ENABLE_SHARED_TRUE@ --libs) +-@ENABLE_SHARED_TRUE@ echo -L@libdir@ @SDL_RLD_FLAGS@ @SDL_LIBS@ ++@ENABLE_SHARED_TRUE@ if test x"${prefix}" != x"/usr" ; then ++@ENABLE_SHARED_TRUE@ libdirs="-L@libdir@" ++@ENABLE_SHARED_TRUE@ else ++@ENABLE_SHARED_TRUE@ libdirs="" ++@ENABLE_SHARED_TRUE@ fi ++@ENABLE_SHARED_TRUE@ echo $libdirs @SDL_RLD_FLAGS@ @SDL_LIBS@ + @ENABLE_SHARED_TRUE@ ;; + @ENABLE_STATIC_TRUE@@ENABLE_SHARED_TRUE@ --static-libs) + @ENABLE_STATIC_TRUE@@ENABLE_SHARED_FALSE@ --libs|--static-libs) diff --git a/media-libs/libsdl/libsdl-1.2.10.ebuild b/media-libs/libsdl/libsdl-1.2.10.ebuild new file mode 100644 index 000000000000..7cee87c2817a --- /dev/null +++ b/media-libs/libsdl/libsdl-1.2.10.ebuild @@ -0,0 +1,150 @@ +# Copyright 1999-2006 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-libs/libsdl/libsdl-1.2.10.ebuild,v 1.1 2006/05/26 05:26:45 vapier Exp $ + +inherit flag-o-matic toolchain-funcs eutils libtool + +DESCRIPTION="Simple Direct Media Layer" +HOMEPAGE="http://www.libsdl.org/" +SRC_URI="http://www.libsdl.org/release/SDL-${PV}.tar.gz" + +LICENSE="LGPL-2" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ia64 ~mips ~ppc ppc-macos ~ppc64 ~sh ~sparc ~x86 ~x86-fbsd" +# WARNING: +# if you have the noaudio, novideo, nojoystick, or noflagstrip use flags +# in USE and something breaks, you pick up the pieces. Be prepared for +# bug reports to be marked INVALID. +IUSE="oss alsa esd arts nas X dga xv xinerama fbcon directfb ggi svga aalib opengl libcaca noaudio novideo nojoystick noflagstrip" + +RDEPEND="!noaudio? ( >=media-libs/audiofile-0.1.9 ) + alsa? ( media-libs/alsa-lib ) + esd? ( >=media-sound/esound-0.2.19 ) + arts? ( kde-base/arts ) + nas? ( + media-libs/nas + || ( ( + x11-libs/libXt + x11-libs/libXext + x11-libs/libX11 ) + virtual/x11 ) ) + X? ( + || ( ( + x11-libs/libXt + x11-libs/libXext + x11-libs/libX11 ) + virtual/x11 ) ) + directfb? ( >=dev-libs/DirectFB-0.9.19 ) + ggi? ( >=media-libs/libggi-2.0_beta3 ) + svga? ( >=media-libs/svgalib-1.4.2 ) + aalib? ( media-libs/aalib ) + libcaca? ( >=media-libs/libcaca-0.9-r1 ) + opengl? ( virtual/opengl )" +DEPEND="${RDEPEND} + nas? ( + || ( ( + x11-proto/xextproto + x11-proto/xproto ) + virtual/x11 ) ) + X? ( + || ( ( + x11-proto/xextproto + x11-proto/xproto ) + virtual/x11 ) ) + x86? ( dev-lang/nasm )" + +S=${WORKDIR}/SDL-${PV} + +pkg_setup() { + if use noaudio || use novideo || use nojoystick ; then + ewarn "Since you've chosen to turn off some of libsdl's functionality," + ewarn "don't bother filing libsdl-related bugs until trying to remerge" + ewarn "libsdl without the no* flags in USE. You need to know what" + ewarn "you're doing to selectively turn off parts of libsdl." + epause 30 + fi + if use noflagstrip ; then + ewarn "Since you've chosen to use possibly unsafe CFLAGS," + ewarn "don't bother filing libsdl-related bugs until trying to remerge" + ewarn "libsdl without the noflagstrip use flag in USE." + epause 10 + fi +} + +src_unpack() { + unpack ${A} + cd "${S}" + + epatch "${FILESDIR}"/libsdl-1.2.10-libcaca.patch #40224 + epatch "${FILESDIR}"/libsdl-1.2.10-sdl-config.patch + epatch "${FILESDIR}"/libsdl-1.2.10-PIC-hidden-symbols.patch + + ./autogen.sh || die "autogen failed" + elibtoolize +} + +src_compile() { + local myconf= + if [[ $(tc-arch) != "x86" ]] ; then + myconf="${myconf} --disable-nasm" + else + myconf="${myconf} $(use_enable x86 nasm)" + fi + use noflagstrip || strip-flags + use noaudio && myconf="${myconf} --disable-audio" + use novideo \ + && myconf="${myconf} --disable-video" \ + || myconf="${myconf} --enable-video-dummy" + use nojoystick && myconf="${myconf} --disable-joystick" + + local directfbconf="--disable-video-directfb" + if use directfb ; then + # since DirectFB can link against SDL and trigger a + # dependency loop, only link against DirectFB if it + # isn't broken #61592 + echo 'int main(){}' > directfb-test.c + $(tc-getCC) directfb-test.c -ldirectfb 2>/dev/null \ + && directfbconf="--enable-video-directfb" \ + || ewarn "Disabling DirectFB since libdirectfb.so is broken" + fi + + myconf="${myconf} ${directfbconf}" + + econf \ + --disable-dependency-tracking \ + --disable-rpath \ + --enable-events \ + --enable-cdrom \ + --enable-threads \ + --enable-timers \ + --enable-endian \ + --enable-file \ + --enable-cpuinfo \ + $(use_enable oss) \ + $(use_enable alsa) \ + $(use_enable esd) \ + $(use_enable arts) \ + $(use_enable nas) \ + $(use_enable X video-x11) \ + $(use_enable dga) \ + $(use_enable xv video-x11-xv) \ + $(use_enable xinerama video-x11-xinerama) \ + $(use_enable X video-x11-xrandr) \ + $(use_enable dga video-dga) \ + $(use_enable fbcon video-fbcon) \ + $(use_enable ggi video-ggi) \ + $(use_enable svga video-svga) \ + $(use_enable aalib video-aalib) \ + $(use_enable libcaca video-caca) \ + $(use_enable opengl video-opengl) \ + $(use_with X x) \ + --disable-video-x11-xme \ + ${myconf} || die + emake || die "emake failed" +} + +src_install() { + make DESTDIR="${D}" install || die "make install failed" + dodoc BUGS CREDITS README README-SDL.txt README.CVS TODO WhatsNew + dohtml -r ./ +} |