mirror of https://gitee.com/bigwinds/arangodb
480 lines
15 KiB
C++
480 lines
15 KiB
C++
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test suite for TRI_vector_t
|
|
///
|
|
/// @file
|
|
///
|
|
/// DISCLAIMER
|
|
///
|
|
/// Copyright 2012 triagens GmbH, Cologne, Germany
|
|
///
|
|
/// Licensed under the Apache License, Version 2.0 (the "License");
|
|
/// you may not use this file except in compliance with the License.
|
|
/// You may obtain a copy of the License at
|
|
///
|
|
/// http://www.apache.org/licenses/LICENSE-2.0
|
|
///
|
|
/// Unless required by applicable law or agreed to in writing, software
|
|
/// distributed under the License is distributed on an "AS IS" BASIS,
|
|
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
/// See the License for the specific language governing permissions and
|
|
/// limitations under the License.
|
|
///
|
|
/// Copyright holder is triAGENS GmbH, Cologne, Germany
|
|
///
|
|
/// @author Jan Steemann
|
|
/// @author Copyright 2012, triAGENS GmbH, Cologne, Germany
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "Basics/Common.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
#include "Basics/vector.h"
|
|
|
|
// -----------------------------------------------------------------------------
|
|
// --SECTION-- private macros
|
|
// -----------------------------------------------------------------------------
|
|
|
|
#define VECTOR_INIT \
|
|
TRI_vector_t v1; \
|
|
TRI_InitVector(&v1, sizeof(int));
|
|
|
|
#define VECTOR_DESTROY \
|
|
TRI_DestroyVector(&v1);
|
|
|
|
// -----------------------------------------------------------------------------
|
|
// --SECTION-- test suite
|
|
// -----------------------------------------------------------------------------
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test length after vector initialization
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_length_init) {
|
|
VECTOR_INIT
|
|
|
|
EXPECT_TRUE((size_t) 0 == TRI_LengthVector(&v1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test vector length after insertions
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_length_insert) {
|
|
VECTOR_INIT
|
|
|
|
int p1 = 1;
|
|
int p2 = 2;
|
|
TRI_PushBackVector(&v1, &p1);
|
|
EXPECT_TRUE((size_t) 1 == TRI_LengthVector(&v1));
|
|
|
|
TRI_PushBackVector(&v1, &p1);
|
|
EXPECT_TRUE((size_t) 2 == TRI_LengthVector(&v1));
|
|
|
|
TRI_PushBackVector(&v1, &p2);
|
|
EXPECT_TRUE((size_t) 3 == TRI_LengthVector(&v1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test vector length after insertions & deletions
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_length_insert_remove) {
|
|
VECTOR_INIT
|
|
|
|
int p1 = 1;
|
|
int p2 = 2;
|
|
int p3 = 3;
|
|
TRI_PushBackVector(&v1, &p1);
|
|
EXPECT_TRUE((size_t) 1 == TRI_LengthVector(&v1));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE((size_t) 0 == TRI_LengthVector(&v1));
|
|
|
|
TRI_PushBackVector(&v1, &p2);
|
|
TRI_PushBackVector(&v1, &p3);
|
|
EXPECT_TRUE((size_t) 2 == TRI_LengthVector(&v1));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE((size_t) 1 == TRI_LengthVector(&v1));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE((size_t) 0 == TRI_LengthVector(&v1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test removal of elements at invalid positions
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_remove_invalid1) {
|
|
VECTOR_INIT
|
|
|
|
TRI_RemoveVector(&v1, 0); // invalid position
|
|
TRI_RemoveVector(&v1, 0); // invalid position
|
|
TRI_RemoveVector(&v1, 1); // invalid position
|
|
TRI_RemoveVector(&v1, -1); // invalid position
|
|
TRI_RemoveVector(&v1, 99); // invalid position
|
|
|
|
EXPECT_TRUE((size_t) 0 == TRI_LengthVector(&v1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test removal of elements at invalid positions
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_remove_invalid2) {
|
|
VECTOR_INIT
|
|
|
|
int p1 = 1;
|
|
int p2 = 2;
|
|
|
|
TRI_PushBackVector(&v1, &p1);
|
|
TRI_PushBackVector(&v1, &p2);
|
|
|
|
TRI_RemoveVector(&v1, 0); // valid
|
|
TRI_RemoveVector(&v1, 0); // valid
|
|
TRI_RemoveVector(&v1, 0); // now invalid
|
|
|
|
TRI_RemoveVector(&v1, 1); // invalid position
|
|
TRI_RemoveVector(&v1, -1); // invalid position
|
|
TRI_RemoveVector(&v1, 99); // invalid position
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test at
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_at_empty) {
|
|
VECTOR_INIT
|
|
|
|
void* r = nullptr;
|
|
|
|
EXPECT_TRUE(r == TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(r == TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(r == TRI_AtVector(&v1, -1));
|
|
EXPECT_TRUE(r == TRI_AtVector(&v1, 99));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test at and insert
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_at_insert) {
|
|
VECTOR_INIT
|
|
|
|
int a = 1;
|
|
int b = 2;
|
|
int c = 3;
|
|
int d = 4;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
|
|
TRI_PushBackVector(&v1, &b);
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
|
|
TRI_PushBackVector(&v1, &c);
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
|
|
TRI_PushBackVector(&v1, &d);
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test at and insert and remove
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_at_insert_remove) {
|
|
VECTOR_INIT
|
|
|
|
void* r = nullptr;
|
|
int a = 1;
|
|
int b = 2;
|
|
int c = 3;
|
|
int d = 4;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE(r == TRI_AtVector(&v1, 0));
|
|
|
|
TRI_PushBackVector(&v1, &b);
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 0));
|
|
|
|
TRI_PushBackVector(&v1, &c);
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 1));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 0));
|
|
|
|
TRI_PushBackVector(&v1, &d);
|
|
TRI_PushBackVector(&v1, &a);
|
|
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 2));
|
|
|
|
TRI_RemoveVector(&v1, 1);
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test duplicate pointers
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_push_back_duplicate) {
|
|
VECTOR_INIT
|
|
int a = 1;
|
|
int b = 2;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &b);
|
|
TRI_PushBackVector(&v1, &b);
|
|
|
|
EXPECT_TRUE((size_t) 6 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 4));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 5));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test duplicate pointers
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_remove_duplicate) {
|
|
VECTOR_INIT
|
|
int a = 1;
|
|
int b = 2;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &b);
|
|
TRI_PushBackVector(&v1, &b);
|
|
|
|
EXPECT_TRUE((size_t) 5 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 4));
|
|
|
|
TRI_RemoveVector(&v1, 4);
|
|
TRI_RemoveVector(&v1, 0);
|
|
TRI_RemoveVector(&v1, 1);
|
|
EXPECT_TRUE((size_t) 2 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test push back and remove
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_push_back_remove) {
|
|
VECTOR_INIT
|
|
|
|
int a = 1;
|
|
int b = 2;
|
|
int c = 3;
|
|
int d = 4;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &b);
|
|
TRI_PushBackVector(&v1, &c);
|
|
TRI_PushBackVector(&v1, &d);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &b);
|
|
TRI_PushBackVector(&v1, &c);
|
|
TRI_PushBackVector(&v1, &d);
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &a);
|
|
|
|
EXPECT_TRUE((size_t) 10 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 4));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 5));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 6));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 7));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 8));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 9));
|
|
|
|
TRI_RemoveVector(&v1, 4);
|
|
EXPECT_TRUE((size_t) 9 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 4));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 5));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 6));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 7));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 8));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE((size_t) 8 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 4));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 5));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 6));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 7));
|
|
|
|
TRI_RemoveVector(&v1, 7);
|
|
EXPECT_TRUE((size_t) 7 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 4));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 5));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 6));
|
|
|
|
TRI_RemoveVector(&v1, 0);
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE((size_t) 5 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 4));
|
|
|
|
TRI_RemoveVector(&v1, 1);
|
|
TRI_RemoveVector(&v1, 1);
|
|
EXPECT_TRUE((size_t) 3 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 2));
|
|
|
|
TRI_RemoveVector(&v1, 1);
|
|
EXPECT_TRUE((size_t) 2 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 1));
|
|
|
|
TRI_RemoveVector(&v1, 1);
|
|
TRI_RemoveVector(&v1, 0);
|
|
EXPECT_TRUE((size_t) 0 == TRI_LengthVector(&v1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test set
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_set) {
|
|
VECTOR_INIT
|
|
|
|
int a = 1;
|
|
int b = 2;
|
|
int c = 3;
|
|
int d = 4;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &b);
|
|
TRI_PushBackVector(&v1, &c);
|
|
TRI_PushBackVector(&v1, &d);
|
|
|
|
EXPECT_TRUE((size_t) 4 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(1 == *(int*) TRI_BeginVector(&v1));
|
|
EXPECT_TRUE(4 == *((int*) (int*) TRI_BeginVector(&v1) + TRI_LengthVector(&v1) - 1));
|
|
|
|
TRI_SetVector(&v1, 0, &d);
|
|
TRI_SetVector(&v1, 1, &c);
|
|
TRI_SetVector(&v1, 2, &b);
|
|
TRI_SetVector(&v1, 3, &a);
|
|
|
|
EXPECT_TRUE((size_t) 4 == TRI_LengthVector(&v1));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 3));
|
|
EXPECT_TRUE(4 == *(int*) TRI_BeginVector(&v1));
|
|
EXPECT_TRUE(1 == *((int*) (int*) TRI_BeginVector(&v1) + TRI_LengthVector(&v1) - 1));
|
|
|
|
TRI_SetVector(&v1, 0, &b);
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_BeginVector(&v1));
|
|
|
|
VECTOR_DESTROY
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test modifications
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
TEST(CVectorTest, tst_value_modifications) {
|
|
VECTOR_INIT
|
|
|
|
int a = 1;
|
|
int b = 2;
|
|
int c = 3;
|
|
int d = 4;
|
|
|
|
TRI_PushBackVector(&v1, &a);
|
|
TRI_PushBackVector(&v1, &b);
|
|
TRI_PushBackVector(&v1, &c);
|
|
TRI_PushBackVector(&v1, &d);
|
|
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
|
|
a = 99;
|
|
b = 42;
|
|
c = -1;
|
|
d = 0;
|
|
|
|
EXPECT_TRUE(1 == *(int*) TRI_AtVector(&v1, 0));
|
|
EXPECT_TRUE(2 == *(int*) TRI_AtVector(&v1, 1));
|
|
EXPECT_TRUE(3 == *(int*) TRI_AtVector(&v1, 2));
|
|
EXPECT_TRUE(4 == *(int*) TRI_AtVector(&v1, 3));
|
|
|
|
VECTOR_DESTROY
|
|
}
|