diff options
| author | Chia-I Wu <olvaffe@gmail.com> | 2009-09-07 16:59:27 +0800 | 
|---|---|---|
| committer | Brian Paul <brianp@vmware.com> | 2009-09-24 21:48:05 -0600 | 
| commit | dbb8fb8de9a9deca0ae22015e4680f4e631d6d32 (patch) | |
| tree | e89ee4868282337b96a599c5bc8d3a13e04d2e09 /src | |
| parent | 17099f5e19dc0ce65cb4e4110d9d22de803c4e52 (diff) | |
mesa/main: Make FEATURE_pixel_transfer follow feature conventions.
As shown in mfeatures.h, this allows users of pixel.h to work without
knowing if the feature is available.
Diffstat (limited to 'src')
| -rw-r--r-- | src/mesa/main/api_exec.c | 16 | ||||
| -rw-r--r-- | src/mesa/main/pixel.c | 40 | ||||
| -rw-r--r-- | src/mesa/main/pixel.h | 47 | ||||
| -rw-r--r-- | src/mesa/main/state.c | 4 | 
4 files changed, 51 insertions, 56 deletions
| diff --git a/src/mesa/main/api_exec.c b/src/mesa/main/api_exec.c index 02550ae108..39941a1b03 100644 --- a/src/mesa/main/api_exec.c +++ b/src/mesa/main/api_exec.c @@ -93,9 +93,7 @@  #include "macros.h"  #include "matrix.h"  #include "multisample.h" -#if FEATURE_pixel_transfer  #include "pixel.h" -#endif  #include "pixelstore.h"  #include "points.h"  #include "polygon.h" @@ -284,17 +282,9 @@ _mesa_init_exec_table(struct _glapi_table *exec)     SET_MapGrid2f(exec, _mesa_MapGrid2f);  #endif     SET_MultMatrixd(exec, _mesa_MultMatrixd); -#if FEATURE_pixel_transfer -   SET_GetPixelMapfv(exec, _mesa_GetPixelMapfv); -   SET_GetPixelMapuiv(exec, _mesa_GetPixelMapuiv); -   SET_GetPixelMapusv(exec, _mesa_GetPixelMapusv); -   SET_PixelMapfv(exec, _mesa_PixelMapfv); -   SET_PixelMapuiv(exec, _mesa_PixelMapuiv); -   SET_PixelMapusv(exec, _mesa_PixelMapusv); -   SET_PixelTransferf(exec, _mesa_PixelTransferf); -   SET_PixelTransferi(exec, _mesa_PixelTransferi); -   SET_PixelZoom(exec, _mesa_PixelZoom); -#endif + +   _mesa_init_pixel_dispatch(exec); +     SET_PixelStoref(exec, _mesa_PixelStoref);     SET_PointSize(exec, _mesa_PointSize);     SET_PolygonMode(exec, _mesa_PolygonMode); diff --git a/src/mesa/main/pixel.c b/src/mesa/main/pixel.c index fcef6dfd42..3820ebd889 100644 --- a/src/mesa/main/pixel.c +++ b/src/mesa/main/pixel.c @@ -36,13 +36,17 @@  #include "macros.h"  #include "pixel.h"  #include "mtypes.h" +#include "glapi/dispatch.h" + + +#if FEATURE_pixel_transfer  /**********************************************************************/  /*****                    glPixelZoom                             *****/  /**********************************************************************/ -void GLAPIENTRY +static void GLAPIENTRY  _mesa_PixelZoom( GLfloat xfactor, GLfloat yfactor )  {     GET_CURRENT_CONTEXT(ctx); @@ -163,7 +167,7 @@ validate_pbo_access(GLcontext *ctx, struct gl_pixelstore_attrib *pack,  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_PixelMapfv( GLenum map, GLsizei mapsize, const GLfloat *values )  {     GET_CURRENT_CONTEXT(ctx); @@ -205,7 +209,7 @@ _mesa_PixelMapfv( GLenum map, GLsizei mapsize, const GLfloat *values )  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_PixelMapuiv(GLenum map, GLsizei mapsize, const GLuint *values )  {     GLfloat fvalues[MAX_PIXEL_MAP_TABLE]; @@ -261,7 +265,7 @@ _mesa_PixelMapuiv(GLenum map, GLsizei mapsize, const GLuint *values )  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_PixelMapusv(GLenum map, GLsizei mapsize, const GLushort *values )  {     GLfloat fvalues[MAX_PIXEL_MAP_TABLE]; @@ -317,7 +321,7 @@ _mesa_PixelMapusv(GLenum map, GLsizei mapsize, const GLushort *values )  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_GetPixelMapfv( GLenum map, GLfloat *values )  {     GET_CURRENT_CONTEXT(ctx); @@ -362,7 +366,7 @@ _mesa_GetPixelMapfv( GLenum map, GLfloat *values )  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_GetPixelMapuiv( GLenum map, GLuint *values )  {     GET_CURRENT_CONTEXT(ctx); @@ -406,7 +410,7 @@ _mesa_GetPixelMapuiv( GLenum map, GLuint *values )  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_GetPixelMapusv( GLenum map, GLushort *values )  {     GET_CURRENT_CONTEXT(ctx); @@ -468,7 +472,7 @@ _mesa_GetPixelMapusv( GLenum map, GLushort *values )   * Implements glPixelTransfer[fi] whether called immediately or from a   * display list.   */ -void GLAPIENTRY +static void GLAPIENTRY  _mesa_PixelTransferf( GLenum pname, GLfloat param )  {     GET_CURRENT_CONTEXT(ctx); @@ -662,7 +666,7 @@ _mesa_PixelTransferf( GLenum pname, GLfloat param )  } -void GLAPIENTRY +static void GLAPIENTRY  _mesa_PixelTransferi( GLenum pname, GLint param )  {     _mesa_PixelTransferf( pname, (GLfloat) param ); @@ -756,6 +760,24 @@ void _mesa_update_pixel( GLcontext *ctx, GLuint new_state )  } +void +_mesa_init_pixel_dispatch(struct _glapi_table *disp) +{ +   SET_GetPixelMapfv(disp, _mesa_GetPixelMapfv); +   SET_GetPixelMapuiv(disp, _mesa_GetPixelMapuiv); +   SET_GetPixelMapusv(disp, _mesa_GetPixelMapusv); +   SET_PixelMapfv(disp, _mesa_PixelMapfv); +   SET_PixelMapuiv(disp, _mesa_PixelMapuiv); +   SET_PixelMapusv(disp, _mesa_PixelMapusv); +   SET_PixelTransferf(disp, _mesa_PixelTransferf); +   SET_PixelTransferi(disp, _mesa_PixelTransferi); +   SET_PixelZoom(disp, _mesa_PixelZoom); +} + + +#endif /* FEATURE_pixel_transfer */ + +  /**********************************************************************/  /*****                      Initialization                        *****/  /**********************************************************************/ diff --git a/src/mesa/main/pixel.h b/src/mesa/main/pixel.h index cb6c5262a3..f4d3f1efdb 100644 --- a/src/mesa/main/pixel.h +++ b/src/mesa/main/pixel.h @@ -33,48 +33,35 @@  #define PIXEL_H -#include "mtypes.h" +#include "main/mtypes.h" -/** \name API functions */ -/*@{*/ +#if FEATURE_pixel_transfer -extern void GLAPIENTRY -_mesa_GetPixelMapfv( GLenum map, GLfloat *values ); - -extern void GLAPIENTRY -_mesa_GetPixelMapuiv( GLenum map, GLuint *values ); - -extern void GLAPIENTRY -_mesa_GetPixelMapusv( GLenum map, GLushort *values ); - -extern void GLAPIENTRY -_mesa_PixelMapfv( GLenum map, GLsizei mapsize, const GLfloat *values ); - -extern void GLAPIENTRY -_mesa_PixelMapuiv(GLenum map, GLsizei mapsize, const GLuint *values ); - -extern void GLAPIENTRY -_mesa_PixelMapusv(GLenum map, GLsizei mapsize, const GLushort *values ); +extern void  +_mesa_update_pixel( GLcontext *ctx, GLuint newstate ); -extern void GLAPIENTRY -_mesa_PixelTransferf( GLenum pname, GLfloat param ); +extern void +_mesa_init_pixel_dispatch( struct _glapi_table * disp ); -extern void GLAPIENTRY -_mesa_PixelTransferi( GLenum pname, GLint param ); +#else /* FEATURE_pixel_transfer */ -extern void GLAPIENTRY -_mesa_PixelZoom( GLfloat xfactor, GLfloat yfactor ); +static INLINE void +_mesa_update_pixel(GLcontext *ctx, GLuint newstate) +{ +} -/*@}*/ +static INLINE void +_mesa_init_pixel_dispatch(struct _glapi_table *disp) +{ +} +#endif /* FEATURE_pixel_transfer */ -extern void  -_mesa_update_pixel( GLcontext *ctx, GLuint newstate );  extern void   _mesa_init_pixel( GLcontext * ctx );  /*@}*/ -#endif +#endif /* PIXEL_H */ diff --git a/src/mesa/main/state.c b/src/mesa/main/state.c index 140a998df2..f10e6b04b7 100644 --- a/src/mesa/main/state.c +++ b/src/mesa/main/state.c @@ -40,9 +40,7 @@  #include "framebuffer.h"  #include "light.h"  #include "matrix.h" -#if FEATURE_pixel_transfer  #include "pixel.h" -#endif  #include "shader/program.h"  #include "shader/prog_parameter.h"  #include "state.h" @@ -585,10 +583,8 @@ _mesa_update_state_locked( GLcontext *ctx )     if (new_state & (_NEW_STENCIL | _NEW_BUFFERS))        _mesa_update_stencil( ctx ); -#if FEATURE_pixel_transfer     if (new_state & _MESA_NEW_TRANSFER_STATE)        _mesa_update_pixel( ctx, new_state ); -#endif     if (new_state & _DD_NEW_SEPARATE_SPECULAR)        update_separate_specular( ctx ); | 
