mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-22 07:28:16 +01:00
better display of "sms" message passing
This commit is contained in:
parent
c54eba2ee5
commit
0486b956c8
5 changed files with 32 additions and 18 deletions
|
@ -478,8 +478,8 @@ addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd,
|
||||||
rec->msgs = XP_REALLOC( state->mpool, rec->msgs, (1 + rec->nMsgs) * sizeof(*rec->msgs) );
|
rec->msgs = XP_REALLOC( state->mpool, rec->msgs, (1 + rec->nMsgs) * sizeof(*rec->msgs) );
|
||||||
rec->msgs[rec->nMsgs++] = mRec;
|
rec->msgs[rec->nMsgs++] = mRec;
|
||||||
rec->totalSize += len;
|
rec->totalSize += len;
|
||||||
XP_LOGF( "%s(): added msg to %s of len %d; total now %d", __func__, rec->phone,
|
XP_LOGFF( "added msg to %s of len %d; total now %d", rec->phone, len,
|
||||||
len, rec->totalSize );
|
rec->totalSize );
|
||||||
|
|
||||||
if ( rec->nMsgs == 1 ) {
|
if ( rec->nMsgs == 1 ) {
|
||||||
rec->createSeconds = nowSeconds;
|
rec->createSeconds = nowSeconds;
|
||||||
|
|
|
@ -1547,7 +1547,7 @@ linux_send( const XP_U8* buf, XP_U16 buflen, const XP_UCHAR* XP_UNUSED_DBG(msgNo
|
||||||
|
|
||||||
// use serverphone if I'm a client, else hope one's provided (this is
|
// use serverphone if I'm a client, else hope one's provided (this is
|
||||||
// a reply)
|
// a reply)
|
||||||
nSent = linux_sms_send( cGlobals->params, buf, buflen,
|
nSent = linux_sms_send( cGlobals->params, buf, buflen, msgNo,
|
||||||
addrRec->u.sms.phone, addrRec->u.sms.port,
|
addrRec->u.sms.phone, addrRec->u.sms.port,
|
||||||
gameID );
|
gameID );
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,7 +71,7 @@ typedef struct _LinSMSData {
|
||||||
static gboolean retrySend( gpointer data );
|
static gboolean retrySend( gpointer data );
|
||||||
static void sendOrRetry( LaunchParams* params, SMSMsgArray* arr, SMS_CMD cmd,
|
static void sendOrRetry( LaunchParams* params, SMSMsgArray* arr, SMS_CMD cmd,
|
||||||
XP_U16 waitSecs, const XP_UCHAR* phone, XP_U16 port,
|
XP_U16 waitSecs, const XP_UCHAR* phone, XP_U16 port,
|
||||||
XP_U32 gameID );
|
XP_U32 gameID, const XP_UCHAR* msgNo );
|
||||||
static gint check_for_files( gpointer data );
|
static gint check_for_files( gpointer data );
|
||||||
static gint check_for_files_once( gpointer data );
|
static gint check_for_files_once( gpointer data );
|
||||||
|
|
||||||
|
@ -107,7 +107,7 @@ unlock_queue( LinSMSData* storage )
|
||||||
|
|
||||||
static XP_S16
|
static XP_S16
|
||||||
write_fake_sms( LaunchParams* params, const void* buf, XP_U16 buflen,
|
write_fake_sms( LaunchParams* params, const void* buf, XP_U16 buflen,
|
||||||
const XP_UCHAR* phone, XP_U16 port )
|
const XP_UCHAR* msgNo, const XP_UCHAR* phone, XP_U16 port )
|
||||||
{
|
{
|
||||||
XP_S16 nSent;
|
XP_S16 nSent;
|
||||||
XP_U16 pct = XP_RANDOM() % 100;
|
XP_U16 pct = XP_RANDOM() % 100;
|
||||||
|
@ -132,11 +132,14 @@ write_fake_sms( LaunchParams* params, const void* buf, XP_U16 buflen,
|
||||||
formatQueuePath( phone, port, path, sizeof(path) );
|
formatQueuePath( phone, port, path, sizeof(path) );
|
||||||
|
|
||||||
/* Random-number-based name is fine, as we pick based on age. */
|
/* Random-number-based name is fine, as we pick based on age. */
|
||||||
int rint = makeRandomInt();
|
|
||||||
g_mkdir_with_parents( path, 0777 ); /* just in case */
|
g_mkdir_with_parents( path, 0777 ); /* just in case */
|
||||||
int len = strlen( path );
|
int len = strlen( path );
|
||||||
|
int rint = makeRandomInt();
|
||||||
|
if ( !!msgNo ) {
|
||||||
|
snprintf( &path[len], sizeof(path)-len, "/%s_%u", msgNo, rint );
|
||||||
|
} else {
|
||||||
snprintf( &path[len], sizeof(path)-len, "/%u", rint );
|
snprintf( &path[len], sizeof(path)-len, "/%u", rint );
|
||||||
|
}
|
||||||
XP_UCHAR sms[buflen*2]; /* more like (buflen*4/3) */
|
XP_UCHAR sms[buflen*2]; /* more like (buflen*4/3) */
|
||||||
XP_U16 smslen = sizeof(sms);
|
XP_U16 smslen = sizeof(sms);
|
||||||
binToSms( sms, &smslen, buf, buflen );
|
binToSms( sms, &smslen, buf, buflen );
|
||||||
|
@ -293,20 +296,21 @@ linux_sms_invite( LaunchParams* params, const NetLaunchInfo* nli,
|
||||||
= smsproto_prepOutbound( storage->protoState, INVITE, nli->gameID, nli,
|
= smsproto_prepOutbound( storage->protoState, INVITE, nli->gameID, nli,
|
||||||
sizeof(*nli), toPhone, toPort, XP_FALSE,
|
sizeof(*nli), toPhone, toPort, XP_FALSE,
|
||||||
&waitSecs );
|
&waitSecs );
|
||||||
sendOrRetry( params, arr, INVITE, waitSecs, toPhone, toPort, nli->gameID );
|
sendOrRetry( params, arr, INVITE, waitSecs, toPhone, toPort,
|
||||||
|
nli->gameID, "invite" );
|
||||||
}
|
}
|
||||||
|
|
||||||
XP_S16
|
XP_S16
|
||||||
linux_sms_send( LaunchParams* params, const XP_U8* buf,
|
linux_sms_send( LaunchParams* params, const XP_U8* buf,
|
||||||
XP_U16 buflen, const XP_UCHAR* phone, XP_U16 port,
|
XP_U16 buflen, const XP_UCHAR* msgNo, const XP_UCHAR* phone,
|
||||||
XP_U32 gameID )
|
XP_U16 port, XP_U32 gameID )
|
||||||
{
|
{
|
||||||
LinSMSData* storage = getStorage( params );
|
LinSMSData* storage = getStorage( params );
|
||||||
XP_U16 waitSecs;
|
XP_U16 waitSecs;
|
||||||
SMSMsgArray* arr = smsproto_prepOutbound( storage->protoState, DATA, gameID,
|
SMSMsgArray* arr = smsproto_prepOutbound( storage->protoState, DATA, gameID,
|
||||||
buf, buflen, phone, port,
|
buf, buflen, phone, port,
|
||||||
XP_TRUE, &waitSecs );
|
XP_TRUE, &waitSecs );
|
||||||
sendOrRetry( params, arr, DATA, waitSecs, phone, port, gameID );
|
sendOrRetry( params, arr, DATA, waitSecs, phone, port, gameID, msgNo );
|
||||||
return buflen;
|
return buflen;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -315,19 +319,20 @@ typedef struct _RetryClosure {
|
||||||
SMS_CMD cmd;
|
SMS_CMD cmd;
|
||||||
XP_U16 port;
|
XP_U16 port;
|
||||||
XP_U32 gameID;
|
XP_U32 gameID;
|
||||||
|
XP_UCHAR msgNo[32];
|
||||||
XP_UCHAR phone[32];
|
XP_UCHAR phone[32];
|
||||||
} RetryClosure;
|
} RetryClosure;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
sendOrRetry( LaunchParams* params, SMSMsgArray* arr, SMS_CMD cmd,
|
sendOrRetry( LaunchParams* params, SMSMsgArray* arr, SMS_CMD cmd,
|
||||||
XP_U16 waitSecs, const XP_UCHAR* phone, XP_U16 port,
|
XP_U16 waitSecs, const XP_UCHAR* phone, XP_U16 port,
|
||||||
XP_U32 gameID )
|
XP_U32 gameID, const XP_UCHAR* msgNo )
|
||||||
{
|
{
|
||||||
if ( !!arr ) {
|
if ( !!arr ) {
|
||||||
for ( XP_U16 ii = 0; ii < arr->nMsgs; ++ii ) {
|
for ( XP_U16 ii = 0; ii < arr->nMsgs; ++ii ) {
|
||||||
const SMSMsgNet* msg = &arr->u.msgsNet[ii];
|
const SMSMsgNet* msg = &arr->u.msgsNet[ii];
|
||||||
// doSend( params, msg->data, msg->len, phone, port, gameID );
|
// doSend( params, msg->data, msg->len, phone, port, gameID );
|
||||||
(void)write_fake_sms( params, msg->data, msg->len,
|
(void)write_fake_sms( params, msg->data, msg->len, msgNo,
|
||||||
phone, port );
|
phone, port );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -338,6 +343,7 @@ sendOrRetry( LaunchParams* params, SMSMsgArray* arr, SMS_CMD cmd,
|
||||||
sizeof(*closure) );
|
sizeof(*closure) );
|
||||||
closure->params = params;
|
closure->params = params;
|
||||||
XP_STRCAT( closure->phone, phone );
|
XP_STRCAT( closure->phone, phone );
|
||||||
|
XP_STRCAT( closure->msgNo, msgNo );
|
||||||
closure->port = port;
|
closure->port = port;
|
||||||
closure->gameID = gameID;
|
closure->gameID = gameID;
|
||||||
closure->cmd = cmd;
|
closure->cmd = cmd;
|
||||||
|
@ -356,7 +362,7 @@ retrySend( gpointer data )
|
||||||
closure->phone, closure->port,
|
closure->phone, closure->port,
|
||||||
XP_TRUE, &waitSecs );
|
XP_TRUE, &waitSecs );
|
||||||
sendOrRetry( closure->params, arr, closure->cmd, waitSecs, closure->phone,
|
sendOrRetry( closure->params, arr, closure->cmd, waitSecs, closure->phone,
|
||||||
closure->port, closure->gameID );
|
closure->port, closure->gameID, closure->msgNo );
|
||||||
XP_FREEP( closure->params->mpool, &closure );
|
XP_FREEP( closure->params->mpool, &closure );
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,8 +39,8 @@ typedef struct _SMSProcs {
|
||||||
|
|
||||||
void linux_sms_init( LaunchParams* params, const gchar* phone,
|
void linux_sms_init( LaunchParams* params, const gchar* phone,
|
||||||
XP_U16 port, const SMSProcs* procs, void* procClosure );
|
XP_U16 port, const SMSProcs* procs, void* procClosure );
|
||||||
XP_S16 linux_sms_send( LaunchParams* params, const XP_U8* buf,
|
XP_S16 linux_sms_send( LaunchParams* params, const XP_U8* buf, XP_U16 buflen,
|
||||||
XP_U16 buflen, const XP_UCHAR* phone, XP_U16 port,
|
const XP_UCHAR* msgNo, const XP_UCHAR* phone, XP_U16 port,
|
||||||
XP_U32 gameID );
|
XP_U32 gameID );
|
||||||
void linux_sms_invite( LaunchParams* params, const NetLaunchInfo* nli,
|
void linux_sms_invite( LaunchParams* params, const NetLaunchInfo* nli,
|
||||||
const gchar* phone, int port );
|
const gchar* phone, int port );
|
||||||
|
|
|
@ -1,3 +1,11 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
ls -l /tmp/xw_sms
|
for MSG in $(find /tmp/xw_sms/ -type f); do
|
||||||
|
NOLOCK=$(echo $MSG | sed 's,.lock,,')
|
||||||
|
if [ $NOLOCK = $MSG ]; then
|
||||||
|
basename $(dirname "$MSG")
|
||||||
|
echo -n "${MSG}: "
|
||||||
|
head -n 1 $MSG
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
# ls -l /tmp/xw_sms/*
|
||||||
|
|
Loading…
Reference in a new issue