version  0.0.1
Defines the C++ API for MsPASS
Loading...
Searching...
No Matches
Public Member Functions | List of all members
mspass::utility::AntelopePf Class Reference

C++ object version of a parameter file. More...

#include <AntelopePf.h>

Inheritance diagram for mspass::utility::AntelopePf:
mspass::utility::Metadata mspass::utility::BasicMetadata

Public Member Functions

 AntelopePf ()
 
 AntelopePf (std::string pfbase)
 Construct from a base pf name.
 
 AntelopePf (std::list< std::string > lines)
 Construct from a set of text lines.
 
 AntelopePf (const AntelopePf &parent)
 
std::list< std::string > get_tbl (const std::string key) const
 get a Tbl component by key.
 
AntelopePf get_branch (const std::string key) const
 used for subtrees (nested Arrs in antelope)
 
std::list< std::string > arr_keys () const
 
std::list< std::string > tbl_keys () const
 
Metadata ConvertToMetadata ()
 Return an object with only simple name:value pairs.
 
AntelopePfoperator= (const AntelopePf &parent)
 
void pfwrite (std::ostream &ofs)
 save result in a pf format.
 

Additional Inherited Members

Detailed Description

C++ object version of a parameter file.

This object encapsulates the Antelope concept of a parameter file in a single wrapper. The main constructor is actually act much like the Antelope pfread procedure. Internally this object does not use an antelope Pf at all directly, but it is a child of Metadata. Simple attributes (i.e. key-value pairs) are posted directly to the Metadata associative array (map) container. Note that the parser attempts to guess the type of each value given in the obvious ways (periods imply real numbers, e or E imply real numbers, etc.) but the algorithm used may not be foolproof. The get methods are from the Metadata object. Be warned like the Metadata object the type of an entry for a key can change and will be the last one set. An Antelope Tbl in a pf file is converted to an stl list container of stl::string's that contain the input lines. This is a strong divergence from the tbl interface of Antelope, but one I judged a reasonable modernization. Similarly, Arr's are converted to what I am here calling a "branch". Branches are map indexed containers with the key pointing to nested versions of this sampe object type. This is in keeping with the way Arr's are used in antelope, but with an object flavor instead of the pointer style of pfget_arr. Thus, get_branch returns a AntelopePf object instead of a pointer that has to be memory managed. A final note about this beast is that the entire thing was created with a tacit assumption the object itself is not huge. i.e. this implementation may not scale well if applied to very large (millions) line pf files. This is a job for something like MongoDB. View this as a convenient format for building a Metadata object. Note, a code fragment to use this to create lower level metadata would go like this: AntelopePf pfdata("example"); //parameter file constructor Metadata md(dynamic_cast<Metadata&>(pfdata);

Author
Gary L. Pavlis, Indiana University

This version for MsPASS is derived from a similar thing called a PfStyleMetadata object in antelope contrib.

Constructor & Destructor Documentation

◆ AntelopePf() [1/4]

mspass::utility::AntelopePf::AntelopePf ( )
inline

Default constructor - does nothing.

64: Metadata() {};
Metadata()
Definition Metadata.h:75

◆ AntelopePf() [2/4]

mspass::utility::AntelopePf::AntelopePf ( std::string  pfbase)

Construct from a base pf name.

This constructor acts like the antelope pfread function for parameter files constructed in plain C. That is, the argument is a base name sans the .pf extension. Like antelope's pfread it will follow the chain of directories defined by PFPATH. As with the antelope pfread procedure the last file read takes precendence. Note if PFPATH is not defined the path defaults to ".". Further if pfbase begins with a slash (i.e. "/") it is assumed to be the actual file name to read and the PFPATH feature is disabled.

Parameters
pfbaseis a the base pf name (always adds .pf to each name in PFPATH)
Exceptions
-throws a MsPASSError object with an informative message if constuctor fails for any reason.

◆ AntelopePf() [3/4]

mspass::utility::AntelopePf::AntelopePf ( std::list< std::string >  lines)

Construct from a set of text lines.

This is a cruder constructor that could be used for small pf file. Read the contents of a pf file into a vector of lines with each line being one line from the pf. The constructor then sequentially parses this series of lines as it would if reading from a file.

Parameters
linesis the modified version of the text pf file.

◆ AntelopePf() [4/4]

mspass::utility::AntelopePf::AntelopePf ( const AntelopePf parent)

Standard copy constructor.

381 : Metadata(parent) {
382 pftbls = parent.pftbls;
383 pfbranches = parent.pfbranches;
384}
T get(const std::string key) const
Definition Metadata.h:445

References mspass::utility::Metadata::get().

Member Function Documentation

◆ arr_keys()

list< string > mspass::utility::AntelopePf::arr_keys ( ) const

Return a list of keys for branches (Arrs) in the pf file.

400 {
401 map<string, AntelopePf>::const_iterator iptr;
402 list<string> result;
403 for (iptr = pfbranches.begin(); iptr != pfbranches.end(); ++iptr)
404 result.push_back((*iptr).first);
405 return result;
406}

References mspass::utility::Metadata::get().

◆ ConvertToMetadata()

Metadata mspass::utility::AntelopePf::ConvertToMetadata ( )

Return an object with only simple name:value pairs.

The Metadata parent of this object only handles name:value pairs. The values can, however, be any object boost::any can handle. The documentation says that means it is copy constructable. For now this method returns an object containin the boost::any values. Any Arr and Tbl entries are pushed directly to the output Metadata using boost::any and the two keys defined as const strings at the top of this file (pftbl_key and pfarr_key).

Returns
Metadata sans any Arr and Tbl entries.
423 {
424 try {
425 Metadata result(dynamic_cast<Metadata &>(*this));
426 boost::any aTbl = this->pftbls;
427 // boost::any<map<string,list<string>> aTbl(this->pftbl);
428 boost::any aArr = this->pfbranches;
429 result.put<boost::any>(pftbl_key, aTbl);
430 result.put<boost::any>(pfarr_key, aArr);
431 return result;
432 } catch (...) {
433 throw;
434 };
435}

References mspass::utility::Metadata::get().

◆ get_branch()

AntelopePf mspass::utility::AntelopePf::get_branch ( const std::string  key) const

used for subtrees (nested Arrs in antelope)

This method is used for nested Arr constructs. This returns a copy of the branch defined by key attached to this object. The original from the parent is retained.

Parameters
keyis the key used to locate this branch.
Returns
a copy of the contents of the branch linked to key.
Exceptions
AntelopePfErrorwill be thrown if the key is not found.
392 {
393 map<string, AntelopePf>::const_iterator iptr;
394 iptr = pfbranches.find(key);
395 if (iptr == pfbranches.end())
396 throw AntelopePfError("get_branch failed trying to find data for key=" +
397 key);
398 return iptr->second;
399}

References mspass::utility::Metadata::get().

◆ get_tbl()

list< string > mspass::utility::AntelopePf::get_tbl ( const std::string  key) const

get a Tbl component by key.

Antelope has the idea of a tbl, which is a list of lines that are parsed independently. This is the get method to extract one of these by its key.

Parameters
keyis the key for the Tbl desired.
Exceptions
AntelopePfErrorwill be thrown if the key is not present.
385 {
387 iptr = pftbls.find(key);
388 if (iptr == pftbls.end())
389 throw AntelopePfError("get_tbl failed trying to find data for key=" + key);
390 return (iptr->second);
391}

References mspass::utility::Metadata::get().

◆ operator=()

Standard assignment operator,

414 {
415 if (this != &parent) {
416 /* This uses a trick to use operator = of the parent object */
418 pftbls = parent.pftbls;
419 pfbranches = parent.pfbranches;
420 }
421 return (*this);
422}
Metadata & operator=(const Metadata &mdold)
Definition Metadata.cc:90

References mspass::utility::Metadata::get(), and mspass::utility::Metadata::operator=().

◆ pfwrite()

void mspass::utility::AntelopePf::pfwrite ( std::ostream &  ofs)

save result in a pf format.

This is functionally equivalent to the Antelope pfwrite procedure, but is a member of this object. A feature of the current implementation is that all simply type parameters will usually be listed twice in the output file. The reason is that the constructor attempts to guess type, but to allow for mistakes all simple parameters are also treated as string variables so get methods are more robust.

Parameters
ofsis a std::ostream (e.g. cout) where the result will be written in pf style. Usually should end in ".pf".

◆ tbl_keys()

list< string > mspass::utility::AntelopePf::tbl_keys ( ) const

Return a list of keys for Tbls in the pf.

407 {
409 list<string> result;
410 for (iptr = pftbls.begin(); iptr != pftbls.end(); ++iptr)
411 result.push_back((*iptr).first);
412 return (result);
413}

References mspass::utility::Metadata::get().


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