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