aws_sdk_codecommit/operation/
merge_pull_request_by_squash.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `MergePullRequestBySquash`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct MergePullRequestBySquash;
6impl MergePullRequestBySquash {
7    /// Creates a new `MergePullRequestBySquash`
8    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::merge_pull_request_by_squash::MergePullRequestBySquashInput,
14    ) -> ::std::result::Result<
15        crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashError,
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::merge_pull_request_by_squash::MergePullRequestBySquashError>()
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::merge_pull_request_by_squash::MergePullRequestBySquashOutput>()
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::merge_pull_request_by_squash::MergePullRequestBySquashInput,
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            "MergePullRequestBySquash",
57            input,
58            runtime_plugins,
59            stop_point,
60        )
61        // Create a parent span for the entire operation. Includes a random, internal-only,
62        // seven-digit ID for the operation orchestration so that it can be correlated in the logs.
63        .instrument(::tracing::debug_span!(
64            "CodeCommit.MergePullRequestBySquash",
65            "rpc.service" = "CodeCommit",
66            "rpc.method" = "MergePullRequestBySquash",
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_client_plugin(crate::auth_plugin::DefaultAuthOptionsPlugin::new(vec![
80            ::aws_runtime::auth::sigv4::SCHEME_ID,
81        ]));
82        if let ::std::option::Option::Some(config_override) = config_override {
83            for plugin in config_override.runtime_plugins.iter().cloned() {
84                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
85            }
86            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
87                config_override,
88                client_config.config.clone(),
89                &client_config.runtime_components,
90            ));
91        }
92        runtime_plugins
93    }
94}
95impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for MergePullRequestBySquash {
96    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
97        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("MergePullRequestBySquash");
98
99        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
100            MergePullRequestBySquashRequestSerializer,
101        ));
102        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
103            MergePullRequestBySquashResponseDeserializer,
104        ));
105
106        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
107            ::aws_smithy_runtime_api::client::auth::static_resolver::StaticAuthSchemeOptionResolverParams::new(),
108        ));
109
110        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
111            "MergePullRequestBySquash",
112            "CodeCommit",
113        ));
114        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
115        signing_options.double_uri_encode = true;
116        signing_options.content_sha256_header = false;
117        signing_options.normalize_uri_path = true;
118        signing_options.payload_override = None;
119
120        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
121            signing_options,
122            ..::std::default::Default::default()
123        });
124
125        ::std::option::Option::Some(cfg.freeze())
126    }
127
128    fn runtime_components(
129        &self,
130        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
131    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
132        #[allow(unused_mut)]
133        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("MergePullRequestBySquash")
134            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
135            .with_interceptor(MergePullRequestBySquashEndpointParamsInterceptor)
136            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
137                crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashError,
138            >::new())
139            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
140                crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashError,
141            >::new())
142            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
143                crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashError,
144            >::new());
145
146        ::std::borrow::Cow::Owned(rcb)
147    }
148}
149
150#[derive(Debug)]
151struct MergePullRequestBySquashResponseDeserializer;
152impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for MergePullRequestBySquashResponseDeserializer {
153    fn deserialize_nonstreaming(
154        &self,
155        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
156    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
157        let (success, status) = (response.status().is_success(), response.status().as_u16());
158        let headers = response.headers();
159        let body = response.body().bytes().expect("body loaded");
160        #[allow(unused_mut)]
161        let mut force_error = false;
162        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
163        let parse_result = if !success && status != 200 || force_error {
164            crate::protocol_serde::shape_merge_pull_request_by_squash::de_merge_pull_request_by_squash_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_merge_pull_request_by_squash::de_merge_pull_request_by_squash_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct MergePullRequestBySquashRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for MergePullRequestBySquashRequestSerializer {
174    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
175    fn serialize_input(
176        &self,
177        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
178        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
179    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
180        let input = input
181            .downcast::<crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashInput>()
182            .expect("correct type");
183        let _header_serialization_settings = _cfg
184            .load::<crate::serialization_settings::HeaderSerializationSettings>()
185            .cloned()
186            .unwrap_or_default();
187        let mut request_builder = {
188            fn uri_base(
189                _input: &crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashInput,
190                output: &mut ::std::string::String,
191            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
192                use ::std::fmt::Write as _;
193                ::std::write!(output, "/").expect("formatting should succeed");
194                ::std::result::Result::Ok(())
195            }
196            #[allow(clippy::unnecessary_wraps)]
197            fn update_http_builder(
198                input: &crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashInput,
199                builder: ::http::request::Builder,
200            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
201                let mut uri = ::std::string::String::new();
202                uri_base(input, &mut uri)?;
203                ::std::result::Result::Ok(builder.method("POST").uri(uri))
204            }
205            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
206            builder = _header_serialization_settings.set_default_header(builder, ::http::header::CONTENT_TYPE, "application/x-amz-json-1.1");
207            builder = _header_serialization_settings.set_default_header(
208                builder,
209                ::http::header::HeaderName::from_static("x-amz-target"),
210                "CodeCommit_20150413.MergePullRequestBySquash",
211            );
212            builder
213        };
214        let body = ::aws_smithy_types::body::SdkBody::from(
215            crate::protocol_serde::shape_merge_pull_request_by_squash::ser_merge_pull_request_by_squash_input(&input)?,
216        );
217        if let Some(content_length) = body.content_length() {
218            let content_length = content_length.to_string();
219            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http::header::CONTENT_LENGTH, &content_length);
220        }
221        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
222    }
223}
224#[derive(Debug)]
225struct MergePullRequestBySquashEndpointParamsInterceptor;
226
227impl ::aws_smithy_runtime_api::client::interceptors::Intercept for MergePullRequestBySquashEndpointParamsInterceptor {
228    fn name(&self) -> &'static str {
229        "MergePullRequestBySquashEndpointParamsInterceptor"
230    }
231
232    fn read_before_execution(
233        &self,
234        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
235            '_,
236            ::aws_smithy_runtime_api::client::interceptors::context::Input,
237            ::aws_smithy_runtime_api::client::interceptors::context::Output,
238            ::aws_smithy_runtime_api::client::interceptors::context::Error,
239        >,
240        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
241    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
242        let _input = context
243            .input()
244            .downcast_ref::<MergePullRequestBySquashInput>()
245            .ok_or("failed to downcast to MergePullRequestBySquashInput")?;
246
247        let params = crate::config::endpoint::Params::builder()
248            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
249            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
250            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
251            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
252            .build()
253            .map_err(|err| {
254                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
255            })?;
256        cfg.interceptor_state()
257            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
258        ::std::result::Result::Ok(())
259    }
260}
261
262// The get_* functions below are generated from JMESPath expressions in the
263// operationContextParams trait. They target the operation's input shape.
264
265/// Error type for the `MergePullRequestBySquashError` operation.
266#[non_exhaustive]
267#[derive(::std::fmt::Debug)]
268pub enum MergePullRequestBySquashError {
269    /// <p>The commit message is too long. Provide a shorter string.</p>
270    CommitMessageLengthExceededException(crate::types::error::CommitMessageLengthExceededException),
271    /// <p>The merge cannot be completed because the target branch has been modified. Another user might have modified the target branch while the merge was in progress. Wait a few minutes, and then try again.</p>
272    ConcurrentReferenceUpdateException(crate::types::error::ConcurrentReferenceUpdateException),
273    /// <p>An encryption integrity check failed.</p>
274    EncryptionIntegrityChecksFailedException(crate::types::error::EncryptionIntegrityChecksFailedException),
275    /// <p>An encryption key could not be accessed.</p>
276    EncryptionKeyAccessDeniedException(crate::types::error::EncryptionKeyAccessDeniedException),
277    /// <p>The encryption key is disabled.</p>
278    EncryptionKeyDisabledException(crate::types::error::EncryptionKeyDisabledException),
279    /// <p>No encryption key was found.</p>
280    EncryptionKeyNotFoundException(crate::types::error::EncryptionKeyNotFoundException),
281    /// <p>The encryption key is not available.</p>
282    EncryptionKeyUnavailableException(crate::types::error::EncryptionKeyUnavailableException),
283    /// <p>The file cannot be added because it is too large. The maximum file size is 6 MB, and the combined file content change size is 7 MB. Consider making these changes using a Git client.</p>
284    FileContentSizeLimitExceededException(crate::types::error::FileContentSizeLimitExceededException),
285    /// <p>The commit cannot be created because at least one of the overall changes in the commit results in a folder whose contents exceed the limit of 6 MB. Either reduce the number and size of your changes, or split the changes across multiple folders.</p>
286    FolderContentSizeLimitExceededException(crate::types::error::FolderContentSizeLimitExceededException),
287    /// <p>The specified commit ID is not valid.</p>
288    InvalidCommitIdException(crate::types::error::InvalidCommitIdException),
289    /// <p>The specified conflict detail level is not valid.</p>
290    InvalidConflictDetailLevelException(crate::types::error::InvalidConflictDetailLevelException),
291    /// <p>The specified conflict resolution list is not valid.</p>
292    InvalidConflictResolutionException(crate::types::error::InvalidConflictResolutionException),
293    /// <p>The specified conflict resolution strategy is not valid.</p>
294    InvalidConflictResolutionStrategyException(crate::types::error::InvalidConflictResolutionStrategyException),
295    /// <p>The specified email address either contains one or more characters that are not allowed, or it exceeds the maximum number of characters allowed for an email address.</p>
296    InvalidEmailException(crate::types::error::InvalidEmailException),
297    /// <p>The specified file mode permission is not valid. For a list of valid file mode permissions, see <code>PutFile</code>.</p>
298    InvalidFileModeException(crate::types::error::InvalidFileModeException),
299    /// <p>The specified path is not valid.</p>
300    InvalidPathException(crate::types::error::InvalidPathException),
301    /// <p>The pull request ID is not valid. Make sure that you have provided the full ID and that the pull request is in the specified repository, and then try again.</p>
302    InvalidPullRequestIdException(crate::types::error::InvalidPullRequestIdException),
303    /// <p>Automerge was specified for resolving the conflict, but the replacement type is not valid or content is missing.</p>
304    InvalidReplacementContentException(crate::types::error::InvalidReplacementContentException),
305    /// <p>Automerge was specified for resolving the conflict, but the specified replacement type is not valid.</p>
306    InvalidReplacementTypeException(crate::types::error::InvalidReplacementTypeException),
307    /// <p>A specified repository name is not valid.</p><note>
308    /// <p>This exception occurs only when a specified repository name is not valid. Other exceptions occur when a required repository parameter is missing, or when a specified repository does not exist.</p>
309    /// </note>
310    InvalidRepositoryNameException(crate::types::error::InvalidRepositoryNameException),
311    /// <p>The pull request cannot be merged automatically into the destination branch. You must manually merge the branches and resolve any conflicts.</p>
312    ManualMergeRequiredException(crate::types::error::ManualMergeRequiredException),
313    /// <p>The number of allowed conflict resolution entries was exceeded.</p>
314    MaximumConflictResolutionEntriesExceededException(crate::types::error::MaximumConflictResolutionEntriesExceededException),
315    /// <p>The number of files to load exceeds the allowed limit.</p>
316    MaximumFileContentToLoadExceededException(crate::types::error::MaximumFileContentToLoadExceededException),
317    /// <p>The number of items to compare between the source or destination branches and the merge base has exceeded the maximum allowed.</p>
318    MaximumItemsToCompareExceededException(crate::types::error::MaximumItemsToCompareExceededException),
319    /// <p>More than one conflict resolution entries exists for the conflict. A conflict can have only one conflict resolution entry.</p>
320    MultipleConflictResolutionEntriesException(crate::types::error::MultipleConflictResolutionEntriesException),
321    /// <p>The user name is not valid because it has exceeded the character limit for author names.</p>
322    NameLengthExceededException(crate::types::error::NameLengthExceededException),
323    /// <p>The folderPath for a location cannot be null.</p>
324    PathRequiredException(crate::types::error::PathRequiredException),
325    /// <p>The pull request status cannot be updated because it is already closed.</p>
326    PullRequestAlreadyClosedException(crate::types::error::PullRequestAlreadyClosedException),
327    /// <p>The pull request cannot be merged because one or more approval rules applied to the pull request have conditions that have not been met.</p>
328    PullRequestApprovalRulesNotSatisfiedException(crate::types::error::PullRequestApprovalRulesNotSatisfiedException),
329    /// <p>The pull request ID could not be found. Make sure that you have specified the correct repository name and pull request ID, and then try again.</p>
330    PullRequestDoesNotExistException(crate::types::error::PullRequestDoesNotExistException),
331    /// <p>A pull request ID is required, but none was provided.</p>
332    PullRequestIdRequiredException(crate::types::error::PullRequestIdRequiredException),
333    /// <p>USE_NEW_CONTENT was specified, but no replacement content has been provided.</p>
334    ReplacementContentRequiredException(crate::types::error::ReplacementContentRequiredException),
335    /// <p>A replacement type is required.</p>
336    ReplacementTypeRequiredException(crate::types::error::ReplacementTypeRequiredException),
337    /// <p>The specified repository does not exist.</p>
338    RepositoryDoesNotExistException(crate::types::error::RepositoryDoesNotExistException),
339    /// <p>A repository name is required, but was not specified.</p>
340    RepositoryNameRequiredException(crate::types::error::RepositoryNameRequiredException),
341    /// <p>The repository does not contain any pull requests with that pull request ID. Use GetPullRequest to verify the correct repository name for the pull request ID.</p>
342    RepositoryNotAssociatedWithPullRequestException(crate::types::error::RepositoryNotAssociatedWithPullRequestException),
343    /// <p>The tip of the source branch in the destination repository does not match the tip of the source branch specified in your request. The pull request might have been updated. Make sure that you have the latest changes.</p>
344    TipOfSourceReferenceIsDifferentException(crate::types::error::TipOfSourceReferenceIsDifferentException),
345    /// <p>The divergence between the tips of the provided commit specifiers is too great to determine whether there might be any merge conflicts. Locally compare the specifiers using <code>git diff</code> or a diff tool.</p>
346    TipsDivergenceExceededException(crate::types::error::TipsDivergenceExceededException),
347    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
348    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
349    variable wildcard pattern and check `.code()`:
350     \
351    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
352     \
353    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-MergePullRequestBySquashError) for what information is available for the error.")]
354    Unhandled(crate::error::sealed_unhandled::Unhandled),
355}
356impl MergePullRequestBySquashError {
357    /// Creates the `MergePullRequestBySquashError::Unhandled` variant from any error type.
358    pub fn unhandled(
359        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
360    ) -> Self {
361        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
362            source: err.into(),
363            meta: ::std::default::Default::default(),
364        })
365    }
366
367    /// Creates the `MergePullRequestBySquashError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
368    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
369        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
370            source: err.clone().into(),
371            meta: err,
372        })
373    }
374    ///
375    /// Returns error metadata, which includes the error code, message,
376    /// request ID, and potentially additional information.
377    ///
378    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
379        match self {
380            Self::CommitMessageLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
381            Self::ConcurrentReferenceUpdateException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
382            Self::EncryptionIntegrityChecksFailedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
383            Self::EncryptionKeyAccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
384            Self::EncryptionKeyDisabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
385            Self::EncryptionKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
386            Self::EncryptionKeyUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
387            Self::FileContentSizeLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
388            Self::FolderContentSizeLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
389            Self::InvalidCommitIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
390            Self::InvalidConflictDetailLevelException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
391            Self::InvalidConflictResolutionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
392            Self::InvalidConflictResolutionStrategyException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
393            Self::InvalidEmailException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
394            Self::InvalidFileModeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
395            Self::InvalidPathException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
396            Self::InvalidPullRequestIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
397            Self::InvalidReplacementContentException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
398            Self::InvalidReplacementTypeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
399            Self::InvalidRepositoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
400            Self::ManualMergeRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
401            Self::MaximumConflictResolutionEntriesExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
402            Self::MaximumFileContentToLoadExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
403            Self::MaximumItemsToCompareExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
404            Self::MultipleConflictResolutionEntriesException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
405            Self::NameLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
406            Self::PathRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
407            Self::PullRequestAlreadyClosedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
408            Self::PullRequestApprovalRulesNotSatisfiedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
409            Self::PullRequestDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
410            Self::PullRequestIdRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
411            Self::ReplacementContentRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
412            Self::ReplacementTypeRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
413            Self::RepositoryDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
414            Self::RepositoryNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
415            Self::RepositoryNotAssociatedWithPullRequestException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
416            Self::TipOfSourceReferenceIsDifferentException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
417            Self::TipsDivergenceExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
418            Self::Unhandled(e) => &e.meta,
419        }
420    }
421    /// Returns `true` if the error kind is `MergePullRequestBySquashError::CommitMessageLengthExceededException`.
422    pub fn is_commit_message_length_exceeded_exception(&self) -> bool {
423        matches!(self, Self::CommitMessageLengthExceededException(_))
424    }
425    /// Returns `true` if the error kind is `MergePullRequestBySquashError::ConcurrentReferenceUpdateException`.
426    pub fn is_concurrent_reference_update_exception(&self) -> bool {
427        matches!(self, Self::ConcurrentReferenceUpdateException(_))
428    }
429    /// Returns `true` if the error kind is `MergePullRequestBySquashError::EncryptionIntegrityChecksFailedException`.
430    pub fn is_encryption_integrity_checks_failed_exception(&self) -> bool {
431        matches!(self, Self::EncryptionIntegrityChecksFailedException(_))
432    }
433    /// Returns `true` if the error kind is `MergePullRequestBySquashError::EncryptionKeyAccessDeniedException`.
434    pub fn is_encryption_key_access_denied_exception(&self) -> bool {
435        matches!(self, Self::EncryptionKeyAccessDeniedException(_))
436    }
437    /// Returns `true` if the error kind is `MergePullRequestBySquashError::EncryptionKeyDisabledException`.
438    pub fn is_encryption_key_disabled_exception(&self) -> bool {
439        matches!(self, Self::EncryptionKeyDisabledException(_))
440    }
441    /// Returns `true` if the error kind is `MergePullRequestBySquashError::EncryptionKeyNotFoundException`.
442    pub fn is_encryption_key_not_found_exception(&self) -> bool {
443        matches!(self, Self::EncryptionKeyNotFoundException(_))
444    }
445    /// Returns `true` if the error kind is `MergePullRequestBySquashError::EncryptionKeyUnavailableException`.
446    pub fn is_encryption_key_unavailable_exception(&self) -> bool {
447        matches!(self, Self::EncryptionKeyUnavailableException(_))
448    }
449    /// Returns `true` if the error kind is `MergePullRequestBySquashError::FileContentSizeLimitExceededException`.
450    pub fn is_file_content_size_limit_exceeded_exception(&self) -> bool {
451        matches!(self, Self::FileContentSizeLimitExceededException(_))
452    }
453    /// Returns `true` if the error kind is `MergePullRequestBySquashError::FolderContentSizeLimitExceededException`.
454    pub fn is_folder_content_size_limit_exceeded_exception(&self) -> bool {
455        matches!(self, Self::FolderContentSizeLimitExceededException(_))
456    }
457    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidCommitIdException`.
458    pub fn is_invalid_commit_id_exception(&self) -> bool {
459        matches!(self, Self::InvalidCommitIdException(_))
460    }
461    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidConflictDetailLevelException`.
462    pub fn is_invalid_conflict_detail_level_exception(&self) -> bool {
463        matches!(self, Self::InvalidConflictDetailLevelException(_))
464    }
465    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidConflictResolutionException`.
466    pub fn is_invalid_conflict_resolution_exception(&self) -> bool {
467        matches!(self, Self::InvalidConflictResolutionException(_))
468    }
469    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidConflictResolutionStrategyException`.
470    pub fn is_invalid_conflict_resolution_strategy_exception(&self) -> bool {
471        matches!(self, Self::InvalidConflictResolutionStrategyException(_))
472    }
473    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidEmailException`.
474    pub fn is_invalid_email_exception(&self) -> bool {
475        matches!(self, Self::InvalidEmailException(_))
476    }
477    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidFileModeException`.
478    pub fn is_invalid_file_mode_exception(&self) -> bool {
479        matches!(self, Self::InvalidFileModeException(_))
480    }
481    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidPathException`.
482    pub fn is_invalid_path_exception(&self) -> bool {
483        matches!(self, Self::InvalidPathException(_))
484    }
485    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidPullRequestIdException`.
486    pub fn is_invalid_pull_request_id_exception(&self) -> bool {
487        matches!(self, Self::InvalidPullRequestIdException(_))
488    }
489    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidReplacementContentException`.
490    pub fn is_invalid_replacement_content_exception(&self) -> bool {
491        matches!(self, Self::InvalidReplacementContentException(_))
492    }
493    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidReplacementTypeException`.
494    pub fn is_invalid_replacement_type_exception(&self) -> bool {
495        matches!(self, Self::InvalidReplacementTypeException(_))
496    }
497    /// Returns `true` if the error kind is `MergePullRequestBySquashError::InvalidRepositoryNameException`.
498    pub fn is_invalid_repository_name_exception(&self) -> bool {
499        matches!(self, Self::InvalidRepositoryNameException(_))
500    }
501    /// Returns `true` if the error kind is `MergePullRequestBySquashError::ManualMergeRequiredException`.
502    pub fn is_manual_merge_required_exception(&self) -> bool {
503        matches!(self, Self::ManualMergeRequiredException(_))
504    }
505    /// Returns `true` if the error kind is `MergePullRequestBySquashError::MaximumConflictResolutionEntriesExceededException`.
506    pub fn is_maximum_conflict_resolution_entries_exceeded_exception(&self) -> bool {
507        matches!(self, Self::MaximumConflictResolutionEntriesExceededException(_))
508    }
509    /// Returns `true` if the error kind is `MergePullRequestBySquashError::MaximumFileContentToLoadExceededException`.
510    pub fn is_maximum_file_content_to_load_exceeded_exception(&self) -> bool {
511        matches!(self, Self::MaximumFileContentToLoadExceededException(_))
512    }
513    /// Returns `true` if the error kind is `MergePullRequestBySquashError::MaximumItemsToCompareExceededException`.
514    pub fn is_maximum_items_to_compare_exceeded_exception(&self) -> bool {
515        matches!(self, Self::MaximumItemsToCompareExceededException(_))
516    }
517    /// Returns `true` if the error kind is `MergePullRequestBySquashError::MultipleConflictResolutionEntriesException`.
518    pub fn is_multiple_conflict_resolution_entries_exception(&self) -> bool {
519        matches!(self, Self::MultipleConflictResolutionEntriesException(_))
520    }
521    /// Returns `true` if the error kind is `MergePullRequestBySquashError::NameLengthExceededException`.
522    pub fn is_name_length_exceeded_exception(&self) -> bool {
523        matches!(self, Self::NameLengthExceededException(_))
524    }
525    /// Returns `true` if the error kind is `MergePullRequestBySquashError::PathRequiredException`.
526    pub fn is_path_required_exception(&self) -> bool {
527        matches!(self, Self::PathRequiredException(_))
528    }
529    /// Returns `true` if the error kind is `MergePullRequestBySquashError::PullRequestAlreadyClosedException`.
530    pub fn is_pull_request_already_closed_exception(&self) -> bool {
531        matches!(self, Self::PullRequestAlreadyClosedException(_))
532    }
533    /// Returns `true` if the error kind is `MergePullRequestBySquashError::PullRequestApprovalRulesNotSatisfiedException`.
534    pub fn is_pull_request_approval_rules_not_satisfied_exception(&self) -> bool {
535        matches!(self, Self::PullRequestApprovalRulesNotSatisfiedException(_))
536    }
537    /// Returns `true` if the error kind is `MergePullRequestBySquashError::PullRequestDoesNotExistException`.
538    pub fn is_pull_request_does_not_exist_exception(&self) -> bool {
539        matches!(self, Self::PullRequestDoesNotExistException(_))
540    }
541    /// Returns `true` if the error kind is `MergePullRequestBySquashError::PullRequestIdRequiredException`.
542    pub fn is_pull_request_id_required_exception(&self) -> bool {
543        matches!(self, Self::PullRequestIdRequiredException(_))
544    }
545    /// Returns `true` if the error kind is `MergePullRequestBySquashError::ReplacementContentRequiredException`.
546    pub fn is_replacement_content_required_exception(&self) -> bool {
547        matches!(self, Self::ReplacementContentRequiredException(_))
548    }
549    /// Returns `true` if the error kind is `MergePullRequestBySquashError::ReplacementTypeRequiredException`.
550    pub fn is_replacement_type_required_exception(&self) -> bool {
551        matches!(self, Self::ReplacementTypeRequiredException(_))
552    }
553    /// Returns `true` if the error kind is `MergePullRequestBySquashError::RepositoryDoesNotExistException`.
554    pub fn is_repository_does_not_exist_exception(&self) -> bool {
555        matches!(self, Self::RepositoryDoesNotExistException(_))
556    }
557    /// Returns `true` if the error kind is `MergePullRequestBySquashError::RepositoryNameRequiredException`.
558    pub fn is_repository_name_required_exception(&self) -> bool {
559        matches!(self, Self::RepositoryNameRequiredException(_))
560    }
561    /// Returns `true` if the error kind is `MergePullRequestBySquashError::RepositoryNotAssociatedWithPullRequestException`.
562    pub fn is_repository_not_associated_with_pull_request_exception(&self) -> bool {
563        matches!(self, Self::RepositoryNotAssociatedWithPullRequestException(_))
564    }
565    /// Returns `true` if the error kind is `MergePullRequestBySquashError::TipOfSourceReferenceIsDifferentException`.
566    pub fn is_tip_of_source_reference_is_different_exception(&self) -> bool {
567        matches!(self, Self::TipOfSourceReferenceIsDifferentException(_))
568    }
569    /// Returns `true` if the error kind is `MergePullRequestBySquashError::TipsDivergenceExceededException`.
570    pub fn is_tips_divergence_exceeded_exception(&self) -> bool {
571        matches!(self, Self::TipsDivergenceExceededException(_))
572    }
573}
574impl ::std::error::Error for MergePullRequestBySquashError {
575    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
576        match self {
577            Self::CommitMessageLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
578            Self::ConcurrentReferenceUpdateException(_inner) => ::std::option::Option::Some(_inner),
579            Self::EncryptionIntegrityChecksFailedException(_inner) => ::std::option::Option::Some(_inner),
580            Self::EncryptionKeyAccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
581            Self::EncryptionKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
582            Self::EncryptionKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
583            Self::EncryptionKeyUnavailableException(_inner) => ::std::option::Option::Some(_inner),
584            Self::FileContentSizeLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
585            Self::FolderContentSizeLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
586            Self::InvalidCommitIdException(_inner) => ::std::option::Option::Some(_inner),
587            Self::InvalidConflictDetailLevelException(_inner) => ::std::option::Option::Some(_inner),
588            Self::InvalidConflictResolutionException(_inner) => ::std::option::Option::Some(_inner),
589            Self::InvalidConflictResolutionStrategyException(_inner) => ::std::option::Option::Some(_inner),
590            Self::InvalidEmailException(_inner) => ::std::option::Option::Some(_inner),
591            Self::InvalidFileModeException(_inner) => ::std::option::Option::Some(_inner),
592            Self::InvalidPathException(_inner) => ::std::option::Option::Some(_inner),
593            Self::InvalidPullRequestIdException(_inner) => ::std::option::Option::Some(_inner),
594            Self::InvalidReplacementContentException(_inner) => ::std::option::Option::Some(_inner),
595            Self::InvalidReplacementTypeException(_inner) => ::std::option::Option::Some(_inner),
596            Self::InvalidRepositoryNameException(_inner) => ::std::option::Option::Some(_inner),
597            Self::ManualMergeRequiredException(_inner) => ::std::option::Option::Some(_inner),
598            Self::MaximumConflictResolutionEntriesExceededException(_inner) => ::std::option::Option::Some(_inner),
599            Self::MaximumFileContentToLoadExceededException(_inner) => ::std::option::Option::Some(_inner),
600            Self::MaximumItemsToCompareExceededException(_inner) => ::std::option::Option::Some(_inner),
601            Self::MultipleConflictResolutionEntriesException(_inner) => ::std::option::Option::Some(_inner),
602            Self::NameLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
603            Self::PathRequiredException(_inner) => ::std::option::Option::Some(_inner),
604            Self::PullRequestAlreadyClosedException(_inner) => ::std::option::Option::Some(_inner),
605            Self::PullRequestApprovalRulesNotSatisfiedException(_inner) => ::std::option::Option::Some(_inner),
606            Self::PullRequestDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
607            Self::PullRequestIdRequiredException(_inner) => ::std::option::Option::Some(_inner),
608            Self::ReplacementContentRequiredException(_inner) => ::std::option::Option::Some(_inner),
609            Self::ReplacementTypeRequiredException(_inner) => ::std::option::Option::Some(_inner),
610            Self::RepositoryDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
611            Self::RepositoryNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
612            Self::RepositoryNotAssociatedWithPullRequestException(_inner) => ::std::option::Option::Some(_inner),
613            Self::TipOfSourceReferenceIsDifferentException(_inner) => ::std::option::Option::Some(_inner),
614            Self::TipsDivergenceExceededException(_inner) => ::std::option::Option::Some(_inner),
615            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
616        }
617    }
618}
619impl ::std::fmt::Display for MergePullRequestBySquashError {
620    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
621        match self {
622            Self::CommitMessageLengthExceededException(_inner) => _inner.fmt(f),
623            Self::ConcurrentReferenceUpdateException(_inner) => _inner.fmt(f),
624            Self::EncryptionIntegrityChecksFailedException(_inner) => _inner.fmt(f),
625            Self::EncryptionKeyAccessDeniedException(_inner) => _inner.fmt(f),
626            Self::EncryptionKeyDisabledException(_inner) => _inner.fmt(f),
627            Self::EncryptionKeyNotFoundException(_inner) => _inner.fmt(f),
628            Self::EncryptionKeyUnavailableException(_inner) => _inner.fmt(f),
629            Self::FileContentSizeLimitExceededException(_inner) => _inner.fmt(f),
630            Self::FolderContentSizeLimitExceededException(_inner) => _inner.fmt(f),
631            Self::InvalidCommitIdException(_inner) => _inner.fmt(f),
632            Self::InvalidConflictDetailLevelException(_inner) => _inner.fmt(f),
633            Self::InvalidConflictResolutionException(_inner) => _inner.fmt(f),
634            Self::InvalidConflictResolutionStrategyException(_inner) => _inner.fmt(f),
635            Self::InvalidEmailException(_inner) => _inner.fmt(f),
636            Self::InvalidFileModeException(_inner) => _inner.fmt(f),
637            Self::InvalidPathException(_inner) => _inner.fmt(f),
638            Self::InvalidPullRequestIdException(_inner) => _inner.fmt(f),
639            Self::InvalidReplacementContentException(_inner) => _inner.fmt(f),
640            Self::InvalidReplacementTypeException(_inner) => _inner.fmt(f),
641            Self::InvalidRepositoryNameException(_inner) => _inner.fmt(f),
642            Self::ManualMergeRequiredException(_inner) => _inner.fmt(f),
643            Self::MaximumConflictResolutionEntriesExceededException(_inner) => _inner.fmt(f),
644            Self::MaximumFileContentToLoadExceededException(_inner) => _inner.fmt(f),
645            Self::MaximumItemsToCompareExceededException(_inner) => _inner.fmt(f),
646            Self::MultipleConflictResolutionEntriesException(_inner) => _inner.fmt(f),
647            Self::NameLengthExceededException(_inner) => _inner.fmt(f),
648            Self::PathRequiredException(_inner) => _inner.fmt(f),
649            Self::PullRequestAlreadyClosedException(_inner) => _inner.fmt(f),
650            Self::PullRequestApprovalRulesNotSatisfiedException(_inner) => _inner.fmt(f),
651            Self::PullRequestDoesNotExistException(_inner) => _inner.fmt(f),
652            Self::PullRequestIdRequiredException(_inner) => _inner.fmt(f),
653            Self::ReplacementContentRequiredException(_inner) => _inner.fmt(f),
654            Self::ReplacementTypeRequiredException(_inner) => _inner.fmt(f),
655            Self::RepositoryDoesNotExistException(_inner) => _inner.fmt(f),
656            Self::RepositoryNameRequiredException(_inner) => _inner.fmt(f),
657            Self::RepositoryNotAssociatedWithPullRequestException(_inner) => _inner.fmt(f),
658            Self::TipOfSourceReferenceIsDifferentException(_inner) => _inner.fmt(f),
659            Self::TipsDivergenceExceededException(_inner) => _inner.fmt(f),
660            Self::Unhandled(_inner) => {
661                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
662                    write!(f, "unhandled error ({code})")
663                } else {
664                    f.write_str("unhandled error")
665                }
666            }
667        }
668    }
669}
670impl ::aws_smithy_types::retry::ProvideErrorKind for MergePullRequestBySquashError {
671    fn code(&self) -> ::std::option::Option<&str> {
672        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
673    }
674    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
675        ::std::option::Option::None
676    }
677}
678impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for MergePullRequestBySquashError {
679    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
680        match self {
681            Self::CommitMessageLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
682            Self::ConcurrentReferenceUpdateException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
683            Self::EncryptionIntegrityChecksFailedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
684            Self::EncryptionKeyAccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
685            Self::EncryptionKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
686            Self::EncryptionKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
687            Self::EncryptionKeyUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
688            Self::FileContentSizeLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
689            Self::FolderContentSizeLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
690            Self::InvalidCommitIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
691            Self::InvalidConflictDetailLevelException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
692            Self::InvalidConflictResolutionException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
693            Self::InvalidConflictResolutionStrategyException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
694            Self::InvalidEmailException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
695            Self::InvalidFileModeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
696            Self::InvalidPathException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
697            Self::InvalidPullRequestIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
698            Self::InvalidReplacementContentException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
699            Self::InvalidReplacementTypeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
700            Self::InvalidRepositoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
701            Self::ManualMergeRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
702            Self::MaximumConflictResolutionEntriesExceededException(_inner) => {
703                ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner)
704            }
705            Self::MaximumFileContentToLoadExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
706            Self::MaximumItemsToCompareExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
707            Self::MultipleConflictResolutionEntriesException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
708            Self::NameLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
709            Self::PathRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
710            Self::PullRequestAlreadyClosedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
711            Self::PullRequestApprovalRulesNotSatisfiedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
712            Self::PullRequestDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
713            Self::PullRequestIdRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
714            Self::ReplacementContentRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
715            Self::ReplacementTypeRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
716            Self::RepositoryDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
717            Self::RepositoryNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
718            Self::RepositoryNotAssociatedWithPullRequestException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
719            Self::TipOfSourceReferenceIsDifferentException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
720            Self::TipsDivergenceExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
721            Self::Unhandled(_inner) => &_inner.meta,
722        }
723    }
724}
725impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for MergePullRequestBySquashError {
726    fn create_unhandled_error(
727        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
728        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
729    ) -> Self {
730        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
731            source,
732            meta: meta.unwrap_or_default(),
733        })
734    }
735}
736impl ::aws_types::request_id::RequestId for crate::operation::merge_pull_request_by_squash::MergePullRequestBySquashError {
737    fn request_id(&self) -> Option<&str> {
738        self.meta().request_id()
739    }
740}
741
742pub use crate::operation::merge_pull_request_by_squash::_merge_pull_request_by_squash_output::MergePullRequestBySquashOutput;
743
744pub use crate::operation::merge_pull_request_by_squash::_merge_pull_request_by_squash_input::MergePullRequestBySquashInput;
745
746mod _merge_pull_request_by_squash_input;
747
748mod _merge_pull_request_by_squash_output;
749
750/// Builders
751pub mod builders;