src/video/photon/SDL_ph_video.c
author Sam Lantinga <slouken@lokigames.com>
Thu, 10 May 2001 18:42:17 +0000
changeset 19 8cc4dbfab9ab
parent 0 74212992fb08
child 204 62bad9a82022
permissions -rw-r--r--
Date: Thu, 19 Apr 2001 08:36:54 +0300
From: "Mike Gorchak" <mike@malva.com.ua>
Subject: Patches for QNX RtP

Here my patch for QNX RtP/Photon for SDL-1.2.

Detailed description of my changes:

SDL/configure.in:
If Photon detected declare define ENABLE_PHOTON.

SDL/src/video/SDL_sysvideo.h:
Added extern to ph_bootstrap.

SDL/src/video/SDL_video.c:
Added ph_bootstrap to bootstrap array.

SDL/src/video/photon/SDL_ph_events.c:
Declare DISABLE_X11 if compiled for Photon.

SDL/src/video/photon/SDL_ph_image.c:
Fixed segment violation on exit. Please update BUGS file.

SDL/src/video/photon/SDL_ph_video.c:
1. Enabling window manager.
2. Added to device capabilities Photon Window Manager functions:
SetCaption and IconifyWindow.
3. Renamed X11_bootstrap to ph_bootstrap.
4. Removed SEGFAULT termination of programs if Photon not available.

SDL/src/video/photon/SDL_ph_wm.c:
1. Declare DISABLE_X11 if compiled for Photon.
2. Added ph_SetCaption and ph_IconifyWindow code. (Thanks to
'phearbear' for iconify window source).
3. Some stubers for other wm functions.

Thanks !

----------------------------
Mike Gorchak
CJSC Malva
System Programmer
slouken@0
     1
/*
slouken@0
     2
    SDL - Simple DirectMedia Layer
slouken@0
     3
    Copyright (C) 1997, 1998, 1999, 2000, 2001  Sam Lantinga
slouken@0
     4
slouken@0
     5
    This library is free software; you can redistribute it and/or
slouken@0
     6
    modify it under the terms of the GNU Library General Public
slouken@0
     7
    License as published by the Free Software Foundation; either
slouken@0
     8
    version 2 of the License, or (at your option) any later version.
slouken@0
     9
slouken@0
    10
    This library is distributed in the hope that it will be useful,
slouken@0
    11
    but WITHOUT ANY WARRANTY; without even the implied warranty of
slouken@0
    12
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
slouken@0
    13
    Library General Public License for more details.
slouken@0
    14
slouken@0
    15
    You should have received a copy of the GNU Library General Public
slouken@0
    16
    License along with this library; if not, write to the Free
slouken@0
    17
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
slouken@0
    18
slouken@0
    19
    Sam Lantinga
slouken@0
    20
    slouken@devolution.com
slouken@0
    21
*/
slouken@0
    22
slouken@0
    23
#ifdef SAVE_RCSID
slouken@0
    24
static char rcsid =
slouken@0
    25
 "@(#) $Id$";
slouken@0
    26
#endif
slouken@0
    27
slouken@0
    28
#include <stdlib.h>
slouken@0
    29
#include <stdio.h>
slouken@0
    30
#include <unistd.h>
slouken@0
    31
#include <string.h>
slouken@0
    32
#include <sys/ioctl.h>
slouken@0
    33
slouken@0
    34
#include "SDL.h"
slouken@0
    35
#include "SDL_error.h"
slouken@0
    36
#include "SDL_timer.h"
slouken@0
    37
#include "SDL_thread.h"
slouken@0
    38
#include "SDL_video.h"
slouken@0
    39
#include "SDL_mouse.h"
slouken@0
    40
#include "SDL_endian.h"
slouken@0
    41
#include "SDL_sysvideo.h"
slouken@0
    42
#include "SDL_pixels_c.h"
slouken@0
    43
#include "SDL_events_c.h"
slouken@0
    44
#include "SDL_ph_video.h"
slouken@0
    45
#include "SDL_ph_modes_c.h"
slouken@0
    46
#include "SDL_ph_image_c.h"
slouken@0
    47
#include "SDL_ph_events_c.h"
slouken@0
    48
#include "SDL_ph_mouse_c.h"
slouken@19
    49
#include "SDL_ph_wm_c.h"
slouken@0
    50
#include "SDL_phyuv_c.h"
slouken@0
    51
#include "blank_cursor.h"
slouken@0
    52
slouken@0
    53
static int ph_VideoInit(_THIS, SDL_PixelFormat *vformat);
slouken@0
    54
static SDL_Surface *ph_SetVideoMode(_THIS, SDL_Surface *current,
slouken@0
    55
                int width, int height, int bpp, Uint32 flags);
slouken@0
    56
static int ph_SetColors(_THIS, int firstcolor, int ncolors, SDL_Color *colors);
slouken@0
    57
static void ph_VideoQuit(_THIS);
slouken@0
    58
static void ph_DeleteDevice(SDL_VideoDevice *device);
slouken@0
    59
slouken@0
    60
static int ph_Available(void)
slouken@0
    61
{
slouken@0
    62
slouken@0
    63
        return 1;
slouken@0
    64
}
slouken@0
    65
slouken@0
    66
static SDL_VideoDevice *ph_CreateDevice(int devindex)
slouken@0
    67
{
slouken@0
    68
    SDL_VideoDevice *device;
slouken@0
    69
slouken@0
    70
    /* Initialize all variables that we clean on shutdown */
slouken@0
    71
    device = (SDL_VideoDevice *)malloc(sizeof(SDL_VideoDevice));
slouken@0
    72
    if ( device ) {
slouken@0
    73
        memset(device, 0, (sizeof *device));
slouken@0
    74
        device->hidden = (struct SDL_PrivateVideoData *)
slouken@0
    75
                malloc((sizeof *device->hidden));
slouken@0
    76
        device->gl_data = NULL;
slouken@0
    77
    }
slouken@0
    78
    if ( (device == NULL) || (device->hidden == NULL) ) {
slouken@0
    79
        SDL_OutOfMemory();
slouken@0
    80
        ph_DeleteDevice(device);
slouken@0
    81
        return(0);
slouken@0
    82
    }
slouken@0
    83
    memset(device->hidden, 0, (sizeof *device->hidden));
slouken@0
    84
slouken@0
    85
    /* Set the driver flags */
slouken@0
    86
    device->handles_any_size = 1; //JB not true for fullscreen
slouken@0
    87
slouken@0
    88
    /* Set the function pointers */
slouken@0
    89
	device->CreateYUVOverlay = ph_CreateYUVOverlay;
slouken@0
    90
    device->VideoInit = ph_VideoInit;
slouken@0
    91
    device->ListModes = ph_ListModes;
slouken@0
    92
    device->SetVideoMode = ph_SetVideoMode;
slouken@0
    93
    device->ToggleFullScreen =  ph_ToggleFullScreen;
slouken@0
    94
    device->UpdateMouse = NULL;	
slouken@0
    95
    device->SetColors = ph_SetColors;
slouken@0
    96
    device->UpdateRects =  NULL; //set in ph_ResizeImage
slouken@0
    97
    device->VideoQuit = ph_VideoQuit;
slouken@0
    98
    device->AllocHWSurface = ph_AllocHWSurface;
slouken@0
    99
    device->CheckHWBlit = NULL;
slouken@0
   100
    device->FillHWRect = NULL;
slouken@0
   101
    device->SetHWColorKey = NULL;
slouken@0
   102
    device->SetHWAlpha = NULL;
slouken@0
   103
    device->LockHWSurface = ph_LockHWSurface;
slouken@0
   104
    device->UnlockHWSurface = ph_UnlockHWSurface;
slouken@0
   105
    device->FlipHWSurface = ph_FlipHWSurface;
slouken@0
   106
    device->FreeHWSurface = ph_FreeHWSurface;
slouken@19
   107
    device->SetCaption = ph_SetCaption;
slouken@0
   108
    device->SetIcon = NULL;
slouken@19
   109
    device->IconifyWindow = ph_IconifyWindow;
slouken@0
   110
    device->GrabInput = NULL;
slouken@0
   111
    device->GetWMInfo = NULL;
slouken@0
   112
    device->FreeWMCursor = ph_FreeWMCursor;
slouken@0
   113
    device->CreateWMCursor = ph_CreateWMCursor;
slouken@0
   114
    device->ShowWMCursor = ph_ShowWMCursor;
slouken@0
   115
    device->WarpWMCursor = ph_WarpWMCursor;
slouken@0
   116
    device->CheckMouseMode = ph_CheckMouseMode;
slouken@0
   117
    device->InitOSKeymap = ph_InitOSKeymap;
slouken@0
   118
    device->PumpEvents = ph_PumpEvents;
slouken@0
   119
slouken@0
   120
    device->free = ph_DeleteDevice;
slouken@0
   121
slouken@0
   122
    return device;
slouken@0
   123
}
slouken@0
   124
slouken@19
   125
VideoBootStrap ph_bootstrap = {
slouken@0
   126
        "photon", "QNX Photon video output",
slouken@0
   127
	ph_Available, ph_CreateDevice
slouken@0
   128
};
slouken@0
   129
slouken@0
   130
static void ph_DeleteDevice(SDL_VideoDevice *device)
slouken@0
   131
{
slouken@0
   132
slouken@0
   133
    if ( device ) {
slouken@0
   134
        if ( device->hidden ) {
slouken@0
   135
            free(device->hidden);
slouken@0
   136
            device->hidden = NULL;
slouken@0
   137
        }
slouken@0
   138
        if ( device->gl_data ) {
slouken@0
   139
            free(device->gl_data);
slouken@0
   140
            device->gl_data = NULL;
slouken@0
   141
        }
slouken@0
   142
        free(device);
slouken@0
   143
        device = NULL;
slouken@0
   144
    }
slouken@0
   145
}
slouken@0
   146
slouken@0
   147
static int ph_VideoInit(_THIS, SDL_PixelFormat *vformat)
slouken@0
   148
{
slouken@0
   149
	PtArg_t arg[1];
slouken@0
   150
    PhDim_t dim;
slouken@0
   151
	PgColor_t ph_palette[_Pg_MAX_PALETTE];
slouken@0
   152
	int i;
slouken@0
   153
	unsigned long *tempptr;
slouken@0
   154
	int rtnval;
slouken@0
   155
	PgDisplaySettings_t mysettings;
slouken@0
   156
	PgVideoModeInfo_t my_mode_info;
slouken@0
   157
	
slouken@0
   158
     if( NULL == ( event = malloc( EVENT_SIZE ) ) )
slouken@0
   159
          exit( EXIT_FAILURE );
slouken@0
   160
slouken@0
   161
	/* Create a widget 'window' to capture events */
slouken@0
   162
    dim.w=0; //JB test320;
slouken@0
   163
    dim.h=0; //JB test240;
slouken@0
   164
    //We need to return BytesPerPixel as it in used by CreateRGBsurface
slouken@0
   165
	
slouken@0
   166
    PtSetArg(&arg[0], Pt_ARG_DIM, &dim,0);
slouken@0
   167
    
slouken@0
   168
/*    
slouken@0
   169
    PtSetArg(&arg[1], Pt_ARG_RESIZE_FLAGS, Pt_TRUE, Pt_RESIZE_XY_AS_REQUIRED);
slouken@0
   170
    PtSetArg(&arg[2], Pt_ARG_WINDOW_STATE, Pt_TRUE, Ph_WM_STATE_ISFRONT |
slouken@0
   171
                        Ph_WM_STATE_ISMAX |
slouken@0
   172
                        Ph_WM_STATE_ISFOCUS);
slouken@0
   173
slouken@0
   174
    PtSetArg(&arg[3], Pt_ARG_WINDOW_RENDER_FLAGS,Pt_FALSE,~0);
slouken@0
   175
    PtSetArg(&arg[4], Pt_ARG_WINDOW_MANAGED_FLAGS,Pt_TRUE,
slouken@0
   176
                        Ph_WM_FFRONT |
slouken@0
   177
                        Ph_WM_CLOSE |
slouken@0
   178
                        Ph_WM_TOFRONT |
slouken@0
   179
                        Ph_WM_CONSWITCH);
slouken@0
   180
*/    
slouken@0
   181
    
slouken@0
   182
    
slouken@0
   183
	window=PtAppInit(NULL, NULL, NULL, 1, arg);
slouken@0
   184
slouken@0
   185
  	if(window == NULL)
slouken@0
   186
  	{
slouken@19
   187
  		printf("Photon application init failed, probably Photon is not running.\n");
slouken@19
   188
        	exit( EXIT_FAILURE );
slouken@19
   189
//        PtExit(EXIT_FAILURE);         // Got SEGFAULT.
slouken@0
   190
  	}
slouken@0
   191
slouken@0
   192
    //PgSetDrawBufferSize(16 *1024);
slouken@0
   193
   	PgSetRegion(PtWidgetRid(window));
slouken@0
   194
    PgSetClipping(0,NULL);
slouken@0
   195
    PtRealizeWidget(window);
slouken@0
   196
slouken@0
   197
slouken@0
   198
    /* Get the available video modes */
slouken@0
   199
//    if(ph_GetVideoModes(this) < 0)
slouken@0
   200
//        return -1;
slouken@0
   201
slouken@0
   202
	/* Create the blank cursor */
slouken@0
   203
	SDL_BlankCursor = this->CreateWMCursor(this, blank_cdata, blank_cmask,
slouken@0
   204
                (int)BLANK_CWIDTH, (int)BLANK_CHEIGHT,
slouken@0
   205
                   (int)BLANK_CHOTX, (int)BLANK_CHOTY);
slouken@0
   206
slouken@0
   207
	if(SDL_BlankCursor == NULL)
slouken@0
   208
	  printf("could not create blank cursor\n");
slouken@0
   209
     /* Get the video mode */
slouken@0
   210
         if (PgGetVideoMode( &mysettings ) < 0)
slouken@0
   211
            {
slouken@0
   212
                fprintf(stderr,"ph_VideoInit:  PgGetVideoMode failed\n");
slouken@0
   213
      			//QNX6/Patch A always fails return code even though call succeeds. fixed Patch B
slouken@0
   214
            }
slouken@0
   215
        
slouken@0
   216
         if (PgGetVideoModeInfo(mysettings.mode, &my_mode_info) < 0)
slouken@0
   217
            {
slouken@0
   218
                fprintf(stderr,"ph_VideoInit:  PgGetVideoModeInfo failed\n");
slouken@0
   219
            }
slouken@0
   220
       //We need to return BytesPerPixel as it in used by CreateRGBsurface
slouken@0
   221
       vformat->BitsPerPixel = my_mode_info.bits_per_pixel;
slouken@0
   222
       vformat->BytesPerPixel = vformat->BitsPerPixel/8;
slouken@0
   223
 
slouken@0
   224
       //return a palette if we are in 256 color mode           
slouken@0
   225
		if(vformat->BitsPerPixel == 8)
slouken@0
   226
		{
slouken@0
   227
			vformat->palette = malloc(sizeof(SDL_Palette));
slouken@0
   228
			memset(vformat->palette, 0, sizeof(SDL_Palette));
slouken@0
   229
			vformat->palette->ncolors = 256;
slouken@0
   230
			vformat->palette->colors = (SDL_Color *)malloc(256 *sizeof(SDL_Color));
slouken@0
   231
			
slouken@0
   232
			//fill the palette
slouken@0
   233
			rtnval = PgGetPalette(ph_palette);
slouken@0
   234
			if(rtnval < 0)
slouken@0
   235
			   printf("ph_VideoInit:  PgGetPalette failed\n");
slouken@0
   236
			   
slouken@0
   237
       	tempptr = (unsigned long *)vformat->palette->colors;
slouken@0
   238
slouken@0
   239
			for(i=0;i<256; i++)
slouken@0
   240
			{
slouken@0
   241
  				*tempptr = (((unsigned long)ph_palette[i]) << 8);
slouken@0
   242
  				tempptr++;
slouken@0
   243
slouken@0
   244
			}		
slouken@0
   245
		
slouken@0
   246
		}
slouken@0
   247
slouken@0
   248
slouken@19
   249
    currently_fullscreen = 0;
slouken@19
   250
    
slouken@19
   251
    this->info.wm_available = 1;
slouken@19
   252
    
slouken@0
   253
    return 0;
slouken@0
   254
}
slouken@0
   255
slouken@0
   256
static SDL_Surface *ph_SetVideoMode(_THIS, SDL_Surface *current,
slouken@0
   257
                int width, int height, int bpp, Uint32 flags)
slouken@0
   258
{
slouken@0
   259
    PhRegion_t region_info;
slouken@0
   260
    PgDisplaySettings_t settings;
slouken@0
   261
	PgVideoModeInfo_t mode_info;
slouken@0
   262
    int mode, actual_width, actual_height;
slouken@0
   263
	PtArg_t arg[5];
slouken@0
   264
	PhDim_t dim;	
slouken@0
   265
		int rtnval;
slouken@0
   266
	SDL_Rect ** mymodelist;
slouken@0
   267
	SDL_PixelFormat myformat;
slouken@0
   268
	PgColor_t ph_palette[_Pg_MAX_PALETTE];
slouken@0
   269
	int i;
slouken@0
   270
	unsigned long *tempptr;
slouken@0
   271
slouken@0
   272
	actual_width = width;
slouken@0
   273
	actual_height = height;
slouken@0
   274
slouken@0
   275
slouken@0
   276
    /* Lock the event thread, in multi-threading environments */
slouken@0
   277
    SDL_Lock_EventThread();
slouken@0
   278
slouken@0
   279
slouken@0
   280
     /* Initialize the window */
slouken@0
   281
    if (flags & SDL_FULLSCREEN) //Direct Context , assume SDL_HWSURFACE also set
slouken@0
   282
    {
slouken@0
   283
slouken@0
   284
/*  
slouken@0
   285
	if (old_video_mode==-1)
slouken@0
   286
	{
slouken@0
   287
		PgGetGraphicsHWCaps(&graphics_card_caps);
slouken@0
   288
		old_video_mode=graphics_card_caps.current_video_mode;
slouken@0
   289
		old_refresh_rate=graphics_card_caps.current_rrate;
slouken@0
   290
	}
slouken@0
   291
*/    	
slouken@0
   292
    	  	
slouken@0
   293
    	  	  	
slouken@0
   294
    	  	  	  	  	
slouken@0
   295
        /* Get the video mode and set it */
slouken@0
   296
        if (bpp == 0)
slouken@0
   297
        {
slouken@0
   298
            if (PgGetVideoMode( &settings ) < 0)
slouken@0
   299
            {
slouken@0
   300
                fprintf(stderr,"error: PgGetVideoMode failed\n");
slouken@0
   301
            }
slouken@0
   302
            if (PgGetVideoModeInfo(settings.mode, &mode_info) < 0)
slouken@0
   303
            {
slouken@0
   304
                fprintf(stderr,"error: PgGetVideoModeInfo failed\n");
slouken@0
   305
            }
slouken@0
   306
            bpp = mode_info.bits_per_pixel;
slouken@0
   307
        }
slouken@0
   308
        if (flags & SDL_ANYFORMAT)
slouken@0
   309
        {
slouken@0
   310
            if ((mode = get_mode_any_format(width, height, bpp)) == 0)
slouken@0
   311
            {
slouken@0
   312
                fprintf(stderr,"error: get_mode_any_format failed\n");
slouken@0
   313
                exit(1);
slouken@0
   314
            }
slouken@0
   315
        }
slouken@0
   316
        else
slouken@0
   317
        {
slouken@0
   318
            if ((mode = get_mode(width, height, bpp)) == 0)
slouken@0
   319
            {
slouken@0
   320
                 	fprintf(stderr,"error: get_mode failed\n");
slouken@0
   321
                	exit(1);
slouken@0
   322
            }
slouken@0
   323
               
slouken@0
   324
           
slouken@0
   325
        }
slouken@0
   326
        settings.mode = mode;
slouken@0
   327
        settings.refresh = 0;
slouken@0
   328
        settings.flags  = 0;       
slouken@0
   329
             
slouken@0
   330
        
slouken@0
   331
        if (PgSetVideoMode( &settings ) < 0)
slouken@0
   332
        {
slouken@0
   333
            fprintf(stderr,"error: PgSetVideoMode failed\n");
slouken@0
   334
        }
slouken@0
   335
slouken@0
   336
		/* Get the true height and width */
slouken@0
   337
		
slouken@0
   338
      current->flags = (flags|(~SDL_RESIZABLE)); //no resize for Direct Context
slouken@0
   339
slouken@0
   340
		 /* Begin direct mode */
slouken@0
   341
		 ph_EnterFullScreen(this);
slouken@0
   342
slouken@0
   343
       
slouken@0
   344
slouken@0
   345
    } //end fullscreen flag
slouken@0
   346
    else if (flags & SDL_HWSURFACE)  /* Use offscreen memory iff SDL_HWSURFACE flag is set */
slouken@0
   347
    {
slouken@0
   348
      // Hardware surface is Offsceen Context.  ph_ResizeImage handles the switch
slouken@0
   349
      current->flags = (flags|(~SDL_RESIZABLE)); //no stretch blit in offscreen context
slouken@0
   350
    }
slouken@0
   351
    else // must be SDL_SWSURFACE
slouken@0
   352
    {
slouken@0
   353
     current->flags = (flags|SDL_RESIZABLE); //yes we can resize as this is a software surface
slouken@0
   354
     }
slouken@0
   355
slouken@0
   356
slouken@0
   357
	//If we are setting video to use the palette make sure we have allocated memory for it
slouken@0
   358
	if(bpp == 8)
slouken@0
   359
	{
slouken@0
   360
		current->format->palette = malloc(sizeof(SDL_Palette));
slouken@0
   361
		memset(current->format->palette, 0, sizeof(SDL_Palette));
slouken@0
   362
		current->format->palette->ncolors = 256;
slouken@0
   363
		current->format->palette->colors = (SDL_Color *)malloc(256 *sizeof(SDL_Color));
slouken@0
   364
		//fill the palette
slouken@0
   365
		rtnval = PgGetPalette(ph_palette);
slouken@0
   366
slouken@0
   367
       tempptr = (unsigned long *)current->format->palette->colors;
slouken@0
   368
slouken@0
   369
		for(i=0;i<256; i++)
slouken@0
   370
		{
slouken@0
   371
  			*tempptr = (((unsigned long)ph_palette[i]) << 8);
slouken@0
   372
  			tempptr++;
slouken@0
   373
slouken@0
   374
		}
slouken@0
   375
	}
slouken@0
   376
slouken@0
   377
slouken@0
   378
	//Current window dimensions
slouken@0
   379
	PtGetResource( window, Pt_ARG_DIM, &dim, 0 );
slouken@0
   380
	
slouken@0
   381
	//If we need to resize the window
slouken@0
   382
	if((dim.w != width)||(dim.h != height))
slouken@0
   383
	{
slouken@0
   384
	    dim.w=width;
slouken@0
   385
    	dim.h=height; 
slouken@0
   386
    	PtSetArg(&arg[0], Pt_ARG_DIM, &dim,0);
slouken@0
   387
		PtSetResources( window, 1, arg ); 	
slouken@0
   388
       current->w = width;
slouken@0
   389
       current->h = height;
slouken@0
   390
       current->format->BitsPerPixel = bpp;
slouken@0
   391
		current->format->BytesPerPixel = bpp/8;
slouken@0
   392
       current->pitch = SDL_CalculatePitch(current);
slouken@0
   393
       //Must call at least once it setup image planes 
slouken@0
   394
       ph_ResizeImage(this, current, flags);
slouken@0
   395
    }
slouken@0
   396
slouken@0
   397
slouken@0
   398
    SDL_Unlock_EventThread();
slouken@0
   399
slouken@0
   400
    /* We're done! */
slouken@0
   401
    return(current);
slouken@0
   402
}
slouken@0
   403
slouken@0
   404
static void ph_VideoQuit(_THIS)
slouken@0
   405
{
slouken@0
   406
		
slouken@0
   407
	if(SDL_Image != NULL)
slouken@0
   408
	{
slouken@0
   409
	  	    ph_DestroyImage(this, SDL_VideoSurface); 
slouken@0
   410
	
slouken@0
   411
	}
slouken@0
   412
slouken@0
   413
	if (currently_fullscreen)
slouken@0
   414
	{
slouken@0
   415
		PdDirectStop( directContext );
slouken@0
   416
		PdReleaseDirectContext( directContext );
slouken@0
   417
		directContext=0;	
slouken@0
   418
		currently_fullscreen = 0;
slouken@0
   419
	}
slouken@0
   420
	
slouken@0
   421
}
slouken@0
   422
slouken@0
   423
slouken@0
   424
static int ph_SetColors(_THIS, int firstcolor, int ncolors, SDL_Color *colors)
slouken@0
   425
{
slouken@0
   426
	PgColor_t *in, *out;
slouken@0
   427
	int i, j;
slouken@0
   428
	int alloct_all = 1;
slouken@0
   429
slouken@0
   430
    	colors = this->screen->format->palette->colors;
slouken@0
   431
slouken@0
   432
	in = alloca( ncolors*sizeof(PgColor_t)  );
slouken@0
   433
	if ( in == NULL  ) {
slouken@0
   434
		return 0;
slouken@0
   435
	}
slouken@0
   436
	memset(in,0,ncolors*sizeof(PgColor_t));
slouken@0
   437
slouken@0
   438
    out = alloca( ncolors*sizeof(PgColor_t)  );
slouken@0
   439
    if ( out == NULL  ) {
slouken@0
   440
		return 0;
slouken@0
   441
    }
slouken@0
   442
	
slouken@0
   443
	for (i=0,j=firstcolor;i<ncolors;i++,j++)
slouken@0
   444
	{
slouken@0
   445
		in[i] |= colors[j].r<<16 ;
slouken@0
   446
		in[i] |= colors[j].g<<8 ;
slouken@0
   447
		in[i] |= colors[j].b ; 
slouken@0
   448
	}
slouken@0
   449
slouken@0
   450
	if ( (this->screen->flags & SDL_HWPALETTE) == SDL_HWPALETTE ) 
slouken@0
   451
	{
slouken@0
   452
		if( PgSetPalette( in, 0, 0, ncolors, Pg_PALSET_HARD, 0) < 0 )
slouken@0
   453
		{
slouken@0
   454
			fprintf(stderr,"error: PgSetPalette(..,Pg_PALSET_HARD)  failed\n");
slouken@0
   455
			return 0;
slouken@0
   456
		}  
slouken@0
   457
	}
slouken@0
   458
	else 
slouken@0
   459
	{
slouken@0
   460
		if ( PgColorMatch(ncolors, in, out) < 0 )
slouken@0
   461
        {
slouken@0
   462
            fprintf(stderr,"error: PgColorMatch failed\n");
slouken@0
   463
            return 0;
slouken@0
   464
        }
slouken@0
   465
		for (i=0;i<ncolors;i++)
slouken@0
   466
		{
slouken@0
   467
			if (memcmp(&in[i],&out[i],sizeof(PgColor_t)))
slouken@0
   468
			{
slouken@0
   469
				alloct_all = 0;
slouken@0
   470
				break;
slouken@0
   471
			}
slouken@0
   472
		}
slouken@0
   473
        if( PgSetPalette( out, 0, 0, ncolors, Pg_PALSET_SOFT, 0) < 0 )
slouken@0
   474
        {
slouken@0
   475
            fprintf(stderr,"error: PgSetPalette(..,Pg_PALSET_SOFT) failed\n");
slouken@0
   476
            return 0;
slouken@0
   477
        }
slouken@0
   478
	}
slouken@0
   479
	return alloct_all;
slouken@0
   480
}
slouken@0
   481
slouken@0
   482
static int ph_ResizeWindow(_THIS,
slouken@0
   483
            SDL_Surface *screen, int w, int h, Uint32 flags)
slouken@0
   484
{
slouken@0
   485
	PhWindowEvent_t winevent;
slouken@0
   486
slouken@0
   487
	memset( &winevent, 0, sizeof(winevent) ); 
slouken@0
   488
	winevent.event_f = Ph_WM_RESIZE;
slouken@0
   489
	winevent.size.w = w;
slouken@0
   490
	winevent.size.h = h;
slouken@0
   491
	winevent.rid = PtWidgetRid( window );
slouken@0
   492
	if (PtForwardWindowEvent( &winevent ) < 0)
slouken@0
   493
	{
slouken@0
   494
		fprintf(stderr,"error: PtForwardWindowEvent failed.\n");
slouken@0
   495
	}
slouken@0
   496
	current_w = w;
slouken@0
   497
	current_h = h;
slouken@0
   498
    return(0);
slouken@0
   499
}
slouken@0
   500
slouken@0
   501