mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-07 05:24:46 +01:00
Work when initialized with a null instance of DrawCtxt. (All calls
into java world come from java so no guard against that needed.)
This commit is contained in:
parent
cd89ede3c5
commit
f7c8a2f384
2 changed files with 30 additions and 24 deletions
|
@ -31,7 +31,7 @@ enum {
|
||||||
typedef struct _AndDraw {
|
typedef struct _AndDraw {
|
||||||
DrawCtxVTable* vtable;
|
DrawCtxVTable* vtable;
|
||||||
JNIEnv** env;
|
JNIEnv** env;
|
||||||
jobject j_draw; /* global ref; free it! */
|
jobject jdraw; /* global ref; free it! */
|
||||||
jobject jCache[JCACHE_COUNT];
|
jobject jCache[JCACHE_COUNT];
|
||||||
MPSLOT
|
MPSLOT
|
||||||
} AndDraw;
|
} AndDraw;
|
||||||
|
@ -109,7 +109,7 @@ makeDSI( AndDraw* draw, int indx, const DrawScoreInfo* dsi )
|
||||||
#define DRAW_CBK_HEADER(nam,sig) \
|
#define DRAW_CBK_HEADER(nam,sig) \
|
||||||
AndDraw* draw = (AndDraw*)dctx; \
|
AndDraw* draw = (AndDraw*)dctx; \
|
||||||
JNIEnv* env = *draw->env; \
|
JNIEnv* env = *draw->env; \
|
||||||
jmethodID mid = getMethodID( env, draw->j_draw, nam, sig );
|
jmethodID mid = getMethodID( env, draw->jdraw, nam, sig );
|
||||||
|
|
||||||
static void
|
static void
|
||||||
and_draw_scoreBegin( DrawCtx* dctx, const XP_Rect* rect,
|
and_draw_scoreBegin( DrawCtx* dctx, const XP_Rect* rect,
|
||||||
|
@ -127,7 +127,7 @@ and_draw_scoreBegin( DrawCtx* dctx, const XP_Rect* rect,
|
||||||
jintArray jscores = makeIntArray( env, numPlayers, jarr );
|
jintArray jscores = makeIntArray( env, numPlayers, jarr );
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, numPlayers, jscores, remCount, dfs );
|
jrect, numPlayers, jscores, remCount, dfs );
|
||||||
|
|
||||||
(*env)->DeleteLocalRef( env, jscores );
|
(*env)->DeleteLocalRef( env, jscores );
|
||||||
|
@ -144,7 +144,7 @@ and_draw_measureRemText( DrawCtx* dctx, const XP_Rect* r,
|
||||||
jintArray heightArray = makeIntArray( env, 1, NULL );
|
jintArray heightArray = makeIntArray( env, 1, NULL );
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, r );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, r );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid, jrect, nTilesLeft,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid, jrect, nTilesLeft,
|
||||||
widthArray, heightArray );
|
widthArray, heightArray );
|
||||||
|
|
||||||
*width = getIntFromArray( env, widthArray, true );
|
*width = getIntFromArray( env, widthArray, true );
|
||||||
|
@ -167,7 +167,7 @@ and_draw_measureScoreText( DrawCtx* dctx,
|
||||||
jintArray widthArray = makeIntArray( env, 1, NULL );
|
jintArray widthArray = makeIntArray( env, 1, NULL );
|
||||||
jintArray heightArray = makeIntArray( env, 1, NULL );
|
jintArray heightArray = makeIntArray( env, 1, NULL );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid, jrect, jdsi,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid, jrect, jdsi,
|
||||||
widthArray, heightArray );
|
widthArray, heightArray );
|
||||||
|
|
||||||
*width = getIntFromArray( env, widthArray, true );
|
*width = getIntFromArray( env, widthArray, true );
|
||||||
|
@ -185,7 +185,7 @@ and_draw_drawRemText( DrawCtx* dctx, const XP_Rect* rInner,
|
||||||
jobject jrinner = makeJRect( draw, JCACHE_RECT0, rInner );
|
jobject jrinner = makeJRect( draw, JCACHE_RECT0, rInner );
|
||||||
jobject jrouter = makeJRect( draw, JCACHE_RECT1, rOuter );
|
jobject jrouter = makeJRect( draw, JCACHE_RECT1, rOuter );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid, jrinner, jrouter,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid, jrinner, jrouter,
|
||||||
nTilesLeft, focussed );
|
nTilesLeft, focussed );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,7 +203,7 @@ and_draw_score_drawPlayer( DrawCtx* dctx,
|
||||||
jobject jrouter = makeJRect( draw, JCACHE_RECT1, rOuter );
|
jobject jrouter = makeJRect( draw, JCACHE_RECT1, rOuter );
|
||||||
jobject jdsi = makeDSI( draw, JCACHE_DSI, dsi );
|
jobject jdsi = makeDSI( draw, JCACHE_DSI, dsi );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid, jrinner, jrouter, jdsi );
|
(*env)->CallVoidMethod( env, draw->jdraw, mid, jrinner, jrouter, jdsi );
|
||||||
} /* and_draw_score_drawPlayer */
|
} /* and_draw_score_drawPlayer */
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
|
@ -226,7 +226,7 @@ and_draw_drawCell( DrawCtx* dctx, const XP_Rect* rect, const XP_UCHAR* text,
|
||||||
}
|
}
|
||||||
|
|
||||||
jobjectArray jbitmaps = !!bitmaps ? makeBitmapsArray( env, bitmaps ) : NULL;
|
jobjectArray jbitmaps = !!bitmaps ? makeBitmapsArray( env, bitmaps ) : NULL;
|
||||||
jboolean result = (*env)->CallBooleanMethod( env, draw->j_draw, mid,
|
jboolean result = (*env)->CallBooleanMethod( env, draw->jdraw, mid,
|
||||||
jrect, jtext, jbitmaps, tile,
|
jrect, jtext, jbitmaps, tile,
|
||||||
owner, bonus, hintAtts,
|
owner, bonus, hintAtts,
|
||||||
flags );
|
flags );
|
||||||
|
@ -247,7 +247,7 @@ and_draw_drawBoardArrow(DrawCtx* dctx, const XP_Rect* rect, XWBonusType bonus,
|
||||||
DRAW_CBK_HEADER("drawBoardArrow", "(Landroid/graphics/Rect;IZII)V" );
|
DRAW_CBK_HEADER("drawBoardArrow", "(Landroid/graphics/Rect;IZII)V" );
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, bonus, vert, hintAtts, flags );
|
jrect, bonus, vert, hintAtts, flags );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -258,7 +258,7 @@ and_draw_vertScrollBoard( DrawCtx* dctx, XP_Rect* rect, XP_S16 dist,
|
||||||
DRAW_CBK_HEADER( "vertScrollBoard", "(Landroid/graphics/Rect;II)Z" );
|
DRAW_CBK_HEADER( "vertScrollBoard", "(Landroid/graphics/Rect;II)Z" );
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
jboolean result = (*env)->CallBooleanMethod( env, draw->j_draw, mid,
|
jboolean result = (*env)->CallBooleanMethod( env, draw->jdraw, mid,
|
||||||
jrect, dist, dfs );
|
jrect, dist, dfs );
|
||||||
copyJRect( env, rect, jrect );
|
copyJRect( env, rect, jrect );
|
||||||
|
|
||||||
|
@ -273,7 +273,7 @@ and_draw_trayBegin( DrawCtx* dctx, const XP_Rect* rect, XP_U16 owner,
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
|
|
||||||
jboolean result = (*env)->CallBooleanMethod( env, draw->j_draw, mid,
|
jboolean result = (*env)->CallBooleanMethod( env, draw->jdraw, mid,
|
||||||
jrect, owner, (jint)dfs );
|
jrect, owner, (jint)dfs );
|
||||||
|
|
||||||
return XP_TRUE;
|
return XP_TRUE;
|
||||||
|
@ -292,7 +292,7 @@ and_draw_drawTile( DrawCtx* dctx, const XP_Rect* rect, const XP_UCHAR* text,
|
||||||
}
|
}
|
||||||
|
|
||||||
jobjectArray jbitmaps = makeBitmapsArray( env, bitmaps );
|
jobjectArray jbitmaps = makeBitmapsArray( env, bitmaps );
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, jtext, jbitmaps, val, flags );
|
jrect, jtext, jbitmaps, val, flags );
|
||||||
|
|
||||||
if ( !!jtext ) {
|
if ( !!jtext ) {
|
||||||
|
@ -319,7 +319,7 @@ and_draw_drawTileMidDrag( DrawCtx* dctx, const XP_Rect* rect,
|
||||||
}
|
}
|
||||||
|
|
||||||
jobjectArray jbitmaps = makeBitmapsArray( env, bitmaps );
|
jobjectArray jbitmaps = makeBitmapsArray( env, bitmaps );
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, jtext, jbitmaps, val, owner, flags );
|
jrect, jtext, jbitmaps, val, owner, flags );
|
||||||
|
|
||||||
if ( !!jtext ) {
|
if ( !!jtext ) {
|
||||||
|
@ -337,7 +337,7 @@ and_draw_drawTileBack( DrawCtx* dctx, const XP_Rect* rect, CellFlags flags )
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, flags );
|
jrect, flags );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -348,7 +348,7 @@ and_draw_drawTrayDivider( DrawCtx* dctx, const XP_Rect* rect, CellFlags flags )
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, flags );
|
jrect, flags );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -361,7 +361,7 @@ and_draw_score_pendingScore( DrawCtx* dctx, const XP_Rect* rect,
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
|
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
jrect, score, playerNum, flags );
|
jrect, score, playerNum, flags );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -373,7 +373,7 @@ and_draw_objFinished( DrawCtx* dctx, BoardObjectType typ,
|
||||||
DRAW_CBK_HEADER( "objFinished", "(ILandroid/graphics/Rect;I)V" );
|
DRAW_CBK_HEADER( "objFinished", "(ILandroid/graphics/Rect;I)V" );
|
||||||
|
|
||||||
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
jobject jrect = makeJRect( draw, JCACHE_RECT0, rect );
|
||||||
(*env)->CallVoidMethod( env, draw->j_draw, mid,
|
(*env)->CallVoidMethod( env, draw->jdraw, mid,
|
||||||
(jint)typ, jrect, (jint)dfs );
|
(jint)typ, jrect, (jint)dfs );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -412,12 +412,14 @@ draw_doNothing( DrawCtx* dctx, ... )
|
||||||
} /* draw_doNothing */
|
} /* draw_doNothing */
|
||||||
|
|
||||||
DrawCtx*
|
DrawCtx*
|
||||||
makeDraw( MPFORMAL JNIEnv** envp, jobject j_draw )
|
makeDraw( MPFORMAL JNIEnv** envp, jobject jdraw )
|
||||||
{
|
{
|
||||||
AndDraw* draw = (AndDraw*)XP_CALLOC( mpool, sizeof(*draw) );
|
AndDraw* draw = (AndDraw*)XP_CALLOC( mpool, sizeof(*draw) );
|
||||||
JNIEnv* env = *envp;
|
JNIEnv* env = *envp;
|
||||||
draw->vtable = XP_MALLOC( mpool, sizeof(*draw->vtable) );
|
draw->vtable = XP_MALLOC( mpool, sizeof(*draw->vtable) );
|
||||||
draw->j_draw = (*env)->NewGlobalRef( env, j_draw );
|
if ( NULL != jdraw ) {
|
||||||
|
draw->jdraw = (*env)->NewGlobalRef( env, jdraw );
|
||||||
|
}
|
||||||
draw->env = envp;
|
draw->env = envp;
|
||||||
MPASSIGN( draw->mpool, mpool );
|
MPASSIGN( draw->mpool, mpool );
|
||||||
|
|
||||||
|
@ -452,16 +454,18 @@ makeDraw( MPFORMAL JNIEnv** envp, jobject j_draw )
|
||||||
SET_PROC(drawMiniWindow);
|
SET_PROC(drawMiniWindow);
|
||||||
|
|
||||||
#undef SET_PROC
|
#undef SET_PROC
|
||||||
|
|
||||||
return (DrawCtx*)draw;
|
return (DrawCtx*)draw;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
destroyDraw( DrawCtx* dctx )
|
destroyDraw( DrawCtx** dctx )
|
||||||
{
|
{
|
||||||
AndDraw* draw = (AndDraw*)dctx;
|
LOG_FUNC();
|
||||||
|
AndDraw* draw = (AndDraw*)*dctx;
|
||||||
JNIEnv* env = *draw->env;
|
JNIEnv* env = *draw->env;
|
||||||
(*env)->DeleteGlobalRef( env, draw->j_draw );
|
if ( NULL != draw->jdraw ) {
|
||||||
|
(*env)->DeleteGlobalRef( env, draw->jdraw );
|
||||||
|
}
|
||||||
|
|
||||||
int ii;
|
int ii;
|
||||||
for ( ii = 0; ii < JCACHE_COUNT; ++ii ) {
|
for ( ii = 0; ii < JCACHE_COUNT; ++ii ) {
|
||||||
|
@ -473,4 +477,6 @@ destroyDraw( DrawCtx* dctx )
|
||||||
|
|
||||||
XP_FREE( draw->mpool, draw->vtable );
|
XP_FREE( draw->mpool, draw->vtable );
|
||||||
XP_FREE( draw->mpool, draw );
|
XP_FREE( draw->mpool, draw );
|
||||||
|
*dctx = NULL;
|
||||||
|
LOG_RETURN_VOID();
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include "draw.h"
|
#include "draw.h"
|
||||||
|
|
||||||
DrawCtx* makeDraw( MPFORMAL JNIEnv** env, jobject j_draw );
|
DrawCtx* makeDraw( MPFORMAL JNIEnv** env, jobject j_draw );
|
||||||
void destroyDraw( DrawCtx* dctx );
|
void destroyDraw( DrawCtx** dctx );
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue