/* * Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com * The software in this package is published under the terms of the CPAL v1.0 * license, a copy of which has been included with this distribution in the * LICENSE.txt file. */ package org.mule.runtime.core.transformer.simple; import org.mule.runtime.api.metadata.DataType; import org.mule.runtime.core.api.transformer.DiscoverableTransformer; import org.mule.runtime.core.api.transformer.TransformerException; import org.mule.runtime.core.transformer.AbstractTransformer; import org.mule.runtime.core.util.StringUtils; import java.nio.charset.Charset; /** * <code>ObjectArrayToString</code> transformer is the opposite of StringToObjectArray - it simply converts Object[] to a String * in which each element is separated by a configurable delimiter (default is a space). */ public class ObjectArrayToString extends AbstractTransformer implements DiscoverableTransformer { /** Give core transformers a slighty higher priority */ private int priorityWeighting = DiscoverableTransformer.DEFAULT_PRIORITY_WEIGHTING + 1; private static final String DEFAULT_DELIMITER = " "; private String delimiter = null; public ObjectArrayToString() { registerSourceType(DataType.fromType(Object[].class)); setReturnDataType(DataType.STRING); } @Override public Object doTransform(Object src, Charset encoding) throws TransformerException { if (src == null) { return src; } Object[] in = (Object[]) src; String out = StringUtils.join(in, getDelimiter()); /* * for (int i = 0; i < in.length; i++) { if (in[i] != null) { if (i > 0) out += getDelimiter(); out += in[i].toString(); } } */ return out; } public String getDelimiter() { if (delimiter == null) { return DEFAULT_DELIMITER; } else { return delimiter; } } public void setDelimiter(String delimiter) { this.delimiter = delimiter; } @Override public int getPriorityWeighting() { return priorityWeighting; } @Override public void setPriorityWeighting(int priorityWeighting) { this.priorityWeighting = priorityWeighting; } }