logo top
Main Page   Widgets   glibmm Namespaces   Book  

Glib::Source Class Reference
[The Main Event Loop]

Inheritance diagram for Glib::Source:

Inheritance graph
[legend]
List of all members.

Public Types

typedef Glib::Source CppObjectType
typedef GSource BaseObjectType

Public Member Functions

unsigned int attach (const Glib::RefPtr<MainContext>& context)
 Adds a Source to a context so that it will be executed within that context.
unsigned int attach ()
 Adds a Source to a context so that it will be executed within that context.
void destroy ()
 Removes a source from its MainContext, if any, and marks it as destroyed.
void set_priority (int priority)
 Sets the priority of a source.
int get_priority () const
 Gets the priority of a source.
void set_can_recurse (bool can_recurse)
 Sets whether a source can be called recursively.
bool get_can_recurse () const
 Checks whether a source is allowed to be called recursively.
unsigned int get_id () const
 Returns the numeric ID for a particular source.
Glib::RefPtr<MainContextget_context ()
 Gets the MainContext with which the source is associated.
GSource* gobj ()
const GSource* gobj () const
GSource* gobj_copy () const
void reference () const
void unreference () const

Static Public Member Functions

static Glib::RefPtr<Sourcecreate ()
static void destroy_notify_callback (void* data)

Protected Member Functions

 Source ()
 Construct an object that uses the virtual functions prepare(), check() and dispatch().
 Source (GSource* cast_item, GSourceFunc callback_func)
 Wrap an existing GSource object and install the given callback function.
virtual ~Source ()
sigc::connection connect_generic (const sigc::slot_base& slot)
void add_poll (PollFD& poll_fd)
 Adds a file descriptor to the set of file descriptors polled for this source.
void remove_poll (PollFD& poll_fd)
 Removes a file descriptor from the set of file descriptors polled for this source.
void get_current_time (Glib::TimeVal& current_time)
 Gets the "current time" to be used when checking this source.
virtual bool prepare (int& timeout)=0
virtual bool check ()=0
virtual bool dispatch (sigc::slot_base* slot)=0

Member Typedef Documentation


Constructor & Destructor Documentation

Glib::Source::Source (  )  [protected]

Construct an object that uses the virtual functions prepare(), check() and dispatch().

Glib::Source::Source ( GSource *  cast_item,
GSourceFunc  callback_func 
) [protected]

Wrap an existing GSource object and install the given callback function.

The constructed object doesn't use the virtual functions prepare(), check() and dispatch(). This constructor is for use by derived types that need to wrap a GSource object. The callback function can be a static member function. But beware - depending on the actual implementation of the GSource's virtual functions the expected type of the callback function can differ from GSourceFunc.

virtual Glib::Source::~Source (  )  [protected, virtual]


Member Function Documentation

static Glib::RefPtr<Source> Glib::Source::create (  )  [static]

Reimplemented in Glib::IdleSource.

unsigned int Glib::Source::attach ( const Glib::RefPtr<MainContext>&  context  ) 

Adds a Source to a context so that it will be executed within that context.

Parameters:
context A MainContext.
Returns:
The ID for the source within the MainContext.

unsigned int Glib::Source::attach (  ) 

Adds a Source to a context so that it will be executed within that context.

The default context will be used.

Returns:
The ID for the source within the MainContext.

void Glib::Source::destroy (  ) 

Removes a source from its MainContext, if any, and marks it as destroyed.

The source cannot be subsequently added to another context.

void Glib::Source::set_priority ( int  priority  ) 

Sets the priority of a source.

While the main loop is being run, a source will be dispatched if it is ready to be dispatched and no sources at a higher (numerically smaller) priority are ready to be dispatched.

Parameters:
priority The new priority.

int Glib::Source::get_priority (  )  const

Gets the priority of a source.

Returns:
The priority of the source.

void Glib::Source::set_can_recurse ( bool  can_recurse  ) 

Sets whether a source can be called recursively.

If can_recurse is true, then while the source is being dispatched then this source will be processed normally. Otherwise, all processing of this source is blocked until the dispatch function returns.

Parameters:
can_recurse Whether recursion is allowed for this source.

bool Glib::Source::get_can_recurse (  )  const

Checks whether a source is allowed to be called recursively.

see set_can_recurse().

Returns:
Whether recursion is allowed.

unsigned int Glib::Source::get_id (  )  const

Returns the numeric ID for a particular source.

The ID of a source is unique within a particular main loop context. The reverse mapping from ID to source is done by MainContext::find_source_by_id().

Returns:
The ID for the source.

Glib::RefPtr<MainContext> Glib::Source::get_context (  ) 

Gets the MainContext with which the source is associated.

Calling this function on a destroyed source is an error.

Returns:
The MainContext with which the source is associated, or a null RefPtr if the context has not yet been added to a source.

GSource* Glib::Source::gobj (  )  [inline]

const GSource* Glib::Source::gobj (  )  const [inline]

GSource* Glib::Source::gobj_copy (  )  const

void Glib::Source::reference (  )  const

void Glib::Source::unreference (  )  const

sigc::connection Glib::Source::connect_generic ( const sigc::slot_base &  slot  )  [protected]

void Glib::Source::add_poll ( PollFD poll_fd  )  [protected]

Adds a file descriptor to the set of file descriptors polled for this source.

The event source's check function will typically test the revents field in the PollFD and return true if events need to be processed.

Parameters:
poll_fd A PollFD object holding information about a file descriptor to watch.

void Glib::Source::remove_poll ( PollFD poll_fd  )  [protected]

Removes a file descriptor from the set of file descriptors polled for this source.

Parameters:
poll_fd A PollFD object previously passed to add_poll().

void Glib::Source::get_current_time ( Glib::TimeVal current_time  )  [protected]

Gets the "current time" to be used when checking this source.

The advantage of calling this function over calling get_current_time() directly is that when checking multiple sources, GLib can cache a single value instead of having to repeatedly get the system time.

Parameters:
current_time Glib::TimeVal in which to store current time

virtual bool Glib::Source::prepare ( int &  timeout  )  [protected, pure virtual]

virtual bool Glib::Source::check (  )  [protected, pure virtual]

virtual bool Glib::Source::dispatch ( sigc::slot_base *  slot  )  [protected, pure virtual]

static void Glib::Source::destroy_notify_callback ( void *  data  )  [static]


The documentation for this class was generated from the following file:

Generated for glibmm 2.4 by Doxygen 1.5.1 © 1997-2001