
org.arquillian.spacelift.task.text.StringReplacementTool Maven / Gradle / Ivy
Show all versions of arquillian-spacelift Show documentation
/*
* JBoss, Home of Professional Open Source
* Copyright 2014, Red Hat, Inc. and/or its affiliates, and individual
* contributors by the @authors tag. See the copyright.txt in the
* distribution for a full listing of individual contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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 org.arquillian.spacelift.task.text;
import java.io.File;
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import org.arquillian.spacelift.Spacelift;
import org.arquillian.spacelift.task.Task;
import org.arquillian.spacelift.task.io.FileReader;
import org.arquillian.spacelift.task.io.FileSelector;
import org.arquillian.spacelift.task.io.FileWriter;
import org.arquillian.spacelift.util.CharsetUtil;
/**
* Tool for string replacement inside files. It has no input and outputs list of modified files. To select the files
* to be processed, use {@link #in(File...)} or {@link #in(String)}. All the files you select for processing has to
* be using the same charset. If you wish to replace files with different charsets,
* you need to use this task multiple times and use {@link #charset(Charset)} to set the charset of processed files.
*
* @author Stefan Miklosovic
* @author Tadeas Kriz
*/
public class StringReplacementTool extends Task
* NOTE: You can specify multiple replacements and they will all be evaluated when the task is run. The order of their
* evaluation is the same as you add the replacements into this tool.
*/
public ReplacementTuple replace(String regex) {
ReplacementTuple replacement = new ReplacementTuple(this, regex);
replacements.add(replacement);
return replacement;
}
/**
* Selects the charset which will be used for reading and writing the files.
*/
public StringReplacementTool charset(Charset charset) {
this.charset = charset;
return this;
}
@Override
protected List process(Object input) throws Exception {
// FIXME should we remove the processed files from #files list?
return Spacelift.task(FileSelector.class)
.select(files)
.then(FileReader.class)
.charset(charset)
.then(StringReplacementTask.class)
.replace(replacements)
.then(FileWriter.class)
.charset(charset)
.execute().await();
}
}