/*******************************************************************************
* 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.content;
import org.eclipse.jface.text.formatter.IFormattingStrategy;
import org.eclipse.jface.text.rules.IPredicateRule;
import org.eclipse.jface.text.rules.IRule;
import com.technophobia.substeps.colour.ColourManager;
import com.technophobia.substeps.document.formatting.FormattingContext;
import com.technophobia.substeps.document.partition.PartitionContext;
import com.technophobia.substeps.supplier.Supplier;
/**
* Representation of a content type allowed in the editor
*
* @author sforbes
*
*/
public interface ContentTypeDefinition {
/**
* Unique id of the content type
*
* @return id
*/
String id();
/**
* Text that will be visible in the editor for this content type
*
* @return prefixText
*/
String prefixText();
/**
* Is this item optional in the editor
*
* @return true if content type is optional, false otherwise
*/
boolean isOptional();
/**
* Return the {@link PredicateRule} associated with this content type
*
* @param partitionContext
*
* @return PredicateRule
*/
IPredicateRule partitionRule(final Supplier<PartitionContext> partitionContextSupplier);
/**
* Return the DamageRepairer {@link IRule} associated with this content type
*
* @return DamageRepairer Rule
*/
IRule damageRepairerRule(ColourManager colourManager, final Supplier<PartitionContext> partitionContextSupplier);
/**
* Returns the {@link IFormattingStrategy} based on the supplied
* {@link FormattingContext}
*
* @param formattingContextSupplier
* Supplies the formatting context
* @return IFormattingStrategy
*/
IFormattingStrategy formattingStrategy(Supplier<FormattingContext> formattingContextSupplier);
}