2017-11-04 07:03:53 +01:00
|
|
|
/***********************************************************************
|
|
|
|
* fapplication.cpp - Manages the application events *
|
|
|
|
* *
|
|
|
|
* This file is part of the Final Cut widget toolkit *
|
|
|
|
* *
|
|
|
|
* Copyright 2013-2017 Markus Gans *
|
|
|
|
* *
|
|
|
|
* The Final Cut is free software; you can redistribute it and/or *
|
|
|
|
* modify it under the terms of the GNU Lesser General Public License *
|
|
|
|
* as published by the Free Software Foundation; either version 3 of *
|
|
|
|
* the License, or (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
* The Final Cut is distributed in the hope that it will be useful, *
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
|
|
|
* GNU Lesser General Public License for more details. *
|
|
|
|
* *
|
|
|
|
* You should have received a copy of the GNU Lesser General Public *
|
|
|
|
* License along with this program. If not, see *
|
|
|
|
* <http://www.gnu.org/licenses/>. *
|
|
|
|
***********************************************************************/
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-09-11 03:06:02 +02:00
|
|
|
#include <string>
|
|
|
|
|
2017-09-17 21:32:46 +02:00
|
|
|
#include "final/fapplication.h"
|
|
|
|
#include "final/fmenu.h"
|
2017-10-30 20:56:00 +01:00
|
|
|
#include "final/fmessagebox.h"
|
2017-09-17 21:32:46 +02:00
|
|
|
#include "final/fstatusbar.h"
|
|
|
|
#include "final/fwindow.h"
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
// global application object
|
|
|
|
static FApplication* rootObj = 0;
|
|
|
|
|
|
|
|
// flag to exit local loop
|
|
|
|
static bool app_exit_loop = false;
|
|
|
|
|
|
|
|
// static attributes
|
2016-10-01 23:18:49 +02:00
|
|
|
int FApplication::loop_level = 0; // event loop level
|
|
|
|
FWidget* FApplication::main_widget = 0; // main application widget
|
|
|
|
FWidget* FApplication::active_window = 0; // the active window
|
|
|
|
FWidget* FApplication::focus_widget = 0; // has keyboard input focus
|
|
|
|
FWidget* FApplication::clicked_widget = 0; // is focused by click
|
|
|
|
FWidget* FApplication::open_menu = 0; // currently open menu
|
2016-10-06 23:15:09 +02:00
|
|
|
FWidget* FApplication::move_size_widget = 0; // move/size by keyboard
|
2016-10-01 23:18:49 +02:00
|
|
|
FPoint* FApplication::zero_point = 0; // zero point (x=0, y=0)
|
2016-10-13 02:16:51 +02:00
|
|
|
uChar FApplication::x11_button_state = 0x03;
|
2016-10-01 23:18:49 +02:00
|
|
|
int FApplication::quit_code = 0;
|
|
|
|
bool FApplication::quit_now = false;
|
|
|
|
|
2016-11-02 00:37:58 +01:00
|
|
|
FApplication::eventQueue* FApplication::event_queue = 0;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// class FApplication
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
|
|
|
|
// constructors and destructor
|
|
|
|
//----------------------------------------------------------------------
|
2017-09-11 03:06:02 +02:00
|
|
|
FApplication::FApplication ( const int& _argc
|
2017-03-26 20:40:04 +02:00
|
|
|
, char* _argv[]
|
|
|
|
, bool disable_alt_screen )
|
2017-11-18 02:34:41 +01:00
|
|
|
: FWidget(processParameters(_argc,_argv), disable_alt_screen)
|
2016-07-30 23:00:37 +02:00
|
|
|
, app_argc(_argc)
|
2016-02-07 22:02:38 +01:00
|
|
|
, app_argv(_argv)
|
2015-09-22 04:18:20 +02:00
|
|
|
, key(0)
|
|
|
|
#ifdef F_HAVE_LIBGPM
|
|
|
|
, gpm_ev()
|
|
|
|
, gpmMouseEvent(false)
|
|
|
|
#endif
|
|
|
|
, b_state()
|
|
|
|
, fifo_offset(0)
|
|
|
|
, fifo_in_use(false)
|
|
|
|
, fifo_buf_size(sizeof(fifo_buf))
|
2015-10-07 21:32:30 +02:00
|
|
|
, key_timeout(100000) // 100 ms
|
2015-09-22 04:18:20 +02:00
|
|
|
, dblclick_interval(500000) // 500 ms
|
|
|
|
, time_keypressed()
|
|
|
|
, time_mousepressed()
|
2016-09-27 00:46:05 +02:00
|
|
|
, new_mouse_position()
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
assert ( ! rootObj
|
2017-11-26 22:37:18 +01:00
|
|
|
&& "FApplication: There should be only one application object" );
|
2015-05-23 13:35:12 +02:00
|
|
|
rootObj = this;
|
|
|
|
|
2016-08-21 21:27:44 +02:00
|
|
|
if ( ! (_argc && _argv) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2017-12-17 01:06:53 +01:00
|
|
|
static char* empty = C_STR("");
|
2016-11-20 18:26:15 +01:00
|
|
|
app_argc = 0;
|
|
|
|
app_argv = static_cast<char**>(&empty);
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
2016-02-07 22:02:38 +01:00
|
|
|
init();
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-09-11 03:06:02 +02:00
|
|
|
FApplication::~FApplication() // destructor
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
if ( zero_point )
|
|
|
|
delete zero_point;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( event_queue )
|
|
|
|
delete event_queue;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
rootObj = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-11-02 00:37:58 +01:00
|
|
|
// public methods of FApplication
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::setMainWidget (FWidget* widget)
|
|
|
|
{
|
|
|
|
main_widget = widget;
|
|
|
|
|
|
|
|
if ( widget && ! getFocusWidget() )
|
|
|
|
rootObj->focusFirstChild();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
bool FApplication::isQuit()
|
|
|
|
{
|
|
|
|
if ( rootObj )
|
|
|
|
return quit_now;
|
|
|
|
else
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::exec() // run
|
|
|
|
{
|
|
|
|
if ( quit_now )
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
|
|
|
|
quit_now = false;
|
|
|
|
quit_code = 0;
|
|
|
|
|
|
|
|
enter_loop();
|
|
|
|
return quit_code;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::enter_loop() // event loop
|
|
|
|
{
|
|
|
|
bool old_app_exit_loop;
|
|
|
|
loop_level++;
|
|
|
|
quit_now = false;
|
|
|
|
|
|
|
|
old_app_exit_loop = app_exit_loop;
|
|
|
|
app_exit_loop = false;
|
|
|
|
|
|
|
|
while ( ! (quit_now || app_exit_loop) )
|
|
|
|
processNextEvent();
|
|
|
|
|
|
|
|
app_exit_loop = old_app_exit_loop;
|
|
|
|
loop_level--;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::exit_loop()
|
|
|
|
{
|
|
|
|
app_exit_loop = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::exit (int retcode)
|
|
|
|
{
|
|
|
|
if ( ! rootObj ) // no global app object
|
|
|
|
return;
|
|
|
|
|
2017-09-11 03:06:02 +02:00
|
|
|
if ( quit_now ) // don't overwrite quit code
|
2016-11-02 00:37:58 +01:00
|
|
|
return;
|
|
|
|
|
|
|
|
quit_now = true;
|
|
|
|
quit_code = retcode;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::quit()
|
|
|
|
{
|
|
|
|
FApplication::exit(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-08-12 20:10:27 +02:00
|
|
|
bool FApplication::sendEvent ( const FObject* receiver
|
|
|
|
, const FEvent* event )
|
2016-11-02 00:37:58 +01:00
|
|
|
{
|
|
|
|
if ( quit_now || app_exit_loop )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if ( ! receiver )
|
|
|
|
return false;
|
|
|
|
|
2017-06-11 17:47:50 +02:00
|
|
|
if ( ! receiver->isWidget() )
|
|
|
|
return false;
|
|
|
|
|
2017-08-12 20:10:27 +02:00
|
|
|
const FWidget* r_widget = static_cast<const FWidget*>(receiver);
|
|
|
|
FWidget* widget = const_cast<FWidget*>(r_widget);
|
2016-11-02 00:37:58 +01:00
|
|
|
|
|
|
|
if ( modal_dialogs > 0 )
|
|
|
|
{
|
2017-08-12 20:10:27 +02:00
|
|
|
const FWidget* window;
|
2016-11-02 00:37:58 +01:00
|
|
|
if ( widget->isWindowWidget() )
|
|
|
|
window = widget;
|
|
|
|
else
|
|
|
|
window = FWindow::getWindowWidget(widget);
|
|
|
|
|
|
|
|
// block events for widgets in non modal windows
|
|
|
|
if ( window
|
2017-11-26 22:37:18 +01:00
|
|
|
&& (window->getFlags() & fc::modal) == 0
|
|
|
|
&& ! window->isMenuWidget() )
|
2016-11-02 00:37:58 +01:00
|
|
|
{
|
|
|
|
switch ( event->type() )
|
|
|
|
{
|
|
|
|
case fc::KeyPress_Event:
|
|
|
|
case fc::KeyUp_Event:
|
|
|
|
case fc::KeyDown_Event:
|
|
|
|
case fc::MouseDown_Event:
|
|
|
|
case fc::MouseUp_Event:
|
|
|
|
case fc::MouseDoubleClick_Event:
|
|
|
|
case fc::MouseWheel_Event:
|
|
|
|
case fc::MouseMove_Event:
|
|
|
|
case fc::FocusIn_Event:
|
|
|
|
case fc::FocusOut_Event:
|
|
|
|
case fc::Accelerator_Event:
|
|
|
|
return false;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-12 20:10:27 +02:00
|
|
|
// Throw away mouse events for disabled widgets
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( event->type() >= fc::MouseDown_Event
|
2017-11-26 22:37:18 +01:00
|
|
|
&& event->type() <= fc::MouseMove_Event
|
|
|
|
&& ! widget->isEnabled() )
|
2016-11-02 00:37:58 +01:00
|
|
|
return false;
|
|
|
|
|
2017-08-12 20:10:27 +02:00
|
|
|
// For access to a protected base class member
|
2017-09-11 03:06:02 +02:00
|
|
|
const FApplication* const_w = static_cast<const FApplication*>(widget);
|
|
|
|
FApplication* w = const_cast<FApplication*>(const_w);
|
|
|
|
|
2017-08-12 20:10:27 +02:00
|
|
|
// Sends event event directly to receiver
|
|
|
|
return w->event(const_cast<FEvent*>(event));
|
2016-11-02 00:37:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-08-12 20:10:27 +02:00
|
|
|
void FApplication::queueEvent ( const FObject* receiver
|
|
|
|
, const FEvent* event )
|
2016-11-02 00:37:58 +01:00
|
|
|
{
|
|
|
|
if ( ! receiver )
|
|
|
|
return;
|
|
|
|
|
|
|
|
// queue this event
|
|
|
|
eventPair Event (receiver, event);
|
|
|
|
event_queue->push_back(Event);
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendQueuedEvents()
|
|
|
|
{
|
|
|
|
eventQueue* events;
|
|
|
|
|
|
|
|
if ( ! eventInQueue() )
|
|
|
|
return;
|
|
|
|
|
|
|
|
events = event_queue;
|
|
|
|
|
|
|
|
while ( ! eventInQueue() )
|
|
|
|
{
|
|
|
|
sendEvent(events->front().first, events->front().second);
|
|
|
|
events->pop_front();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
bool FApplication::eventInQueue()
|
|
|
|
{
|
|
|
|
if ( rootObj )
|
|
|
|
return ( ! event_queue->empty() );
|
|
|
|
else
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-08-12 20:10:27 +02:00
|
|
|
bool FApplication::removeQueuedEvent (const FObject* receiver)
|
2016-11-02 00:37:58 +01:00
|
|
|
{
|
|
|
|
bool retval;
|
|
|
|
eventQueue::iterator iter;
|
|
|
|
|
|
|
|
if ( ! eventInQueue() )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if ( ! receiver )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
retval = false;
|
|
|
|
iter = event_queue->begin();
|
|
|
|
|
|
|
|
while ( iter != event_queue->end() )
|
|
|
|
{
|
|
|
|
if ( iter->first == receiver )
|
|
|
|
{
|
|
|
|
iter = event_queue->erase(iter);
|
|
|
|
retval = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
++iter;
|
|
|
|
}
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-11-18 02:34:41 +01:00
|
|
|
FWidget* FApplication::processParameters (const int& argc, char* argv[])
|
2016-11-02 00:37:58 +01:00
|
|
|
{
|
2017-09-19 06:18:03 +02:00
|
|
|
if ( argc > 0 && argv[1] && ( std::strcmp(argv[1], "--help") == 0
|
2017-11-26 22:37:18 +01:00
|
|
|
|| std::strcmp(argv[1], "-h") == 0 ) )
|
2017-09-19 06:18:03 +02:00
|
|
|
{
|
2017-11-18 02:34:41 +01:00
|
|
|
showParameterUsage();
|
2017-09-19 06:18:03 +02:00
|
|
|
}
|
|
|
|
|
2017-12-10 15:36:02 +01:00
|
|
|
init_values.setDefault();
|
2017-11-18 02:34:41 +01:00
|
|
|
cmd_options (argc, argv);
|
2017-09-19 06:18:03 +02:00
|
|
|
return 0;
|
2016-11-02 00:37:58 +01:00
|
|
|
}
|
|
|
|
|
2017-11-18 02:34:41 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::showParameterUsage()
|
|
|
|
{
|
|
|
|
std::cout \
|
|
|
|
<< "Generic options:" << std::endl
|
|
|
|
<< " -h, --help "
|
|
|
|
<< " Display this help and exit" << std::endl
|
|
|
|
<< std::endl
|
|
|
|
<< "FinalCut Options:" << std::endl
|
|
|
|
<< " --encoding <name> "
|
|
|
|
<< " Sets the character encoding mode" << std::endl
|
|
|
|
<< " "
|
|
|
|
<< " {UTF8, VT100, PC, ASCII}" << std::endl
|
|
|
|
<< " --no-optimized-cursor "
|
|
|
|
<< " Disable cursor optimization" << std::endl
|
|
|
|
<< " --no-terminal-detection"
|
|
|
|
<< " Disable terminal detection" << std::endl
|
|
|
|
<< " --no-color-change "
|
|
|
|
<< " Do not redefine the color palette" << std::endl
|
|
|
|
<< " --vgafont "
|
|
|
|
<< " Set the standard vga 8x16 font" << std::endl
|
|
|
|
<< " --newfont "
|
|
|
|
<< " Enables the graphical font" << std::endl;
|
|
|
|
std::exit(EXIT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
2017-10-30 20:56:00 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::closeConfirmationDialog (FWidget* w, FCloseEvent* ev)
|
|
|
|
{
|
|
|
|
int ret = FMessageBox::info ( w, "Quit"
|
|
|
|
, "Do you really want\n"
|
|
|
|
"to quit the program ?"
|
|
|
|
, FMessageBox::Yes
|
|
|
|
, FMessageBox::No );
|
|
|
|
if ( ret == FMessageBox::Yes )
|
|
|
|
ev->accept();
|
|
|
|
else
|
|
|
|
ev->ignore();
|
|
|
|
}
|
2016-11-02 00:37:58 +01:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
// private methods of FApplication
|
|
|
|
//----------------------------------------------------------------------
|
2016-02-07 22:02:38 +01:00
|
|
|
void FApplication::init()
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
// init keyboard values
|
|
|
|
time_keypressed.tv_sec = 0;
|
|
|
|
time_keypressed.tv_usec = 0;
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
x11_button_state = 0x23;
|
2016-10-11 04:57:36 +02:00
|
|
|
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2015-05-23 13:35:12 +02:00
|
|
|
gpm_ev.x = -1;
|
|
|
|
#endif
|
2016-10-11 04:57:36 +02:00
|
|
|
|
2017-08-12 22:55:29 +02:00
|
|
|
try
|
|
|
|
{
|
2017-09-11 03:06:02 +02:00
|
|
|
zero_point = new FPoint (0,0);
|
2017-08-12 22:55:29 +02:00
|
|
|
event_queue = new eventQueue;
|
|
|
|
}
|
|
|
|
catch (const std::bad_alloc& ex)
|
|
|
|
{
|
|
|
|
std::cerr << "not enough memory to alloc " << ex.what() << std::endl;
|
|
|
|
std::abort();
|
|
|
|
}
|
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
// init arrays with '\0'
|
|
|
|
std::fill_n (k_buf, sizeof(k_buf), '\0');
|
|
|
|
std::fill_n (fifo_buf, fifo_buf_size, '\0');
|
|
|
|
std::fill_n (x11_mouse, sizeof(x11_mouse), '\0');
|
|
|
|
std::fill_n (sgr_mouse, sizeof(sgr_mouse), '\0');
|
|
|
|
std::fill_n (urxvt_mouse, sizeof(urxvt_mouse), '\0');
|
|
|
|
// init bit field with 0
|
2016-10-06 23:15:09 +02:00
|
|
|
std::memset(&b_state, 0x00, sizeof(b_state));
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
2016-08-28 22:43:14 +02:00
|
|
|
//----------------------------------------------------------------------
|
2017-11-18 02:34:41 +01:00
|
|
|
void FApplication::cmd_options (const int& argc, char* argv[])
|
2016-08-28 22:43:14 +02:00
|
|
|
{
|
2017-11-18 02:34:41 +01:00
|
|
|
// interpret the command line options
|
2016-08-28 22:43:14 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
while ( true )
|
|
|
|
{
|
|
|
|
int c, idx = 0;
|
2017-10-02 07:32:33 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
static struct option long_options[] =
|
|
|
|
{
|
2017-12-17 01:06:53 +01:00
|
|
|
{C_STR("encoding"), required_argument, 0, 0 },
|
|
|
|
{C_STR("no-optimized-cursor"), no_argument, 0, 0 },
|
|
|
|
{C_STR("no-terminal-detection"), no_argument, 0, 0 },
|
|
|
|
{C_STR("no-color-change"), no_argument, 0, 0 },
|
|
|
|
{C_STR("vgafont"), no_argument, 0, 0 },
|
|
|
|
{C_STR("newfont"), no_argument, 0, 0 },
|
|
|
|
{0, 0, 0, 0 }
|
2015-05-23 13:35:12 +02:00
|
|
|
};
|
2017-10-02 07:32:33 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
opterr = 0;
|
2017-11-18 02:34:41 +01:00
|
|
|
c = getopt_long ( argc
|
|
|
|
, argv
|
2015-09-24 00:41:43 +02:00
|
|
|
, ""
|
|
|
|
, long_options
|
|
|
|
, &idx );
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( c == -1 )
|
|
|
|
break;
|
2015-09-24 00:41:43 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( c == 0 )
|
|
|
|
{
|
2016-10-06 23:15:09 +02:00
|
|
|
if ( std::strcmp(long_options[idx].name, "encoding") == 0 )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
FString encoding(optarg);
|
|
|
|
encoding = encoding.toUpper();
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-11-18 02:34:41 +01:00
|
|
|
if ( encoding.includes("UTF8") )
|
|
|
|
init_values.encoding = fc::UTF8;
|
|
|
|
else if ( encoding.includes("VT100") )
|
|
|
|
init_values.encoding = fc::VT100;
|
|
|
|
else if ( encoding.includes("PC") )
|
|
|
|
init_values.encoding = fc::PC;
|
|
|
|
else if ( encoding.includes("ASCII") )
|
|
|
|
init_values.encoding = fc::ASCII;
|
|
|
|
else if ( encoding.includes("HELP") )
|
|
|
|
showParameterUsage();
|
2016-08-28 22:43:14 +02:00
|
|
|
else
|
2017-11-18 02:34:41 +01:00
|
|
|
exitWithMessage ( "Unknown encoding "
|
|
|
|
+ std::string(encoding.c_str()) );
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2015-12-21 18:37:20 +01:00
|
|
|
|
2016-11-27 00:41:34 +01:00
|
|
|
if ( std::strcmp(long_options[idx].name, "no-optimized-cursor") == 0 )
|
2017-11-18 02:34:41 +01:00
|
|
|
init_values.cursor_optimisation = false;
|
2015-12-21 18:37:20 +01:00
|
|
|
|
2017-11-18 02:34:41 +01:00
|
|
|
if ( std::strcmp(long_options[idx].name, "no-terminal-detection") == 0 )
|
|
|
|
init_values.terminal_detection = false;
|
2016-08-28 22:43:14 +02:00
|
|
|
|
2017-11-18 02:34:41 +01:00
|
|
|
if ( std::strcmp(long_options[idx].name, "no-color-change") == 0 )
|
|
|
|
init_values.color_change = false;
|
2015-12-21 18:37:20 +01:00
|
|
|
|
2017-11-18 02:34:41 +01:00
|
|
|
if ( std::strcmp(long_options[idx].name, "vgafont") == 0 )
|
|
|
|
init_values.vgafont = true;
|
2016-08-28 22:43:14 +02:00
|
|
|
|
2017-11-18 02:34:41 +01:00
|
|
|
if ( std::strcmp(long_options[idx].name, "newfont") == 0 )
|
|
|
|
init_values.newfont = true;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2015-10-17 19:40:43 +02:00
|
|
|
int FApplication::gpmEvent (bool clear)
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
register int result;
|
2017-09-17 21:32:46 +02:00
|
|
|
register int max = ( gpm_fd > stdin_no ) ? gpm_fd : stdin_no;
|
2015-05-23 13:35:12 +02:00
|
|
|
fd_set ifds;
|
|
|
|
struct timeval tv;
|
|
|
|
|
|
|
|
FD_ZERO(&ifds);
|
|
|
|
FD_SET(stdin_no, &ifds);
|
|
|
|
FD_SET(gpm_fd, &ifds);
|
|
|
|
tv.tv_sec = 0;
|
|
|
|
tv.tv_usec = 100000; // 100 ms
|
2017-08-27 09:50:30 +02:00
|
|
|
result = select (max + 1, &ifds, 0, 0, &tv);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-06 12:19:39 +02:00
|
|
|
if ( result > 0 && FD_ISSET(stdin_no, &ifds) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2015-10-03 01:45:13 +02:00
|
|
|
if ( clear )
|
|
|
|
FD_CLR (stdin_no, &ifds);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
return keyboard_event;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-06 12:19:39 +02:00
|
|
|
if ( clear && result > 0 && FD_ISSET(gpm_fd, &ifds) )
|
2015-05-23 13:35:12 +02:00
|
|
|
FD_CLR (gpm_fd, &ifds);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-06 12:19:39 +02:00
|
|
|
if ( result > 0 )
|
2015-05-23 13:35:12 +02:00
|
|
|
return mouse_event;
|
|
|
|
else
|
|
|
|
return no_event;
|
|
|
|
}
|
2015-08-22 18:53:52 +02:00
|
|
|
#endif // F_HAVE_LIBGPM
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline bool FApplication::KeyPressed()
|
|
|
|
{
|
|
|
|
register int result;
|
|
|
|
fd_set ifds;
|
|
|
|
struct timeval tv;
|
|
|
|
|
|
|
|
FD_ZERO(&ifds);
|
|
|
|
FD_SET(stdin_no, &ifds);
|
|
|
|
tv.tv_sec = 0;
|
|
|
|
tv.tv_usec = 100000; // 100 ms
|
2017-08-27 09:50:30 +02:00
|
|
|
result = select (stdin_no + 1, &ifds, 0, 0, &tv);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-06 12:19:39 +02:00
|
|
|
if ( result > 0 && FD_ISSET(stdin_no, &ifds) )
|
2015-05-23 13:35:12 +02:00
|
|
|
FD_CLR (stdin_no, &ifds);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-09-17 21:32:46 +02:00
|
|
|
return ( result > 0 );
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline ssize_t FApplication::readKey()
|
|
|
|
{
|
|
|
|
register ssize_t bytes;
|
|
|
|
setNonBlockingInput();
|
2017-08-27 09:50:30 +02:00
|
|
|
bytes = read(stdin_no, &k_buf, sizeof(k_buf) - 1);
|
2015-05-23 13:35:12 +02:00
|
|
|
unsetNonBlockingInput();
|
|
|
|
return bytes;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-12-05 23:55:12 +01:00
|
|
|
inline FWidget* FApplication::findKeyboardWidget()
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
FWidget* widget = 0;
|
|
|
|
|
|
|
|
if ( focus_widget )
|
2016-09-30 04:55:28 +02:00
|
|
|
{
|
2016-10-01 23:18:49 +02:00
|
|
|
if ( move_size_widget )
|
|
|
|
widget = move_size_widget;
|
2016-09-30 04:55:28 +02:00
|
|
|
else
|
|
|
|
widget = focus_widget;
|
|
|
|
}
|
2015-05-23 13:35:12 +02:00
|
|
|
else
|
|
|
|
{
|
2016-09-30 04:55:28 +02:00
|
|
|
widget = main_widget;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-11-26 15:18:44 +01:00
|
|
|
if ( widget && widget->numOfChildren() >= 1 )
|
2015-05-23 13:35:12 +02:00
|
|
|
widget->focusFirstChild();
|
|
|
|
}
|
|
|
|
|
2017-12-05 23:55:12 +01:00
|
|
|
return widget;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline void FApplication::keyboardBufferTimeout (FWidget*)
|
|
|
|
{
|
2017-09-18 00:10:14 +02:00
|
|
|
// Empty the buffer on timeout
|
2017-12-05 23:55:12 +01:00
|
|
|
if ( fifo_in_use && isKeyTimeout(&time_keypressed, key_timeout) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
fifo_offset = 0;
|
|
|
|
key = 0;
|
|
|
|
std::fill_n (fifo_buf, fifo_buf_size, '\0');
|
|
|
|
fifo_in_use = false;
|
|
|
|
}
|
2017-12-05 23:55:12 +01:00
|
|
|
}
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-12-05 23:55:12 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline bool FApplication::getKeyPressedState()
|
|
|
|
{
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2016-10-11 04:57:36 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( isGpmMouseEnabled() )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
gpmMouseEvent = false;
|
|
|
|
int type = gpmEvent();
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
switch ( type )
|
|
|
|
{
|
|
|
|
case mouse_event:
|
|
|
|
gpmMouseEvent = true;
|
|
|
|
break;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
case keyboard_event:
|
2017-12-05 23:55:12 +01:00
|
|
|
return true;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
|
|
|
default:
|
2017-12-05 23:55:12 +01:00
|
|
|
return false;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
}
|
2016-10-11 04:57:36 +02:00
|
|
|
|
2017-12-05 23:55:12 +01:00
|
|
|
#endif // F_HAVE_LIBGPM
|
2016-10-11 04:57:36 +02:00
|
|
|
|
2017-12-05 23:55:12 +01:00
|
|
|
return KeyPressed();
|
|
|
|
}
|
2016-10-11 04:57:36 +02:00
|
|
|
|
2017-12-05 23:55:12 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline void FApplication::readRawX11MouseData()
|
|
|
|
{
|
|
|
|
static const int len = 6;
|
|
|
|
int n;
|
|
|
|
x11_mouse[0] = fifo_buf[3];
|
|
|
|
x11_mouse[1] = fifo_buf[4];
|
|
|
|
x11_mouse[2] = fifo_buf[5];
|
|
|
|
x11_mouse[3] = '\0';
|
|
|
|
|
|
|
|
// Remove founded entry
|
|
|
|
for (n = len; n < fifo_buf_size; n++)
|
|
|
|
fifo_buf[n - len] = fifo_buf[n];
|
|
|
|
|
|
|
|
n = fifo_buf_size - len - 1;
|
|
|
|
|
|
|
|
// Fill rest with '\0'
|
|
|
|
for (; n < fifo_buf_size; n++)
|
|
|
|
fifo_buf[n - len] = '\0';
|
|
|
|
|
|
|
|
unprocessedInput() = bool(fifo_buf[0] != '\0');
|
|
|
|
processMouseEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline void FApplication::readRawExtendedMouseData()
|
|
|
|
{
|
|
|
|
int len = int(std::strlen(fifo_buf));
|
|
|
|
int n = 3;
|
|
|
|
|
|
|
|
while ( n < len && n < fifo_buf_size )
|
|
|
|
{
|
|
|
|
sgr_mouse[n - 3] = fifo_buf[n];
|
|
|
|
n++;
|
|
|
|
|
|
|
|
if ( fifo_buf[n] == 'M' || fifo_buf[n] == 'm' )
|
|
|
|
len = n + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
sgr_mouse[n - 3] = '\0';
|
|
|
|
|
|
|
|
for (n = len; n < fifo_buf_size; n++) // Remove founded entry
|
|
|
|
fifo_buf[n - len] = fifo_buf[n];
|
|
|
|
|
|
|
|
n = fifo_buf_size - len - 1;
|
|
|
|
|
|
|
|
for (; n < fifo_buf_size; n++) // Fill rest with '\0'
|
|
|
|
fifo_buf[n - len] = '\0';
|
|
|
|
|
|
|
|
unprocessedInput() = bool(fifo_buf[0] != '\0');
|
|
|
|
processMouseEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline void FApplication::readRawUrxvtMouseData()
|
|
|
|
{
|
|
|
|
int len = int(std::strlen(fifo_buf));
|
|
|
|
int n = 2;
|
|
|
|
|
|
|
|
while ( n < len && n < fifo_buf_size )
|
|
|
|
{
|
|
|
|
urxvt_mouse[n - 2] = fifo_buf[n];
|
|
|
|
n++;
|
|
|
|
|
|
|
|
if ( fifo_buf[n] == 'M' || fifo_buf[n] == 'm' )
|
|
|
|
len = n + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
urxvt_mouse[n - 2] = '\0';
|
|
|
|
|
|
|
|
for (n = len; n < fifo_buf_size; n++) // Remove founded entry
|
|
|
|
fifo_buf[n - len] = fifo_buf[n];
|
|
|
|
|
|
|
|
n = fifo_buf_size - len - 1;
|
|
|
|
|
|
|
|
for (; n < fifo_buf_size; n++) // Fill rest with '\0'
|
|
|
|
fifo_buf[n - len] = '\0';
|
|
|
|
|
|
|
|
unprocessedInput() = bool(fifo_buf[0] != '\0');
|
|
|
|
processMouseEvent();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline void FApplication::sendEscapeKeyPressEvent (FWidget* widget)
|
|
|
|
{
|
|
|
|
// Send an escape key press event if there is only one 0x1b
|
|
|
|
// in the buffer and the timeout is reached
|
|
|
|
|
|
|
|
if ( fifo_in_use
|
|
|
|
&& fifo_offset == 1
|
|
|
|
&& fifo_buf[0] == 0x1b
|
|
|
|
&& fifo_buf[1] == 0x00
|
|
|
|
&& isKeyTimeout(&time_keypressed, key_timeout) )
|
|
|
|
{
|
|
|
|
FKeyEvent k_press_ev (fc::KeyPress_Event, fc::Fkey_escape);
|
|
|
|
sendEvent (widget, &k_press_ev);
|
|
|
|
unprocessedInput() = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline bool FApplication::sendKeyDownEvent (FWidget* widget)
|
|
|
|
{
|
|
|
|
// Send key down event
|
|
|
|
FKeyEvent k_down_ev (fc::KeyDown_Event, key);
|
|
|
|
sendEvent (widget, &k_down_ev);
|
|
|
|
return k_down_ev.isAccepted();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline bool FApplication::sendKeyPressEvent (FWidget* widget)
|
|
|
|
{
|
|
|
|
// Send key press event
|
|
|
|
FKeyEvent k_press_ev (fc::KeyPress_Event, key);
|
|
|
|
sendEvent (widget, &k_press_ev);
|
|
|
|
return k_press_ev.isAccepted();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline bool FApplication::sendKeyUpEvent (FWidget* widget)
|
|
|
|
{
|
|
|
|
// Send key up event
|
|
|
|
FKeyEvent k_up_ev (fc::KeyUp_Event, key);
|
|
|
|
sendEvent (widget, &k_up_ev);
|
|
|
|
return k_up_ev.isAccepted();
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
inline void FApplication::sendKeyboardAccelerator()
|
|
|
|
{
|
|
|
|
if ( open_menu )
|
|
|
|
return;
|
|
|
|
|
|
|
|
// Switch to a specific dialog with Meta + 1..9
|
|
|
|
bool accpt = processDialogSwitchAccelerator();
|
|
|
|
|
|
|
|
// Windows keyboard accelerator
|
|
|
|
if ( ! accpt )
|
|
|
|
{
|
|
|
|
const FWidget* window = active_window;
|
|
|
|
|
|
|
|
if ( window )
|
|
|
|
accpt = processAccelerator (window);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Global keyboard accelerator
|
|
|
|
if ( ! accpt )
|
|
|
|
{
|
|
|
|
const FWidget* root_widget = getRootWidget();
|
|
|
|
|
|
|
|
if ( root_widget )
|
|
|
|
processAccelerator (root_widget);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::processKeyboardEvent()
|
|
|
|
{
|
2017-12-10 15:36:02 +01:00
|
|
|
bool isKeyPressed;
|
2017-12-05 23:55:12 +01:00
|
|
|
FWidget* widget = findKeyboardWidget();
|
|
|
|
keyboardBufferTimeout(widget);
|
|
|
|
flush_out();
|
|
|
|
isKeyPressed = getKeyPressedState();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
if ( isKeyPressed )
|
|
|
|
{
|
|
|
|
register ssize_t bytesread;
|
2017-09-11 03:06:02 +02:00
|
|
|
widget->getCurrentTime (&time_keypressed);
|
2015-05-23 13:35:12 +02:00
|
|
|
x11_mouse[0] = sgr_mouse[0] = urxvt_mouse[0] = '\0';
|
|
|
|
|
|
|
|
if ( quit_now || app_exit_loop )
|
|
|
|
return;
|
|
|
|
|
|
|
|
while ( (bytesread = readKey()) > 0 )
|
|
|
|
{
|
2015-09-24 00:41:43 +02:00
|
|
|
if ( bytesread + fifo_offset <= fifo_buf_size )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2017-08-27 09:50:30 +02:00
|
|
|
for (int i = 0; i < bytesread; i++)
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
fifo_buf[fifo_offset] = k_buf[i];
|
|
|
|
fifo_offset++;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
fifo_in_use = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// read the rest from the fifo buffer
|
2016-12-18 23:34:11 +01:00
|
|
|
while ( ! widget->isKeyTimeout(&time_keypressed, key_timeout)
|
2017-11-26 22:37:18 +01:00
|
|
|
&& fifo_offset > 0
|
|
|
|
&& key != NEED_MORE_DATA )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
key = FTerm::parseKeyString(fifo_buf, fifo_buf_size, &time_keypressed);
|
|
|
|
|
|
|
|
if ( key != NEED_MORE_DATA )
|
|
|
|
{
|
2017-03-26 20:40:04 +02:00
|
|
|
|
|
|
|
#if defined(__linux__)
|
2017-04-14 23:55:44 +02:00
|
|
|
key = linuxModifierKeyCorrection (key);
|
2017-03-26 20:40:04 +02:00
|
|
|
#endif
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2016-07-28 23:38:17 +02:00
|
|
|
switch ( key )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2016-07-28 23:38:17 +02:00
|
|
|
case fc::Fckey_l: // Ctrl-L (redraw the screen)
|
|
|
|
redraw();
|
|
|
|
break;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2016-07-28 23:38:17 +02:00
|
|
|
case fc::Fkey_mouse:
|
2017-12-05 23:55:12 +01:00
|
|
|
readRawX11MouseData();
|
2016-07-28 23:38:17 +02:00
|
|
|
break;
|
2016-07-31 20:25:25 +02:00
|
|
|
|
2016-07-28 23:38:17 +02:00
|
|
|
case fc::Fkey_extended_mouse:
|
2017-12-05 23:55:12 +01:00
|
|
|
readRawExtendedMouseData();
|
2016-07-28 23:38:17 +02:00
|
|
|
break;
|
2016-07-12 23:35:33 +02:00
|
|
|
|
2016-07-28 23:38:17 +02:00
|
|
|
case fc::Fkey_urxvt_mouse:
|
2017-12-05 23:55:12 +01:00
|
|
|
readRawUrxvtMouseData();
|
2016-07-28 23:38:17 +02:00
|
|
|
break;
|
2016-07-25 23:50:57 +02:00
|
|
|
|
2016-07-28 23:38:17 +02:00
|
|
|
default:
|
2017-12-05 23:55:12 +01:00
|
|
|
bool acceptKeyDown = sendKeyDownEvent (widget);
|
|
|
|
bool acceptKeyPress = sendKeyPressEvent (widget);
|
|
|
|
|
|
|
|
if ( ! (acceptKeyDown || acceptKeyPress) )
|
|
|
|
sendKeyboardAccelerator();
|
|
|
|
|
2016-07-28 23:38:17 +02:00
|
|
|
break;
|
2017-09-11 03:06:02 +02:00
|
|
|
} // end of switch
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-10-06 23:15:09 +02:00
|
|
|
fifo_offset = int(std::strlen(fifo_buf));
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 23:55:12 +01:00
|
|
|
// Send key up event
|
|
|
|
sendKeyUpEvent (widget);
|
2015-05-23 13:35:12 +02:00
|
|
|
key = 0;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
std::fill_n (k_buf, sizeof(k_buf), '\0');
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
// special case: Esc key
|
2017-12-05 23:55:12 +01:00
|
|
|
sendEscapeKeyPressEvent (widget);
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
2017-03-26 20:40:04 +02:00
|
|
|
#if defined(__linux__)
|
2016-07-23 19:50:28 +02:00
|
|
|
//----------------------------------------------------------------------
|
2017-12-02 18:52:51 +01:00
|
|
|
int FApplication::linuxShiftKeyCorrection (const int& key_id)
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fkey_sr; // Shift+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fkey_sf; // Shift+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fkey_sleft; // Shift+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fkey_sright; // Shift+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fkey_sic; // Shift+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fkey_sdc; // Shift+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fkey_shome; // Shift+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fkey_send; // Shift+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fkey_sprevious; // Shift+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fkey_snext; // Shift+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-12-02 18:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxCtrlKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fckey_up; // Ctrl+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fckey_down; // Ctrl+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fckey_left; // Ctrl+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fckey_right; // Ctrl+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fckey_ic; // Ctrl+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fckey_dc; // Ctrl+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fckey_home; // Ctrl+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fckey_end; // Ctrl+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fckey_ppage; // Ctrl+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fckey_npage; // Ctrl+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-12-02 18:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxAltKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fmkey_up; // Meta+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fmkey_down; // Meta+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fmkey_left; // Meta+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fmkey_right; // Meta+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fmkey_ic; // Meta+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fmkey_dc; // Meta+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fmkey_home; // Meta+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fmkey_end; // Meta+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fmkey_ppage; // Meta+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fmkey_npage; // Meta+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-12-02 18:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxShiftCtrlKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fckey_sup; // Shift+Ctrl+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fckey_sdown; // Shift+Ctrl+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fckey_sleft; // Shift+Ctrl+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fckey_sright; // Shift+Ctrl+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fckey_sic; // Shift+Ctrl+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fckey_sdc; // Shift+Ctrl+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fckey_shome; // Shift+Ctrl+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fckey_send; // Shift+Ctrl+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fckey_sppage; // Shift+Ctrl+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fckey_snpage; // Shift+Ctrl+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-12-02 18:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxShiftAltKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fmkey_sup; // Shift+Meta+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fmkey_sdown; // Shift+Meta+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fmkey_sright; // Shift+Meta+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fmkey_sleft; // Shift+Meta+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fmkey_sic; // Shift+Meta+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fmkey_sdc; // Shift+Meta+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fmkey_shome; // Shift+Meta+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fmkey_send; // Shift+Meta+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fmkey_sppage; // Shift+Meta+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fmkey_snpage; // Shift+Meta+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-12-02 18:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxCtrlAltKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fcmkey_up; // Ctrl+Meta+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fcmkey_down; // Ctrl+Meta+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fcmkey_left; // Ctrl+Meta+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fcmkey_right; // Ctrl+Meta+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fcmkey_ic; // Ctrl+Meta+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fcmkey_dc; // Ctrl+Meta+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fcmkey_home; // Ctrl+Meta+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fcmkey_end; // Ctrl+Meta+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fcmkey_ppage; // Ctrl+Meta+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fcmkey_npage; // Ctrl+Meta+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-12-02 18:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxShiftCtrlAltKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
switch ( key_id )
|
2016-07-23 19:50:28 +02:00
|
|
|
{
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_up:
|
|
|
|
return fc::Fcmkey_sup; // Shift+Ctrl+Meta+Up
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_down:
|
|
|
|
return fc::Fcmkey_sdown; // Shift+Ctrl+Meta+Down
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_left:
|
|
|
|
return fc::Fcmkey_sleft; // Shift+Ctrl+Meta+Left
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_right:
|
|
|
|
return fc::Fcmkey_sright; // Shift+Ctrl+Meta+Right
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ic:
|
|
|
|
return fc::Fcmkey_sic; // Shift+Ctrl+Meta+Ins
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_dc:
|
|
|
|
return fc::Fcmkey_sdc; // Shift+Ctrl+Meta+Del
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_home:
|
|
|
|
return fc::Fcmkey_shome; // Shift+Ctrl+Meta+Home
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_end:
|
|
|
|
return fc::Fcmkey_send; // Shift+Ctrl+Meta+End
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_ppage:
|
|
|
|
return fc::Fcmkey_sppage; // Shift+Ctrl+Meta+PgUp
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
case fc::Fkey_npage:
|
|
|
|
return fc::Fcmkey_snpage; // Shift+Ctrl+Meta+PgDn
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2017-12-02 18:52:51 +01:00
|
|
|
default:
|
|
|
|
return key_id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::linuxModifierKeyCorrection (const int& key_id)
|
|
|
|
{
|
|
|
|
// Get the current modifier key state
|
|
|
|
|
|
|
|
FTerm::modifier_key& m = getLinuxModifierKey();
|
|
|
|
|
|
|
|
if ( ! (m.shift || m.ctrl || m.alt) )
|
|
|
|
{
|
|
|
|
return key_id;
|
|
|
|
}
|
|
|
|
else if ( m.shift && ! m.ctrl && ! m.alt )
|
|
|
|
{
|
|
|
|
return linuxShiftKeyCorrection(key_id);
|
|
|
|
}
|
|
|
|
else if ( ! m.shift && m.ctrl && ! m.alt )
|
|
|
|
{
|
|
|
|
return linuxCtrlKeyCorrection(key_id);
|
|
|
|
}
|
|
|
|
else if ( ! m.shift && ! m.ctrl && m.alt )
|
|
|
|
{
|
|
|
|
return linuxAltKeyCorrection(key_id);
|
|
|
|
}
|
|
|
|
else if ( m.shift && m.ctrl && ! m.alt )
|
|
|
|
{
|
|
|
|
return linuxShiftCtrlKeyCorrection(key_id);
|
|
|
|
}
|
|
|
|
else if ( m.shift && ! m.ctrl && m.alt )
|
|
|
|
{
|
|
|
|
return linuxShiftAltKeyCorrection(key_id);
|
|
|
|
}
|
|
|
|
else if ( ! m.shift && m.ctrl && m.alt )
|
|
|
|
{
|
|
|
|
return linuxCtrlAltKeyCorrection(key_id);
|
|
|
|
}
|
|
|
|
else if ( m.shift && m.ctrl && m.alt )
|
|
|
|
{
|
|
|
|
return linuxShiftCtrlAltKeyCorrection(key_id);
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
|
|
|
|
2016-07-23 20:56:20 +02:00
|
|
|
return key_id;
|
2016-07-23 19:50:28 +02:00
|
|
|
}
|
2017-03-26 20:40:04 +02:00
|
|
|
#endif
|
2016-07-23 19:50:28 +02:00
|
|
|
|
2016-07-16 20:39:38 +02:00
|
|
|
//----------------------------------------------------------------------
|
2016-07-24 20:18:23 +02:00
|
|
|
bool FApplication::processDialogSwitchAccelerator()
|
2016-07-16 20:39:38 +02:00
|
|
|
{
|
|
|
|
if ( key >= fc::Fmkey_1 && key <= fc::Fmkey_9 )
|
|
|
|
{
|
2016-07-23 20:56:20 +02:00
|
|
|
uLong n = uLong(key - fc::Fmkey_0);
|
|
|
|
uLong s = dialog_list->size();
|
2016-07-16 20:39:38 +02:00
|
|
|
|
|
|
|
if ( s > 0 && s >= n )
|
|
|
|
{
|
2016-09-30 04:55:28 +02:00
|
|
|
// unset the move/size mode
|
2016-10-02 21:26:25 +02:00
|
|
|
if ( move_size_widget )
|
|
|
|
{
|
|
|
|
FWidget* w = move_size_widget;
|
|
|
|
move_size_widget = 0;
|
|
|
|
w->redraw();
|
|
|
|
}
|
|
|
|
|
2016-07-16 20:39:38 +02:00
|
|
|
FAccelEvent a_ev (fc::Accelerator_Event, focus_widget);
|
2017-08-27 09:50:30 +02:00
|
|
|
sendEvent (dialog_list->at(n - 1), &a_ev);
|
2016-07-24 20:18:23 +02:00
|
|
|
return true;
|
2016-07-16 20:39:38 +02:00
|
|
|
}
|
|
|
|
}
|
2016-07-24 20:18:23 +02:00
|
|
|
|
|
|
|
return false;
|
2016-07-16 20:39:38 +02:00
|
|
|
}
|
|
|
|
|
2016-07-12 23:35:33 +02:00
|
|
|
//----------------------------------------------------------------------
|
2017-08-12 20:10:27 +02:00
|
|
|
bool FApplication::processAccelerator (const FWidget*& widget)
|
2016-07-12 23:35:33 +02:00
|
|
|
{
|
2016-07-24 20:18:23 +02:00
|
|
|
bool accpt = false;
|
|
|
|
|
2016-07-12 23:35:33 +02:00
|
|
|
if ( widget
|
2017-11-26 22:37:18 +01:00
|
|
|
&& widget->accelerator_list
|
|
|
|
&& ! widget->accelerator_list->empty() )
|
2016-07-12 23:35:33 +02:00
|
|
|
{
|
2017-09-17 01:50:41 +02:00
|
|
|
FWidget::Accelerators::const_iterator iter, last;
|
2016-07-12 23:35:33 +02:00
|
|
|
iter = widget->accelerator_list->begin();
|
2017-09-17 01:50:41 +02:00
|
|
|
last = widget->accelerator_list->end();
|
2016-07-12 23:35:33 +02:00
|
|
|
|
2017-09-17 01:50:41 +02:00
|
|
|
while ( iter != last )
|
2016-07-12 23:35:33 +02:00
|
|
|
{
|
|
|
|
if ( quit_now || app_exit_loop )
|
|
|
|
break;
|
|
|
|
|
|
|
|
if ( iter->key == key )
|
|
|
|
{
|
2016-09-30 04:55:28 +02:00
|
|
|
// unset the move/size mode
|
2016-10-02 21:26:25 +02:00
|
|
|
if ( move_size_widget )
|
|
|
|
{
|
|
|
|
FWidget* w = move_size_widget;
|
|
|
|
move_size_widget = 0;
|
|
|
|
w->redraw();
|
|
|
|
}
|
|
|
|
|
2016-07-12 23:35:33 +02:00
|
|
|
FAccelEvent a_ev (fc::Accelerator_Event, focus_widget);
|
|
|
|
sendEvent (iter->object, &a_ev);
|
2016-07-24 20:18:23 +02:00
|
|
|
accpt = a_ev.isAccepted();
|
2016-07-12 23:35:33 +02:00
|
|
|
break;
|
|
|
|
};
|
|
|
|
|
|
|
|
++iter;
|
|
|
|
}
|
|
|
|
}
|
2016-07-24 20:18:23 +02:00
|
|
|
|
|
|
|
return accpt;
|
2016-07-12 23:35:33 +02:00
|
|
|
}
|
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
//----------------------------------------------------------------------
|
2015-10-09 01:23:49 +02:00
|
|
|
void FApplication::getX11ButtonState (int button)
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2015-10-09 01:23:49 +02:00
|
|
|
// get the x11 and urxvt mouse button state
|
2016-10-13 02:16:51 +02:00
|
|
|
const FPoint& mouse_position = getMousePos();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2015-10-09 01:23:49 +02:00
|
|
|
enum btn_states
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
key_shift = 0x04,
|
|
|
|
key_meta = 0x08,
|
|
|
|
key_ctrl = 0x10,
|
|
|
|
key_button_mask = 0x1c,
|
|
|
|
button1_pressed = 0x20,
|
|
|
|
button2_pressed = 0x21,
|
|
|
|
button3_pressed = 0x22,
|
|
|
|
all_buttons_released = 0x23,
|
|
|
|
button1_pressed_move = 0x40,
|
|
|
|
button2_pressed_move = 0x41,
|
|
|
|
button3_pressed_move = 0x42,
|
|
|
|
button_mask = 0x63,
|
|
|
|
button_up = 0x60,
|
2015-10-09 01:23:49 +02:00
|
|
|
button_down = 0x61,
|
|
|
|
button_up_move = 0x60,
|
|
|
|
button_down_move = 0x61
|
2015-05-23 13:35:12 +02:00
|
|
|
};
|
|
|
|
|
2015-10-09 01:23:49 +02:00
|
|
|
switch ( button )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
case button1_pressed:
|
|
|
|
case button1_pressed_move:
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( mouse_position == new_mouse_position
|
2017-11-26 22:37:18 +01:00
|
|
|
&& x11_button_state == all_buttons_released
|
|
|
|
&& ! isKeyTimeout(&time_mousepressed, dblclick_interval) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.left_button = DoubleClick;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
time_mousepressed = time_keypressed; // save click time
|
|
|
|
b_state.left_button = Pressed;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button2_pressed:
|
|
|
|
case button2_pressed_move:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.middle_button = Pressed;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button3_pressed:
|
|
|
|
case button3_pressed_move:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.right_button = Pressed;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case all_buttons_released:
|
|
|
|
switch ( x11_button_state & button_mask )
|
|
|
|
{
|
|
|
|
case button1_pressed:
|
|
|
|
case button1_pressed_move:
|
|
|
|
b_state.left_button = Released;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button2_pressed:
|
|
|
|
case button2_pressed_move:
|
|
|
|
b_state.middle_button = Released;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button3_pressed:
|
|
|
|
case button3_pressed_move:
|
|
|
|
b_state.right_button = Released;
|
|
|
|
break;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button_up:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.wheel_up = Pressed;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button_down:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.wheel_down = Pressed;
|
|
|
|
break;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2015-10-09 01:23:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
bool FApplication::parseX11Mouse()
|
|
|
|
{
|
2016-10-13 02:16:51 +02:00
|
|
|
const FPoint& mouse_position = getMousePos();
|
2015-10-09 01:23:49 +02:00
|
|
|
uChar x, y;
|
|
|
|
|
|
|
|
enum x11_btn_states
|
|
|
|
{
|
|
|
|
key_shift = 0x04,
|
|
|
|
key_meta = 0x08,
|
|
|
|
key_ctrl = 0x10,
|
|
|
|
key_button_mask = 0x1c,
|
|
|
|
button1_pressed = 0x20,
|
|
|
|
button2_pressed = 0x21,
|
|
|
|
button3_pressed = 0x22,
|
|
|
|
all_buttons_released = 0x23,
|
|
|
|
button1_pressed_move = 0x40,
|
|
|
|
button2_pressed_move = 0x41,
|
|
|
|
button3_pressed_move = 0x42,
|
|
|
|
button_mask = 0x63,
|
|
|
|
button_up = 0x60,
|
|
|
|
button_down = 0x61
|
|
|
|
};
|
|
|
|
|
|
|
|
x = uChar(x11_mouse[1] - 0x20);
|
|
|
|
y = uChar(x11_mouse[2] - 0x20);
|
2017-09-11 03:06:02 +02:00
|
|
|
new_mouse_position.setPoint (x, y);
|
2016-07-23 19:50:28 +02:00
|
|
|
// fill bit field with 0
|
2016-10-06 23:15:09 +02:00
|
|
|
std::memset(&b_state, 0x00, sizeof(b_state));
|
2015-10-09 01:23:49 +02:00
|
|
|
|
|
|
|
if ( (x11_mouse[0] & key_shift) == key_shift )
|
|
|
|
b_state.shift_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-10-09 01:23:49 +02:00
|
|
|
if ( (x11_mouse[0] & key_meta) == key_meta )
|
|
|
|
b_state.meta_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-10-09 01:23:49 +02:00
|
|
|
if ( (x11_mouse[0] & key_ctrl) == key_ctrl )
|
|
|
|
b_state.control_button = Pressed;
|
|
|
|
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( (x11_mouse[0] & button_mask) >= button1_pressed_move
|
2017-11-26 22:37:18 +01:00
|
|
|
&& (x11_mouse[0] & button_mask) <= button3_pressed_move
|
|
|
|
&& mouse_position != *zero_point )
|
2015-10-09 01:23:49 +02:00
|
|
|
{
|
|
|
|
b_state.mouse_moved = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
getX11ButtonState (x11_mouse[0] & button_mask);
|
|
|
|
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( uChar(x11_mouse[1]) == mouse_position.getX() + 0x20
|
2017-11-26 22:37:18 +01:00
|
|
|
&& uChar(x11_mouse[2]) == mouse_position.getY() + 0x20
|
|
|
|
&& b_state.wheel_up != Pressed
|
|
|
|
&& b_state.wheel_down != Pressed
|
|
|
|
&& uChar(x11_mouse[0]) == x11_button_state )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
setMousePos (x, y);
|
2015-05-23 13:35:12 +02:00
|
|
|
x11_button_state = uChar(x11_mouse[0]);
|
|
|
|
x11_mouse[0] = '\0';
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
bool FApplication::parseSGRMouse()
|
|
|
|
{
|
2016-10-13 02:16:51 +02:00
|
|
|
const FPoint& mouse_position = getMousePos();
|
2015-05-23 13:35:12 +02:00
|
|
|
register char* p;
|
|
|
|
int button;
|
2017-10-02 07:32:33 +02:00
|
|
|
short x, y;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
enum x11_ext_btn_states
|
|
|
|
{
|
|
|
|
key_shift = 0x04,
|
|
|
|
key_meta = 0x08,
|
|
|
|
key_ctrl = 0x10,
|
|
|
|
key_button_mask = 0x1c,
|
|
|
|
button1 = 0x00,
|
|
|
|
button2 = 0x01,
|
|
|
|
button3 = 0x02,
|
|
|
|
button1_move = 0x20,
|
|
|
|
button2_move = 0x21,
|
|
|
|
button3_move = 0x22,
|
|
|
|
button_mask = 0x63,
|
|
|
|
button_up = 0x40,
|
|
|
|
button_down = 0x41,
|
|
|
|
pressed = 'M',
|
|
|
|
released = 'm'
|
|
|
|
};
|
2016-10-13 02:16:51 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
x = 0;
|
|
|
|
y = 0;
|
|
|
|
button = 0;
|
|
|
|
|
|
|
|
// parse the SGR mouse string
|
|
|
|
p = sgr_mouse;
|
|
|
|
|
|
|
|
while ( *p && *p != ';' )
|
|
|
|
{
|
|
|
|
if ( *p < '0' || *p > '9')
|
|
|
|
return false;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
button = 10 * button + (*p - '0');
|
|
|
|
p++;
|
|
|
|
}
|
|
|
|
|
|
|
|
while ( *p++ && *p != ';' )
|
|
|
|
{
|
|
|
|
if ( *p < '0' || *p > '9')
|
|
|
|
return false;
|
2017-10-02 07:32:33 +02:00
|
|
|
x = short(10 * x + (*p - '0'));
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
while ( *p++ && *p != 'M' && *p != 'm' )
|
|
|
|
{
|
|
|
|
if ( *p < '0' || *p > '9')
|
|
|
|
return false;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-02 07:32:33 +02:00
|
|
|
y = short(10 * y + (*p - '0'));
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
2017-09-11 03:06:02 +02:00
|
|
|
new_mouse_position.setPoint (x, y);
|
2016-07-23 19:50:28 +02:00
|
|
|
// fill bit field with 0
|
2016-10-06 23:15:09 +02:00
|
|
|
std::memset(&b_state, 0x00, sizeof(b_state));
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
if ( (button & key_shift) == key_shift )
|
|
|
|
b_state.shift_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( (button & key_meta) == key_meta )
|
|
|
|
b_state.meta_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( (button & key_ctrl) == key_ctrl )
|
|
|
|
b_state.control_button = Pressed;
|
|
|
|
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( (button & button_mask) >= button1_move
|
2017-11-26 22:37:18 +01:00
|
|
|
&& (button & button_mask) <= button3_move
|
|
|
|
&& mouse_position != *zero_point )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
b_state.mouse_moved = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( *p == pressed )
|
|
|
|
{
|
|
|
|
switch ( button & button_mask )
|
|
|
|
{
|
|
|
|
case button1:
|
|
|
|
case button1_move:
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( mouse_position == new_mouse_position
|
2017-11-26 22:37:18 +01:00
|
|
|
&& (((x11_button_state & 0x80) >> 2) + 'M') == released
|
|
|
|
&& ! isKeyTimeout(&time_mousepressed, dblclick_interval) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.left_button = DoubleClick;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
time_mousepressed = time_keypressed; // save click time
|
|
|
|
b_state.left_button = Pressed;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button2:
|
|
|
|
case button2_move:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.middle_button = Pressed;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button3:
|
|
|
|
case button3_move:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.right_button = Pressed;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button_up:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.wheel_up = Pressed;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button_down:
|
|
|
|
time_mousepressed.tv_sec = 0;
|
|
|
|
time_mousepressed.tv_usec = 0;
|
|
|
|
b_state.wheel_down = Pressed;
|
|
|
|
break;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else // *p == released
|
|
|
|
{
|
|
|
|
switch ( button & button_mask )
|
|
|
|
{
|
|
|
|
case button1:
|
|
|
|
case button1_move:
|
|
|
|
b_state.left_button = Released;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button2:
|
|
|
|
case button2_move:
|
|
|
|
b_state.middle_button = Released;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case button3:
|
|
|
|
case button3_move:
|
|
|
|
b_state.right_button = Released;
|
|
|
|
break;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( mouse_position == new_mouse_position
|
2017-11-26 22:37:18 +01:00
|
|
|
&& b_state.wheel_up != Pressed
|
|
|
|
&& b_state.wheel_down != Pressed
|
|
|
|
&& x11_button_state == uChar(((*p & 0x20) << 2) + button) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
setMousePos (x, y);
|
2015-05-23 13:35:12 +02:00
|
|
|
x11_button_state = uChar(((*p & 0x20) << 2) + button);
|
|
|
|
sgr_mouse[0] = '\0';
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
bool FApplication::parseUrxvtMouse()
|
|
|
|
{
|
2016-10-13 02:16:51 +02:00
|
|
|
const FPoint& mouse_position = getMousePos();
|
2015-05-23 13:35:12 +02:00
|
|
|
register char* p;
|
|
|
|
register bool x_neg;
|
|
|
|
register bool y_neg;
|
|
|
|
int button;
|
2017-10-02 07:32:33 +02:00
|
|
|
short x, y;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
enum urxvt_btn_states
|
|
|
|
{
|
|
|
|
key_shift = 0x04,
|
|
|
|
key_meta = 0x08,
|
|
|
|
key_ctrl = 0x10,
|
|
|
|
key_button_mask = 0x1c,
|
|
|
|
button1_pressed = 0x20,
|
|
|
|
button2_pressed = 0x21,
|
|
|
|
button3_pressed = 0x22,
|
|
|
|
all_buttons_released = 0x23,
|
|
|
|
button1_pressed_move = 0x40,
|
|
|
|
button2_pressed_move = 0x41,
|
|
|
|
button3_pressed_move = 0x42,
|
|
|
|
button_mask = 0x63,
|
|
|
|
button_up = 0x60,
|
|
|
|
button_down = 0x61,
|
|
|
|
button_up_move = 0x60,
|
|
|
|
button_down_move = 0x61
|
|
|
|
};
|
|
|
|
x = 0;
|
|
|
|
y = 0;
|
|
|
|
button = 0;
|
|
|
|
|
|
|
|
// parse the SGR mouse string
|
|
|
|
p = urxvt_mouse;
|
|
|
|
x_neg = false;
|
|
|
|
y_neg = false;
|
|
|
|
|
|
|
|
while ( *p && *p != ';' )
|
|
|
|
{
|
|
|
|
if ( *p < '0' || *p > '9')
|
|
|
|
return false;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
button = 10 * button + (*p - '0');
|
|
|
|
p++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( *++p == '-' )
|
|
|
|
{
|
|
|
|
p++;
|
|
|
|
x_neg = true;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
while ( *p && *p != ';' )
|
|
|
|
{
|
|
|
|
if ( *p < '0' || *p > '9')
|
|
|
|
return false;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-02 07:32:33 +02:00
|
|
|
x = short(10 * x + (*p - '0'));
|
2015-05-23 13:35:12 +02:00
|
|
|
p++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( *++p == '-' )
|
|
|
|
{
|
|
|
|
p++;
|
|
|
|
y_neg = true;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
while ( *p && *p != 'M' )
|
|
|
|
{
|
|
|
|
if ( *p < '0' || *p > '9')
|
|
|
|
return false;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-10-02 07:32:33 +02:00
|
|
|
y = short(10 * y + (*p - '0'));
|
2015-05-23 13:35:12 +02:00
|
|
|
p++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( x_neg || x == 0 )
|
|
|
|
x = 1;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( y_neg || y == 0 )
|
|
|
|
y = 1;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-30 21:27:17 +01:00
|
|
|
if ( x > getDesktopWidth() )
|
|
|
|
x = short(getDesktopWidth());
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-30 21:27:17 +01:00
|
|
|
if ( y > getDesktopHeight() )
|
|
|
|
y = short(getDesktopHeight());
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-09-11 03:06:02 +02:00
|
|
|
new_mouse_position.setPoint (x, y);
|
2016-07-23 19:50:28 +02:00
|
|
|
// fill bit field with 0
|
2016-10-06 23:15:09 +02:00
|
|
|
std::memset(&b_state, 0x00, sizeof(b_state));
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
if ( (button & key_shift) == key_shift )
|
|
|
|
b_state.shift_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( (button & key_meta) == key_meta )
|
|
|
|
b_state.meta_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( (button & key_ctrl) == key_ctrl )
|
|
|
|
b_state.control_button = Pressed;
|
|
|
|
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( (button & button_mask) >= button1_pressed_move
|
2017-11-26 22:37:18 +01:00
|
|
|
&& (button & button_mask) <= button3_pressed_move
|
|
|
|
&& mouse_position != *zero_point )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
b_state.mouse_moved = true;
|
|
|
|
}
|
|
|
|
|
2015-10-09 01:23:49 +02:00
|
|
|
getX11ButtonState (button & button_mask);
|
2015-09-20 05:44:50 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( mouse_position == new_mouse_position
|
2017-11-26 22:37:18 +01:00
|
|
|
&& b_state.wheel_up != Pressed
|
|
|
|
&& b_state.wheel_down != Pressed
|
|
|
|
&& x11_button_state == uChar(button) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
setMousePos (x, y);
|
2015-05-23 13:35:12 +02:00
|
|
|
x11_button_state = uChar(button);
|
|
|
|
urxvt_mouse[0] = '\0';
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2015-05-23 13:35:12 +02:00
|
|
|
bool FApplication::processGpmEvent()
|
|
|
|
{
|
2016-07-23 19:50:28 +02:00
|
|
|
// fill bit field with 0
|
2016-10-06 23:15:09 +02:00
|
|
|
std::memset(&b_state, 0x00, sizeof(b_state));
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
if ( Gpm_GetEvent(&gpm_ev) == 1 )
|
|
|
|
{
|
|
|
|
Gpm_FitEvent (&gpm_ev);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.type & GPM_DRAG && gpm_ev.wdx == 0 && gpm_ev.wdy == 0 )
|
|
|
|
b_state.mouse_moved = true;
|
|
|
|
|
2017-10-06 12:19:39 +02:00
|
|
|
if ( gpm_ev.wdy > 0 )
|
2015-05-23 13:35:12 +02:00
|
|
|
b_state.wheel_up = Pressed;
|
2017-10-06 12:19:39 +02:00
|
|
|
else if ( gpm_ev.wdy < 0 )
|
2015-05-23 13:35:12 +02:00
|
|
|
b_state.wheel_down = Pressed;
|
|
|
|
|
|
|
|
switch ( gpm_ev.type & 0x0f )
|
|
|
|
{
|
|
|
|
case GPM_DOWN:
|
|
|
|
case GPM_DRAG:
|
|
|
|
if ( gpm_ev.buttons & GPM_B_LEFT )
|
|
|
|
{
|
|
|
|
if ( gpm_ev.type & GPM_DOUBLE )
|
|
|
|
b_state.left_button = DoubleClick;
|
|
|
|
else
|
|
|
|
b_state.left_button = Pressed;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.buttons & GPM_B_MIDDLE )
|
|
|
|
b_state.middle_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.buttons & GPM_B_RIGHT )
|
|
|
|
b_state.right_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.buttons & GPM_B_UP )
|
|
|
|
b_state.wheel_up = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.buttons & GPM_B_DOWN )
|
|
|
|
b_state.wheel_down = Pressed;
|
|
|
|
|
|
|
|
// keyboard modifiers
|
|
|
|
if ( gpm_ev.modifiers & (1 << KG_SHIFT) )
|
|
|
|
b_state.shift_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.modifiers & ((1 << KG_ALT) | (1 << KG_ALTGR)) )
|
|
|
|
b_state.meta_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.modifiers & (1 << KG_CTRL) )
|
|
|
|
b_state.control_button = Pressed;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
case GPM_UP:
|
|
|
|
if ( gpm_ev.buttons & GPM_B_LEFT )
|
|
|
|
b_state.left_button = Released;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.buttons & GPM_B_MIDDLE )
|
|
|
|
b_state.middle_button = Released;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpm_ev.buttons & GPM_B_RIGHT )
|
|
|
|
b_state.right_button = Released;
|
2015-09-20 05:44:50 +02:00
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
setMousePos (gpm_ev.x, gpm_ev.y);
|
2015-10-03 01:45:13 +02:00
|
|
|
|
|
|
|
if ( gpmEvent(false) == mouse_event )
|
2016-10-01 23:18:49 +02:00
|
|
|
unprocessedInput() = true;
|
2015-10-03 01:45:13 +02:00
|
|
|
else
|
2016-10-01 23:18:49 +02:00
|
|
|
unprocessedInput() = false;
|
2015-10-03 01:45:13 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
GPM_DRAWPOINTER(&gpm_ev);
|
2015-10-03 01:45:13 +02:00
|
|
|
gpmMouseEvent = false;
|
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
return true;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-10-03 01:45:13 +02:00
|
|
|
gpmMouseEvent = false;
|
2015-05-23 13:35:12 +02:00
|
|
|
return false;
|
|
|
|
}
|
2015-08-22 18:53:52 +02:00
|
|
|
#endif // F_HAVE_LIBGPM
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
2017-12-05 01:03:59 +01:00
|
|
|
bool FApplication::getMouseEvent()
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2015-09-20 05:44:50 +02:00
|
|
|
bool Event = false;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( ! gpmMouseEvent
|
2017-11-26 22:37:18 +01:00
|
|
|
&& x11_mouse[0] == '\0'
|
|
|
|
&& sgr_mouse[0] == '\0'
|
|
|
|
&& urxvt_mouse[0] == '\0' )
|
2015-08-10 00:16:26 +02:00
|
|
|
{
|
2017-12-05 01:03:59 +01:00
|
|
|
return false;
|
2015-08-10 00:16:26 +02:00
|
|
|
}
|
|
|
|
#else
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( x11_mouse[0] == '\0'
|
2017-11-26 22:37:18 +01:00
|
|
|
&& sgr_mouse[0] == '\0'
|
|
|
|
&& urxvt_mouse[0] == '\0' )
|
2015-08-10 00:16:26 +02:00
|
|
|
{
|
2017-12-05 01:03:59 +01:00
|
|
|
return false;
|
2015-08-10 00:16:26 +02:00
|
|
|
}
|
|
|
|
#endif
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( gpmMouseEvent )
|
2015-09-20 05:44:50 +02:00
|
|
|
Event = processGpmEvent();
|
2015-05-23 13:35:12 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
if ( x11_mouse[0] )
|
2015-09-20 05:44:50 +02:00
|
|
|
Event = parseX11Mouse();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
if ( sgr_mouse[0] )
|
2015-09-20 05:44:50 +02:00
|
|
|
Event = parseSGRMouse();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
if ( urxvt_mouse[0] )
|
2015-09-20 05:44:50 +02:00
|
|
|
Event = parseUrxvtMouse();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2015-09-20 05:44:50 +02:00
|
|
|
if ( ! Event )
|
2017-12-05 01:03:59 +01:00
|
|
|
return false;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
FWidget*& FApplication::determineClickedWidget()
|
|
|
|
{
|
|
|
|
if ( clicked_widget )
|
|
|
|
return clicked_widget;
|
|
|
|
|
|
|
|
if ( b_state.left_button != Pressed
|
|
|
|
&& b_state.left_button != DoubleClick
|
|
|
|
&& b_state.right_button != Pressed
|
|
|
|
&& b_state.middle_button != Pressed
|
|
|
|
&& b_state.wheel_up != Pressed
|
|
|
|
&& b_state.wheel_down != Pressed )
|
|
|
|
return clicked_widget;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2016-10-13 02:16:51 +02:00
|
|
|
const FPoint& mouse_position = getMousePos();
|
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
// Determine the window object on the current click position
|
|
|
|
FWidget* window = FWindow::getWindowWidgetAt (mouse_position);
|
|
|
|
|
|
|
|
if ( window )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2017-12-05 01:03:59 +01:00
|
|
|
// Determine the widget at the current click position
|
|
|
|
FWidget* child = childWidgetAt (window, mouse_position);
|
|
|
|
clicked_widget = ( child != 0 ) ? child : window;
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
return clicked_widget;
|
|
|
|
}
|
2016-09-30 04:55:28 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::unsetMoveSizeMode()
|
|
|
|
{
|
|
|
|
// Unset the move/size mode
|
|
|
|
if ( move_size_widget )
|
|
|
|
{
|
|
|
|
FWidget* w = move_size_widget;
|
|
|
|
move_size_widget = 0;
|
|
|
|
w->redraw();
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2017-12-05 01:03:59 +01:00
|
|
|
}
|
2015-10-10 03:14:14 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::closeOpenMenu()
|
|
|
|
{
|
|
|
|
// Close the open menu
|
2015-10-23 00:24:20 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( ! open_menu || b_state.mouse_moved )
|
|
|
|
return;
|
2016-08-20 22:27:23 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
FMenu* menu = static_cast<FMenu*>(open_menu);
|
|
|
|
const FPoint& mouse_position = getMousePos();
|
2016-08-20 22:27:23 +02:00
|
|
|
|
2017-12-19 02:06:27 +01:00
|
|
|
if ( menu->containsMenuStructure(mouse_position) )
|
2017-12-05 01:03:59 +01:00
|
|
|
return;
|
2015-11-08 21:50:41 +01:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
bool is_window_menu;
|
|
|
|
FWidget* super = menu->getSuperMenu();
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( super && menu->isWindowsMenu(super) )
|
|
|
|
is_window_menu = true;
|
|
|
|
else
|
|
|
|
is_window_menu = false;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
menu->unselectItem();
|
|
|
|
menu->hide();
|
|
|
|
menu->hideSubMenus();
|
|
|
|
menu->hideSuperMenus();
|
2015-10-23 00:24:20 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
// No widget was been clicked and the menu is no dialog menu
|
|
|
|
if ( ! (clicked_widget || is_window_menu) )
|
|
|
|
FWindow::switchToPrevWindow();
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( getStatusBar() )
|
|
|
|
getStatusBar()->drawMessage();
|
2016-06-19 20:32:03 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
updateTerminal();
|
|
|
|
flush_out();
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::unselectMenubarItems()
|
|
|
|
{
|
|
|
|
// Unselect the menu bar items
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( open_menu || b_state.mouse_moved )
|
|
|
|
return;
|
2015-11-05 23:25:21 +01:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
FMenuBar* menubar = getMenuBar();
|
|
|
|
|
|
|
|
if ( ! menubar )
|
|
|
|
return;
|
|
|
|
|
|
|
|
if ( ! menubar->hasSelectedItem() )
|
|
|
|
return;
|
|
|
|
|
|
|
|
const FPoint& mouse_position = getMousePos();
|
|
|
|
|
|
|
|
if ( ! getMenuBar()->getTermGeometry().contains(mouse_position) )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( getStatusBar() )
|
|
|
|
getStatusBar()->clearMessage();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
getMenuBar()->resetMenu();
|
|
|
|
getMenuBar()->redraw();
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
// No widget was been clicked
|
|
|
|
if ( ! clicked_widget )
|
|
|
|
FWindow::switchToPrevWindow();
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( getStatusBar() )
|
|
|
|
getStatusBar()->drawMessage();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
updateTerminal();
|
|
|
|
flush_out();
|
|
|
|
}
|
|
|
|
}
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendMouseEvent()
|
|
|
|
{
|
|
|
|
if ( ! clicked_widget )
|
|
|
|
return;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
FPoint widgetMousePos;
|
|
|
|
const FPoint& mouse_position = getMousePos();
|
|
|
|
int key_state = 0;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( b_state.shift_button == Pressed )
|
|
|
|
key_state |= fc::ShiftButton;
|
2016-07-25 23:50:57 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( b_state.meta_button == Pressed )
|
|
|
|
key_state |= fc::MetaButton;
|
2016-07-25 23:50:57 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( b_state.control_button == Pressed )
|
|
|
|
key_state |= fc::ControlButton;
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
widgetMousePos = clicked_widget->termToWidgetPos(mouse_position);
|
2016-07-25 23:50:57 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
if ( b_state.mouse_moved )
|
|
|
|
{
|
|
|
|
sendMouseMoveEvent (widgetMousePos, mouse_position, key_state);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sendMouseLeftClickEvent (widgetMousePos, mouse_position, key_state);
|
|
|
|
sendMouseRightClickEvent (widgetMousePos, mouse_position, key_state);
|
|
|
|
sendMouseMiddleClickEvent (widgetMousePos, mouse_position, key_state);
|
|
|
|
}
|
2016-07-25 23:50:57 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
sendWheelEvent (widgetMousePos, mouse_position);
|
|
|
|
}
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendMouseMoveEvent ( const FPoint& widgetMousePos
|
|
|
|
, const FPoint& mouse_position
|
|
|
|
, int key_state )
|
|
|
|
{
|
|
|
|
if ( b_state.left_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseMove_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::LeftButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( b_state.right_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseMove_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::RightButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( b_state.middle_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseMove_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::MiddleButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendMouseLeftClickEvent ( const FPoint& widgetMousePos
|
|
|
|
, const FPoint& mouse_position
|
|
|
|
, int key_state )
|
|
|
|
{
|
|
|
|
if ( b_state.left_button == DoubleClick )
|
|
|
|
{
|
|
|
|
FMouseEvent m_dblclick_ev ( fc::MouseDoubleClick_Event
|
2016-09-25 23:53:48 +02:00
|
|
|
, widgetMousePos
|
2016-10-13 02:16:51 +02:00
|
|
|
, mouse_position
|
2017-12-05 01:03:59 +01:00
|
|
|
, fc::LeftButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_dblclick_ev);
|
|
|
|
}
|
|
|
|
else if ( b_state.left_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseDown_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::LeftButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
}
|
|
|
|
else if ( b_state.left_button == Released )
|
|
|
|
{
|
|
|
|
FMouseEvent m_up_ev ( fc::MouseUp_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::LeftButton | key_state );
|
|
|
|
FWidget* released_widget = clicked_widget;
|
|
|
|
|
|
|
|
if ( b_state.right_button != Pressed
|
|
|
|
&& b_state.middle_button != Pressed )
|
|
|
|
clicked_widget = 0;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
sendEvent (released_widget, &m_up_ev);
|
|
|
|
}
|
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendMouseRightClickEvent ( const FPoint& widgetMousePos
|
|
|
|
, const FPoint& mouse_position
|
|
|
|
, int key_state )
|
|
|
|
{
|
|
|
|
if ( b_state.right_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseDown_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::RightButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
}
|
|
|
|
else if ( b_state.right_button == Released )
|
|
|
|
{
|
|
|
|
FMouseEvent m_up_ev ( fc::MouseUp_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::RightButton | key_state );
|
|
|
|
FWidget* released_widget = clicked_widget;
|
|
|
|
|
|
|
|
if ( b_state.left_button != Pressed
|
|
|
|
&& b_state.middle_button != Pressed )
|
|
|
|
clicked_widget = 0;
|
2016-01-17 02:57:08 +01:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
sendEvent (released_widget, &m_up_ev);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendMouseMiddleClickEvent ( const FPoint& widgetMousePos
|
|
|
|
, const FPoint& mouse_position
|
|
|
|
, int key_state )
|
|
|
|
{
|
|
|
|
if ( b_state.middle_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseDown_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::MiddleButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
|
|
|
|
// gnome-terminal sends no released on middle click
|
|
|
|
if ( isGnomeTerminal() )
|
|
|
|
clicked_widget = 0;
|
|
|
|
}
|
|
|
|
else if ( b_state.middle_button == Released )
|
|
|
|
{
|
|
|
|
FMouseEvent m_up_ev ( fc::MouseUp_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::MiddleButton | key_state );
|
|
|
|
FWidget* released_widget = clicked_widget;
|
|
|
|
|
|
|
|
if ( b_state.right_button != Pressed
|
|
|
|
&& b_state.left_button != Pressed )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
clicked_widget = 0;
|
|
|
|
}
|
2016-01-17 02:57:08 +01:00
|
|
|
|
2017-12-05 01:03:59 +01:00
|
|
|
sendEvent (released_widget, &m_up_ev);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( b_state.middle_button == Pressed )
|
|
|
|
{
|
|
|
|
FMouseEvent m_down_ev ( fc::MouseDown_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::MiddleButton | key_state );
|
|
|
|
sendEvent (clicked_widget, &m_down_ev);
|
|
|
|
|
|
|
|
// gnome-terminal sends no released on middle click
|
|
|
|
if ( isGnomeTerminal() )
|
|
|
|
clicked_widget = 0;
|
|
|
|
}
|
|
|
|
else if ( b_state.middle_button == Released )
|
|
|
|
{
|
|
|
|
FMouseEvent m_up_ev ( fc::MouseUp_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::MiddleButton | key_state );
|
|
|
|
FWidget* released_widget = clicked_widget;
|
|
|
|
|
|
|
|
if ( b_state.right_button != Pressed
|
|
|
|
&& b_state.left_button != Pressed )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
|
|
|
clicked_widget = 0;
|
|
|
|
}
|
2017-12-05 01:03:59 +01:00
|
|
|
|
|
|
|
sendEvent (released_widget, &m_up_ev);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::sendWheelEvent ( const FPoint& widgetMousePos
|
|
|
|
, const FPoint& mouse_position )
|
|
|
|
{
|
|
|
|
if ( b_state.wheel_up == Pressed )
|
|
|
|
{
|
|
|
|
FWheelEvent wheel_ev ( fc::MouseWheel_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::WheelUp );
|
|
|
|
FWidget* scroll_over_widget = clicked_widget;
|
|
|
|
clicked_widget = 0;
|
|
|
|
sendEvent(scroll_over_widget, &wheel_ev);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( b_state.wheel_down == Pressed )
|
|
|
|
{
|
|
|
|
FWheelEvent wheel_ev ( fc::MouseWheel_Event
|
|
|
|
, widgetMousePos
|
|
|
|
, mouse_position
|
|
|
|
, fc::WheelDown );
|
|
|
|
FWidget* scroll_over_widget = clicked_widget;
|
|
|
|
clicked_widget = 0;
|
|
|
|
sendEvent (scroll_over_widget, &wheel_ev);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::processMouseEvent()
|
|
|
|
{
|
|
|
|
if ( ! getMouseEvent() )
|
|
|
|
return;
|
|
|
|
|
|
|
|
determineClickedWidget();
|
|
|
|
unsetMoveSizeMode();
|
|
|
|
closeOpenMenu();
|
|
|
|
unselectMenubarItems();
|
|
|
|
sendMouseEvent();
|
2015-08-11 00:11:07 +02:00
|
|
|
|
2015-08-22 18:53:52 +02:00
|
|
|
#ifdef F_HAVE_LIBGPM
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( isGpmMouseEnabled() && gpm_ev.x != -1 )
|
2015-05-23 13:35:12 +02:00
|
|
|
GPM_DRAWPOINTER(&gpm_ev);
|
2015-08-10 00:18:36 +02:00
|
|
|
#endif
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::processResizeEvent()
|
|
|
|
{
|
2016-10-13 02:16:51 +02:00
|
|
|
if ( hasChangedTermSize() )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2016-01-17 02:57:08 +01:00
|
|
|
FResizeEvent r_ev(fc::Resize_Event);
|
2015-05-23 13:35:12 +02:00
|
|
|
sendEvent(rootObj, &r_ev);
|
|
|
|
|
|
|
|
if ( r_ev.isAccepted() )
|
2016-10-13 02:16:51 +02:00
|
|
|
changeTermSizeFinished();
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
int FApplication::processTimerEvent()
|
|
|
|
{
|
2017-09-17 01:50:41 +02:00
|
|
|
FObject::TimerList::iterator iter, last;
|
2015-05-23 13:35:12 +02:00
|
|
|
timeval currentTime;
|
|
|
|
int activated = 0;
|
|
|
|
|
2017-09-11 03:06:02 +02:00
|
|
|
getCurrentTime (¤tTime);
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2016-10-01 23:18:49 +02:00
|
|
|
if ( isTimerInUpdating() )
|
2015-05-23 13:35:12 +02:00
|
|
|
return 0;
|
|
|
|
|
|
|
|
if ( ! timer_list )
|
|
|
|
return 0;
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( timer_list->empty() )
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
iter = timer_list->begin();
|
2017-09-17 01:50:41 +02:00
|
|
|
last = timer_list->end();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
2017-09-17 01:50:41 +02:00
|
|
|
while ( iter != last )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2016-12-18 23:34:11 +01:00
|
|
|
if ( ! (*iter).id
|
2017-11-26 22:37:18 +01:00
|
|
|
|| ! (*iter).object
|
|
|
|
|| currentTime < (*iter).timeout ) // no timer expired
|
2015-05-23 13:35:12 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
(*iter).timeout += (*iter).interval;
|
|
|
|
|
|
|
|
if ( (*iter).timeout < currentTime )
|
|
|
|
(*iter).timeout = currentTime + (*iter).interval;
|
|
|
|
|
|
|
|
if ( (*iter).interval.tv_usec > 0 || (*iter).interval.tv_sec > 0 )
|
|
|
|
activated++;
|
|
|
|
|
2016-01-17 02:57:08 +01:00
|
|
|
FTimerEvent t_ev(fc::Timer_Event, (*iter).id);
|
2015-05-23 13:35:12 +02:00
|
|
|
sendEvent((*iter).object, &t_ev);
|
|
|
|
|
|
|
|
++iter;
|
|
|
|
}
|
|
|
|
|
|
|
|
return activated;
|
|
|
|
}
|
|
|
|
|
2016-06-25 14:33:43 +02:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void FApplication::processCloseWidget()
|
|
|
|
{
|
2016-07-06 23:11:49 +02:00
|
|
|
updateTerminal(false);
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-05-23 13:35:12 +02:00
|
|
|
if ( close_widget && ! close_widget->empty() )
|
|
|
|
{
|
|
|
|
widgetList::iterator iter;
|
|
|
|
iter = close_widget->begin();
|
|
|
|
|
2016-07-16 20:39:38 +02:00
|
|
|
while ( iter != close_widget->end() && *iter )
|
2015-05-23 13:35:12 +02:00
|
|
|
{
|
2015-10-06 05:09:18 +02:00
|
|
|
delete *iter;
|
|
|
|
++iter;
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2016-07-09 00:01:59 +02:00
|
|
|
|
2015-10-06 05:09:18 +02:00
|
|
|
close_widget->clear();
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|
2016-07-10 00:23:39 +02:00
|
|
|
|
2016-07-06 23:11:49 +02:00
|
|
|
updateTerminal(true);
|
2016-06-25 14:33:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
bool FApplication::processNextEvent()
|
|
|
|
{
|
|
|
|
int num_events = 0;
|
|
|
|
|
|
|
|
processKeyboardEvent();
|
|
|
|
processMouseEvent();
|
|
|
|
processResizeEvent();
|
|
|
|
processTerminalUpdate();
|
|
|
|
processCloseWidget();
|
2015-05-23 13:35:12 +02:00
|
|
|
|
|
|
|
sendQueuedEvents();
|
|
|
|
num_events += processTimerEvent();
|
|
|
|
|
2017-09-17 21:32:46 +02:00
|
|
|
return ( num_events > 0 );
|
2015-05-23 13:35:12 +02:00
|
|
|
}
|