-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathE16_StrBlob.h
85 lines (75 loc) · 2.98 KB
/
E16_StrBlob.h
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#ifndef E16_StrBlob_H
#define E16_StrBlob_H
#include <initializer_list>
#include <vector>
#include <string>
#include <iostream>
#include <memory>
#include <exception>
using std::cin;
using std::cout;
using std::endl;
using std::vector;
using std::string;
using std::shared_ptr;
using std::make_shared;
using std::initializer_list;
using std::out_of_range;
class StrBlob{
friend bool operator==(const StrBlob& lhs, const StrBlob& rhs);
friend bool operator!=(const StrBlob& lhs, const StrBlob& rhs);
friend bool operator>=(const StrBlob& lhs, const StrBlob& rhs);
friend bool operator<=(const StrBlob& lhs, const StrBlob& rhs);
friend bool operator>(const StrBlob& lhs, const StrBlob& rhs);
friend bool operator<(const StrBlob& lhs, const StrBlob& rhs);
public:
typedef vector<string>::size_type size_type;
StrBlob();
StrBlob(initializer_list<string> il);
size_type size() const {return data->size();}
bool empty() const { return data->empty(); }
void push_back(const string &s) const { return data->push_back(s);}
void pop_back();
string& operator[](size_t n) { check(n,"out of range"); return data->at(n); }
const string& operator[](size_t n) const { check(n,"out of range"); return data->at(n); }
// string &front() const { cout << "const front "; return data->front(); }
// string &back() const { cout << "const back "; return data->back(); }
string &front() { cout << "nonconst front "; return data->front(); }
string &back() { cout << "nonconst back "; return data->back(); }
const string &front() const {
check(0, "front on empty StrBlob!");
return data->front();
}
const string& back() const {
check(0, "bacm on empty StrBlob!");
return data->back();
}
private:
shared_ptr<vector<string>> data;
void check(size_type i, const string &msg) const;
};
StrBlob::StrBlob():data(make_shared<vector<string>>()) {}
StrBlob::StrBlob(initializer_list<string> il):data(make_shared<vector<string>>(il)) {}
bool operator==(const StrBlob& lhs, const StrBlob& rhs);
bool operator!=(const StrBlob& lhs, const StrBlob& rhs);
bool operator>=(const StrBlob& lhs, const StrBlob& rhs);
bool operator<=(const StrBlob& lhs, const StrBlob& rhs);
bool operator>(const StrBlob& lhs, const StrBlob& rhs);
bool operator<(const StrBlob& lhs, const StrBlob& rhs);
void StrBlob::check(size_type i, const string &msg) const { if(i >= data->size()){ throw out_of_range(msg); } }
bool operator==(const StrBlob& lhs, const StrBlob& rhs){ return *lhs.data == (*rhs.data); }
bool operator!=(const StrBlob& lhs, const StrBlob& rhs){ return !(rhs == lhs);
}
bool operator>=(const StrBlob& lhs, const StrBlob& rhs){
return !(lhs < rhs);
}
bool operator<=(const StrBlob& lhs, const StrBlob& rhs){
return !(lhs > rhs);
}
bool operator>(const StrBlob& lhs, const StrBlob& rhs){
return (rhs < lhs);
}
bool operator<(const StrBlob& lhs, const StrBlob& rhs){
return lexicographical_compare(lhs.data->begin(), lhs.data->end(), rhs.data->begin(), rhs.data->end());
}
#endif