diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/grpc++/client_context.h | 10 | ||||
-rw-r--r-- | include/grpc++/server_context.h | 3 | ||||
-rw-r--r-- | include/grpc/census.h | 8 |
3 files changed, 13 insertions, 8 deletions
diff --git a/include/grpc++/client_context.h b/include/grpc++/client_context.h index 9d64715803..1f46d8e417 100644 --- a/include/grpc++/client_context.h +++ b/include/grpc++/client_context.h @@ -37,6 +37,7 @@ /// side. /// - Control call settings such as compression and authentication. /// - Initial and trailing metadata coming from the server. +/// - Get performace metrics (ie, census). /// /// Context settings are only relevant to the call they are invoked with, that /// is to say, they aren't sticky. Some of these settings, such as the @@ -63,6 +64,8 @@ #include <grpc/support/log.h> #include <grpc/support/time.h> +struct census_context; + namespace grpc { class Channel; @@ -265,6 +268,12 @@ class ClientContext { /// \return The call's peer URI. grpc::string peer() const; + /// Get and set census context. + void set_census_context(struct census_context* ccp) { census_context_ = ccp; } + struct census_context* census_context() const { + return census_context_; + } + /// Send a best-effort out-of-band cancel. The call could be in any stage. /// e.g. if it is already finished, it may still return success. /// @@ -314,6 +323,7 @@ class ClientContext { grpc::string authority_; std::shared_ptr<CallCredentials> creds_; mutable std::shared_ptr<const AuthContext> auth_context_; + struct census_context* census_context_; std::multimap<grpc::string, grpc::string> send_initial_metadata_; std::multimap<grpc::string_ref, grpc::string_ref> recv_initial_metadata_; std::multimap<grpc::string_ref, grpc::string_ref> trailing_metadata_; diff --git a/include/grpc++/server_context.h b/include/grpc++/server_context.h index de4af7d1c2..85f384d477 100644 --- a/include/grpc++/server_context.h +++ b/include/grpc++/server_context.h @@ -47,6 +47,7 @@ struct gpr_timespec; struct grpc_metadata; struct grpc_call; +struct census_context; namespace grpc { @@ -125,6 +126,8 @@ class ServerContext { // functionality. Instead, use auth_context. grpc::string peer() const; + const struct census_context* census_context() const; + // Async only. Has to be called before the rpc starts. // Returns the tag in completion queue when the rpc finishes. // IsCancelled() can then be called to check whether the rpc was cancelled. diff --git a/include/grpc/census.h b/include/grpc/census.h index 2e6e19a016..d0bc90420c 100644 --- a/include/grpc/census.h +++ b/include/grpc/census.h @@ -79,14 +79,6 @@ int census_enabled(void); */ typedef struct census_context census_context; -/** - Returns the census_context of the current thread, creating one if necessary. - The object pointed to by the returned pointer is thread local, and thus may - be read without concurrency concerns, but should not be shared with other - threads. -*/ -census_context* census_context_current(); - /* This function is called by the RPC subsystem whenever it needs to get a * serialized form of the current census context (presumably to pass across * the wire). Arguments: |