Logo Search packages:      
Sourcecode: unixcw version File versions  Download package


// vi: set ts=2 shiftwidth=2 expandtab:
// Copyright (C) 2001-2006  Simon Baldwin (simon_baldwin@yahoo.com)
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.


class QKeyEvent;
class QMouseEvent;

//  Class Receiver

// Encapsulates the main application receiver data and functions.  Receiver
// abstracts states associated with receiving, event handling, cwlib keyer
// event handling, and data passed between signal handler and foreground
// contexts.

namespace cw {

class Display;
class Mode;

class Receiver
  Receiver (Display *display)
    : display_ (display),
      is_pending_space_ (false), cwlib_receive_errno_ (0),
      tracked_key_state_ (FALSE) { }

  // Poll timeout handler, and keypress and mouse event handlers.
  void poll (const Mode *current_mode);
  void handle_key_event (QKeyEvent *event, const Mode *current_mode,
                         bool is_reverse_paddles);
  void handle_mouse_event (QMouseEvent *event, const Mode *current_mode,
                           bool is_reverse_paddles);

  // CW library keying event handler.
  void handle_cwlib_keying_event (int key_state);

  // Clear out queued data on stop, mode change, etc.
  void clear ();

  // Display used for output.
  Display *display_;

  // Flag indicating if receive polling has received a character, and may need
  // to augment it with a word space on a later poll, and possible receive
  // errno detected in signal handler context and needing to be passed to
  // the foreground.
  volatile bool is_pending_space_;
  volatile int cwlib_receive_errno_;

  // Safety flag to ensure that we keep the library in sync with keyer events.
  // Without, there's a chance that of a on-off event, one half will go to one
  // application instance, and the other to another instance.
  volatile int tracked_key_state_;

  // Poll primitives to handle receive errors, characters, and spaces.
  void poll_report_receive_error ();
  void poll_receive_character ();
  void poll_receive_space ();

  // Prevent unwanted operations.
  Receiver (const Receiver &);
  Receiver &operator= (const Receiver &);

}  // cw namespace

#endif  // _XCWCP_RECEIVER_H

Generated by  Doxygen 1.6.0   Back to index