build and install parseThat with cmake
[dyninst.git] / proccontrol / h / Handler.h
1 /*
2  * See the dyninst/COPYRIGHT file for copyright information.
3  * 
4  * We provide the Paradyn Tools (below described as "Paradyn")
5  * on an AS IS basis, and do not warrant its validity or performance.
6  * We reserve the right to update, modify, or discontinue this
7  * software at any time.  We shall have no obligation to supply such
8  * updates or modifications or any other form of support to you.
9  * 
10  * By your use of Paradyn, you understand and agree that we (or any
11  * other person or entity with proprietary rights in Paradyn) are
12  * under no obligation to provide either maintenance services,
13  * update services, notices of latent defects, or correction of
14  * defects for Paradyn.
15  * 
16  * This library is free software; you can redistribute it and/or
17  * modify it under the terms of the GNU Lesser General Public
18  * License as published by the Free Software Foundation; either
19  * version 2.1 of the License, or (at your option) any later version.
20  * 
21  * This library is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
24  * Lesser General Public License for more details.
25  * 
26  * You should have received a copy of the GNU Lesser General Public
27  * License along with this library; if not, write to the Free Software
28  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
29  */
30 #if !defined(HANDLER_H_)
31 #define HANDLER_H_
32
33 #include "Event.h"
34 #include "util.h"
35
36 #include <set>
37 #include <vector>
38
39 namespace Dyninst {
40 namespace ProcControlAPI {
41
42 class PC_EXPORT Handler 
43 {
44  protected:
45    std::string name;
46  public:
47    Handler(std::string name_ = std::string(""));
48    virtual ~Handler();
49
50    typedef enum {
51       ret_success,
52       ret_async,      
53       ret_cbdelay,
54       ret_again,
55       ret_error
56    } handler_ret_t;
57
58    virtual handler_ret_t handleEvent(Event::ptr ev) = 0;
59    virtual void getEventTypesHandled(std::vector<EventType> &etypes) = 0;
60    virtual int getPriority() const;
61    virtual Event::ptr convertEventForCB(Event::ptr orig);
62
63    std::string getName() const;
64    static const int PrePlatformPriority = 0x1000;
65    static const int DefaultPriority = 0x1008;
66    static const int PostPlatformPriority = 0x1010;
67    static const int CallbackPriority = 0x1018;
68    static const int PostCallbackPriority = 0x1020;
69 };
70
71 }
72 }
73
74 #endif