1 /*
2 **********************************************************************
3 * Copyright (C) 2003-2011, International Business Machines
4 * Corporation and others. All Rights Reserved.
5 **********************************************************************
6 */
7
8 #include "uvector.h"
9
10 U_NAMESPACE_BEGIN
11
UOBJECT_DEFINE_RTTI_IMPLEMENTATION(UStack)12 UOBJECT_DEFINE_RTTI_IMPLEMENTATION(UStack)
13
14 UStack::UStack(UErrorCode &status) :
15 UVector(status)
16 {
17 }
18
UStack(int32_t initialCapacity,UErrorCode & status)19 UStack::UStack(int32_t initialCapacity, UErrorCode &status) :
20 UVector(initialCapacity, status)
21 {
22 }
23
UStack(UObjectDeleter * d,UElementsAreEqual * c,UErrorCode & status)24 UStack::UStack(UObjectDeleter *d, UElementsAreEqual *c, UErrorCode &status) :
25 UVector(d, c, status)
26 {
27 }
28
UStack(UObjectDeleter * d,UElementsAreEqual * c,int32_t initialCapacity,UErrorCode & status)29 UStack::UStack(UObjectDeleter *d, UElementsAreEqual *c, int32_t initialCapacity, UErrorCode &status) :
30 UVector(d, c, initialCapacity, status)
31 {
32 }
33
~UStack()34 UStack::~UStack() {}
35
pop(void)36 void* UStack::pop(void) {
37 int32_t n = size() - 1;
38 void* result = 0;
39 if (n >= 0) {
40 result = elementAt(n);
41 removeElementAt(n);
42 }
43 return result;
44 }
45
popi(void)46 int32_t UStack::popi(void) {
47 int32_t n = size() - 1;
48 int32_t result = 0;
49 if (n >= 0) {
50 result = elementAti(n);
51 removeElementAt(n);
52 }
53 return result;
54 }
55
search(void * obj) const56 int32_t UStack::search(void* obj) const {
57 int32_t i = indexOf(obj);
58 return (i >= 0) ? size() - i : i;
59 }
60
61 U_NAMESPACE_END
62