2019-05-08 19:15:44 +02:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
2019-05-20 19:01:46 +02:00
|
|
|
// apps/include/graphics/twm4nx/apps/cnxterm.hxx
|
2019-05-08 19:15:44 +02:00
|
|
|
//
|
2021-06-11 08:28:21 +02:00
|
|
|
// Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
// contributor license agreements. See the NOTICE file distributed with
|
|
|
|
// this work for additional information regarding copyright ownership. The
|
|
|
|
// ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
// "License"); you may not use this file except in compliance with the
|
|
|
|
// License. You may obtain a copy of the License at
|
2019-05-08 19:15:44 +02:00
|
|
|
//
|
2021-06-11 08:28:21 +02:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2019-05-08 19:15:44 +02:00
|
|
|
//
|
2021-06-11 08:28:21 +02:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing permissions and limitations
|
|
|
|
// under the License.
|
2019-05-08 19:15:44 +02:00
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2019-05-20 19:01:46 +02:00
|
|
|
#ifndef __APPS_INCLUDE_GRAPHICS_TWM4NX_APPS_CNXTERM_HXX
|
|
|
|
#define __APPS_INCLUDE_GRAPHICS_TWM4NX_APPS_CNXTERM_HXX
|
2019-05-08 19:15:44 +02:00
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Included Files
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <nuttx/nx/nxtk.h>
|
|
|
|
#include <nuttx/nx/nxterm.h>
|
|
|
|
|
|
|
|
#include "graphics/twm4nx/ctwm4nx.hxx"
|
2019-05-11 23:48:46 +02:00
|
|
|
#include "graphics/twm4nx/ctwm4nxevent.hxx"
|
2019-05-14 22:00:21 +02:00
|
|
|
#include "graphics/twm4nx/twm4nx_events.hxx"
|
2019-05-11 21:17:19 +02:00
|
|
|
#include "graphics/twm4nx/iapplication.hxx"
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Pre-processor Definitions
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// CNxTerm application events
|
|
|
|
// Window Events
|
|
|
|
|
2019-05-23 18:20:12 +02:00
|
|
|
#define EVENT_NXTERM_REDRAW (EVENT_RECIPIENT_APP | EVENT_CRITICAL | 0x0000)
|
|
|
|
#define EVENT_NXTERM_RESIZE (EVENT_RECIPIENT_APP | EVENT_CRITICAL | 0x0001)
|
2019-05-12 19:57:45 +02:00
|
|
|
#define EVENT_NXTERM_XYINPUT EVENT_SYSTEM_NOP
|
|
|
|
#define EVENT_NXTERM_KBDINPUT EVENT_SYSTEM_NOP
|
2019-05-20 19:01:46 +02:00
|
|
|
#define EVENT_NXTERM_DELETE EVENT_WINDOW_DELETE
|
2019-05-12 19:57:45 +02:00
|
|
|
|
|
|
|
// Button Events
|
|
|
|
|
2019-05-16 21:51:57 +02:00
|
|
|
#define EVENT_NXTERM_CLOSE (EVENT_RECIPIENT_APP | 0x0002)
|
2019-05-12 19:57:45 +02:00
|
|
|
|
2019-05-13 01:40:02 +02:00
|
|
|
// Menu Events
|
|
|
|
|
2019-05-16 21:51:57 +02:00
|
|
|
#define EVENT_NXTERM_START (EVENT_RECIPIENT_APP | 0x0003)
|
2019-05-13 01:40:02 +02:00
|
|
|
|
2019-05-08 19:15:44 +02:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Implementation Classes
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
namespace Twm4Nx
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* This class implements the NxTerm application.
|
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
class CNxTerm : public CTwm4NxEvent
|
2019-05-08 19:15:44 +02:00
|
|
|
{
|
2019-05-11 21:17:19 +02:00
|
|
|
private:
|
2019-06-01 21:00:02 +02:00
|
|
|
FAR CTwm4Nx *m_twm4nx; /**< Reference to the Twm4Nx session instance */
|
|
|
|
FAR CWindow *m_nxtermWindow; /**< Reference to the NxTerm application window */
|
|
|
|
NXTERM m_NxTerm; /**< NxTerm handle */
|
|
|
|
pid_t m_pid; /**< Task ID of the NxTerm thread */
|
|
|
|
int m_minor; /**< Terminal device minor number */
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
|
|
|
* This is the NxTerm task. This function first redirects output to the
|
|
|
|
* console window then calls to start the NSH logic.
|
|
|
|
*/
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
static int nxterm(int argc, char *argv[]);
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
/**
|
|
|
|
* Handle Twm4Nx events. This overrides a method from CTwm4NXEvent
|
|
|
|
*
|
|
|
|
* @param eventmsg. The received NxWidget WINDOW event message.
|
|
|
|
* @return True if the message was properly handled. false is
|
|
|
|
* return on any failure.
|
|
|
|
*/
|
|
|
|
|
2019-06-01 21:00:02 +02:00
|
|
|
bool event(FAR struct SEventMsg *eventmsg);
|
2019-05-11 23:48:46 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-12 19:57:45 +02:00
|
|
|
* Handle the NxTerm redraw event.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
void redraw(void);
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-16 21:51:57 +02:00
|
|
|
/**
|
|
|
|
* inform NxTerm of a new window size.
|
|
|
|
*/
|
|
|
|
|
|
|
|
void resize(void);
|
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-12 19:57:45 +02:00
|
|
|
* This is the close window event handler. It will stop the NxTerm
|
2019-06-01 21:00:02 +02:00
|
|
|
* application thread.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
void stop(void);
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
public:
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-12 19:57:45 +02:00
|
|
|
* CNxTerm constructor
|
2019-05-11 21:17:19 +02:00
|
|
|
*
|
2019-05-12 19:57:45 +02:00
|
|
|
* @param twm4nx. The Twm4Nx session instance
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
CNxTerm(FAR CTwm4Nx *twm4nx);
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-12 19:57:45 +02:00
|
|
|
* CNxTerm destructor
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
~CNxTerm(void);
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-12 19:57:45 +02:00
|
|
|
* CNxTerm initializers. Perform miscellaneous post-construction
|
|
|
|
* initialization that may fail (and hence is not appropriate to be
|
|
|
|
* done in the constructor)
|
|
|
|
*
|
|
|
|
* @return True if the NxTerm application was successfully initialized.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
bool initialize(void);
|
2019-05-08 19:15:44 +02:00
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-12 19:57:45 +02:00
|
|
|
* Start the NxTerm.
|
2019-05-11 21:17:19 +02:00
|
|
|
*
|
2019-05-12 19:57:45 +02:00
|
|
|
* @return True if the NxTerm application was successfully started.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
bool run(void);
|
2019-05-11 21:17:19 +02:00
|
|
|
};
|
|
|
|
|
2019-05-13 01:40:02 +02:00
|
|
|
class CNxTermFactory : public IApplication,
|
|
|
|
public IApplicationFactory,
|
|
|
|
public CTwm4NxEvent
|
2019-05-11 21:17:19 +02:00
|
|
|
{
|
|
|
|
private:
|
|
|
|
|
2019-05-13 01:40:02 +02:00
|
|
|
FAR CTwm4Nx *m_twm4nx; /**< Twm4Nx session instance */
|
|
|
|
|
2019-05-11 21:17:19 +02:00
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* One time NSH initialization. This function must be called exactly
|
|
|
|
* once during the boot-up sequence to initialize the NSH library.
|
2019-05-11 21:17:19 +02:00
|
|
|
*
|
2019-05-11 23:48:46 +02:00
|
|
|
* @return True on successful initialization
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
bool nshlibInitialize(void);
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-20 19:01:46 +02:00
|
|
|
* Handle CNxTermFactory events. This overrides a method from
|
2019-05-13 01:40:02 +02:00
|
|
|
* CTwm4NXEvent
|
2019-05-11 23:48:46 +02:00
|
|
|
*
|
2019-05-13 01:40:02 +02:00
|
|
|
* @param eventmsg. The received NxWidget WINDOW event message.
|
|
|
|
* @return True if the message was properly handled. false is
|
|
|
|
* return on any failure.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-06-01 21:00:02 +02:00
|
|
|
bool event(FAR struct SEventMsg *eventmsg);
|
2019-05-13 01:40:02 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create and start a new instance of an CNxTerm.
|
|
|
|
*/
|
|
|
|
|
|
|
|
bool startFunction(void);
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* Return the Main Menu item string. This overrides the method from
|
|
|
|
* IApplication
|
|
|
|
*
|
|
|
|
* @param name The name of the application.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
inline NXWidgets::CNxString getName(void)
|
|
|
|
{
|
|
|
|
return NXWidgets::CNxString("NuttShell");
|
|
|
|
}
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* There is no sub-menu for this Main Menu item. This overrides
|
|
|
|
* the method from IApplication.
|
2019-05-11 21:17:19 +02:00
|
|
|
*
|
2019-05-11 23:48:46 +02:00
|
|
|
* @return This implementation will always return a null value.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
inline FAR CMenus *getSubMenu(void)
|
|
|
|
{
|
|
|
|
return (FAR CMenus *)0;
|
|
|
|
}
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* There is no custom event handler. We use the common event handler.
|
2019-05-11 21:17:19 +02:00
|
|
|
*
|
2019-06-01 21:00:02 +02:00
|
|
|
* @return. null is always returned in this implementation.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
inline FAR CTwm4NxEvent *getEventHandler(void)
|
|
|
|
{
|
2019-05-13 01:40:02 +02:00
|
|
|
return (FAR CTwm4NxEvent *)this;
|
2019-05-11 23:48:46 +02:00
|
|
|
}
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* Return the Twm4Nx event that will be generated when the Main Menu
|
|
|
|
* item is selected.
|
|
|
|
*
|
|
|
|
* @return. This function always returns EVENT_SYSTEM_NOP.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
inline uint16_t getEvent(void)
|
|
|
|
{
|
2019-05-13 01:40:02 +02:00
|
|
|
return EVENT_NXTERM_START;
|
2019-05-11 23:48:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* CNxTermFactory Constructor
|
2019-05-11 21:17:19 +02:00
|
|
|
*
|
2019-05-13 01:40:02 +02:00
|
|
|
* @param twm4nx. The Twm4Nx session instance
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
inline CNxTermFactory(void)
|
|
|
|
{
|
2019-05-13 01:40:02 +02:00
|
|
|
m_twm4nx = (FAR CTwm4Nx *)0;
|
2019-05-11 23:48:46 +02:00
|
|
|
}
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* CNxTermFactory Destructor
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-11 23:48:46 +02:00
|
|
|
inline ~CNxTermFactory(void)
|
|
|
|
{
|
|
|
|
// REVISIT: Would need to remove Main Menu item
|
|
|
|
}
|
2019-05-11 21:17:19 +02:00
|
|
|
|
|
|
|
/**
|
2019-05-11 23:48:46 +02:00
|
|
|
* CNxTermFactory Initializer. Performs parts of the instance
|
2020-02-23 05:51:44 +01:00
|
|
|
* construction that may fail. In this implementation, it will
|
2019-05-11 23:48:46 +02:00
|
|
|
* initialize the NSH library and register an menu item in the
|
|
|
|
* Main Menu.
|
2019-05-11 21:17:19 +02:00
|
|
|
*/
|
|
|
|
|
2019-05-12 19:57:45 +02:00
|
|
|
bool initialize(FAR CTwm4Nx *twm4nx);
|
2019-05-08 19:15:44 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-05-20 19:01:46 +02:00
|
|
|
#endif // __APPS_INCLUDE_GRAPHICS_TWM4NX_APPS_CNXTERM_HXX
|