Reference documentation for deal.II version 9.1.0-pre
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Static Private Attributes | List of all members
Patterns::FileName Class Reference

#include <deal.II/base/patterns.h>

Inheritance diagram for Patterns::FileName:
[legend]

Public Types

- Public Types inherited from Patterns::PatternBase

Public Member Functions

 FileName (const FileType type=input)
 
virtual bool match (const std::string &test_string) const override
 
virtual std::string description (const OutputStyle style=Machine) const override
 
virtual std::unique_ptr< PatternBaseclone () const override
 
- Public Member Functions inherited from Patterns::PatternBase
virtual ~PatternBase ()=default
 
virtual std::size_t memory_consumption () const
 

Static Public Member Functions

static std::unique_ptr< FileNamecreate (const std::string &description)
 

Public Attributes

FileType file_type
 

Static Private Attributes

static const char * description_init = "[FileName"
 

Detailed Description

A pattern that can be used to indicate when a parameter is intended to be the name of a file. By itself, this class does not check whether the string that is given in a parameter file actually corresponds to an existing file (it could, for example, be the name of a file to which you want to write output). Functionally, the class is therefore equivalent to the Anything class. However, it allows to specify the intent of a parameter. The flag given to the constructor also allows to specify whether the file is supposed to be an input or output file.

The reason for the existence of this class is to support graphical user interfaces for editing parameter files. These may open a file selection dialog if the filename is supposed to represent an input file.

Definition at line 1078 of file patterns.h.

Member Enumeration Documentation

Files can be used for input or output. This can be specified in the constructor by choosing the flag type.

Enumerator
input 

Open for input.

output 

Open for output.

Definition at line 1085 of file patterns.h.

Constructor & Destructor Documentation

Patterns::FileName::FileName ( const FileType  type = input)

Constructor. The type of the file can be specified by choosing the flag.

Definition at line 1510 of file patterns.cc.

Member Function Documentation

bool Patterns::FileName::match ( const std::string &  test_string) const
overridevirtual

Return true if the string matches its constraints, i.e. always.

Implements Patterns::PatternBase.

Definition at line 1517 of file patterns.cc.

std::string Patterns::FileName::description ( const OutputStyle  style = Machine) const
overridevirtual

Return a description of the pattern that valid strings are expected to match. Here, this is the string "[Filename]".

Implements Patterns::PatternBase.

Definition at line 1525 of file patterns.cc.

std::unique_ptr< PatternBase > Patterns::FileName::clone ( ) const
overridevirtual

Return a copy of the present object, which is newly allocated on the heap. Ownership of that object is transferred to the caller of this function.

Implements Patterns::PatternBase.

Definition at line 1561 of file patterns.cc.

std::unique_ptr< FileName > Patterns::FileName::create ( const std::string &  description)
static

Create a new object if the start of description matches description_init. Ownership of that object is transferred to the caller of this function.

Definition at line 1569 of file patterns.cc.

Member Data Documentation

FileType Patterns::FileName::file_type

file type flag

Definition at line 1128 of file patterns.h.

const char * Patterns::FileName::description_init = "[FileName"
staticprivate

Initial part of description

Definition at line 1142 of file patterns.h.


The documentation for this class was generated from the following files: