From c41ee8f7e365eabcc5391cb953c9c81af34c6bb6 Mon Sep 17 00:00:00 2001 From: Don Heyse Date: Thu, 28 Nov 2002 23:09:47 +0000 Subject: [PATCH] Fixes from freeglut_portable patch. Memory leak fix from John. Return_if_fail fix. git-svn-id: svn+ssh://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@30 7f0cb862-5218-0410-a997-914c9d46530a --- freeglut-1.3/freeglut_joystick.c | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/freeglut-1.3/freeglut_joystick.c b/freeglut-1.3/freeglut_joystick.c index 202e576..8619b79 100644 --- a/freeglut-1.3/freeglut_joystick.c +++ b/freeglut-1.3/freeglut_joystick.c @@ -126,7 +126,7 @@ struct tagSFG_Joystick int tmp_buttons; float tmp_axes[ _JS_MAX_AXES ]; # else - JS_DATA_TYPE js; + struct JS_DATA_TYPE js; # endif char fname[ 128 ]; @@ -251,7 +251,7 @@ static void fghJoystickRawRead ( SFG_Joystick* joy, int* buttons, float* axes ) if( status != JS_RETURN ) { - g_warning( fname ); + g_warning( joy->fname ); joy->error = TRUE; return; } @@ -466,9 +466,9 @@ static void fghJoystickOpen( SFG_Joystick* joy ) do { - fghJoystickRawRead( joy, NULL, center ); + fghJoystickRawRead( joy, NULL, joy->center ) counter++; - } while( !joy->error && counter < 100 && center[ 0 ] == 512.0f && center[ 1 ] == 512.0f ); + } while( !joy->error && counter < 100 && joy->center[ 0 ] == 512.0f && joy->center[ 1 ] == 512.0f ); if( counter >= 100 ) joy->error = TRUE; @@ -481,7 +481,7 @@ static void fghJoystickOpen( SFG_Joystick* joy ) joy->center[ i ] = 0.0f; joy->min [ i ] = -32767.0f; # else - joy->max[ i ] = center[ i ] * 2.0f; + joy->max[ i ] = joy->center[ i ] * 2.0f; joy->min[ i ] = 0.0f; # endif joy->dead_band[ i ] = 0.0f ; @@ -542,6 +542,8 @@ void fgJoystickClose( void ) if( fgJoystick->error != TRUE ) close( fgJoystick->fd ); #endif + + free ( fgJoystick ) ; } /* @@ -557,8 +559,8 @@ void fgJoystickPollWindow( SFG_Window* window ) * Make sure the joystick device is initialized, the window seems valid * and that there is a joystick callback hooked to it: */ - freeglut_return_if_fail( fgJoystick == NULL || window == NULL ); - freeglut_return_if_fail( window->Callbacks.Joystick == NULL ); + freeglut_return_if_fail( fgJoystick != NULL && window != NULL ); + freeglut_return_if_fail( window->Callbacks.Joystick != NULL ); /* * Poll the joystick now: -- 1.7.10.4