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