
com.amazonaws.services.elasticmapreduce.model.transform.HadoopJarStepConfigJsonMarshaller Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws-java-sdk-emr Show documentation
Show all versions of aws-java-sdk-emr Show documentation
The AWS Java SDK for Amazon EMR module holds the client classes that are used for communicating with Amazon Elastic MapReduce Service
/*
* Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights
* Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.amazonaws.services.elasticmapreduce.model.transform;
import java.util.Map;
import java.util.List;
import com.amazonaws.AmazonClientException;
import com.amazonaws.services.elasticmapreduce.model.*;
import com.amazonaws.transform.Marshaller;
import com.amazonaws.util.BinaryUtils;
import com.amazonaws.util.StringUtils;
import com.amazonaws.util.IdempotentUtils;
import com.amazonaws.util.StringInputStream;
import com.amazonaws.protocol.json.*;
/**
* HadoopJarStepConfigMarshaller
*/
public class HadoopJarStepConfigJsonMarshaller {
/**
* Marshall the given parameter object, and output to a SdkJsonGenerator
*/
public void marshall(HadoopJarStepConfig hadoopJarStepConfig,
StructuredJsonGenerator jsonGenerator) {
if (hadoopJarStepConfig == null) {
throw new AmazonClientException(
"Invalid argument passed to marshall(...)");
}
try {
jsonGenerator.writeStartObject();
com.amazonaws.internal.SdkInternalList propertiesList = (com.amazonaws.internal.SdkInternalList) hadoopJarStepConfig
.getProperties();
if (!propertiesList.isEmpty() || !propertiesList.isAutoConstruct()) {
jsonGenerator.writeFieldName("Properties");
jsonGenerator.writeStartArray();
for (KeyValue propertiesListValue : propertiesList) {
if (propertiesListValue != null) {
KeyValueJsonMarshaller.getInstance().marshall(
propertiesListValue, jsonGenerator);
}
}
jsonGenerator.writeEndArray();
}
if (hadoopJarStepConfig.getJar() != null) {
jsonGenerator.writeFieldName("Jar").writeValue(
hadoopJarStepConfig.getJar());
}
if (hadoopJarStepConfig.getMainClass() != null) {
jsonGenerator.writeFieldName("MainClass").writeValue(
hadoopJarStepConfig.getMainClass());
}
com.amazonaws.internal.SdkInternalList argsList = (com.amazonaws.internal.SdkInternalList) hadoopJarStepConfig
.getArgs();
if (!argsList.isEmpty() || !argsList.isAutoConstruct()) {
jsonGenerator.writeFieldName("Args");
jsonGenerator.writeStartArray();
for (String argsListValue : argsList) {
if (argsListValue != null) {
jsonGenerator.writeValue(argsListValue);
}
}
jsonGenerator.writeEndArray();
}
jsonGenerator.writeEndObject();
} catch (Throwable t) {
throw new AmazonClientException(
"Unable to marshall request to JSON: " + t.getMessage(), t);
}
}
private static HadoopJarStepConfigJsonMarshaller instance;
public static HadoopJarStepConfigJsonMarshaller getInstance() {
if (instance == null)
instance = new HadoopJarStepConfigJsonMarshaller();
return instance;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy