Skip to main content

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