/*******************************************************************************
* Copyright Technophobia Ltd 2012
*
* This file is part of the Substeps Eclipse Plugin.
*
* The Substeps Eclipse Plugin is free software: you can redistribute it and/or modify
* it under the terms of the Eclipse Public License v1.0.
*
* The Substeps Eclipse Plugin is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Eclipse Public License for more details.
*
* You should have received a copy of the Eclipse Public License
* along with the Substeps Eclipse Plugin. If not, see <http://www.eclipse.org/legal/epl-v10.html>.
******************************************************************************/
package com.technophobia.substeps.document.formatting.strategy;
import com.technophobia.substeps.document.formatting.FormattingContext;
import com.technophobia.substeps.supplier.Supplier;
/**
* Formatting Strategy that indents the content value
*
* @author sforbes
*
*/
public abstract class IndentationFormattingStrategy extends DefaultFormattingStrategy {
private final Supplier<FormattingContext> formattingContextSupplier;
public IndentationFormattingStrategy(final Supplier<FormattingContext> formattingContextSupplier) {
this.formattingContextSupplier = formattingContextSupplier;
}
@Override
public void formatterStarts(final String initialIndentation) {
super.formatterStarts(initialIndentation);
}
@Override
public String format(final String content, final boolean isLineStart, final String indentation,
final int[] positions) {
final String indentedContent = indent() + content.trim();
return formattingContextSupplier.get().hasPreviousContent() ? NEWLINE + indentedContent : indentedContent;
}
/**
* What indent should the content have
*
* @return The indent in string format
*/
protected abstract String indent();
}