blob: 6b97b21f2c6985300e1131eeedbc9a3c3e6c96fa (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
// $Id$
#include "Thread_Task.h"
#include "ace/OS_NS_unistd.h"
#include "../Scheduler.h"
#include "tao/RTScheduling/RTScheduler_Manager.h"
#include "tao/ORB_Core.h"
int
ACE_TMAIN(int argc, ACE_TCHAR *argv[])
{
try
{
CORBA::ORB_var orb =
CORBA::ORB_init (argc,
argv,
"");
CORBA::Object_var manager_obj = orb->resolve_initial_references ("RTSchedulerManager");
TAO_RTScheduler_Manager_var manager = TAO_RTScheduler_Manager::_narrow (manager_obj.in ());
TAO_Scheduler scheduler (orb.in ());
manager->rtscheduler (&scheduler);
Thread_Task task;
task.activate_task (orb.in ());
ACE_DEBUG ((LM_DEBUG,
"Waiting for Threads to Activate...\n"));
ACE_OS::sleep (10);
ACE_DEBUG ((LM_DEBUG,
"Threads Activated\n"));
ACE_DEBUG ((LM_DEBUG,
"Cancelling Threads.....\n"));
CORBA::Object_var current_obj = orb->resolve_initial_references ("RTScheduler_Current");
RTScheduling::Current_var current = RTScheduling::Current::_narrow (current_obj.in ());
for (int i = 0; i < 4; i++)
{
RTScheduling::DistributableThread_var DT = current->lookup ((task.guids ())[i]);
DT->cancel ();
}
orb->run ();
ACE_Thread_Manager::instance ()->wait ();
}
catch (const CORBA::Exception& ex)
{
ex._tao_print_exception ("Caught exception:");
return 1;
}
return 0;
}
|