// Generated file - DO NOT MODIFY #include "example.yunq.client.h" #include <glacier/buffer/byte_buffer.h> #include <glacier/buffer/cap_buffer.h> #include <mammoth/util/debug.h> #include <zcall.h> namespace srv::file { VFSClient::~VFSClient() { if (endpoint_ != 0) { check(ZCapRelease(endpoint_)); } } glcr::ErrorCode VFSClient::open(const OpenFileRequest& request, File& response) { uint64_t buffer_size = kBufferSize; uint64_t cap_size = kCapBufferSize; const uint32_t kSentinel = 0xBEEFDEAD; buffer_.WriteAt<uint32_t>(0, kSentinel); buffer_.WriteAt<uint64_t>(8, 0); cap_buffer_.Reset(); uint64_t length = request.SerializeToBytes(buffer_, /*offset=*/16, cap_buffer_); buffer_.WriteAt<uint32_t>(4, 16 + length); z_cap_t reply_port_cap; RET_ERR(ZEndpointSend(endpoint_, 16 + length, buffer_.RawPtr(), cap_buffer_.UsedSlots(), cap_buffer_.RawPtr(), &reply_port_cap)); // FIXME: Add a way to zero out the first buffer. RET_ERR(ZReplyPortRecv(reply_port_cap, &buffer_size, buffer_.RawPtr(), &cap_size, cap_buffer_.RawPtr())); if (buffer_.At<uint32_t>(0) != kSentinel) { return glcr::INVALID_RESPONSE; } // Check Response Code. RET_ERR(buffer_.At<uint64_t>(8)); response.ParseFromBytes(buffer_, 16, cap_buffer_); return glcr::OK; } } // namepace srv::file