1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- #Adapted from IndirectArray
- struct Vec{T, N} <: AbstractArray{T,1}
- cpp_object
- data::AbstractArray{T, 1}
- cpp_allocated::Bool
- @inline function Vec{T, N}(obj) where {T, N}
- new{T, N}(obj, Base.unsafe_wrap(Array{T, 1}, Ptr{T}(obj.cpp_object), N), true)
- end
- @inline function Vec{T, N}(data_raw::AbstractArray{T, 1}) where {T, N}
- if size(data_raw, 1) != N
- throw("Array is improper Size for Vec declared")
- end
- new{T, N}(nothing, data_raw, false)
- end
- end
- function Base.deepcopy_internal(x::Vec{T,N}, y::IdDict) where {T, N}
- if haskey(y, x)
- return y[x]
- end
- ret = Base.copy(x)
- y[x] = ret
- return ret
- end
- Base.size(A::Vec) = Base.size(A.data)
- Base.axes(A::Vec) = Base.axes(A.data)
- Base.IndexStyle(::Type{Vec{T,N}}) where {T, N} = IndexLinear()
- Base.strides(A::Vec{T,N}) where {T, N} = (1)
- function Base.copy(A::Vec{T,N}) where {T, N}
- return Vec{T, N}(copy(A.data))
- end
- Base.pointer(A::Vec) = Base.pointer(A.data)
- Base.unsafe_convert(::Type{Ptr{T}}, A::Vec{S, N}) where {T, S, N} = Base.unsafe_convert(Ptr{T}, A.data)
- @inline function Base.getindex(A::Vec{T,N}, I::Int) where {T, N}
- @boundscheck checkbounds(A.data, I)
- return A.data[I]
- end
- @inline function Base.setindex!(A::Vec, x, I::Int)
- @boundscheck checkbounds(A.data, I)
- A.data[I] = x
- return A
- end
|