1#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct PostCommentForComparedCommit;
6impl PostCommentForComparedCommit {
7 pub fn new() -> Self {
9 Self
10 }
11 pub(crate) async fn orchestrate(
12 runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
13 input: crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitInput,
14 ) -> ::std::result::Result<
15 crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitOutput,
16 ::aws_smithy_runtime_api::client::result::SdkError<
17 crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitError,
18 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
19 >,
20 > {
21 let map_err = |err: ::aws_smithy_runtime_api::client::result::SdkError<
22 ::aws_smithy_runtime_api::client::interceptors::context::Error,
23 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
24 >| {
25 err.map_service_error(|err| {
26 err.downcast::<crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitError>()
27 .expect("correct error type")
28 })
29 };
30 let context = Self::orchestrate_with_stop_point(runtime_plugins, input, ::aws_smithy_runtime::client::orchestrator::StopPoint::None)
31 .await
32 .map_err(map_err)?;
33 let output = context.finalize().map_err(map_err)?;
34 ::std::result::Result::Ok(
35 output
36 .downcast::<crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitOutput>()
37 .expect("correct output type"),
38 )
39 }
40
41 pub(crate) async fn orchestrate_with_stop_point(
42 runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
43 input: crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitInput,
44 stop_point: ::aws_smithy_runtime::client::orchestrator::StopPoint,
45 ) -> ::std::result::Result<
46 ::aws_smithy_runtime_api::client::interceptors::context::InterceptorContext,
47 ::aws_smithy_runtime_api::client::result::SdkError<
48 ::aws_smithy_runtime_api::client::interceptors::context::Error,
49 ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
50 >,
51 > {
52 let input = ::aws_smithy_runtime_api::client::interceptors::context::Input::erase(input);
53 use ::tracing::Instrument;
54 ::aws_smithy_runtime::client::orchestrator::invoke_with_stop_point(
55 "CodeCommit",
56 "PostCommentForComparedCommit",
57 input,
58 runtime_plugins,
59 stop_point,
60 )
61 .instrument(::tracing::debug_span!(
64 "CodeCommit.PostCommentForComparedCommit",
65 "rpc.service" = "CodeCommit",
66 "rpc.method" = "PostCommentForComparedCommit",
67 "sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
68 "rpc.system" = "aws-api",
69 ))
70 .await
71 }
72
73 pub(crate) fn operation_runtime_plugins(
74 client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
75 client_config: &crate::config::Config,
76 config_override: ::std::option::Option<crate::config::Builder>,
77 ) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
78 let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
79 runtime_plugins = runtime_plugins.with_operation_plugin(crate::client_idempotency_token::IdempotencyTokenRuntimePlugin::new(
80 |token_provider, input| {
81 let input: &mut crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitInput =
82 input.downcast_mut().expect("correct type");
83 if input.client_request_token.is_none() {
84 input.client_request_token = ::std::option::Option::Some(token_provider.make_idempotency_token());
85 }
86 },
87 ));
88 if let ::std::option::Option::Some(config_override) = config_override {
89 for plugin in config_override.runtime_plugins.iter().cloned() {
90 runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
91 }
92 runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
93 config_override,
94 client_config.config.clone(),
95 &client_config.runtime_components,
96 ));
97 }
98 runtime_plugins
99 }
100}
101impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for PostCommentForComparedCommit {
102 fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
103 let mut cfg = ::aws_smithy_types::config_bag::Layer::new("PostCommentForComparedCommit");
104
105 cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
106 PostCommentForComparedCommitRequestSerializer,
107 ));
108 cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
109 PostCommentForComparedCommitResponseDeserializer,
110 ));
111
112 cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
113 crate::config::auth::Params::builder()
114 .operation_name("PostCommentForComparedCommit")
115 .build()
116 .expect("required fields set"),
117 ));
118
119 cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
120 "PostCommentForComparedCommit",
121 "CodeCommit",
122 ));
123 let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
124 signing_options.double_uri_encode = true;
125 signing_options.content_sha256_header = false;
126 signing_options.normalize_uri_path = true;
127 signing_options.payload_override = None;
128
129 cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
130 signing_options,
131 ..::std::default::Default::default()
132 });
133
134 ::std::option::Option::Some(cfg.freeze())
135 }
136
137 fn runtime_components(
138 &self,
139 _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
140 ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
141 #[allow(unused_mut)]
142 let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("PostCommentForComparedCommit")
143 .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
144 ::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
145 ))
146 .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
147 PostCommentForComparedCommitEndpointParamsInterceptor,
148 ))
149 .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
150 crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitError,
151 >::new())
152 .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
153 crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitError,
154 >::new())
155 .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
156 crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitError,
157 >::new());
158
159 ::std::borrow::Cow::Owned(rcb)
160 }
161}
162
163#[derive(Debug)]
164struct PostCommentForComparedCommitResponseDeserializer;
165impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for PostCommentForComparedCommitResponseDeserializer {
166 fn deserialize_nonstreaming(
167 &self,
168 response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
169 ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
170 let (success, status) = (response.status().is_success(), response.status().as_u16());
171 let headers = response.headers();
172 let body = response.body().bytes().expect("body loaded");
173 #[allow(unused_mut)]
174 let mut force_error = false;
175 ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
176 let parse_result = if !success && status != 200 || force_error {
177 crate::protocol_serde::shape_post_comment_for_compared_commit::de_post_comment_for_compared_commit_http_error(status, headers, body)
178 } else {
179 crate::protocol_serde::shape_post_comment_for_compared_commit::de_post_comment_for_compared_commit_http_response(status, headers, body)
180 };
181 crate::protocol_serde::type_erase_result(parse_result)
182 }
183}
184#[derive(Debug)]
185struct PostCommentForComparedCommitRequestSerializer;
186impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for PostCommentForComparedCommitRequestSerializer {
187 #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
188 fn serialize_input(
189 &self,
190 input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
191 _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
192 ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
193 let input = input
194 .downcast::<crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitInput>()
195 .expect("correct type");
196 let _header_serialization_settings = _cfg
197 .load::<crate::serialization_settings::HeaderSerializationSettings>()
198 .cloned()
199 .unwrap_or_default();
200 let mut request_builder = {
201 #[allow(clippy::uninlined_format_args)]
202 fn uri_base(
203 _input: &crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitInput,
204 output: &mut ::std::string::String,
205 ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
206 use ::std::fmt::Write as _;
207 ::std::write!(output, "/").expect("formatting should succeed");
208 ::std::result::Result::Ok(())
209 }
210 #[allow(clippy::unnecessary_wraps)]
211 fn update_http_builder(
212 input: &crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitInput,
213 builder: ::http_1x::request::Builder,
214 ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
215 let mut uri = ::std::string::String::new();
216 uri_base(input, &mut uri)?;
217 ::std::result::Result::Ok(builder.method("POST").uri(uri))
218 }
219 let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
220 builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
221 builder = _header_serialization_settings.set_default_header(
222 builder,
223 ::http_1x::header::HeaderName::from_static("x-amz-target"),
224 "CodeCommit_20150413.PostCommentForComparedCommit",
225 );
226 builder
227 };
228 let body = ::aws_smithy_types::body::SdkBody::from(
229 crate::protocol_serde::shape_post_comment_for_compared_commit::ser_post_comment_for_compared_commit_input(&input)?,
230 );
231 if let Some(content_length) = body.content_length() {
232 let content_length = content_length.to_string();
233 request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
234 }
235 ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
236 }
237}
238#[derive(Debug)]
239struct PostCommentForComparedCommitEndpointParamsInterceptor;
240
241#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
242impl ::aws_smithy_runtime_api::client::interceptors::Intercept for PostCommentForComparedCommitEndpointParamsInterceptor {
243 fn name(&self) -> &'static str {
244 "PostCommentForComparedCommitEndpointParamsInterceptor"
245 }
246
247 fn read_before_execution(
248 &self,
249 context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
250 '_,
251 ::aws_smithy_runtime_api::client::interceptors::context::Input,
252 ::aws_smithy_runtime_api::client::interceptors::context::Output,
253 ::aws_smithy_runtime_api::client::interceptors::context::Error,
254 >,
255 cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
256 ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
257 let _input = context
258 .input()
259 .downcast_ref::<PostCommentForComparedCommitInput>()
260 .ok_or("failed to downcast to PostCommentForComparedCommitInput")?;
261
262 let params = crate::config::endpoint::Params::builder()
263 .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
264 .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
265 .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
266 .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
267 .build()
268 .map_err(|err| {
269 ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
270 })?;
271 cfg.interceptor_state()
272 .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
273 ::std::result::Result::Ok(())
274 }
275}
276
277#[non_exhaustive]
282#[derive(::std::fmt::Debug)]
283pub enum PostCommentForComparedCommitError {
284 BeforeCommitIdAndAfterCommitIdAreSameException(crate::types::error::BeforeCommitIdAndAfterCommitIdAreSameException),
286 ClientRequestTokenRequiredException(crate::types::error::ClientRequestTokenRequiredException),
288 CommentContentRequiredException(crate::types::error::CommentContentRequiredException),
290 CommentContentSizeLimitExceededException(crate::types::error::CommentContentSizeLimitExceededException),
292 CommitDoesNotExistException(crate::types::error::CommitDoesNotExistException),
294 CommitIdRequiredException(crate::types::error::CommitIdRequiredException),
296 EncryptionIntegrityChecksFailedException(crate::types::error::EncryptionIntegrityChecksFailedException),
298 EncryptionKeyAccessDeniedException(crate::types::error::EncryptionKeyAccessDeniedException),
300 EncryptionKeyDisabledException(crate::types::error::EncryptionKeyDisabledException),
302 EncryptionKeyNotFoundException(crate::types::error::EncryptionKeyNotFoundException),
304 EncryptionKeyUnavailableException(crate::types::error::EncryptionKeyUnavailableException),
306 IdempotencyParameterMismatchException(crate::types::error::IdempotencyParameterMismatchException),
308 InvalidClientRequestTokenException(crate::types::error::InvalidClientRequestTokenException),
310 InvalidCommitIdException(crate::types::error::InvalidCommitIdException),
312 InvalidFileLocationException(crate::types::error::InvalidFileLocationException),
314 InvalidFilePositionException(crate::types::error::InvalidFilePositionException),
316 InvalidPathException(crate::types::error::InvalidPathException),
318 InvalidRelativeFileVersionEnumException(crate::types::error::InvalidRelativeFileVersionEnumException),
320 InvalidRepositoryNameException(crate::types::error::InvalidRepositoryNameException),
324 PathDoesNotExistException(crate::types::error::PathDoesNotExistException),
326 PathRequiredException(crate::types::error::PathRequiredException),
328 RepositoryDoesNotExistException(crate::types::error::RepositoryDoesNotExistException),
330 RepositoryNameRequiredException(crate::types::error::RepositoryNameRequiredException),
332 #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
334 variable wildcard pattern and check `.code()`:
335 \
336 `err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
337 \
338 See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-PostCommentForComparedCommitError) for what information is available for the error.")]
339 Unhandled(crate::error::sealed_unhandled::Unhandled),
340}
341impl PostCommentForComparedCommitError {
342 pub fn unhandled(
344 err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
345 ) -> Self {
346 Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
347 source: err.into(),
348 meta: ::std::default::Default::default(),
349 })
350 }
351
352 pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
354 Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
355 source: err.clone().into(),
356 meta: err,
357 })
358 }
359 pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
364 match self {
365 Self::BeforeCommitIdAndAfterCommitIdAreSameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
366 Self::ClientRequestTokenRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
367 Self::CommentContentRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
368 Self::CommentContentSizeLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
369 Self::CommitDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
370 Self::CommitIdRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
371 Self::EncryptionIntegrityChecksFailedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
372 Self::EncryptionKeyAccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
373 Self::EncryptionKeyDisabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
374 Self::EncryptionKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
375 Self::EncryptionKeyUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
376 Self::IdempotencyParameterMismatchException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
377 Self::InvalidClientRequestTokenException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
378 Self::InvalidCommitIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
379 Self::InvalidFileLocationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
380 Self::InvalidFilePositionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
381 Self::InvalidPathException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
382 Self::InvalidRelativeFileVersionEnumException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
383 Self::InvalidRepositoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
384 Self::PathDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
385 Self::PathRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
386 Self::RepositoryDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
387 Self::RepositoryNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
388 Self::Unhandled(e) => &e.meta,
389 }
390 }
391 pub fn is_before_commit_id_and_after_commit_id_are_same_exception(&self) -> bool {
393 matches!(self, Self::BeforeCommitIdAndAfterCommitIdAreSameException(_))
394 }
395 pub fn is_client_request_token_required_exception(&self) -> bool {
397 matches!(self, Self::ClientRequestTokenRequiredException(_))
398 }
399 pub fn is_comment_content_required_exception(&self) -> bool {
401 matches!(self, Self::CommentContentRequiredException(_))
402 }
403 pub fn is_comment_content_size_limit_exceeded_exception(&self) -> bool {
405 matches!(self, Self::CommentContentSizeLimitExceededException(_))
406 }
407 pub fn is_commit_does_not_exist_exception(&self) -> bool {
409 matches!(self, Self::CommitDoesNotExistException(_))
410 }
411 pub fn is_commit_id_required_exception(&self) -> bool {
413 matches!(self, Self::CommitIdRequiredException(_))
414 }
415 pub fn is_encryption_integrity_checks_failed_exception(&self) -> bool {
417 matches!(self, Self::EncryptionIntegrityChecksFailedException(_))
418 }
419 pub fn is_encryption_key_access_denied_exception(&self) -> bool {
421 matches!(self, Self::EncryptionKeyAccessDeniedException(_))
422 }
423 pub fn is_encryption_key_disabled_exception(&self) -> bool {
425 matches!(self, Self::EncryptionKeyDisabledException(_))
426 }
427 pub fn is_encryption_key_not_found_exception(&self) -> bool {
429 matches!(self, Self::EncryptionKeyNotFoundException(_))
430 }
431 pub fn is_encryption_key_unavailable_exception(&self) -> bool {
433 matches!(self, Self::EncryptionKeyUnavailableException(_))
434 }
435 pub fn is_idempotency_parameter_mismatch_exception(&self) -> bool {
437 matches!(self, Self::IdempotencyParameterMismatchException(_))
438 }
439 pub fn is_invalid_client_request_token_exception(&self) -> bool {
441 matches!(self, Self::InvalidClientRequestTokenException(_))
442 }
443 pub fn is_invalid_commit_id_exception(&self) -> bool {
445 matches!(self, Self::InvalidCommitIdException(_))
446 }
447 pub fn is_invalid_file_location_exception(&self) -> bool {
449 matches!(self, Self::InvalidFileLocationException(_))
450 }
451 pub fn is_invalid_file_position_exception(&self) -> bool {
453 matches!(self, Self::InvalidFilePositionException(_))
454 }
455 pub fn is_invalid_path_exception(&self) -> bool {
457 matches!(self, Self::InvalidPathException(_))
458 }
459 pub fn is_invalid_relative_file_version_enum_exception(&self) -> bool {
461 matches!(self, Self::InvalidRelativeFileVersionEnumException(_))
462 }
463 pub fn is_invalid_repository_name_exception(&self) -> bool {
465 matches!(self, Self::InvalidRepositoryNameException(_))
466 }
467 pub fn is_path_does_not_exist_exception(&self) -> bool {
469 matches!(self, Self::PathDoesNotExistException(_))
470 }
471 pub fn is_path_required_exception(&self) -> bool {
473 matches!(self, Self::PathRequiredException(_))
474 }
475 pub fn is_repository_does_not_exist_exception(&self) -> bool {
477 matches!(self, Self::RepositoryDoesNotExistException(_))
478 }
479 pub fn is_repository_name_required_exception(&self) -> bool {
481 matches!(self, Self::RepositoryNameRequiredException(_))
482 }
483}
484impl ::std::error::Error for PostCommentForComparedCommitError {
485 fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
486 match self {
487 Self::BeforeCommitIdAndAfterCommitIdAreSameException(_inner) => ::std::option::Option::Some(_inner),
488 Self::ClientRequestTokenRequiredException(_inner) => ::std::option::Option::Some(_inner),
489 Self::CommentContentRequiredException(_inner) => ::std::option::Option::Some(_inner),
490 Self::CommentContentSizeLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
491 Self::CommitDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
492 Self::CommitIdRequiredException(_inner) => ::std::option::Option::Some(_inner),
493 Self::EncryptionIntegrityChecksFailedException(_inner) => ::std::option::Option::Some(_inner),
494 Self::EncryptionKeyAccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
495 Self::EncryptionKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
496 Self::EncryptionKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
497 Self::EncryptionKeyUnavailableException(_inner) => ::std::option::Option::Some(_inner),
498 Self::IdempotencyParameterMismatchException(_inner) => ::std::option::Option::Some(_inner),
499 Self::InvalidClientRequestTokenException(_inner) => ::std::option::Option::Some(_inner),
500 Self::InvalidCommitIdException(_inner) => ::std::option::Option::Some(_inner),
501 Self::InvalidFileLocationException(_inner) => ::std::option::Option::Some(_inner),
502 Self::InvalidFilePositionException(_inner) => ::std::option::Option::Some(_inner),
503 Self::InvalidPathException(_inner) => ::std::option::Option::Some(_inner),
504 Self::InvalidRelativeFileVersionEnumException(_inner) => ::std::option::Option::Some(_inner),
505 Self::InvalidRepositoryNameException(_inner) => ::std::option::Option::Some(_inner),
506 Self::PathDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
507 Self::PathRequiredException(_inner) => ::std::option::Option::Some(_inner),
508 Self::RepositoryDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
509 Self::RepositoryNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
510 Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
511 }
512 }
513}
514impl ::std::fmt::Display for PostCommentForComparedCommitError {
515 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
516 match self {
517 Self::BeforeCommitIdAndAfterCommitIdAreSameException(_inner) => _inner.fmt(f),
518 Self::ClientRequestTokenRequiredException(_inner) => _inner.fmt(f),
519 Self::CommentContentRequiredException(_inner) => _inner.fmt(f),
520 Self::CommentContentSizeLimitExceededException(_inner) => _inner.fmt(f),
521 Self::CommitDoesNotExistException(_inner) => _inner.fmt(f),
522 Self::CommitIdRequiredException(_inner) => _inner.fmt(f),
523 Self::EncryptionIntegrityChecksFailedException(_inner) => _inner.fmt(f),
524 Self::EncryptionKeyAccessDeniedException(_inner) => _inner.fmt(f),
525 Self::EncryptionKeyDisabledException(_inner) => _inner.fmt(f),
526 Self::EncryptionKeyNotFoundException(_inner) => _inner.fmt(f),
527 Self::EncryptionKeyUnavailableException(_inner) => _inner.fmt(f),
528 Self::IdempotencyParameterMismatchException(_inner) => _inner.fmt(f),
529 Self::InvalidClientRequestTokenException(_inner) => _inner.fmt(f),
530 Self::InvalidCommitIdException(_inner) => _inner.fmt(f),
531 Self::InvalidFileLocationException(_inner) => _inner.fmt(f),
532 Self::InvalidFilePositionException(_inner) => _inner.fmt(f),
533 Self::InvalidPathException(_inner) => _inner.fmt(f),
534 Self::InvalidRelativeFileVersionEnumException(_inner) => _inner.fmt(f),
535 Self::InvalidRepositoryNameException(_inner) => _inner.fmt(f),
536 Self::PathDoesNotExistException(_inner) => _inner.fmt(f),
537 Self::PathRequiredException(_inner) => _inner.fmt(f),
538 Self::RepositoryDoesNotExistException(_inner) => _inner.fmt(f),
539 Self::RepositoryNameRequiredException(_inner) => _inner.fmt(f),
540 Self::Unhandled(_inner) => {
541 if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
542 write!(f, "unhandled error ({code})")
543 } else {
544 f.write_str("unhandled error")
545 }
546 }
547 }
548 }
549}
550impl ::aws_smithy_types::retry::ProvideErrorKind for PostCommentForComparedCommitError {
551 fn code(&self) -> ::std::option::Option<&str> {
552 ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
553 }
554 fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
555 ::std::option::Option::None
556 }
557}
558impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for PostCommentForComparedCommitError {
559 fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
560 match self {
561 Self::BeforeCommitIdAndAfterCommitIdAreSameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
562 Self::ClientRequestTokenRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
563 Self::CommentContentRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
564 Self::CommentContentSizeLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
565 Self::CommitDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
566 Self::CommitIdRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
567 Self::EncryptionIntegrityChecksFailedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
568 Self::EncryptionKeyAccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
569 Self::EncryptionKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
570 Self::EncryptionKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
571 Self::EncryptionKeyUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
572 Self::IdempotencyParameterMismatchException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
573 Self::InvalidClientRequestTokenException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
574 Self::InvalidCommitIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
575 Self::InvalidFileLocationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
576 Self::InvalidFilePositionException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
577 Self::InvalidPathException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
578 Self::InvalidRelativeFileVersionEnumException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
579 Self::InvalidRepositoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
580 Self::PathDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
581 Self::PathRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
582 Self::RepositoryDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
583 Self::RepositoryNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
584 Self::Unhandled(_inner) => &_inner.meta,
585 }
586 }
587}
588impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for PostCommentForComparedCommitError {
589 fn create_unhandled_error(
590 source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
591 meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
592 ) -> Self {
593 Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
594 source,
595 meta: meta.unwrap_or_default(),
596 })
597 }
598}
599impl ::aws_types::request_id::RequestId for crate::operation::post_comment_for_compared_commit::PostCommentForComparedCommitError {
600 fn request_id(&self) -> Option<&str> {
601 self.meta().request_id()
602 }
603}
604
605pub use crate::operation::post_comment_for_compared_commit::_post_comment_for_compared_commit_input::PostCommentForComparedCommitInput;
606
607pub use crate::operation::post_comment_for_compared_commit::_post_comment_for_compared_commit_output::PostCommentForComparedCommitOutput;
608
609mod _post_comment_for_compared_commit_input;
610
611mod _post_comment_for_compared_commit_output;
612
613pub mod builders;