summaryrefslogtreecommitdiff
path: root/plugins/ExternalAPI/m_actman.h
blob: c900ba9c6ca599972c0e467fe10a05d3bd8f90d8 (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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#ifndef M_ACTMAN
#define M_ACTMAN

#define ACCF_DISABLED 0x10000000 // action disabled
#define ACCF_EXPORT   0x08000000 // action to export
#define ACCF_VOLATILE 0x04000000 // don't save in DB
#define ACCF_IMPORTED ACF_EXPORT
#define ACCF_FLAGS    (ACCF_DISABLED | ACCF_EXPORT | ACCF_IMPORTED | ACCF_VOLATILE)
#define ACCF_ID       0x02000000 // for MS_ACT_SELECT, lParam is ID (else name)
#define ACCF_CLEAR    0x01000000 // clear other flags, else - set


typedef struct{
	WCHAR* Descr;
	DWORD  ID;
	DWORD  flags; // ACCF_* flags
	} TChain, *PChain;

//	Service to get list of all configured actions;
//	wParam : 0
//	lParam : address of destination list variable (address of pointer to TChain)
//	         Notes: first 4 bytes of list = size of TChain structure (to add new fields in future)
//	Return value: count of elements;
#define MS_ACT_GETLIST "Actions/GetList"

//	Service to free list of all configured actions got with MS_ACT_GETLIST service call;
//	wParam : 0
//	lParam : list address (pointer to ACTION returned by MS_ACT_GETLIST)
#define MS_ACT_FREELIST "Actions/FreeList"

//	Service to call action defined in wParam;
//	wParam: ID of an action (see ACTION.ActID) when calling MS_ACT_RUN
//		or description of an action (see ACTION.ActDescr) when calling MS_ACT_RUNGROUP
//	lParam: parameter (will be passed to action called)
#define MS_ACT_RUNBYID   "Actions/RunById"
#define MS_ACT_RUNBYNAME "Actions/RunByName"

//	Event: action group list was changed: something was added or deleted
//	wParam: set of ACTM_* flags
//	lParam : 0
#define ME_ACT_CHANGED "Actions/Changed"

//	Starts action with 2 parameters
//	wParam: 0
//	lParam: pointer to TAct_Param

#define MS_ACT_RUNPARAMS "Actions/RunWithParams"
typedef struct TAct_Param
	{
    DWORD flags; // 0 - ID, 1 - Name
    DWORD ID; // Id or name
    WPARAM wParam;
    LPARAM lParam;
	} TAct_Param, *PAct_Param;

#define ACTM_NEW      0x00000001
#define ACTM_DELETE   0x00000002
#define ACTM_RELOAD   0x00000004
#define ACTM_RENAME   0x00000008
#define ACTM_SORT     0x00000010
#define ACTM_ACT      0x10000000 // do not check, internal
#define ACTM_ACTS     0x20000000 // do not check, internal
#define ACTM_LOADED   0x80000000


#define ACIO_EXPORT   0x00000001 // export, else - import
#define ACIO_APPEND   0x00000002 // append file on export
#define ACIO_ASKEXIST 0x00000004 // ask, if action exists on import
#define ACIO_SELECTED 0x00000008 // export selected actions only

//	wParam: ACIO_* flags
//	lParam: Unicode file name
//	Return - true, if totally succesful
#define MS_ACT_INOUT "Actions/ImpExp"


//Event: Export actions
//		   wParam - ACIO_* flags
//		   lParam - unicode filename
#define ME_ACT_INOUT "Actions/InOut"


//      Select/unselect specified action
//      wParam: set of ACCF_* consts
//      lParam: unicode action name / number
//      Return - -1 if unsuccesful
#define MS_ACT_SELECT "Actions/Select"


//    Event: Action started/finished
//    wParam - Action status: 0 - started, 1 - finished
//    lParam - action id

#define ME_ACT_ACTION "Actions/Action"

#endif