}
Bundle::~Bundle() {
- if (impl_->handle_ && (impl_->own_ || impl_->copy_))
+ if (impl_ && impl_->handle_ && (impl_->own_ || impl_->copy_))
bundle_free(impl_->handle_);
}
}
Bundle::Bundle(Bundle&& b) noexcept {
- impl_ = std::unique_ptr<Impl>(new Impl(this));
- impl_->handle_ = b.impl_->handle_;
- b.impl_->handle_ = nullptr;
+ impl_ = std::move(b.impl_);
+ impl_->parent_ = this;
}
Bundle& Bundle::operator = (Bundle&& b) noexcept {
return *this;
}
+bool Bundle::IsEmpty() const noexcept {
+ return (bundle_get_count(impl_->handle_) == 0) ? true : false;
+}
+
std::vector<Bundle::KeyInfo> Bundle::GetKeys() {
std::vector<Bundle::KeyInfo> v;
std::vector<unsigned char> Bundle::GetByte(const std::string& key) const {
size_t size;
unsigned char* bytes = nullptr;
- bundle_get_byte(impl_->handle_, key.c_str(),
+ int ret = bundle_get_byte(impl_->handle_, key.c_str(),
reinterpret_cast<void**>(&bytes), &size);
+ if (ret != BUNDLE_ERROR_NONE) {
+ LOGE("bundle_get_byte() is failed");
+ return {};
+ }
+
return std::vector<unsigned char>(bytes, bytes + size);
}