-
Notifications
You must be signed in to change notification settings - Fork 0
/
oleacc_arm64.go
98 lines (89 loc) · 3.52 KB
/
oleacc_arm64.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
// Copyright 2010 The win Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// +build windows,arm64
package win
import (
"syscall"
"unsafe"
)
func (idProp *MSAAPROPID) split() (uintptr, uintptr) {
if idProp == nil {
return 0, 0
}
x := (*struct { a, b uintptr })(unsafe.Pointer(idProp))
return x.a, x.b
}
// SetPropValue identifies the accessible element to be annotated, specify the property to be annotated, and provide a new value for that property.
// If server developers know the HWND of the accessible element they want to annotate, they can use one of the following methods: SetHwndPropStr, SetHwndProp, or SetHwndPropServer
func (obj *IAccPropServices) SetPropValue(idString []byte, idProp *MSAAPROPID, v *VARIANT) HRESULT {
var idStringPtr unsafe.Pointer
idStringLen := len(idString)
if idStringLen != 0 {
idStringPtr = unsafe.Pointer(&idString[0])
}
propA, propB := idProp.split()
ret, _, _ := syscall.Syscall6(obj.LpVtbl.SetPropValue, 6,
uintptr(unsafe.Pointer(obj)),
uintptr(idStringPtr),
uintptr(idStringLen),
propA, propB,
uintptr(unsafe.Pointer(v)))
return HRESULT(ret)
}
// SetHwndProp wraps SetPropValue, providing a convenient entry point for callers who are annotating HWND-based accessible elements. If the new value is a string, you can use SetHwndPropStr instead.
func (obj *IAccPropServices) SetHwndProp(hwnd HWND, idObject int32, idChild uint32, idProp *MSAAPROPID, v *VARIANT) HRESULT {
propA, propB := idProp.split()
ret, _, _ := syscall.Syscall9(obj.LpVtbl.SetHwndProp, 7,
uintptr(unsafe.Pointer(obj)),
uintptr(hwnd),
uintptr(idObject),
uintptr(idChild),
propA, propB,
uintptr(unsafe.Pointer(v)),
0, 0)
return HRESULT(ret)
}
// SetHwndPropStr wraps SetPropValue, providing a more convenient entry point for callers who are annotating HWND-based accessible elements.
func (obj *IAccPropServices) SetHwndPropStr(hwnd HWND, idObject int32, idChild uint32, idProp *MSAAPROPID, str string) HRESULT {
str16, err := syscall.UTF16PtrFromString(str)
if err != nil {
return -((E_INVALIDARG ^ 0xFFFFFFFF) + 1)
}
propA, propB := idProp.split()
ret, _, _ := syscall.Syscall9(obj.LpVtbl.SetHwndPropStr, 7,
uintptr(unsafe.Pointer(obj)),
uintptr(hwnd),
uintptr(idObject),
uintptr(idChild),
propA, propB,
uintptr(unsafe.Pointer(str16)),
0, 0)
return HRESULT(ret)
}
// SetHmenuProp wraps SetPropValue, providing a convenient entry point for callers who are annotating HMENU-based accessible elements. If the new value is a string, you can use IAccPropServices::SetHmenuPropStr instead.
func (obj *IAccPropServices) SetHmenuProp(hmenu HMENU, idChild uint32, idProp *MSAAPROPID, v *VARIANT) HRESULT {
propA, propB := idProp.split()
ret, _, _ := syscall.Syscall6(obj.LpVtbl.SetHmenuProp, 6,
uintptr(unsafe.Pointer(obj)),
uintptr(hmenu),
uintptr(idChild),
propA, propB,
uintptr(unsafe.Pointer(v)))
return HRESULT(ret)
}
// SetHmenuPropStr wraps SetPropValue, providing a more convenient entry point for callers who are annotating HMENU-based accessible elements.
func (obj *IAccPropServices) SetHmenuPropStr(hmenu HMENU, idChild uint32, idProp *MSAAPROPID, str string) HRESULT {
str16, err := syscall.UTF16PtrFromString(str)
if err != nil {
return -((E_INVALIDARG ^ 0xFFFFFFFF) + 1)
}
propA, propB := idProp.split()
ret, _, _ := syscall.Syscall6(obj.LpVtbl.SetHmenuPropStr, 6,
uintptr(unsafe.Pointer(obj)),
uintptr(hmenu),
uintptr(idChild),
propA, propB,
uintptr(unsafe.Pointer(str16)))
return HRESULT(ret)
}