NAME ^

src/pmc/schedulermessage.pmc - The concurrency scheduler

DESCRIPTION ^

Implements a message passed between concurrency schedulers.

Vtable Functions ^

void init()

Initialize a concurrency scheduler message object.

void init_pmc(PMC *data)

Initializes a new SchedulerMessage with a Hash PMC with any or all of the keys:

id

An Integer representing the unique identifier for this scheduler message.

type

A String representing the unique type for this scheduler message.

data

An PMC representing the data passed in this scheduler message.

INTVAL get_integer()

Retrieve the message ID.

void set_integer_native(INTVAL value)

Set the message ID.

STRING *get_string()

Retrieve the message type.

void set_string_native(STRING *value)

Set the message type.

PMC *share_ro()

Set this PMC as shared.

void destroy()

Free the scheduler's underlying struct.

void mark()

Mark any referenced strings and PMCs.

void visit(visit_info *info)

This is used by freeze/thaw to visit the contents of the scheduler message.

*info is the visit info, (see include/parrot/pmc_freeze.h).

void freeze(visit_info *info)

Used to archive the scheduler message.

void thaw(visit_info *info)

Used to unarchive the scheduler message.

SEE ALSO ^

docs/pdds/pdd25_concurrency.pod.


parrot