using namespace llvm;
using namespace object;
-namespace {
-struct SymEntry {
- symbol_iterator I;
- uint64_t Address;
- unsigned Number;
- unsigned SectionID;
-};
-}
-
-static int compareAddress(const SymEntry *A, const SymEntry *B) {
+// Orders increasingly by (SectionID, Address).
+int llvm::object::compareAddress(const SymEntry *A, const SymEntry *B) {
if (A->SectionID != B->SectionID)
- return A->SectionID - B->SectionID;
- return A->Address - B->Address;
+ return A->SectionID < B->SectionID ? -1 : 1;
+ if (A->Address != B->Address)
+ return A->Address < B->Address ? -1 : 1;
+ return 0;
}
static unsigned getSectionID(const ObjectFile &O, SectionRef Sec) {
--- /dev/null
+//===- SymbolSizeTest.cpp - Tests for SymbolSize.cpp ----------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/Object/SymbolSize.h"
+#include "gtest/gtest.h"
+
+using namespace llvm;
+using namespace llvm::object;
+
+TEST(Object, SymbolSizeSort) {
+ auto it = symbol_iterator(SymbolRef());
+ std::vector<SymEntry> Syms{
+ SymEntry{it, 0xffffffff00000000ull, 1, 0},
+ SymEntry{it, 0x00ffffff00000000ull, 2, 0},
+ SymEntry{it, 0x00ffffff000000ffull, 3, 0},
+ SymEntry{it, 0x0000000100000000ull, 4, 0},
+ SymEntry{it, 0x00000000000000ffull, 5, 0},
+ SymEntry{it, 0x00000001000000ffull, 6, 0},
+ SymEntry{it, 0x000000010000ffffull, 7, 0},
+ };
+
+ array_pod_sort(Syms.begin(), Syms.end(), compareAddress);
+
+ for (unsigned I = 0, N = Syms.size(); I < N - 1; ++I) {
+ EXPECT_LE(Syms[I].Address, Syms[I + 1].Address);
+ }
+}