-
Notifications
You must be signed in to change notification settings - Fork 22
/
global_work_scheduler.go
128 lines (107 loc) · 3.38 KB
/
global_work_scheduler.go
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
//----------------------------------------
//
// Copyright © yanghy. All Rights Reserved.
//
// Licensed under Apache License Version 2.0, January 2004
//
// https://www.apache.org/licenses/LICENSE-2.0
//
//----------------------------------------
package cef
import (
"github.com/energye/energy/v2/cef/internal/def"
"github.com/energye/energy/v2/common/imports"
"github.com/energye/energy/v2/consts"
"github.com/energye/golcl/lcl"
"github.com/energye/golcl/lcl/api"
"unsafe"
)
var GlobalWorkScheduler *TCEFWorkScheduler
type TCEFWorkScheduler struct {
instance unsafe.Pointer
}
// Instance 实例
func (m *TCEFWorkScheduler) Instance() uintptr {
if m == nil {
return 0
}
return uintptr(m.instance)
}
func (m *TCEFWorkScheduler) IsValid() bool {
if m == nil || m.instance == nil {
return false
}
return m.instance != nil
}
func GlobalWorkSchedulerCreate(owner lcl.IComponent) *TCEFWorkScheduler {
if GlobalWorkScheduler != nil {
return GlobalWorkScheduler
}
var aOwner uintptr
if owner != nil {
aOwner = owner.Instance()
}
var result uintptr
imports.Proc(def.CEFWorkScheduler_Create).Call(aOwner, uintptr(unsafe.Pointer(&result)))
if result != 0 {
GlobalWorkScheduler = &TCEFWorkScheduler{instance: unsafe.Pointer(result)}
}
return GlobalWorkScheduler
}
func GlobalWorkSchedulerCreateDelayed() *TCEFWorkScheduler {
if GlobalWorkScheduler != nil {
return GlobalWorkScheduler
}
var result uintptr
imports.Proc(def.CEFWorkScheduler_CreateDelayed).Call(uintptr(unsafe.Pointer(&result)))
if result != 0 {
GlobalWorkScheduler = &TCEFWorkScheduler{instance: unsafe.Pointer(result)}
}
return GlobalWorkScheduler
}
func (m *TCEFWorkScheduler) StopScheduler() {
imports.Proc(def.CEFWorkScheduler_StopScheduler).Call()
}
func (m *TCEFWorkScheduler) CreateThread() {
imports.Proc(def.CEFWorkScheduler_CreateThread).Call()
}
func (m *TCEFWorkScheduler) Destroy() {
imports.Proc(def.CEFWorkScheduler_Destroy).Call()
}
// GetPriority Windows
func (m *TCEFWorkScheduler) GetPriority() consts.TThreadPriority {
r := imports.SysCallN(def.CEFWorkScheduler_GetPriority)
return consts.TThreadPriority(r)
}
// GetPriority Windows
func (m *TCEFWorkScheduler) SetPriority(value consts.TThreadPriority) {
imports.SysCallN(def.CEFWorkScheduler_SetPriority, uintptr(value))
}
func (m *TCEFWorkScheduler) GetDefaultInterval() int32 {
r := imports.SysCallN(def.CEFWorkScheduler_GetDefaultInterval)
return int32(r)
}
func (m *TCEFWorkScheduler) GetDepleteWorkCycles() uint32 {
r := imports.SysCallN(def.CEFWorkScheduler_GetDepleteWorkCycles)
return uint32(r)
}
func (m *TCEFWorkScheduler) GetDepleteWorkDelay() uint32 {
r := imports.SysCallN(def.CEFWorkScheduler_GetDepleteWorkDelay)
return uint32(r)
}
func (m *TCEFWorkScheduler) GetUseQueueThread() bool {
r := imports.SysCallN(def.CEFWorkScheduler_GetUseQueueThread)
return api.GoBool(r)
}
func (m *TCEFWorkScheduler) SetDefaultInterval(value int32) {
imports.SysCallN(def.CEFWorkScheduler_SetDefaultInterval, uintptr(value))
}
func (m *TCEFWorkScheduler) SetDepleteWorkCycles(value uint32) {
imports.SysCallN(def.CEFWorkScheduler_SetDepleteWorkCycles, uintptr(value))
}
func (m *TCEFWorkScheduler) SetDepleteWorkDelay(value uint32) {
imports.SysCallN(def.CEFWorkScheduler_SetDepleteWorkDelay, uintptr(value))
}
func (m *TCEFWorkScheduler) SetUseQueueThread(value bool) {
imports.SysCallN(def.CEFWorkScheduler_SetUseQueueThread, api.PascalBool(value))
}