Using wrong(invalid) callback structure
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@1357 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
a2740a9c1e
commit
94c66e2480
@ -187,46 +187,54 @@ int nx_eventhandler(NXHANDLE handle)
|
|||||||
return ERROR;
|
return ERROR;
|
||||||
|
|
||||||
case NX_CLIMSG_REDRAW:
|
case NX_CLIMSG_REDRAW:
|
||||||
if (conn->cb->redraw)
|
|
||||||
{
|
{
|
||||||
FAR struct nxclimsg_redraw_s *redraw = (FAR struct nxclimsg_redraw_s *)buffer;
|
FAR struct nxclimsg_redraw_s *redraw = (FAR struct nxclimsg_redraw_s *)buffer;
|
||||||
wnd = redraw->wnd;
|
wnd = redraw->wnd;
|
||||||
DEBUGASSERT(wnd);
|
DEBUGASSERT(wnd);
|
||||||
|
if (wnd->cb->redraw)
|
||||||
|
{
|
||||||
wnd->cb->redraw((NXWINDOW)wnd, &redraw->rect, redraw->more);
|
wnd->cb->redraw((NXWINDOW)wnd, &redraw->rect, redraw->more);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NX_CLIMSG_NEWPOSITION:
|
case NX_CLIMSG_NEWPOSITION:
|
||||||
if (conn->cb->position)
|
|
||||||
{
|
{
|
||||||
FAR struct nxclimsg_newposition_s *postn = (FAR struct nxclimsg_newposition_s *)buffer;
|
FAR struct nxclimsg_newposition_s *postn = (FAR struct nxclimsg_newposition_s *)buffer;
|
||||||
wnd = postn->wnd;
|
wnd = postn->wnd;
|
||||||
DEBUGASSERT(wnd);
|
DEBUGASSERT(wnd);
|
||||||
|
if (wnd->cb->position)
|
||||||
|
{
|
||||||
wnd->cb->position((NXWINDOW)wnd, &postn->size, &postn->pos, &postn->bounds);
|
wnd->cb->position((NXWINDOW)wnd, &postn->size, &postn->pos, &postn->bounds);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#ifdef CONFIG_NX_KBD
|
#ifdef CONFIG_NX_KBD
|
||||||
case NX_CLIMSG_MOUSEIN:
|
case NX_CLIMSG_MOUSEIN:
|
||||||
if (conn->cb->mousein)
|
|
||||||
{
|
{
|
||||||
FAR struct nxclimsg_mousein_s *mouse = (FAR struct nxclimsg_mousein_s *)buffer;
|
FAR struct nxclimsg_mousein_s *mouse = (FAR struct nxclimsg_mousein_s *)buffer;
|
||||||
wnd = mouse->wnd;
|
wnd = mouse->wnd;
|
||||||
DEBUGASSERT(wnd);
|
DEBUGASSERT(wnd);
|
||||||
|
if (wnd->cb->mousein)
|
||||||
|
{
|
||||||
wnd->cb->mousein((NXWINDOW)wnd, &mouse->pos, mouse->buttons);
|
wnd->cb->mousein((NXWINDOW)wnd, &mouse->pos, mouse->buttons);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_NX_KBD
|
#ifdef CONFIG_NX_KBD
|
||||||
case NX_CLIMSG_KBDIN:
|
case NX_CLIMSG_KBDIN:
|
||||||
if (conn->cb->kbdin)
|
|
||||||
{
|
{
|
||||||
FAR struct nxclimsg_kbdin_s *kbd = (FAR struct nxclimsg_kbdin_s *)buffer;
|
FAR struct nxclimsg_kbdin_s *kbd = (FAR struct nxclimsg_kbdin_s *)buffer;
|
||||||
wnd = kbd->wnd;
|
wnd = kbd->wnd;
|
||||||
DEBUGASSERT(wnd);
|
DEBUGASSERT(wnd);
|
||||||
|
if (wnd->cb->kbdin)
|
||||||
|
{
|
||||||
wnd->cb->kbdin((NXWINDOW)wnd, kbd->nch, kbd->ch);
|
wnd->cb->kbdin((NXWINDOW)wnd, kbd->nch, kbd->ch);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -84,6 +84,9 @@
|
|||||||
* client can then call nv_eventhandler() only when incoming events are
|
* client can then call nv_eventhandler() only when incoming events are
|
||||||
* available.
|
* available.
|
||||||
*
|
*
|
||||||
|
* Only one such event is issued. Upon receipt of the signal, if the client
|
||||||
|
* wishes further notifications, it must call nx_eventnotify again.
|
||||||
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* handle - the handle returned by nx_connect
|
* handle - the handle returned by nx_connect
|
||||||
*
|
*
|
||||||
|
@ -111,12 +111,17 @@ NXWINDOW nx_openwindow(NXHANDLE handle, FAR const struct nx_callback_s *cb)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Setup only the connection structure. We'll need this to communicate with
|
||||||
|
* the server. The server will set everything else up.
|
||||||
|
*/
|
||||||
|
|
||||||
|
wnd->conn = conn;
|
||||||
|
wnd->cb = cb;
|
||||||
|
|
||||||
/* Request initialization the new window from the server */
|
/* Request initialization the new window from the server */
|
||||||
|
|
||||||
outmsg.msgid = NX_SVRMSG_OPENWINDOW;
|
outmsg.msgid = NX_SVRMSG_OPENWINDOW;
|
||||||
outmsg.conn = conn;
|
|
||||||
outmsg.wnd = wnd;
|
outmsg.wnd = wnd;
|
||||||
outmsg.cb = cb;
|
|
||||||
|
|
||||||
ret = mq_send(conn->cwrmq, &outmsg, sizeof(struct nxsvrmsg_openwindow_s), NX_SVRMSG_PRIO);
|
ret = mq_send(conn->cwrmq, &outmsg, sizeof(struct nxsvrmsg_openwindow_s), NX_SVRMSG_PRIO);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
|
@ -110,7 +110,6 @@ struct nxfe_conn_s
|
|||||||
|
|
||||||
mqd_t crdmq; /* MQ to read from the server (may be non-blocking) */
|
mqd_t crdmq; /* MQ to read from the server (may be non-blocking) */
|
||||||
mqd_t cwrmq; /* MQ to write to the server (blocking) */
|
mqd_t cwrmq; /* MQ to write to the server (blocking) */
|
||||||
FAR const struct nx_callback_s *cb; /* Message handling callbacks */
|
|
||||||
|
|
||||||
/* These are only usable on the server side of the connection */
|
/* These are only usable on the server side of the connection */
|
||||||
|
|
||||||
@ -179,16 +178,27 @@ enum nxmsg_e
|
|||||||
|
|
||||||
/* Server-to-Client Message Structures **************************************/
|
/* Server-to-Client Message Structures **************************************/
|
||||||
|
|
||||||
/* The generic message structure. All messages begin with this form. Also, messages
|
/* The generic message structure. All messages begin with this form. */
|
||||||
* that have no data other than the msgid event use this structure. This includes:
|
|
||||||
* NX_CLIMSG_CONNECTED and NX_CLIMSG_DISCONNECTED.
|
|
||||||
*/
|
|
||||||
|
|
||||||
struct nxclimsg_s
|
struct nxclimsg_s
|
||||||
{
|
{
|
||||||
uint32 msgid; /* Any of nxclimsg_e */
|
uint32 msgid; /* Any of nxclimsg_e */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* The server is now connected */
|
||||||
|
|
||||||
|
struct nxclimsg_connected_s
|
||||||
|
{
|
||||||
|
uint32 msgid; /* NX_CLIMSG_REDRAW_CONNECTED */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* The server is now disconnected */
|
||||||
|
|
||||||
|
struct nxclimsg_disconnected_s
|
||||||
|
{
|
||||||
|
uint32 msgid; /* NX_CLIMSG_REDRAW_DISCONNECTED */
|
||||||
|
};
|
||||||
|
|
||||||
/* This message is received when a requested window has been opened. If wnd is NULL
|
/* This message is received when a requested window has been opened. If wnd is NULL
|
||||||
* then errorcode is the errno value that provides the explanation of the error.
|
* then errorcode is the errno value that provides the explanation of the error.
|
||||||
*/
|
*/
|
||||||
@ -254,9 +264,7 @@ struct nxsvrmsg_s /* Generic server message */
|
|||||||
struct nxsvrmsg_openwindow_s
|
struct nxsvrmsg_openwindow_s
|
||||||
{
|
{
|
||||||
uint32 msgid; /* NX_SVRMSG_OPENWINDOW */
|
uint32 msgid; /* NX_SVRMSG_OPENWINDOW */
|
||||||
FAR struct nxfe_conn_s *conn; /* The specific connection sending the message */
|
|
||||||
FAR struct nxbe_window_s *wnd; /* The pre-allocated window structure */
|
FAR struct nxbe_window_s *wnd; /* The pre-allocated window structure */
|
||||||
FAR const struct nx_callback_s *cb; /* Event handling callbacks */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/* This message informs the server that client wishes to close a window */
|
/* This message informs the server that client wishes to close a window */
|
||||||
@ -442,8 +450,7 @@ EXTERN void nxmu_semtake(sem_t *sem);
|
|||||||
* Create a new window.
|
* Create a new window.
|
||||||
*
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* conn - The client containing connection information [IN]
|
* be - The back-end status structure
|
||||||
* svr - The server state structure [IN]
|
|
||||||
* wnd - The pre-allocated window structure to be ininitilized [IN/OUT]
|
* wnd - The pre-allocated window structure to be ininitilized [IN/OUT]
|
||||||
*
|
*
|
||||||
* Return:
|
* Return:
|
||||||
@ -451,10 +458,8 @@ EXTERN void nxmu_semtake(sem_t *sem);
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
EXTERN void nxmu_openwindow(FAR struct nxfe_conn_s *conn,
|
EXTERN void nxmu_openwindow(FAR struct nxbe_state_s *be,
|
||||||
FAR struct nxbe_state_s *be,
|
FAR struct nxbe_window_s *wnd);
|
||||||
FAR struct nxbe_window_s *wnd,
|
|
||||||
FAR const struct nx_callback_s *cb);
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: nxmu_requestbkgd
|
* Name: nxmu_requestbkgd
|
||||||
@ -565,7 +570,7 @@ EXTERN nxmu_mousein(FAR struct nxfe_state_s *fe,
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_NX_KBD
|
#ifdef CONFIG_NX_KBD
|
||||||
EXTERN void nxmu_kbdin(FAR struct nxs_server_s *svr, ubyte nch, ubyte *ch);
|
EXTERN void nxmu_kbdin(FAR struct nxfe_state_s *fe, ubyte nch, ubyte *ch);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#undef EXTERN
|
#undef EXTERN
|
||||||
|
@ -74,29 +74,23 @@
|
|||||||
* Create a new window.
|
* Create a new window.
|
||||||
*
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* conn - The client containing connection information [IN]
|
* be - The back-end status structure
|
||||||
* be - The server state structure [IN]
|
|
||||||
* wnd - The pre-allocated window structure to be ininitilized [IN/OUT]
|
* wnd - The pre-allocated window structure to be ininitilized [IN/OUT]
|
||||||
* cb - Callbacks used to process window events
|
|
||||||
*
|
*
|
||||||
* Return:
|
* Return:
|
||||||
* None
|
* None
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
void nxmu_openwindow(FAR struct nxfe_conn_s *conn,
|
void nxmu_openwindow(FAR struct nxbe_state_s *be, FAR struct nxbe_window_s *wnd)
|
||||||
FAR struct nxbe_state_s *be,
|
|
||||||
FAR struct nxbe_window_s *wnd,
|
|
||||||
FAR const struct nx_callback_s *cb)
|
|
||||||
{
|
{
|
||||||
/* The window structure was allocated in nx_openwindow and all fields have
|
/* The window structure was allocated in nx_openwindow and all fields have
|
||||||
* been set to zero (except sem... see below). We need only initialize the
|
* been set to zero cb and conn which were initialized on the client side.
|
||||||
* the non zero fields and insert the new window.
|
* On the server side, we need only initialize a few more the non zero fields
|
||||||
|
* and insert the new window at the top of the display.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
wnd->be = be;
|
wnd->be = be;
|
||||||
wnd->conn = conn;
|
|
||||||
wnd->cb = cb;
|
|
||||||
|
|
||||||
/* Now, insert the new window at the top on the display. topwind is
|
/* Now, insert the new window at the top on the display. topwind is
|
||||||
* never NULL (it may point only at the background window, however)
|
* never NULL (it may point only at the background window, however)
|
||||||
|
@ -80,14 +80,14 @@
|
|||||||
|
|
||||||
static inline void nxmu_disconnect(FAR struct nxfe_conn_s *conn)
|
static inline void nxmu_disconnect(FAR struct nxfe_conn_s *conn)
|
||||||
{
|
{
|
||||||
struct nxclimsg_s outmsg;
|
struct nxclimsg_disconnected_s outmsg;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* Send the handshake message back to the client */
|
/* Send the handshake message back to the client */
|
||||||
|
|
||||||
outmsg.msgid = NX_CLIMSG_DISCONNECTED;
|
outmsg.msgid = NX_CLIMSG_DISCONNECTED;
|
||||||
|
|
||||||
ret = mq_send(conn->swrmq, &outmsg, sizeof(struct nxclimsg_s), NX_CLIMSG_PRIO);
|
ret = mq_send(conn->swrmq, &outmsg, sizeof(struct nxclimsg_disconnected_s), NX_CLIMSG_PRIO);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
gdbg("mq_send failed: %d\n", errno);
|
gdbg("mq_send failed: %d\n", errno);
|
||||||
@ -105,7 +105,7 @@ static inline void nxmu_disconnect(FAR struct nxfe_conn_s *conn)
|
|||||||
static inline void nxmu_connect(FAR struct nxfe_conn_s *conn)
|
static inline void nxmu_connect(FAR struct nxfe_conn_s *conn)
|
||||||
{
|
{
|
||||||
char mqname[NX_CLIENT_MXNAMELEN];
|
char mqname[NX_CLIENT_MXNAMELEN];
|
||||||
struct nxclimsg_s outmsg;
|
struct nxclimsg_connected_s outmsg;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* Create the client MQ name */
|
/* Create the client MQ name */
|
||||||
@ -114,7 +114,6 @@ static inline void nxmu_connect(FAR struct nxfe_conn_s *conn)
|
|||||||
|
|
||||||
/* Open the client MQ -- this should have already been created by the client */
|
/* Open the client MQ -- this should have already been created by the client */
|
||||||
|
|
||||||
outmsg.msgid = NX_CLIMSG_CONNECTED;
|
|
||||||
conn->swrmq = mq_open(mqname, O_WRONLY);
|
conn->swrmq = mq_open(mqname, O_WRONLY);
|
||||||
if (conn->swrmq == (mqd_t)-1)
|
if (conn->swrmq == (mqd_t)-1)
|
||||||
{
|
{
|
||||||
@ -124,7 +123,9 @@ static inline void nxmu_connect(FAR struct nxfe_conn_s *conn)
|
|||||||
|
|
||||||
/* Send the handshake message back to the client */
|
/* Send the handshake message back to the client */
|
||||||
|
|
||||||
ret = mq_send(conn->swrmq, &outmsg, sizeof(struct nxclimsg_s), NX_CLIMSG_PRIO);
|
outmsg.msgid = NX_CLIMSG_CONNECTED;
|
||||||
|
|
||||||
|
ret = mq_send(conn->swrmq, &outmsg, sizeof(struct nxclimsg_connected_s), NX_CLIMSG_PRIO);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
gdbg("mq_send failed: %d\n", errno);
|
gdbg("mq_send failed: %d\n", errno);
|
||||||
@ -376,7 +377,7 @@ int nx_runinstance(FAR const char *mqname, FAR struct fb_vtable_s *fb)
|
|||||||
case NX_SVRMSG_OPENWINDOW: /* Create a new window */
|
case NX_SVRMSG_OPENWINDOW: /* Create a new window */
|
||||||
{
|
{
|
||||||
FAR struct nxsvrmsg_openwindow_s *openmsg = (FAR struct nxsvrmsg_openwindow_s *)buffer;
|
FAR struct nxsvrmsg_openwindow_s *openmsg = (FAR struct nxsvrmsg_openwindow_s *)buffer;
|
||||||
nxmu_openwindow(openmsg->conn, &fe.be, openmsg->wnd, openmsg->cb);
|
nxmu_openwindow(&fe.be, openmsg->wnd);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
void nx_releasebkgd(NXWINDOW hwnd)
|
int nx_releasebkgd(NXWINDOW hwnd)
|
||||||
{
|
{
|
||||||
FAR struct nxfe_state_s *fe = (FAR struct nxfe_state_s *)hwnd;
|
FAR struct nxfe_state_s *fe = (FAR struct nxfe_state_s *)hwnd;
|
||||||
FAR struct nxbe_state_s *be = &fe->be;
|
FAR struct nxbe_state_s *be = &fe->be;
|
||||||
|
@ -227,10 +227,15 @@ EXTERN int nx_runinstance(FAR const char *mqname, FAR struct fb_vtable_s *fb);
|
|||||||
* connection is normally needed per thread as each connection can host
|
* connection is normally needed per thread as each connection can host
|
||||||
* multiple windows.
|
* multiple windows.
|
||||||
*
|
*
|
||||||
* NOTE that multiple instances of the NX server may run at the same time,
|
* NOTES:
|
||||||
* each with different message queue names. nx_connect() is simply
|
* - This function returns before the connection is fully instantiated.
|
||||||
* a macro that can be used when only one server instance is required. In
|
* it is necessary to wait for the connection event before using the
|
||||||
* that case, a default server name is used.
|
* returned handle.
|
||||||
|
* - Multiple instances of the NX server may run at the same time,
|
||||||
|
* each with different message queue names.
|
||||||
|
* - nx_connect() is simply a macro that can be used when only one
|
||||||
|
* server instance is required. In that case, a default server name
|
||||||
|
* is used.
|
||||||
*
|
*
|
||||||
* Multiple user mode only!
|
* Multiple user mode only!
|
||||||
*
|
*
|
||||||
@ -357,6 +362,9 @@ EXTERN int nx_eventhandler(NXHANDLE handle);
|
|||||||
* client can then call nv_eventhandler() only when incoming events are
|
* client can then call nv_eventhandler() only when incoming events are
|
||||||
* available.
|
* available.
|
||||||
*
|
*
|
||||||
|
* Only one such event is issued. Upon receipt of the signal, if the client
|
||||||
|
* wishes further notifications, it must call nx_eventnotify again.
|
||||||
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* handle - the handle returned by nx_connect
|
* handle - the handle returned by nx_connect
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user