/usr/include/anfo/conffile.h is in libanfo0-dev 0.98-6.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 | // Copyright 2009 Udo Stenzel
// This file is part of ANFO
//
// ANFO is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Anfo 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Anfo. If not, see <http://www.gnu.org/licenses/>.
#ifndef INCLUDED_CONFFILE_H
#define INCLUDED_CONFFILE_H
#include "config.pb.h"
#include <google/protobuf/io/zero_copy_stream_impl.h>
#include <google/protobuf/text_format.h>
#include <fstream>
#include <string>
#include <unistd.h>
/*! \page configuration Configuration Files, Metadata, Output Format
*
* In order to keep configuration files and somewhat complicated,
* persistent data structures in a sensible format and extensible, we
* abuse Google's protocol buffers (http://code.google.com/p/protobuf/)
* for this. Code to handle protocol buffers can be generated for C++,
* Java and Pyhton by the Google toolchain, but also for Haskell
* (http://hackage.haskell.org/cgi-bin/hackage-scripts/package/hprotoc)
* and possibly for more languages. The definition of the possible
* parts of the configuration resides in \c config.proto, we store the
* configuration in a single file using the protobuf text format.
* Metadata for genomes and indices is also defined there, those files
* incorporate their metadata in binary form. If the need arises, we
* can easily move to multiple files, binary files, or a combination of
* both. Text and binary files are interconvertible using \c protoc.
*/
//! \brief reads the configuration from a text file.
//! A text format configuration file is read and parsed into a config
//! object.
//!
//! \param filename filename of configuration file
//! \return parsed configuration
inline config::Config parse_text_config( const std::string& filename )
{
config::Config c ;
std::ifstream config_in( filename.c_str() ) ;
google::protobuf::io::IstreamInputStream fis( &config_in ) ;
if( !google::protobuf::TextFormat::Parse( &fis, &c ) )
throw "parse error reading " + filename ;
return c ;
}
inline config::Config get_default_config( const char* config_file = 0 )
{
if( config_file ) return parse_text_config( config_file ) ;
else if( !access( "anfo.cfg", F_OK ) ) return parse_text_config( "anfo.cfg" ) ;
else if( !access( ".anfo.cfg", F_OK ) ) return parse_text_config( ".anfo.cfg" ) ;
else {
std::string f = getenv( "HOME" ) + std::string( "/.anfo.cfg" ) ;
if( !access( f.c_str(), F_OK ) ) return parse_text_config( f.c_str() ) ;
else throw "no config file found" ;
}
}
#endif
|