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