util.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. #ifndef LIB_COMMON_UTIL_H_
  19. #define LIB_COMMON_UTIL_H_
  20. #include "libhdfs++/status.h"
  21. #include <asio/error_code.hpp>
  22. #include <google/protobuf/message_lite.h>
  23. #include <google/protobuf/io/coded_stream.h>
  24. namespace hdfs {
  25. static inline Status ToStatus(const ::asio::error_code &ec) {
  26. if (ec) {
  27. return Status(ec.value(), ec.message().c_str());
  28. } else {
  29. return Status::OK();
  30. }
  31. }
  32. static inline int DelimitedPBMessageSize(
  33. const ::google::protobuf::MessageLite *msg) {
  34. size_t size = msg->ByteSize();
  35. return ::google::protobuf::io::CodedOutputStream::VarintSize32(size) + size;
  36. }
  37. static inline void ReadDelimitedPBMessage(
  38. ::google::protobuf::io::CodedInputStream *in,
  39. ::google::protobuf::MessageLite *msg) {
  40. uint32_t size = 0;
  41. in->ReadVarint32(&size);
  42. auto limit = in->PushLimit(size);
  43. msg->ParseFromCodedStream(in);
  44. in->PopLimit(limit);
  45. }
  46. std::string Base64Encode(const std::string &src);
  47. }
  48. #endif