#[allow(missing_docs)] #[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct TranslateTextOutput {
pub translated_text: ::std::string::String,
pub source_language_code: ::std::string::String,
pub target_language_code: ::std::string::String,
pub applied_terminologies: ::std::option::Option<::std::vec::Vec<crate::types::AppliedTerminology>>,
pub applied_settings: ::std::option::Option<crate::types::TranslationSettings>,
_request_id: Option<String>,
}
impl TranslateTextOutput {
pub fn translated_text(&self) -> &str {
use std::ops::Deref;
self.translated_text.deref()
}
pub fn source_language_code(&self) -> &str {
use std::ops::Deref;
self.source_language_code.deref()
}
pub fn target_language_code(&self) -> &str {
use std::ops::Deref;
self.target_language_code.deref()
}
pub fn applied_terminologies(&self) -> &[crate::types::AppliedTerminology] {
self.applied_terminologies.as_deref().unwrap_or_default()
}
pub fn applied_settings(&self) -> ::std::option::Option<&crate::types::TranslationSettings> {
self.applied_settings.as_ref()
}
}
impl ::aws_types::request_id::RequestId for TranslateTextOutput {
fn request_id(&self) -> Option<&str> {
self._request_id.as_deref()
}
}
impl TranslateTextOutput {
pub fn builder() -> crate::operation::translate_text::builders::TranslateTextOutputBuilder {
crate::operation::translate_text::builders::TranslateTextOutputBuilder::default()
}
}
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct TranslateTextOutputBuilder {
pub(crate) translated_text: ::std::option::Option<::std::string::String>,
pub(crate) source_language_code: ::std::option::Option<::std::string::String>,
pub(crate) target_language_code: ::std::option::Option<::std::string::String>,
pub(crate) applied_terminologies: ::std::option::Option<::std::vec::Vec<crate::types::AppliedTerminology>>,
pub(crate) applied_settings: ::std::option::Option<crate::types::TranslationSettings>,
_request_id: Option<String>,
}
impl TranslateTextOutputBuilder {
pub fn translated_text(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.translated_text = ::std::option::Option::Some(input.into());
self
}
pub fn set_translated_text(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.translated_text = input;
self
}
pub fn get_translated_text(&self) -> &::std::option::Option<::std::string::String> {
&self.translated_text
}
pub fn source_language_code(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.source_language_code = ::std::option::Option::Some(input.into());
self
}
pub fn set_source_language_code(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.source_language_code = input;
self
}
pub fn get_source_language_code(&self) -> &::std::option::Option<::std::string::String> {
&self.source_language_code
}
pub fn target_language_code(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.target_language_code = ::std::option::Option::Some(input.into());
self
}
pub fn set_target_language_code(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.target_language_code = input;
self
}
pub fn get_target_language_code(&self) -> &::std::option::Option<::std::string::String> {
&self.target_language_code
}
pub fn applied_terminologies(mut self, input: crate::types::AppliedTerminology) -> Self {
let mut v = self.applied_terminologies.unwrap_or_default();
v.push(input);
self.applied_terminologies = ::std::option::Option::Some(v);
self
}
pub fn set_applied_terminologies(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::AppliedTerminology>>) -> Self {
self.applied_terminologies = input;
self
}
pub fn get_applied_terminologies(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::AppliedTerminology>> {
&self.applied_terminologies
}
pub fn applied_settings(mut self, input: crate::types::TranslationSettings) -> Self {
self.applied_settings = ::std::option::Option::Some(input);
self
}
pub fn set_applied_settings(mut self, input: ::std::option::Option<crate::types::TranslationSettings>) -> Self {
self.applied_settings = input;
self
}
pub fn get_applied_settings(&self) -> &::std::option::Option<crate::types::TranslationSettings> {
&self.applied_settings
}
pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
self._request_id = Some(request_id.into());
self
}
pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
self._request_id = request_id;
self
}
pub fn build(
self,
) -> ::std::result::Result<crate::operation::translate_text::TranslateTextOutput, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::operation::translate_text::TranslateTextOutput {
translated_text: self.translated_text.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"translated_text",
"translated_text was not specified but it is required when building TranslateTextOutput",
)
})?,
source_language_code: self.source_language_code.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"source_language_code",
"source_language_code was not specified but it is required when building TranslateTextOutput",
)
})?,
target_language_code: self.target_language_code.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"target_language_code",
"target_language_code was not specified but it is required when building TranslateTextOutput",
)
})?,
applied_terminologies: self.applied_terminologies,
applied_settings: self.applied_settings,
_request_id: self._request_id,
})
}
}