Skip to main content

aws_sdk_codecommit/operation/
create_commit.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `CreateCommit`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct CreateCommit;
6impl CreateCommit {
7    /// Creates a new `CreateCommit`
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::create_commit::CreateCommitInput,
14    ) -> ::std::result::Result<
15        crate::operation::create_commit::CreateCommitOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::create_commit::CreateCommitError,
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::create_commit::CreateCommitError>()
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::create_commit::CreateCommitOutput>()
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::create_commit::CreateCommitInput,
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("CodeCommit", "CreateCommit", input, runtime_plugins, stop_point)
55            // Create a parent span for the entire operation. Includes a random, internal-only,
56            // seven-digit ID for the operation orchestration so that it can be correlated in the logs.
57            .instrument(::tracing::debug_span!(
58                "CodeCommit.CreateCommit",
59                "rpc.service" = "CodeCommit",
60                "rpc.method" = "CreateCommit",
61                "sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
62                "rpc.system" = "aws-api",
63            ))
64            .await
65    }
66
67    pub(crate) fn operation_runtime_plugins(
68        client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
69        client_config: &crate::config::Config,
70        config_override: ::std::option::Option<crate::config::Builder>,
71    ) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
72        let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
73
74        if let ::std::option::Option::Some(config_override) = config_override {
75            for plugin in config_override.runtime_plugins.iter().cloned() {
76                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
77            }
78            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
79                config_override,
80                client_config.config.clone(),
81                &client_config.runtime_components,
82            ));
83        }
84        runtime_plugins
85    }
86}
87impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for CreateCommit {
88    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
89        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateCommit");
90
91        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
92            CreateCommitRequestSerializer,
93        ));
94        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
95            CreateCommitResponseDeserializer,
96        ));
97
98        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
99            crate::config::auth::Params::builder()
100                .operation_name("CreateCommit")
101                .build()
102                .expect("required fields set"),
103        ));
104
105        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
106            "CreateCommit",
107            "CodeCommit",
108        ));
109        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
110        signing_options.double_uri_encode = true;
111        signing_options.content_sha256_header = false;
112        signing_options.normalize_uri_path = true;
113        signing_options.payload_override = None;
114
115        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
116            signing_options,
117            ..::std::default::Default::default()
118        });
119
120        ::std::option::Option::Some(cfg.freeze())
121    }
122
123    fn runtime_components(
124        &self,
125        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
126    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
127        #[allow(unused_mut)]
128        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("CreateCommit")
129            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
130                ::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
131            ))
132            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
133                CreateCommitEndpointParamsInterceptor,
134            ))
135            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
136                crate::operation::create_commit::CreateCommitError,
137            >::new())
138            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
139                crate::operation::create_commit::CreateCommitError,
140            >::new())
141            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
142                crate::operation::create_commit::CreateCommitError,
143            >::new());
144
145        ::std::borrow::Cow::Owned(rcb)
146    }
147}
148
149#[derive(Debug)]
150struct CreateCommitResponseDeserializer;
151impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateCommitResponseDeserializer {
152    fn deserialize_nonstreaming_with_config(
153        &self,
154        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
155        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
156    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
157        let (success, status) = (response.status().is_success(), response.status().as_u16());
158        let headers = response.headers();
159        let body = response.body().bytes().expect("body loaded");
160        #[allow(unused_mut)]
161        let mut force_error = false;
162        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
163        let parse_result = if !success && status != 200 || force_error {
164            crate::protocol_serde::shape_create_commit::de_create_commit_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_create_commit::de_create_commit_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct CreateCommitRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateCommitRequestSerializer {
174    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
175    fn serialize_input(
176        &self,
177        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
178        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
179    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
180        let input = input
181            .downcast::<crate::operation::create_commit::CreateCommitInput>()
182            .expect("correct type");
183        let _header_serialization_settings = _cfg
184            .load::<crate::serialization_settings::HeaderSerializationSettings>()
185            .cloned()
186            .unwrap_or_default();
187        let mut request_builder = {
188            #[allow(clippy::uninlined_format_args)]
189            fn uri_base(
190                _input: &crate::operation::create_commit::CreateCommitInput,
191                output: &mut ::std::string::String,
192            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
193                use ::std::fmt::Write as _;
194                ::std::write!(output, "/").expect("formatting should succeed");
195                ::std::result::Result::Ok(())
196            }
197            #[allow(clippy::unnecessary_wraps)]
198            fn update_http_builder(
199                input: &crate::operation::create_commit::CreateCommitInput,
200                builder: ::http_1x::request::Builder,
201            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
202                let mut uri = ::std::string::String::new();
203                uri_base(input, &mut uri)?;
204                ::std::result::Result::Ok(builder.method("POST").uri(uri))
205            }
206            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
207            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
208            builder = _header_serialization_settings.set_default_header(
209                builder,
210                ::http_1x::header::HeaderName::from_static("x-amz-target"),
211                "CodeCommit_20150413.CreateCommit",
212            );
213            builder
214        };
215        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_create_commit::ser_create_commit_input(&input)?);
216        if let Some(content_length) = body.content_length() {
217            let content_length = content_length.to_string();
218            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
219        }
220        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
221    }
222}
223#[derive(Debug)]
224struct CreateCommitEndpointParamsInterceptor;
225
226#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
227impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateCommitEndpointParamsInterceptor {
228    fn name(&self) -> &'static str {
229        "CreateCommitEndpointParamsInterceptor"
230    }
231
232    fn read_before_execution(
233        &self,
234        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
235            '_,
236            ::aws_smithy_runtime_api::client::interceptors::context::Input,
237            ::aws_smithy_runtime_api::client::interceptors::context::Output,
238            ::aws_smithy_runtime_api::client::interceptors::context::Error,
239        >,
240        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
241    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
242        let _input = context
243            .input()
244            .downcast_ref::<CreateCommitInput>()
245            .ok_or("failed to downcast to CreateCommitInput")?;
246
247        let params = crate::config::endpoint::Params::builder()
248            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
249            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
250            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
251            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
252            .build()
253            .map_err(|err| {
254                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
255            })?;
256        cfg.interceptor_state()
257            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
258        ::std::result::Result::Ok(())
259    }
260}
261
262// The get_* functions below are generated from JMESPath expressions in the
263// operationContextParams trait. They target the operation's input shape.
264
265/// Error type for the `CreateCommitError` operation.
266#[non_exhaustive]
267#[derive(::std::fmt::Debug)]
268pub enum CreateCommitError {
269    /// <p>The specified branch does not exist.</p>
270    BranchDoesNotExistException(crate::types::error::BranchDoesNotExistException),
271    /// <p>The specified branch name is not valid because it is a tag name. Enter the name of a branch in the repository. For a list of valid branch names, use <code>ListBranches</code>.</p>
272    BranchNameIsTagNameException(crate::types::error::BranchNameIsTagNameException),
273    /// <p>A branch name is required, but was not specified.</p>
274    BranchNameRequiredException(crate::types::error::BranchNameRequiredException),
275    /// <p>The commit message is too long. Provide a shorter string.</p>
276    CommitMessageLengthExceededException(crate::types::error::CommitMessageLengthExceededException),
277    /// <p>A file cannot be added to the repository because the specified path name has the same name as a file that already exists in this repository. Either provide a different name for the file, or specify a different path for the file.</p>
278    DirectoryNameConflictsWithFileNameException(crate::types::error::DirectoryNameConflictsWithFileNameException),
279    /// <p>An encryption integrity check failed.</p>
280    EncryptionIntegrityChecksFailedException(crate::types::error::EncryptionIntegrityChecksFailedException),
281    /// <p>An encryption key could not be accessed.</p>
282    EncryptionKeyAccessDeniedException(crate::types::error::EncryptionKeyAccessDeniedException),
283    /// <p>The encryption key is disabled.</p>
284    EncryptionKeyDisabledException(crate::types::error::EncryptionKeyDisabledException),
285    /// <p>No encryption key was found.</p>
286    EncryptionKeyNotFoundException(crate::types::error::EncryptionKeyNotFoundException),
287    /// <p>The encryption key is not available.</p>
288    EncryptionKeyUnavailableException(crate::types::error::EncryptionKeyUnavailableException),
289    /// <p>The commit cannot be created because both a source file and file content have been specified for the same file. You cannot provide both. Either specify a source file or provide the file content directly.</p>
290    FileContentAndSourceFileSpecifiedException(crate::types::error::FileContentAndSourceFileSpecifiedException),
291    /// <p>The file cannot be added because it is too large. The maximum file size is 6 MB, and the combined file content change size is 7 MB. Consider making these changes using a Git client.</p>
292    FileContentSizeLimitExceededException(crate::types::error::FileContentSizeLimitExceededException),
293    /// <p>The specified file does not exist. Verify that you have used the correct file name, full path, and extension.</p>
294    FileDoesNotExistException(crate::types::error::FileDoesNotExistException),
295    /// <p>The commit cannot be created because no files have been specified as added, updated, or changed (PutFile or DeleteFile) for the commit.</p>
296    FileEntryRequiredException(crate::types::error::FileEntryRequiredException),
297    /// <p>The commit cannot be created because no file mode has been specified. A file mode is required to update mode permissions for a file.</p>
298    FileModeRequiredException(crate::types::error::FileModeRequiredException),
299    /// <p>A file cannot be added to the repository because the specified file name has the same name as a directory in this repository. Either provide another name for the file, or add the file in a directory that does not match the file name.</p>
300    FileNameConflictsWithDirectoryNameException(crate::types::error::FileNameConflictsWithDirectoryNameException),
301    /// <p>The commit cannot be created because a specified file path points to a submodule. Verify that the destination files have valid file paths that do not point to a submodule.</p>
302    FilePathConflictsWithSubmodulePathException(crate::types::error::FilePathConflictsWithSubmodulePathException),
303    /// <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>
304    FolderContentSizeLimitExceededException(crate::types::error::FolderContentSizeLimitExceededException),
305    /// <p>The specified reference name is not valid.</p>
306    InvalidBranchNameException(crate::types::error::InvalidBranchNameException),
307    /// <p>The specified deletion parameter is not valid.</p>
308    InvalidDeletionParameterException(crate::types::error::InvalidDeletionParameterException),
309    /// <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>
310    InvalidEmailException(crate::types::error::InvalidEmailException),
311    /// <p>The specified file mode permission is not valid. For a list of valid file mode permissions, see <code>PutFile</code>.</p>
312    InvalidFileModeException(crate::types::error::InvalidFileModeException),
313    /// <p>The parent commit ID is not valid. The commit ID cannot be empty, and must match the head commit ID for the branch of the repository where you want to add or update a file.</p>
314    InvalidParentCommitIdException(crate::types::error::InvalidParentCommitIdException),
315    /// <p>The specified path is not valid.</p>
316    InvalidPathException(crate::types::error::InvalidPathException),
317    /// <p>A specified repository name is not valid.</p><note>
318    /// <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>
319    /// </note>
320    InvalidRepositoryNameException(crate::types::error::InvalidRepositoryNameException),
321    /// <p>The number of specified files to change as part of this commit exceeds the maximum number of files that can be changed in a single commit. Consider using a Git client for these changes.</p>
322    MaximumFileEntriesExceededException(crate::types::error::MaximumFileEntriesExceededException),
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 commit cannot be created because no changes will be made to the repository as a result of this commit. A commit must contain at least one change.</p>
326    NoChangeException(crate::types::error::NoChangeException),
327    /// <p>The parent commit ID is not valid because it does not exist. The specified parent commit ID does not exist in the specified branch of the repository.</p>
328    ParentCommitDoesNotExistException(crate::types::error::ParentCommitDoesNotExistException),
329    /// <p>The file could not be added because the provided parent commit ID is not the current tip of the specified branch. To view the full commit ID of the current head of the branch, use <code>GetBranch</code>.</p>
330    ParentCommitIdOutdatedException(crate::types::error::ParentCommitIdOutdatedException),
331    /// <p>A parent commit ID is required. To view the full commit ID of a branch in a repository, use <code>GetBranch</code> or a Git command (for example, git pull or git log).</p>
332    ParentCommitIdRequiredException(crate::types::error::ParentCommitIdRequiredException),
333    /// <p>The folderPath for a location cannot be null.</p>
334    PathRequiredException(crate::types::error::PathRequiredException),
335    /// <p>The commit cannot be created because one or more files specified in the commit reference both a file and a folder.</p>
336    PutFileEntryConflictException(crate::types::error::PutFileEntryConflictException),
337    /// <p>The specified repository does not exist.</p>
338    RepositoryDoesNotExistException(crate::types::error::RepositoryDoesNotExistException),
339    /// <p>A repository name is required, but was not specified.</p>
340    RepositoryNameRequiredException(crate::types::error::RepositoryNameRequiredException),
341    /// <p>The commit cannot be created because one of the changes specifies copying or moving a .gitkeep file.</p>
342    RestrictedSourceFileException(crate::types::error::RestrictedSourceFileException),
343    /// <p>The commit cannot be created because one or more changes in this commit duplicate actions in the same file path. For example, you cannot make the same delete request to the same file in the same file path twice, or make a delete request and a move request to the same file as part of the same commit.</p>
344    SamePathRequestException(crate::types::error::SamePathRequestException),
345    /// <p>The commit cannot be created because no source files or file content have been specified for the commit.</p>
346    SourceFileOrContentRequiredException(crate::types::error::SourceFileOrContentRequiredException),
347    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
348    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
349    variable wildcard pattern and check `.code()`:
350     \
351    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
352     \
353    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateCommitError) for what information is available for the error.")]
354    Unhandled(crate::error::sealed_unhandled::Unhandled),
355}
356impl CreateCommitError {
357    /// Creates the `CreateCommitError::Unhandled` variant from any error type.
358    pub fn unhandled(
359        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
360    ) -> Self {
361        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
362            source: err.into(),
363            meta: ::std::default::Default::default(),
364        })
365    }
366
367    /// Creates the `CreateCommitError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
368    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
369        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
370            source: err.clone().into(),
371            meta: err,
372        })
373    }
374    ///
375    /// Returns error metadata, which includes the error code, message,
376    /// request ID, and potentially additional information.
377    ///
378    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
379        match self {
380            Self::BranchDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
381            Self::BranchNameIsTagNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
382            Self::BranchNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
383            Self::CommitMessageLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
384            Self::DirectoryNameConflictsWithFileNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
385            Self::EncryptionIntegrityChecksFailedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
386            Self::EncryptionKeyAccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
387            Self::EncryptionKeyDisabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
388            Self::EncryptionKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
389            Self::EncryptionKeyUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
390            Self::FileContentAndSourceFileSpecifiedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
391            Self::FileContentSizeLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
392            Self::FileDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
393            Self::FileEntryRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
394            Self::FileModeRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
395            Self::FileNameConflictsWithDirectoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
396            Self::FilePathConflictsWithSubmodulePathException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
397            Self::FolderContentSizeLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
398            Self::InvalidBranchNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
399            Self::InvalidDeletionParameterException(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::InvalidParentCommitIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
403            Self::InvalidPathException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
404            Self::InvalidRepositoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
405            Self::MaximumFileEntriesExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
406            Self::NameLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
407            Self::NoChangeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
408            Self::ParentCommitDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
409            Self::ParentCommitIdOutdatedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
410            Self::ParentCommitIdRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
411            Self::PathRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
412            Self::PutFileEntryConflictException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
413            Self::RepositoryDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
414            Self::RepositoryNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
415            Self::RestrictedSourceFileException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
416            Self::SamePathRequestException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
417            Self::SourceFileOrContentRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
418            Self::Unhandled(e) => &e.meta,
419        }
420    }
421    /// Returns `true` if the error kind is `CreateCommitError::BranchDoesNotExistException`.
422    pub fn is_branch_does_not_exist_exception(&self) -> bool {
423        matches!(self, Self::BranchDoesNotExistException(_))
424    }
425    /// Returns `true` if the error kind is `CreateCommitError::BranchNameIsTagNameException`.
426    pub fn is_branch_name_is_tag_name_exception(&self) -> bool {
427        matches!(self, Self::BranchNameIsTagNameException(_))
428    }
429    /// Returns `true` if the error kind is `CreateCommitError::BranchNameRequiredException`.
430    pub fn is_branch_name_required_exception(&self) -> bool {
431        matches!(self, Self::BranchNameRequiredException(_))
432    }
433    /// Returns `true` if the error kind is `CreateCommitError::CommitMessageLengthExceededException`.
434    pub fn is_commit_message_length_exceeded_exception(&self) -> bool {
435        matches!(self, Self::CommitMessageLengthExceededException(_))
436    }
437    /// Returns `true` if the error kind is `CreateCommitError::DirectoryNameConflictsWithFileNameException`.
438    pub fn is_directory_name_conflicts_with_file_name_exception(&self) -> bool {
439        matches!(self, Self::DirectoryNameConflictsWithFileNameException(_))
440    }
441    /// Returns `true` if the error kind is `CreateCommitError::EncryptionIntegrityChecksFailedException`.
442    pub fn is_encryption_integrity_checks_failed_exception(&self) -> bool {
443        matches!(self, Self::EncryptionIntegrityChecksFailedException(_))
444    }
445    /// Returns `true` if the error kind is `CreateCommitError::EncryptionKeyAccessDeniedException`.
446    pub fn is_encryption_key_access_denied_exception(&self) -> bool {
447        matches!(self, Self::EncryptionKeyAccessDeniedException(_))
448    }
449    /// Returns `true` if the error kind is `CreateCommitError::EncryptionKeyDisabledException`.
450    pub fn is_encryption_key_disabled_exception(&self) -> bool {
451        matches!(self, Self::EncryptionKeyDisabledException(_))
452    }
453    /// Returns `true` if the error kind is `CreateCommitError::EncryptionKeyNotFoundException`.
454    pub fn is_encryption_key_not_found_exception(&self) -> bool {
455        matches!(self, Self::EncryptionKeyNotFoundException(_))
456    }
457    /// Returns `true` if the error kind is `CreateCommitError::EncryptionKeyUnavailableException`.
458    pub fn is_encryption_key_unavailable_exception(&self) -> bool {
459        matches!(self, Self::EncryptionKeyUnavailableException(_))
460    }
461    /// Returns `true` if the error kind is `CreateCommitError::FileContentAndSourceFileSpecifiedException`.
462    pub fn is_file_content_and_source_file_specified_exception(&self) -> bool {
463        matches!(self, Self::FileContentAndSourceFileSpecifiedException(_))
464    }
465    /// Returns `true` if the error kind is `CreateCommitError::FileContentSizeLimitExceededException`.
466    pub fn is_file_content_size_limit_exceeded_exception(&self) -> bool {
467        matches!(self, Self::FileContentSizeLimitExceededException(_))
468    }
469    /// Returns `true` if the error kind is `CreateCommitError::FileDoesNotExistException`.
470    pub fn is_file_does_not_exist_exception(&self) -> bool {
471        matches!(self, Self::FileDoesNotExistException(_))
472    }
473    /// Returns `true` if the error kind is `CreateCommitError::FileEntryRequiredException`.
474    pub fn is_file_entry_required_exception(&self) -> bool {
475        matches!(self, Self::FileEntryRequiredException(_))
476    }
477    /// Returns `true` if the error kind is `CreateCommitError::FileModeRequiredException`.
478    pub fn is_file_mode_required_exception(&self) -> bool {
479        matches!(self, Self::FileModeRequiredException(_))
480    }
481    /// Returns `true` if the error kind is `CreateCommitError::FileNameConflictsWithDirectoryNameException`.
482    pub fn is_file_name_conflicts_with_directory_name_exception(&self) -> bool {
483        matches!(self, Self::FileNameConflictsWithDirectoryNameException(_))
484    }
485    /// Returns `true` if the error kind is `CreateCommitError::FilePathConflictsWithSubmodulePathException`.
486    pub fn is_file_path_conflicts_with_submodule_path_exception(&self) -> bool {
487        matches!(self, Self::FilePathConflictsWithSubmodulePathException(_))
488    }
489    /// Returns `true` if the error kind is `CreateCommitError::FolderContentSizeLimitExceededException`.
490    pub fn is_folder_content_size_limit_exceeded_exception(&self) -> bool {
491        matches!(self, Self::FolderContentSizeLimitExceededException(_))
492    }
493    /// Returns `true` if the error kind is `CreateCommitError::InvalidBranchNameException`.
494    pub fn is_invalid_branch_name_exception(&self) -> bool {
495        matches!(self, Self::InvalidBranchNameException(_))
496    }
497    /// Returns `true` if the error kind is `CreateCommitError::InvalidDeletionParameterException`.
498    pub fn is_invalid_deletion_parameter_exception(&self) -> bool {
499        matches!(self, Self::InvalidDeletionParameterException(_))
500    }
501    /// Returns `true` if the error kind is `CreateCommitError::InvalidEmailException`.
502    pub fn is_invalid_email_exception(&self) -> bool {
503        matches!(self, Self::InvalidEmailException(_))
504    }
505    /// Returns `true` if the error kind is `CreateCommitError::InvalidFileModeException`.
506    pub fn is_invalid_file_mode_exception(&self) -> bool {
507        matches!(self, Self::InvalidFileModeException(_))
508    }
509    /// Returns `true` if the error kind is `CreateCommitError::InvalidParentCommitIdException`.
510    pub fn is_invalid_parent_commit_id_exception(&self) -> bool {
511        matches!(self, Self::InvalidParentCommitIdException(_))
512    }
513    /// Returns `true` if the error kind is `CreateCommitError::InvalidPathException`.
514    pub fn is_invalid_path_exception(&self) -> bool {
515        matches!(self, Self::InvalidPathException(_))
516    }
517    /// Returns `true` if the error kind is `CreateCommitError::InvalidRepositoryNameException`.
518    pub fn is_invalid_repository_name_exception(&self) -> bool {
519        matches!(self, Self::InvalidRepositoryNameException(_))
520    }
521    /// Returns `true` if the error kind is `CreateCommitError::MaximumFileEntriesExceededException`.
522    pub fn is_maximum_file_entries_exceeded_exception(&self) -> bool {
523        matches!(self, Self::MaximumFileEntriesExceededException(_))
524    }
525    /// Returns `true` if the error kind is `CreateCommitError::NameLengthExceededException`.
526    pub fn is_name_length_exceeded_exception(&self) -> bool {
527        matches!(self, Self::NameLengthExceededException(_))
528    }
529    /// Returns `true` if the error kind is `CreateCommitError::NoChangeException`.
530    pub fn is_no_change_exception(&self) -> bool {
531        matches!(self, Self::NoChangeException(_))
532    }
533    /// Returns `true` if the error kind is `CreateCommitError::ParentCommitDoesNotExistException`.
534    pub fn is_parent_commit_does_not_exist_exception(&self) -> bool {
535        matches!(self, Self::ParentCommitDoesNotExistException(_))
536    }
537    /// Returns `true` if the error kind is `CreateCommitError::ParentCommitIdOutdatedException`.
538    pub fn is_parent_commit_id_outdated_exception(&self) -> bool {
539        matches!(self, Self::ParentCommitIdOutdatedException(_))
540    }
541    /// Returns `true` if the error kind is `CreateCommitError::ParentCommitIdRequiredException`.
542    pub fn is_parent_commit_id_required_exception(&self) -> bool {
543        matches!(self, Self::ParentCommitIdRequiredException(_))
544    }
545    /// Returns `true` if the error kind is `CreateCommitError::PathRequiredException`.
546    pub fn is_path_required_exception(&self) -> bool {
547        matches!(self, Self::PathRequiredException(_))
548    }
549    /// Returns `true` if the error kind is `CreateCommitError::PutFileEntryConflictException`.
550    pub fn is_put_file_entry_conflict_exception(&self) -> bool {
551        matches!(self, Self::PutFileEntryConflictException(_))
552    }
553    /// Returns `true` if the error kind is `CreateCommitError::RepositoryDoesNotExistException`.
554    pub fn is_repository_does_not_exist_exception(&self) -> bool {
555        matches!(self, Self::RepositoryDoesNotExistException(_))
556    }
557    /// Returns `true` if the error kind is `CreateCommitError::RepositoryNameRequiredException`.
558    pub fn is_repository_name_required_exception(&self) -> bool {
559        matches!(self, Self::RepositoryNameRequiredException(_))
560    }
561    /// Returns `true` if the error kind is `CreateCommitError::RestrictedSourceFileException`.
562    pub fn is_restricted_source_file_exception(&self) -> bool {
563        matches!(self, Self::RestrictedSourceFileException(_))
564    }
565    /// Returns `true` if the error kind is `CreateCommitError::SamePathRequestException`.
566    pub fn is_same_path_request_exception(&self) -> bool {
567        matches!(self, Self::SamePathRequestException(_))
568    }
569    /// Returns `true` if the error kind is `CreateCommitError::SourceFileOrContentRequiredException`.
570    pub fn is_source_file_or_content_required_exception(&self) -> bool {
571        matches!(self, Self::SourceFileOrContentRequiredException(_))
572    }
573}
574impl ::std::error::Error for CreateCommitError {
575    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
576        match self {
577            Self::BranchDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
578            Self::BranchNameIsTagNameException(_inner) => ::std::option::Option::Some(_inner),
579            Self::BranchNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
580            Self::CommitMessageLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
581            Self::DirectoryNameConflictsWithFileNameException(_inner) => ::std::option::Option::Some(_inner),
582            Self::EncryptionIntegrityChecksFailedException(_inner) => ::std::option::Option::Some(_inner),
583            Self::EncryptionKeyAccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
584            Self::EncryptionKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
585            Self::EncryptionKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
586            Self::EncryptionKeyUnavailableException(_inner) => ::std::option::Option::Some(_inner),
587            Self::FileContentAndSourceFileSpecifiedException(_inner) => ::std::option::Option::Some(_inner),
588            Self::FileContentSizeLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
589            Self::FileDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
590            Self::FileEntryRequiredException(_inner) => ::std::option::Option::Some(_inner),
591            Self::FileModeRequiredException(_inner) => ::std::option::Option::Some(_inner),
592            Self::FileNameConflictsWithDirectoryNameException(_inner) => ::std::option::Option::Some(_inner),
593            Self::FilePathConflictsWithSubmodulePathException(_inner) => ::std::option::Option::Some(_inner),
594            Self::FolderContentSizeLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
595            Self::InvalidBranchNameException(_inner) => ::std::option::Option::Some(_inner),
596            Self::InvalidDeletionParameterException(_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::InvalidParentCommitIdException(_inner) => ::std::option::Option::Some(_inner),
600            Self::InvalidPathException(_inner) => ::std::option::Option::Some(_inner),
601            Self::InvalidRepositoryNameException(_inner) => ::std::option::Option::Some(_inner),
602            Self::MaximumFileEntriesExceededException(_inner) => ::std::option::Option::Some(_inner),
603            Self::NameLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
604            Self::NoChangeException(_inner) => ::std::option::Option::Some(_inner),
605            Self::ParentCommitDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
606            Self::ParentCommitIdOutdatedException(_inner) => ::std::option::Option::Some(_inner),
607            Self::ParentCommitIdRequiredException(_inner) => ::std::option::Option::Some(_inner),
608            Self::PathRequiredException(_inner) => ::std::option::Option::Some(_inner),
609            Self::PutFileEntryConflictException(_inner) => ::std::option::Option::Some(_inner),
610            Self::RepositoryDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
611            Self::RepositoryNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
612            Self::RestrictedSourceFileException(_inner) => ::std::option::Option::Some(_inner),
613            Self::SamePathRequestException(_inner) => ::std::option::Option::Some(_inner),
614            Self::SourceFileOrContentRequiredException(_inner) => ::std::option::Option::Some(_inner),
615            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
616        }
617    }
618}
619impl ::std::fmt::Display for CreateCommitError {
620    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
621        match self {
622            Self::BranchDoesNotExistException(_inner) => _inner.fmt(f),
623            Self::BranchNameIsTagNameException(_inner) => _inner.fmt(f),
624            Self::BranchNameRequiredException(_inner) => _inner.fmt(f),
625            Self::CommitMessageLengthExceededException(_inner) => _inner.fmt(f),
626            Self::DirectoryNameConflictsWithFileNameException(_inner) => _inner.fmt(f),
627            Self::EncryptionIntegrityChecksFailedException(_inner) => _inner.fmt(f),
628            Self::EncryptionKeyAccessDeniedException(_inner) => _inner.fmt(f),
629            Self::EncryptionKeyDisabledException(_inner) => _inner.fmt(f),
630            Self::EncryptionKeyNotFoundException(_inner) => _inner.fmt(f),
631            Self::EncryptionKeyUnavailableException(_inner) => _inner.fmt(f),
632            Self::FileContentAndSourceFileSpecifiedException(_inner) => _inner.fmt(f),
633            Self::FileContentSizeLimitExceededException(_inner) => _inner.fmt(f),
634            Self::FileDoesNotExistException(_inner) => _inner.fmt(f),
635            Self::FileEntryRequiredException(_inner) => _inner.fmt(f),
636            Self::FileModeRequiredException(_inner) => _inner.fmt(f),
637            Self::FileNameConflictsWithDirectoryNameException(_inner) => _inner.fmt(f),
638            Self::FilePathConflictsWithSubmodulePathException(_inner) => _inner.fmt(f),
639            Self::FolderContentSizeLimitExceededException(_inner) => _inner.fmt(f),
640            Self::InvalidBranchNameException(_inner) => _inner.fmt(f),
641            Self::InvalidDeletionParameterException(_inner) => _inner.fmt(f),
642            Self::InvalidEmailException(_inner) => _inner.fmt(f),
643            Self::InvalidFileModeException(_inner) => _inner.fmt(f),
644            Self::InvalidParentCommitIdException(_inner) => _inner.fmt(f),
645            Self::InvalidPathException(_inner) => _inner.fmt(f),
646            Self::InvalidRepositoryNameException(_inner) => _inner.fmt(f),
647            Self::MaximumFileEntriesExceededException(_inner) => _inner.fmt(f),
648            Self::NameLengthExceededException(_inner) => _inner.fmt(f),
649            Self::NoChangeException(_inner) => _inner.fmt(f),
650            Self::ParentCommitDoesNotExistException(_inner) => _inner.fmt(f),
651            Self::ParentCommitIdOutdatedException(_inner) => _inner.fmt(f),
652            Self::ParentCommitIdRequiredException(_inner) => _inner.fmt(f),
653            Self::PathRequiredException(_inner) => _inner.fmt(f),
654            Self::PutFileEntryConflictException(_inner) => _inner.fmt(f),
655            Self::RepositoryDoesNotExistException(_inner) => _inner.fmt(f),
656            Self::RepositoryNameRequiredException(_inner) => _inner.fmt(f),
657            Self::RestrictedSourceFileException(_inner) => _inner.fmt(f),
658            Self::SamePathRequestException(_inner) => _inner.fmt(f),
659            Self::SourceFileOrContentRequiredException(_inner) => _inner.fmt(f),
660            Self::Unhandled(_inner) => {
661                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
662                    write!(f, "unhandled error ({code})")
663                } else {
664                    f.write_str("unhandled error")
665                }
666            }
667        }
668    }
669}
670impl ::aws_smithy_types::retry::ProvideErrorKind for CreateCommitError {
671    fn code(&self) -> ::std::option::Option<&str> {
672        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
673    }
674    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
675        ::std::option::Option::None
676    }
677}
678impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateCommitError {
679    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
680        match self {
681            Self::BranchDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
682            Self::BranchNameIsTagNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
683            Self::BranchNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
684            Self::CommitMessageLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
685            Self::DirectoryNameConflictsWithFileNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
686            Self::EncryptionIntegrityChecksFailedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
687            Self::EncryptionKeyAccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
688            Self::EncryptionKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
689            Self::EncryptionKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
690            Self::EncryptionKeyUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
691            Self::FileContentAndSourceFileSpecifiedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
692            Self::FileContentSizeLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
693            Self::FileDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
694            Self::FileEntryRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
695            Self::FileModeRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
696            Self::FileNameConflictsWithDirectoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
697            Self::FilePathConflictsWithSubmodulePathException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
698            Self::FolderContentSizeLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
699            Self::InvalidBranchNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
700            Self::InvalidDeletionParameterException(_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::InvalidParentCommitIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
704            Self::InvalidPathException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
705            Self::InvalidRepositoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
706            Self::MaximumFileEntriesExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
707            Self::NameLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
708            Self::NoChangeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
709            Self::ParentCommitDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
710            Self::ParentCommitIdOutdatedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
711            Self::ParentCommitIdRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
712            Self::PathRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
713            Self::PutFileEntryConflictException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
714            Self::RepositoryDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
715            Self::RepositoryNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
716            Self::RestrictedSourceFileException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
717            Self::SamePathRequestException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
718            Self::SourceFileOrContentRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
719            Self::Unhandled(_inner) => &_inner.meta,
720        }
721    }
722}
723impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateCommitError {
724    fn create_unhandled_error(
725        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
726        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
727    ) -> Self {
728        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
729            source,
730            meta: meta.unwrap_or_default(),
731        })
732    }
733}
734impl ::aws_types::request_id::RequestId for crate::operation::create_commit::CreateCommitError {
735    fn request_id(&self) -> Option<&str> {
736        self.meta().request_id()
737    }
738}
739
740pub use crate::operation::create_commit::_create_commit_input::CreateCommitInput;
741
742pub use crate::operation::create_commit::_create_commit_output::CreateCommitOutput;
743
744mod _create_commit_input;
745
746mod _create_commit_output;
747
748/// Builders
749pub mod builders;