Merge branch 'relay_proxy' of ssh://xwords.git.sourceforge.net/gitroot/xwords/xwords into relay_proxy

This commit is contained in:
Eric House 2010-09-24 20:19:50 -07:00
commit ae53ce5ea9
8 changed files with 46 additions and 2 deletions

View file

@ -355,6 +355,15 @@ and_util_remSelected(XW_UtilCtxt* uc)
UTIL_CBK_TAIL(); UTIL_CBK_TAIL();
} }
static void
and_util_setIsServer(XW_UtilCtxt* uc, XP_Bool isServer )
{
/* Change both the C and Java structs, which need to stay in sync */
uc->gameInfo->serverRole = isServer? SERVER_ISSERVER : SERVER_ISCLIENT;
UTIL_CBK_HEADER("setIsServer", "(Z)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, isServer );
UTIL_CBK_TAIL();
}
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static void static void
@ -437,6 +446,7 @@ makeUtil( MPFORMAL JNIEnv** envp, jobject jutil, CurGameInfo* gi,
SET_PROC(getUserString); SET_PROC(getUserString);
SET_PROC(warnIllegalWord); SET_PROC(warnIllegalWord);
SET_PROC(remSelected); SET_PROC(remSelected);
SET_PROC(setIsServer);
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
SET_PROC(addrChange); SET_PROC(addrChange);

View file

@ -731,6 +731,15 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1redoReplacedTiles
return result; return result;
} }
JNIEXPORT void JNICALL
Java_org_eehouse_android_xw4_jni_XwJNI_server_1reset
(JNIEnv* env, jclass C, jint gamePtr )
{
XWJNI_START();
server_reset( state->game.server, state->game.comms );
XWJNI_END();
}
JNIEXPORT void JNICALL JNIEXPORT void JNICALL
Java_org_eehouse_android_xw4_jni_XwJNI_server_1handleUndo Java_org_eehouse_android_xw4_jni_XwJNI_server_1handleUndo
(JNIEnv* env, jclass C, jint gamePtr) (JNIEnv* env, jclass C, jint gamePtr)

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

View file

@ -604,6 +604,21 @@ public class BoardActivity extends Activity implements UtilCtxt {
R.string.tiles_left_title ); R.string.tiles_left_title );
} }
public void setIsServer( boolean isServer )
{
Utils.logf( "setIsServer(%s)", isServer?"true":"false" );
DeviceRole newRole = isServer? DeviceRole.SERVER_ISSERVER
: DeviceRole.SERVER_ISCLIENT;
if ( newRole != m_gi.serverRole ) {
Utils.logf( "new role: %s; old role: %s",
newRole.toString(), m_gi.serverRole.toString() );
m_gi.serverRole = newRole;
if ( !isServer ) {
m_jniThread.handle( JNIThread.JNICmd.CMD_SWITCHCLIENT );
}
}
}
public void setTimer( int why, int when, int handle ) public void setTimer( int why, int when, int handle )
{ {
if ( null != m_timers[why] ) { if ( null != m_timers[why] ) {

View file

@ -459,7 +459,7 @@ public class GameConfig extends Activity implements View.OnClickListener,
m_notNetworkedGame = m_notNetworkedGameCheckbx.isChecked(); m_notNetworkedGame = m_notNetworkedGameCheckbx.isChecked();
m_gi.setServerRole( m_notNetworkedGame m_gi.setServerRole( m_notNetworkedGame
? DeviceRole.SERVER_STANDALONE ? DeviceRole.SERVER_STANDALONE
: DeviceRole.SERVER_ISSERVER ); : DeviceRole.SERVER_ISCLIENT );
loadPlayers(); loadPlayers();
} else if ( m_joinPublicCheck == view ) { } else if ( m_joinPublicCheck == view ) {

View file

@ -44,6 +44,7 @@ public class JNIThread extends Thread {
CMD_DRAW, CMD_DRAW,
CMD_LAYOUT, CMD_LAYOUT,
CMD_START, CMD_START,
CMD_SWITCHCLIENT,
CMD_RESET, CMD_RESET,
CMD_SAVE, CMD_SAVE,
CMD_DO, CMD_DO,
@ -287,6 +288,13 @@ public class JNIThread extends Thread {
} }
draw = XwJNI.server_do( m_jniGamePtr ); draw = XwJNI.server_do( m_jniGamePtr );
break; break;
case CMD_SWITCHCLIENT:
XwJNI.server_reset( m_jniGamePtr );
XwJNI.server_initClientConnection( m_jniGamePtr );
draw = XwJNI.server_do( m_jniGamePtr );
break;
case CMD_DO: case CMD_DO:
if ( nextSame( JNICmd.CMD_DO ) ) { if ( nextSame( JNICmd.CMD_DO ) ) {
continue; continue;

View file

@ -45,9 +45,10 @@ public interface UtilCtxt {
public static final int TIMER_SLOWROBOT = 4; public static final int TIMER_SLOWROBOT = 4;
void setTimer( int why, int when, int handle ); void setTimer( int why, int when, int handle );
void clearTimer( int why ); void clearTimer( int why );
void requestTime(); void requestTime();
void remSelected(); void remSelected();
void setIsServer( boolean isServer );
static final int STRD_ROBOT_TRADED = 1; static final int STRD_ROBOT_TRADED = 1;
static final int STR_ROBOT_MOVED = 2; static final int STR_ROBOT_MOVED = 2;

View file

@ -182,6 +182,7 @@ public class XwJNI {
public static native int model_getNMoves( int gamePtr ); public static native int model_getNMoves( int gamePtr );
// Server // Server
public static native void server_reset( int gamePtr );
public static native void server_handleUndo( int gamePtr ); public static native void server_handleUndo( int gamePtr );
public static native boolean server_do( int gamePtr ); public static native boolean server_do( int gamePtr );
public static native String server_formatDictCounts( int gamePtr, int nCols ); public static native String server_formatDictCounts( int gamePtr, int nCols );