apparat.tools.reducer.ReducerConfiguration.scala Maven / Gradle / Ivy
/*
* This file is part of Apparat.
*
* Apparat is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Apparat 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
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Apparat. If not, see .
*
* Copyright (C) 2009 Joa Ebert
* http://www.joa-ebert.com/
*
*/
package apparat.tools.reducer
import java.io.{File => JFile}
/**
* @author Joa Ebert
*/
trait ReducerConfiguration {
/**
* The input file.
*/
def input: JFile
/**
* The output file.
*/
def output: JFile
/**
* JPEG compression quality.
*/
def quality: Float
/**
* Strength of the Flash Player deblocking filter.
*/
def deblock: Float
/**
* Whether or not to merge ABC files into a single one.
*/
def mergeABC: Boolean
/**
* Whether or not to sort the constant pool. This option
* is only triggered if mergeABC is specified.
*/
def sortCPool: Boolean
/**
* Use advanced LZMA compression.
*/
def lzma: Boolean
/**
* The type of the Matryoshka to use.
*
* @see MatryoshkaType
*/
def matryoshkaType: Int
/**
* The custom matryoshka. Has to be specified only if
* matryoshkaType
is MatryoshkaType.CUSTOM
.
*/
def matryoshka: Option[JFile]
/**
* Whether or not to merge instructions which are identical in identical
* flow positions.
*/
def mergeCF: Boolean
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy