Merge remote branch 'origin/send_in_background' into send_in_background

This commit is contained in:
eehouse@eehouse.org 2011-11-23 17:57:54 -08:00 committed by Andy2
commit 93a7d15a5e
5 changed files with 76 additions and 64 deletions

View file

@ -1267,10 +1267,9 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
|| comms->r.myHostID == srcID ); || comms->r.myHostID == srcID );
if ( 0 == comms->r.cookieID ) { if ( 0 == comms->r.cookieID ) {
XP_LOGF( "%s: cookieID still 0; most likely packet was lost", XP_LOGF( "%s: cookieID still 0; background send?",
__func__ ); __func__ );
comms_transportFailed( comms ); }
} else {
comms->r.myHostID = srcID; comms->r.myHostID = srcID;
XP_LOGF( "%s: set hostid: %x", __func__, comms->r.myHostID ); XP_LOGF( "%s: set hostid: %x", __func__, comms->r.myHostID );
@ -1281,7 +1280,8 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
stringFromStreamHere( stream, connName, sizeof(connName) ); stringFromStreamHere( stream, connName, sizeof(connName) );
XP_ASSERT( comms->r.connName[0] == '\0' XP_ASSERT( comms->r.connName[0] == '\0'
|| 0 == XP_STRCMP( comms->r.connName, connName ) ); || 0 == XP_STRCMP( comms->r.connName, connName ) );
XP_MEMCPY( comms->r.connName, connName, sizeof(comms->r.connName) ); XP_MEMCPY( comms->r.connName, connName,
sizeof(comms->r.connName) );
XP_LOGF( "%s: connName: \"%s\"", __func__, connName ); XP_LOGF( "%s: connName: \"%s\"", __func__, connName );
} }
#else #else
@ -1290,10 +1290,11 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
#endif #endif
/* We're [re-]connected now. Send any pending messages. This may /* We're [re-]connected now. Send any pending messages. This may
need to be done later since we're inside the platform's socket read need to be done later since we're inside the platform's socket
proc now. But don't resend if we were previously REconnected, as read proc now. But don't resend if we were previously
we'll have sent then. -- I don't see any send on RECONNECTED, so REconnected, as we'll have sent then. -- I don't see any send
removing the test for now to fix recon problems on android. */ on RECONNECTED, so removing the test for now to fix recon
problems on android. */
/* if ( COMMS_RELAYSTATE_RECONNECTED != comms->r.relayState ) { */ /* if ( COMMS_RELAYSTATE_RECONNECTED != comms->r.relayState ) { */
comms_resendAll( comms ); comms_resendAll( comms );
/* } */ /* } */
@ -1303,7 +1304,6 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
comms->r.myHostID, XP_TRUE, 0 ); comms->r.myHostID, XP_TRUE, 0 );
} }
set_relay_state( comms, COMMS_RELAYSTATE_ALLCONNECTED ); set_relay_state( comms, COMMS_RELAYSTATE_ALLCONNECTED );
}
break; break;
case XWRELAY_MSG_FROMRELAY: case XWRELAY_MSG_FROMRELAY:
cookieID = stream_getU16( stream ); cookieID = stream_getU16( stream );

View file

@ -483,32 +483,35 @@ formatConfirmTrade( const XP_UCHAR** tiles, XP_U16 nTiles,
typedef struct _MsgRec { typedef struct _MsgRec {
XP_U8* msg; XP_U8* msg;
XP_U16 len; XP_U16 msglen;
gchar* relayID;
} MsgRec; } MsgRec;
void void
initNoConnStorage( CommonGlobals* cGlobals ) initNoConnStorage( CommonGlobals* cGlobals )
{ {
XP_ASSERT( NULL == cGlobals->noConnMsgs ); XP_ASSERT( NULL == cGlobals->noConnMsgs );
cGlobals->noConnMsgs = (GSList*)-1; /* -1 is flag meaning "use me" */ cGlobals->noConnMsgs = g_hash_table_new( g_str_hash, g_str_equal );
} }
XP_Bool XP_Bool
storeNoConnMsg( CommonGlobals* cGlobals, const XP_U8* msg, XP_U16 len, storeNoConnMsg( CommonGlobals* cGlobals, const XP_U8* msg, XP_U16 msglen,
const XP_UCHAR* relayID ) const XP_UCHAR* relayID )
{ {
XP_ASSERT( 0 < msglen );
XP_Bool inUse = NULL != cGlobals->noConnMsgs; XP_Bool inUse = NULL != cGlobals->noConnMsgs;
if ( inUse ) { if ( inUse ) {
if ( (GSList*)-1 == cGlobals->noConnMsgs ) { GSList* list = g_hash_table_lookup( cGlobals->noConnMsgs, relayID );
cGlobals->noConnMsgs = NULL; gboolean missing = NULL == list;
}
MsgRec* msgrec = g_malloc( sizeof(*msgrec) ); MsgRec* msgrec = g_malloc( sizeof(*msgrec) );
msgrec->msg = g_malloc( len ); msgrec->msg = g_malloc( msglen );
XP_MEMCPY( msgrec->msg, msg, len ); XP_MEMCPY( msgrec->msg, msg, msglen );
msgrec->len = len; msgrec->msglen = msglen;
msgrec->relayID = g_strdup( relayID ); list = g_slist_append( list, msgrec );
cGlobals->noConnMsgs = g_slist_append( cGlobals->noConnMsgs, msgrec ); if ( missing ) {
gchar* key = g_strdup( relayID ); /* will leak */
g_hash_table_insert( cGlobals->noConnMsgs, key, list );
}
} }
return inUse; return inUse;
} }
@ -516,12 +519,14 @@ storeNoConnMsg( CommonGlobals* cGlobals, const XP_U8* msg, XP_U16 len,
void void
writeNoConnMsgs( CommonGlobals* cGlobals, int fd ) writeNoConnMsgs( CommonGlobals* cGlobals, int fd )
{ {
guint nMsgs = (GSList*)-1 == cGlobals->noConnMsgs ? GHashTable* hash = cGlobals->noConnMsgs;
0 : g_slist_length( cGlobals->noConnMsgs ); GList* keys = g_hash_table_get_keys( hash );
if ( 0 < nMsgs ) { GList* iter;
gchar relayID[128] = {0}; for ( iter = keys; !!iter; iter = iter->next ) {
XP_UCHAR* relayID = (XP_UCHAR*)iter->data;
strcpy( relayID, ((MsgRec*)(cGlobals->noConnMsgs->data))->relayID ); GSList* list = (GSList*)g_hash_table_lookup( hash, relayID );
guint nMsgs = g_slist_length( list );
XP_ASSERT( 0 < nMsgs );
XWStreamCtxt* stream = XWStreamCtxt* stream =
mem_stream_make( MPPARM(cGlobals->params->util->mpool) mem_stream_make( MPPARM(cGlobals->params->util->mpool)
@ -534,17 +539,14 @@ writeNoConnMsgs( CommonGlobals* cGlobals, int fd )
int ii; int ii;
for ( ii = 0; ii < nMsgs; ++ii ) { for ( ii = 0; ii < nMsgs; ++ii ) {
MsgRec* rec = g_slist_nth_data( cGlobals->noConnMsgs, ii ); MsgRec* rec = g_slist_nth_data( list, ii );
stream_putU16( stream, rec->len ); stream_putU16( stream, rec->msglen );
stream_putBytes( stream, rec->msg, rec->len ); stream_putBytes( stream, rec->msg, rec->msglen );
g_free( rec->msg ); g_free( rec->msg );
XP_ASSERT( 0 == strcmp( relayID, rec->relayID ) );
g_free( rec->relayID );
g_free( rec ); g_free( rec );
} }
g_slist_free( cGlobals->noConnMsgs ); g_slist_free( list );
cGlobals->noConnMsgs = NULL;
XP_U16 siz = stream_getSize( stream ); XP_U16 siz = stream_getSize( stream );
/* XP_U8 buf[siz]; */ /* XP_U8 buf[siz]; */
@ -556,6 +558,9 @@ writeNoConnMsgs( CommonGlobals* cGlobals, int fd )
XP_ASSERT( nwritten == siz ); XP_ASSERT( nwritten == siz );
stream_destroy( stream ); stream_destroy( stream );
} }
g_list_free( keys );
g_hash_table_unref( hash );
cGlobals->noConnMsgs = NULL;
} /* writeNoConnMsgs */ } /* writeNoConnMsgs */
#ifdef TEXT_MODEL #ifdef TEXT_MODEL

View file

@ -163,7 +163,8 @@ struct CommonGlobals {
AddAcceptorFunc addAcceptor; AddAcceptorFunc addAcceptor;
Acceptor acceptor; Acceptor acceptor;
GSList* noConnMsgs; /* hash by relayID of lists of messages */
GHashTable* noConnMsgs;
#ifdef XWFEATURE_RELAY #ifdef XWFEATURE_RELAY
int socket; /* relay */ int socket; /* relay */

View file

@ -5,6 +5,7 @@ set -e -u
SEED="" SEED=""
RELAY_LOG="../relay/xwrelay.log" RELAY_LOG="../relay/xwrelay.log"
NDEVS=${NDEVS:-2}
usage() { usage() {
echo "usage: $(basename $0) [--seed RANDOM_SEED]" echo "usage: $(basename $0) [--seed RANDOM_SEED]"
@ -38,7 +39,10 @@ DIR=$(basename $0)_$PID
DICT=dict.xwd DICT=dict.xwd
APP=./obj_linux_memdbg/xwords APP=./obj_linux_memdbg/xwords
COMMON_ARGS="--room $ROOM --curses --robot Eric --remote-player --game-dict $DICT --quit-after 2" COMMON_ARGS="--room $ROOM --curses --robot Eric --game-dict $DICT --quit-after 2"
for NUM in $(seq 2 $NDEVS); do
COMMON_ARGS="$COMMON_ARGS --remote-player"
done
mkdir -p $DIR mkdir -p $DIR
@ -50,7 +54,7 @@ else
fi fi
# Run once to connect each with the relay # Run once to connect each with the relay
for NUM in $(seq 1 2); do for NUM in $(seq 1 $((NDEVS))); do
LOG="$(logname $NUM)" LOG="$(logname $NUM)"
ARGS=$COMMON_ARGS ARGS=$COMMON_ARGS
if [ -n "$SEED" ]; then if [ -n "$SEED" ]; then
@ -58,7 +62,7 @@ for NUM in $(seq 1 2); do
fi fi
$APP $ARGS --file $DIR/game_${NUM}.xwg > /dev/null 2>>$LOG & $APP $ARGS --file $DIR/game_${NUM}.xwg > /dev/null 2>>$LOG &
PID1=$! PID1=$!
sleep 4 sleep 2
kill $PID1 kill $PID1
wait $PID1 wait $PID1
done done
@ -68,7 +72,7 @@ NBS=$DIR/nbs
ZERO_COUNT=0 ZERO_COUNT=0
while [ $ZERO_COUNT -lt 2 ]; do while [ $ZERO_COUNT -lt 2 ]; do
WORK_DONE="" WORK_DONE=""
for NUM in $(seq 1 2); do for NUM in $(seq 1 $((NDEVS))); do
LOG="$(logname $NUM)" LOG="$(logname $NUM)"
RELAYID=$(./scripts/relayID.sh --short $LOG) RELAYID=$(./scripts/relayID.sh --short $LOG)
MSG_COUNT=$(../relay/rq -m $RELAYID 2>/dev/null | sed 's,^.*-- ,,') MSG_COUNT=$(../relay/rq -m $RELAYID 2>/dev/null | sed 's,^.*-- ,,')
@ -79,7 +83,8 @@ while [ $ZERO_COUNT -lt 2 ]; do
if [ -n "$SEED" ]; then if [ -n "$SEED" ]; then
ARGS="$ARGS --seed $((SEED+NUM))" ARGS="$ARGS --seed $((SEED+NUM))"
fi fi
$APP $ARGS --file $DIR/game_${NUM}.xwg --with-nbs $NBS > /dev/null 2>>$LOG & $APP $ARGS --file $DIR/game_${NUM}.xwg --with-nbs $NBS \
> /dev/null 2>>$LOG &
PID1=$! PID1=$!
../relay/rq -f $RELAYID -b $NBS ../relay/rq -f $RELAYID -b $NBS
@ -98,7 +103,7 @@ done
# the game's over. Strictly speaking we need to get beyond that, but # the game's over. Strictly speaking we need to get beyond that, but
# reaching it is the first step. Debug failure to get that far first. # reaching it is the first step. Debug failure to get that far first.
ENDED="" ENDED=""
for NUM in $(seq 1 2); do for NUM in $(seq 1 $((NDEVS))); do
LOG="$(logname $NUM)" LOG="$(logname $NUM)"
if grep -q 'waiting for server to end game' $LOG; then if grep -q 'waiting for server to end game' $LOG; then
ENDED=1 ENDED=1
@ -107,7 +112,7 @@ for NUM in $(seq 1 2); do
done done
if [ -z "$ENDED" ]; then if [ -z "$ENDED" ]; then
for NUM in $(seq 1 2); do for NUM in $(seq 1 $((NDEVS))); do
LOG="$(logname $NUM)" LOG="$(logname $NUM)"
if ! grep -q 'all remaining tiles' $LOG; then if ! grep -q 'all remaining tiles' $LOG; then
echo "$LOG didn't seem to end correctly" echo "$LOG didn't seem to end correctly"

View file

@ -390,7 +390,8 @@ do_deletes( int sockfd, const char** connNames, int nConnNames )
char buf[4096]; char buf[4096];
int nused = 0; int nused = 0;
for ( ii = 0; ii < nConnNames; ++ii ) { for ( ii = 0; ii < nConnNames; ++ii ) {
char tmp[32]; char tmp[128];
assert( strlen(connNames[ii]) < sizeof(tmp)-1 );
strcpy( tmp, connNames[ii] ); strcpy( tmp, connNames[ii] );
char* seedp = strrchr( tmp, '/' ); char* seedp = strrchr( tmp, '/' );
assert( !!seedp ); assert( !!seedp );