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