This repository was archived by the owner on Aug 31, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 224
Expand file tree
/
Copy pathtest_proper-list.cpp
More file actions
60 lines (50 loc) · 2.34 KB
/
Copy pathtest_proper-list.cpp
File metadata and controls
60 lines (50 loc) · 2.34 KB
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
/* Copyright (C) 2003-2015 LiveCode Ltd.
This file is part of LiveCode.
LiveCode is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License v3 as published by the Free
Software Foundation.
LiveCode is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
for more details.
You should have received a copy of the GNU General Public License
along with LiveCode. If not see <http://www.gnu.org/licenses/>. */
#include "gtest/gtest.h"
#include "foundation.h"
#include "foundation-span.h"
#include "foundation-auto.h"
TEST(properlist, createwithforeignvalues_bridgable)
{
float t_floats[] = { 1.1, 2.1, 3.1, 5, 10 };
size_t t_float_count = sizeof(t_floats) / sizeof(t_floats[0]);
MCAutoProperListRef t_float_list;
ASSERT_TRUE(MCProperListCreateWithForeignValues(kMCFloatTypeInfo, MCMakeSpan(t_floats), &t_float_list));
ASSERT_EQ(MCProperListGetLength(*t_float_list), t_float_count);
for(size_t i = 0; i < t_float_count; i++)
{
MCValueRef t_element = MCProperListFetchElementAtIndex(*t_float_list, i);
ASSERT_EQ(MCValueGetTypeInfo(t_element), kMCNumberTypeInfo);
if (MCValueGetTypeInfo(t_element) == kMCNumberTypeInfo)
{
ASSERT_EQ(MCNumberFetchAsReal((MCNumberRef)t_element), t_floats[i]);
}
}
}
TEST(properlist, createwithforeignvalues_unbridgable)
{
float t_floats[] = { 1.1, 2.1, 3.1, 5, 10 };
void *t_pointers[] = { nullptr, &t_floats[1], nullptr, &t_floats[2] };
size_t t_pointer_count = sizeof(t_pointers) / sizeof(t_pointers[0]);
MCAutoProperListRef t_pointer_list;
ASSERT_TRUE(MCProperListCreateWithForeignValues(kMCPointerTypeInfo, MCMakeSpan(t_pointers), &t_pointer_list));
ASSERT_EQ(MCProperListGetLength(*t_pointer_list), t_pointer_count);
for(size_t i = 0; i < t_pointer_count; i++)
{
MCValueRef t_element = MCProperListFetchElementAtIndex(*t_pointer_list, i);
ASSERT_EQ(MCValueGetTypeInfo(t_element), kMCPointerTypeInfo);
if (MCValueGetTypeInfo(t_element) == kMCPointerTypeInfo)
{
ASSERT_EQ(*static_cast<void **>(MCForeignValueGetContentsPtr(((MCForeignValueRef)t_element))), t_pointers[i]);
}
}
}