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