forked from tiiuae/rclgo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Float64MultiArray.gen.go
155 lines (127 loc) · 5.47 KB
/
Float64MultiArray.gen.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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
/*
This file is part of rclgo
Copyright © 2021 Technology Innovation Institute, United Arab Emirates
Licensed under the Apache License, Version 2.0 (the "License");
http://www.apache.org/licenses/LICENSE-2.0
*/
/*
THIS FILE IS AUTOGENERATED BY 'rclgo-gen generate'
*/
package example_interfaces_msg
import (
"unsafe"
"github.com/mehmetkillioglu/rclgo/pkg/rclgo/types"
"github.com/mehmetkillioglu/rclgo/pkg/rclgo/typemap"
primitives "github.com/mehmetkillioglu/rclgo/pkg/rclgo/primitives"
)
/*
#cgo LDFLAGS: -L/opt/ros/galactic/lib -Wl,-rpath=/opt/ros/galactic/lib -lrcl -lrosidl_runtime_c -lrosidl_typesupport_c -lrcutils -lrmw_implementation
#cgo LDFLAGS: -lexample_interfaces__rosidl_typesupport_c -lexample_interfaces__rosidl_generator_c
#cgo CFLAGS: -I/opt/ros/galactic/include
#include <rosidl_runtime_c/message_type_support_struct.h>
#include <example_interfaces/msg/float64_multi_array.h>
*/
import "C"
func init() {
typemap.RegisterMessage("example_interfaces/Float64MultiArray", Float64MultiArrayTypeSupport)
}
// Do not create instances of this type directly. Always use NewFloat64MultiArray
// function instead.
type Float64MultiArray struct {
Layout MultiArrayLayout `yaml:"layout"`// specification of data layout
Data []float64 `yaml:"data"`// array of data
}
// NewFloat64MultiArray creates a new Float64MultiArray with default values.
func NewFloat64MultiArray() *Float64MultiArray {
self := Float64MultiArray{}
self.SetDefaults()
return &self
}
func (t *Float64MultiArray) Clone() *Float64MultiArray {
c := &Float64MultiArray{}
c.Layout = *t.Layout.Clone()
if t.Data != nil {
c.Data = make([]float64, len(t.Data))
copy(c.Data, t.Data)
}
return c
}
func (t *Float64MultiArray) CloneMsg() types.Message {
return t.Clone()
}
func (t *Float64MultiArray) SetDefaults() {
t.Layout.SetDefaults()
t.Data = nil
}
// CloneFloat64MultiArraySlice clones src to dst by calling Clone for each element in
// src. Panics if len(dst) < len(src).
func CloneFloat64MultiArraySlice(dst, src []Float64MultiArray) {
for i := range src {
dst[i] = *src[i].Clone()
}
}
// Modifying this variable is undefined behavior.
var Float64MultiArrayTypeSupport types.MessageTypeSupport = _Float64MultiArrayTypeSupport{}
type _Float64MultiArrayTypeSupport struct{}
func (t _Float64MultiArrayTypeSupport) New() types.Message {
return NewFloat64MultiArray()
}
func (t _Float64MultiArrayTypeSupport) PrepareMemory() unsafe.Pointer { //returns *C.example_interfaces__msg__Float64MultiArray
return (unsafe.Pointer)(C.example_interfaces__msg__Float64MultiArray__create())
}
func (t _Float64MultiArrayTypeSupport) ReleaseMemory(pointer_to_free unsafe.Pointer) {
C.example_interfaces__msg__Float64MultiArray__destroy((*C.example_interfaces__msg__Float64MultiArray)(pointer_to_free))
}
func (t _Float64MultiArrayTypeSupport) AsCStruct(dst unsafe.Pointer, msg types.Message) {
m := msg.(*Float64MultiArray)
mem := (*C.example_interfaces__msg__Float64MultiArray)(dst)
MultiArrayLayoutTypeSupport.AsCStruct(unsafe.Pointer(&mem.layout), &m.Layout)
primitives.Float64__Sequence_to_C((*primitives.CFloat64__Sequence)(unsafe.Pointer(&mem.data)), m.Data)
}
func (t _Float64MultiArrayTypeSupport) AsGoStruct(msg types.Message, ros2_message_buffer unsafe.Pointer) {
m := msg.(*Float64MultiArray)
mem := (*C.example_interfaces__msg__Float64MultiArray)(ros2_message_buffer)
MultiArrayLayoutTypeSupport.AsGoStruct(&m.Layout, unsafe.Pointer(&mem.layout))
primitives.Float64__Sequence_to_Go(&m.Data, *(*primitives.CFloat64__Sequence)(unsafe.Pointer(&mem.data)))
}
func (t _Float64MultiArrayTypeSupport) TypeSupport() unsafe.Pointer {
return unsafe.Pointer(C.rosidl_typesupport_c__get_message_type_support_handle__example_interfaces__msg__Float64MultiArray())
}
type CFloat64MultiArray = C.example_interfaces__msg__Float64MultiArray
type CFloat64MultiArray__Sequence = C.example_interfaces__msg__Float64MultiArray__Sequence
func Float64MultiArray__Sequence_to_Go(goSlice *[]Float64MultiArray, cSlice CFloat64MultiArray__Sequence) {
if cSlice.size == 0 {
return
}
*goSlice = make([]Float64MultiArray, int64(cSlice.size))
for i := 0; i < int(cSlice.size); i++ {
cIdx := (*C.example_interfaces__msg__Float64MultiArray__Sequence)(unsafe.Pointer(
uintptr(unsafe.Pointer(cSlice.data)) + (C.sizeof_struct_example_interfaces__msg__Float64MultiArray * uintptr(i)),
))
Float64MultiArrayTypeSupport.AsGoStruct(&(*goSlice)[i], unsafe.Pointer(cIdx))
}
}
func Float64MultiArray__Sequence_to_C(cSlice *CFloat64MultiArray__Sequence, goSlice []Float64MultiArray) {
if len(goSlice) == 0 {
return
}
cSlice.data = (*C.example_interfaces__msg__Float64MultiArray)(C.malloc((C.size_t)(C.sizeof_struct_example_interfaces__msg__Float64MultiArray * uintptr(len(goSlice)))))
cSlice.capacity = C.size_t(len(goSlice))
cSlice.size = cSlice.capacity
for i, v := range goSlice {
cIdx := (*C.example_interfaces__msg__Float64MultiArray)(unsafe.Pointer(
uintptr(unsafe.Pointer(cSlice.data)) + (C.sizeof_struct_example_interfaces__msg__Float64MultiArray * uintptr(i)),
))
Float64MultiArrayTypeSupport.AsCStruct(unsafe.Pointer(cIdx), &v)
}
}
func Float64MultiArray__Array_to_Go(goSlice []Float64MultiArray, cSlice []CFloat64MultiArray) {
for i := 0; i < len(cSlice); i++ {
Float64MultiArrayTypeSupport.AsGoStruct(&goSlice[i], unsafe.Pointer(&cSlice[i]))
}
}
func Float64MultiArray__Array_to_C(cSlice []CFloat64MultiArray, goSlice []Float64MultiArray) {
for i := 0; i < len(goSlice); i++ {
Float64MultiArrayTypeSupport.AsCStruct(unsafe.Pointer(&cSlice[i]), &goSlice[i])
}
}