// Generated file - DO NOT MODIFY #include "{{file}}.client.h" #include #include #include #include {% if package != None %} namespace {{package.cpp_namespace()}} { {% endif %} {% for interface in interfaces %} {{interface.name}}Client::~{{interface.name}}Client() { if (endpoint_ != 0) { check(ZCapRelease(endpoint_)); } } {% for method in interface.methods %} {% if method.request == None %} glcr::Status {{interface.name}}Client::{{method.name}}({{method.response}}& response) { {% elif method.response == None %} glcr::Status {{interface.name}}Client::{{method.name}}(const {{method.request}}& request) { {% else %} glcr::Status {{interface.name}}Client::{{method.name}}(const {{method.request}}& request, {{method.response}}& response) { {% endif %} uint64_t buffer_size = kBufferSize; uint64_t cap_size = kCapBufferSize; const uint32_t kSentinel = 0xBEEFDEAD; buffer_.WriteAt(0, kSentinel); buffer_.WriteAt(8, {{method.number}}); cap_buffer_.Reset(); {% if method.request == None %} uint64_t length = 0; {% else %} uint64_t length = request.SerializeToBytes(buffer_, /*offset=*/16, cap_buffer_); {% endif %} buffer_.WriteAt(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(0) != kSentinel) { return glcr::InvalidResponse("Got an invalid response from server."); } // Check Response Code. RET_ERR(buffer_.At(8)); {% if method.response != None %} yunq::MessageView resp_view(buffer_, 16); RETURN_ERROR(response.ParseFromBytes(resp_view, cap_buffer_)); {% endif %} return glcr::OK; } {% endfor %} {% endfor %} {% if package != None %} } // namepace {{package.cpp_namespace()}} {% endif %}