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