#include <OutputFileHandler.hpp>
Public Member Functions | |
OutputFileHandler (const std::string &rDirectory, bool cleanOutputDirectory=true) | |
OutputFileHandler (const FileFinder &rDirectory, bool cleanOutputDirectory=true) | |
std::string | GetOutputDirectoryFullPath () const |
std::string | GetRelativePath () const |
void | SetArchiveDirectory () const |
out_stream | OpenOutputFile (const std::string &rFileName, std::ios_base::openmode mode=std::ios::out|std::ios::trunc) const |
out_stream | OpenOutputFile (const std::string &rFileName, unsigned number, const std::string &rFileFormat, std::ios_base::openmode mode=std::ios::out|std::ios::trunc) const |
FileFinder | CopyFileTo (const FileFinder &rSourceFile) const |
FileFinder | FindFile (std::string leafName) const |
Static Public Member Functions | |
static std::string | GetChasteTestOutputDirectory () |
Static Public Attributes | |
static const std::string | SIG_FILE_NAME |
Private Member Functions | |
void | CommonConstructor (const std::string &rDirectory, bool cleanOutputDirectory) |
std::string | MakeFoldersAndReturnFullPath (const std::string &rDirectory) const |
Static Private Member Functions | |
static void | AddTrailingSlash (std::string &rDirectory) |
Private Attributes | |
std::string | mDirectory |
The directory to store output files in (always ends in "/"). |
This file abstracts stuff that needs to be done when creating output files for tests. It defines some helpful functions, so that things that are otherwise repeated in lots of places are just done here.
Definition at line 54 of file OutputFileHandler.hpp.
OutputFileHandler::OutputFileHandler | ( | const std::string & | rDirectory, | |
bool | cleanOutputDirectory = true | |||
) |
Create an OutputFileHandler that will create output files in the given directory. The directory name should be relative to the place where Chaste test output is stored. If the user needs to know where this is, use the GetChasteTestOutputDirectory method.
Will check that the directory exists and create it if needed.
rDirectory | the directory to put output files in. | |
cleanOutputDirectory | whether to remove any existing files in the output directory |
Definition at line 87 of file OutputFileHandler.cpp.
References CommonConstructor().
OutputFileHandler::OutputFileHandler | ( | const FileFinder & | rDirectory, | |
bool | cleanOutputDirectory = true | |||
) |
Create an OutputFileHandler that will create output files in the given directory. This must be located inside the folder where Chaste test output is stored, and will typically be obtained with the FindFile method of this class from a parent handler.
Will check that the directory exists and create it if needed.
rDirectory | the directory to put output files in | |
cleanOutputDirectory | whether to remove any existing files in the output directory |
Definition at line 94 of file OutputFileHandler.cpp.
References RelativeTo::ChasteTestOutput, CommonConstructor(), EXCEPTION, FileFinder::GetAbsolutePath(), and FileFinder::GetRelativePath().
void OutputFileHandler::AddTrailingSlash | ( | std::string & | rDirectory | ) | [static, private] |
Takes a reference to a string and adds a trailing slash if one is not already present
rDirectory | The directory name to add a trailing slash to. |
Definition at line 269 of file OutputFileHandler.cpp.
Referenced by GetChasteTestOutputDirectory(), and MakeFoldersAndReturnFullPath().
void OutputFileHandler::CommonConstructor | ( | const std::string & | rDirectory, | |
bool | cleanOutputDirectory | |||
) | [private] |
Functionality common to both constructors.
rDirectory | relative path to the directory to put output files in | |
cleanOutputDirectory | whether to remove any existing files in the output directory |
Definition at line 118 of file OutputFileHandler.cpp.
References RelativeTo::Absolute, PetscTools::AmMaster(), PetscTools::Barrier(), EXCEPTION, FileFinder::Exists(), MakeFoldersAndReturnFullPath(), mDirectory, and SIG_FILE_NAME.
Referenced by OutputFileHandler().
FileFinder OutputFileHandler::CopyFileTo | ( | const FileFinder & | rSourceFile | ) | const |
Copy the given file to this output directory.
rSourceFile | the file to copy |
Definition at line 278 of file OutputFileHandler.cpp.
References RelativeTo::Absolute, PetscTools::AmMaster(), PetscTools::Barrier(), EXCEPTION, FileFinder::GetAbsolutePath(), GetOutputDirectoryFullPath(), FileFinder::IsFile(), and TERMINATE.
Referenced by CellMLLoader::LoadCellMLFile().
FileFinder OutputFileHandler::FindFile | ( | std::string | leafName | ) | const |
leafName | the name of the file to find |
Definition at line 302 of file OutputFileHandler.cpp.
References RelativeTo::Absolute, and GetOutputDirectoryFullPath().
Referenced by AbstractConvergenceTester< CELL, CARDIAC_PROBLEM, DIM, PROBLEM_DIM >::Converge(), CardiacSimulation::CreateAndRun(), GetRelativePath(), CellMLLoader::LoadCellMLFile(), and AbstractTetrahedralMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteNclFile().
std::string OutputFileHandler::GetChasteTestOutputDirectory | ( | ) | [static] |
Static method for getting the test output directory (the directory where chaste stores test output). This is set from the environment variable CHASTE_TEST_OUTPUT, and defaults to "./testoutput" if it is not set.
Attempts to return an absolute path, but may get confused by odd setups.
Static so an output file handler does not have to be created if the test output directory is wanted for, say, reading a file.
Definition at line 159 of file OutputFileHandler.cpp.
References RelativeTo::AbsoluteOrCwd, AddTrailingSlash(), RelativeTo::CWD, FileFinder::GetAbsolutePath(), and FileFinder::SetPath().
Referenced by ArchiveLocationInfo::GetArchiveRelativePath(), ArchiveLocationInfo::GetIsDirRelativeToChasteTestOutput(), AbstractCardiacProblem< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >::InitialiseWriter(), MakeFoldersAndReturnFullPath(), FileFinder::PrivateRemove(), and FileFinder::SetPath().
std::string OutputFileHandler::GetOutputDirectoryFullPath | ( | ) | const |
Definition at line 226 of file OutputFileHandler.cpp.
References mDirectory.
Referenced by ColumnDataReader::ColumnDataReader(), DistributedTetrahedralMesh< ELEMENT_DIM, SPACE_DIM >::ConstructCuboid(), DistributedTetrahedralMesh< ELEMENT_DIM, SPACE_DIM >::ConstructLinearMesh(), DistributedTetrahedralMesh< ELEMENT_DIM, SPACE_DIM >::ConstructRectangularMesh(), CopyFileTo(), CardiacSimulation::CreateResumeXmlFile(), FindFile(), AbstractMeshWriter< ELEMENT_DIM, SPACE_DIM >::GetOutputDirectory(), ColumnDataWriter::GetOutputDirectory(), CmguiMeshWriter< ELEMENT_DIM, SPACE_DIM >::OpenElementFiles(), AbstractCellBasedSimulation< ELEMENT_DIM, SPACE_DIM >::OutputSimulationSetup(), CardiacSimulationArchiver< PROBLEM_CLASS >::Save(), SetArchiveDirectory(), HeartConfig::Write(), VtkMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFiles(), VtkMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFilesUsingMesh(), VertexMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteVtkUsingMesh(), and XdmfMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteXdmfMasterFile().
std::string OutputFileHandler::GetRelativePath | ( | ) | const |
Definition at line 231 of file OutputFileHandler.cpp.
References RelativeTo::ChasteTestOutput, FindFile(), and FileFinder::GetRelativePath().
std::string OutputFileHandler::MakeFoldersAndReturnFullPath | ( | const std::string & | rDirectory | ) | const [private] |
Check that the desired output directory exists and is writable by us. Create it if needed. Return the full pathname of the output directory.
The environment variable CHASTE_TEST_OUTPUT will be examined. If it is set and non-empty it is taken to be a directory where test output should be stored. Otherwise the current directory is used.
rDirectory | pathname of the output directory, relative to where Chaste output will be stored (user shouldn't care about this). |
Definition at line 179 of file OutputFileHandler.cpp.
References AddTrailingSlash(), PetscTools::AmMaster(), PetscTools::Barrier(), GetChasteTestOutputDirectory(), SIG_FILE_NAME, and TERMINATE.
Referenced by CommonConstructor().
out_stream OutputFileHandler::OpenOutputFile | ( | const std::string & | rFileName, | |
unsigned | number, | |||
const std::string & | rFileFormat, | |||
std::ios_base::openmode | mode = std::ios::out | std::ios::trunc | |||
) | const |
This just calls the other OpenOutputFile after concatenating the first three arguments together to make the full filename. For example OpenOutputFile("results_", 3, ".dat") creates results_3.dat. See documentation for OpenOutputFile(std::string, std::ios_base::openmode).
rFileName | the root name of the file to open | |
number | the number to append to the root name of the file | |
rFileFormat | the file format | |
mode | optionally, flags to use when opening the file (defaults are as for std::ofstream). |
Definition at line 253 of file OutputFileHandler.cpp.
References OpenOutputFile().
out_stream OutputFileHandler::OpenOutputFile | ( | const std::string & | rFileName, | |
std::ios_base::openmode | mode = std::ios::out | std::ios::trunc | |||
) | const |
Open an output file in our directory, and check it was opened successfully. Throws an Exception if not.
rFileName | the name of the file to open, relative to the output directory. | |
mode | optionally, flags to use when opening the file (defaults are as for std::ofstream). |
Definition at line 242 of file OutputFileHandler.cpp.
References EXCEPTION, and mDirectory.
Referenced by VtkMeshWriter< ELEMENT_DIM, SPACE_DIM >::AddProvenance(), AbstractConvergenceTester< CELL, CARDIAC_PROBLEM, DIM, PROBLEM_DIM >::Converge(), ColumnDataWriter::CreateFixedDimensionFile(), ColumnDataWriter::CreateInfoFile(), CellMLToSharedLibraryConverter::CreateOptionsFile(), CardiacSimulation::CreateResumeXmlFile(), CardiacElectroMechanicsProblem< DIM, ELEC_PROB_DIM >::DetermineWatchedNodes(), ColumnDataWriter::EndDefineMode(), ActivationOutputModifier::FinaliseAtEnd(), Hdf5ToTxtConverter< ELEMENT_DIM, SPACE_DIM >::Hdf5ToTxtConverter(), SingleTraceOutputModifier::InitialiseAtStart(), MeshalyzerMeshWriter< ELEMENT_DIM, SPACE_DIM >::OpenElementFile(), MeshalyzerMeshWriter< ELEMENT_DIM, SPACE_DIM >::OpenFaceFile(), FibreWriter< DIM >::OpenFileAndWriteHeader(), MeshalyzerMeshWriter< ELEMENT_DIM, SPACE_DIM >::OpenNodeFile(), CmguiMeshWriter< ELEMENT_DIM, SPACE_DIM >::OpenNodeFile(), OpenOutputFile(), AbstractCellBasedWriter< ELEMENT_DIM, SPACE_DIM >::OpenOutputFile(), AbstractCellBasedWriter< ELEMENT_DIM, SPACE_DIM >::OpenOutputFileForAppend(), CellBasedPdeHandler< DIM >::OpenResultsFiles(), AbstractCellPopulation< ELEMENT_DIM, SPACE_DIM >::OpenWritersFiles(), AbstractCellBasedSimulation< ELEMENT_DIM, SPACE_DIM >::OutputSimulationSetup(), StreeterFibreGenerator< SPACE_DIM >::PreWriteCalculations(), ExecutableSupport::PrintError(), ProgressReporter::ProgressReporter(), LogFile::Set(), SimpleDataWriter::SimpleDataWriter(), AbstractCellBasedSimulation< ELEMENT_DIM, SPACE_DIM >::Solve(), LinearParabolicPdeSystemWithCoupledOdeSystemSolver< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >::SolveAndWriteResultsToFile(), Hdf5ToMeshalyzerConverter< ELEMENT_DIM, SPACE_DIM >::Write(), Hdf5ToCmguiConverter< ELEMENT_DIM, SPACE_DIM >::Write(), CmguiDeformedSolutionsWriter< DIM >::WriteCmguiScript(), Hdf5ToCmguiConverter< ELEMENT_DIM, SPACE_DIM >::WriteCmguiScript(), AbstractContinuumMechanicsSolver< DIM >::WriteCurrentPressureSolution(), AbstractContinuumMechanicsSolver< DIM >::WriteCurrentSpatialSolution(), AbstractNonlinearElasticitySolver< DIM >::WriteCurrentStrains(), AbstractPerElementWriter< SPACE_DIM, SPACE_DIM, SPACE_DIM *SPACE_DIM >::WriteData(), CmguiDeformedSolutionsWriter< DIM >::WriteDeformationPositions(), TrianglesMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteElementsAsFaces(), TrianglesMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFacesAsEdges(), XdmfMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFiles(), TrianglesMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFiles(), VertexMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFiles(), PottsMeshWriter< SPACE_DIM >::WriteFiles(), XdmfMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteFilesUsingMesh(), PostProcessingWriter< ELEMENT_DIM, SPACE_DIM >::WriteGenericFileToMeshalyzer(), AbstractHdf5Converter< ELEMENT_DIM, SPACE_DIM >::WriteInfoFile(), HeartGeometryInformation< SPACE_DIM >::WriteLayerForEachNode(), ExecutableSupport::WriteMachineInfoFile(), MeshalyzerMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteMetaFile(), AbstractTetrahedralMeshWriter< ELEMENT_DIM, SPACE_DIM >::WriteNclFile(), ExecutableSupport::WriteProvenanceInfoFile(), PseudoEcgCalculator< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >::WritePseudoEcg(), and DiscreteSystemForceCalculator::WriteResultsToFile().
void OutputFileHandler::SetArchiveDirectory | ( | ) | const |
Helper method to set up ArchiveLocationInfo.
Definition at line 263 of file OutputFileHandler.cpp.
References RelativeTo::Absolute, and GetOutputDirectoryFullPath().
const std::string OutputFileHandler::SIG_FILE_NAME [static] |
The name of the Chaste signature file added to folders we create.
Definition at line 165 of file OutputFileHandler.hpp.
Referenced by CommonConstructor(), MakeFoldersAndReturnFullPath(), and FileFinder::PrivateRemove().