ATLAS Offline Software
Loading...
Searching...
No Matches
SH::DiskListXRD Class Reference

a DiskList implementation for the XRD protocol More...

#include <DiskListXRD.h>

Inheritance diagram for SH::DiskListXRD:
Collaboration diagram for SH::DiskListXRD:

Public Member Functions

void testInvariant () const
 test the invariant of this object
 DiskListXRD (const std::string &val_server, const std::string &val_dir, bool val_laxParsing=false)
 make the listing for the given directory, but replacing the directory with prefix for the path
bool next ()
 get the next list entry
std::string path () const
 the path for the current entry.
std::string fileName () const
 the filename for the current entry
DiskListopenDir () const
 make a new list object for the sub-directory
std::string dirname () const
 the base path for the directory listed

Protected Member Functions

virtual bool getNext ()
 get the next list entry
virtual std::string getPath () const
 the path for the current entry.
virtual DiskListdoOpenDir () const
 make a new list object for the sub-directory
virtual std::string getDirname () const
 the base path for the directory listed

Private Types

enum  State { S_BLANK , S_VALID , S_DONE , S_BROKEN }
 the current state More...

Private Attributes

std::string m_server
 the server from which we are reading
std::string m_directory
 the directory we are reading
bool m_laxParser
 whether we employ lax parsing
std::string m_context
 the context (for error reporting)
std::string m_list
 the result of the directory listing
std::string m_file
 the last file we read
bool m_isDir = false
 whether this is a directory
bool m_isRead
 whether the directory has been read
State m_state
 the current state

Detailed Description

a DiskList implementation for the XRD protocol

Definition at line 17 of file DiskListXRD.h.

Member Enumeration Documentation

◆ State

enum SH::DiskList::State
privateinherited

the current state

Enumerator
S_BLANK 

just initialized

S_VALID 

holding a valid entry

S_DONE 

finished reading entries

S_BROKEN 

an error occured

Definition at line 158 of file DiskList.h.

159 {
160 S_BLANK,
161 S_VALID,
162 S_DONE,
163 S_BROKEN
164 };
@ S_VALID
holding a valid entry
Definition DiskList.h:161
@ S_DONE
finished reading entries
Definition DiskList.h:162
@ S_BROKEN
an error occured
Definition DiskList.h:163
@ S_BLANK
just initialized
Definition DiskList.h:160

Constructor & Destructor Documentation

◆ DiskListXRD()

SH::DiskListXRD::DiskListXRD ( const std::string & val_server,
const std::string & val_dir,
bool val_laxParsing = false )

make the listing for the given directory, but replacing the directory with prefix for the path

Parameters
val_dirthe directory to list
val_prefixthe prefix with which val_dir will be replaced in the reported paths
val_laxParsingif true, graciously skip over any error messages.
Guarantee
strong
Failures
out of memory II
Rationale
this mechanism is meant to allow scanning file servers using one protocol, but then accessing them using another

Definition at line 35 of file DiskListXRD.cxx.

38 : m_server (val_server), m_directory (val_directory),
39 m_laxParser (val_laxParser), m_isRead (false)
40 {
41 RCU_NEW_INVARIANT (this);
42 }
#define RCU_NEW_INVARIANT(x)
Definition Assert.h:228
std::string m_server
the server from which we are reading
Definition DiskListXRD.h:84
bool m_laxParser
whether we employ lax parsing
Definition DiskListXRD.h:92
std::string m_directory
the directory we are reading
Definition DiskListXRD.h:88
bool m_isRead
whether the directory has been read

Member Function Documentation

◆ dirname()

std::string SH::DiskList::dirname ( ) const
inherited

the base path for the directory listed

Guarantee
strong
Failures
out of memory II

Definition at line 103 of file DiskList.cxx.

105 {
106 RCU_READ_INVARIANT (this);
107 return getDirname ();
108 }
#define RCU_READ_INVARIANT(x)
Definition Assert.h:224
virtual std::string getDirname() const =0
the base path for the directory listed

◆ doOpenDir()

DiskList * SH::DiskListXRD::doOpenDir ( ) const
protectedvirtual

make a new list object for the sub-directory

Returns
a new list object for the sub-directory, or NULL if it is not a directory
Precondition
(soft) next() has been called successfully
Guarantee
strong
Failures
out of memory III
Rationale
the virtual part of DiskList::openDir()

Implements SH::DiskList.

Definition at line 106 of file DiskListXRD.cxx.

108 {
109 RCU_READ_INVARIANT (this);
110
111 if (m_file.empty() || !m_isDir)
112 return 0;
113
114 return new DiskListXRD (m_server, m_file, m_laxParser);
115 }
DiskListXRD(const std::string &val_server, const std::string &val_dir, bool val_laxParsing=false)
make the listing for the given directory, but replacing the directory with prefix for the path
bool m_isDir
whether this is a directory
std::string m_file
the last file we read

◆ fileName()

std::string SH::DiskList::fileName ( ) const
inherited

the filename for the current entry

Returns
the filename for the current entry
Precondition
(soft) next() has been called successfully
Guarantee
strong
Failures
out of memory III

Definition at line 80 of file DiskList.cxx.

82 {
83 // no invariant used
84 std::string result = path();
85 std::string::size_type split = result.rfind ('/');
86 if (split != std::string::npos)
87 result = result.substr (split + 1);
88 return result;
89 }
std::string path() const
the path for the current entry.
Definition DiskList.cxx:71
std::vector< std::string > split(const std::string &s, const std::string &t=":")
Definition hcg.cxx:179

◆ getDirname()

std::string SH::DiskListXRD::getDirname ( ) const
protectedvirtual

the base path for the directory listed

Guarantee
strong
Failures
out of memory II
Rationale
the virtual part of DiskList::dirname()

Implements SH::DiskList.

Definition at line 119 of file DiskListXRD.cxx.

121 {
122 RCU_READ_INVARIANT (this);
123 return m_directory;
124 }

◆ getNext()

bool SH::DiskListXRD::getNext ( )
protectedvirtual

get the next list entry

Returns
whether we found another entry
Guarantee
basic
Failures
i/o errors
Rationale
the virtual part of DiskList::next()

Implements SH::DiskList.

Definition at line 46 of file DiskListXRD.cxx.

48 {
50 using namespace msgScanDir;
51
52 if (!m_isRead)
53 {
54 std::string command = "xrdfs " + m_server + " ls -l " + m_directory;
55 ANA_MSG_DEBUG ("trying XRD command: " << command);
56 m_list = RCU::Shell::exec_read (command);
57 ANA_MSG_DEBUG ("XRD command output:\n" << command);
58 m_context = "command: " + command + "\n" + m_list;
59 m_isRead = true;
60 }
61
62 while (!m_list.empty())
63 {
64 std::string::size_type split1 = m_list.find ('\n');
65 if (split1 == std::string::npos)
66 split1 = m_list.size();
67
68 const std::string line (m_list.substr (0, split1));
69 ANA_MSG_DEBUG ("next XRD list line: " << line);
70 m_list = m_list.substr (split1 + 1);
71
72 std::string::size_type split2 = line.find ('/');
73 if (split2 != std::string::npos &&
74 (line[0] == '-' || line[0] == 'd'))
75 {
76 m_isDir = line[0] == 'd';
77 m_file = line.substr (split2);
78 ANA_MSG_DEBUG ("next XRD file found: " << m_file);
79 ANA_MSG_DEBUG ("XRD file isDir: " << m_isDir);
80 return true;
81 }
82
83 if (!line.empty())
84 {
85 std::string message = "failed to parse line: \"" + line + "\"\n" + m_context;
86
87 ANA_MSG_WARNING (message);
88 if (!m_laxParser)
89 throw std::runtime_error (message);
90 }
91 }
92 return false;
93 }
#define RCU_CHANGE_INVARIANT(x)
Definition Assert.h:226
#define ANA_MSG_WARNING(xmsg)
Macro printing warning messages.
#define ANA_MSG_DEBUG(xmsg)
Macro printing debug messages.
std::string m_context
the context (for error reporting)
Definition DiskListXRD.h:96
std::string m_list
the result of the directory listing
std::string exec_read(const std::string &cmd)
effects: execute the given command and return the output returns: the output of the command guarantee...
Definition ShellExec.cxx:34

◆ getPath()

std::string SH::DiskListXRD::getPath ( ) const
protectedvirtual

the path for the current entry.

Returns
the path for the current entry
Precondition
(soft) next() has been called successfully
Guarantee
strong failures: out of memory III
Rationale
the virtual part of DiskList::path()

Implements SH::DiskList.

Definition at line 97 of file DiskListXRD.cxx.

99 {
100 RCU_READ_INVARIANT (this);
101 return "root://" + m_server + "/" + m_file;
102 }

◆ next()

bool SH::DiskList::next ( )
inherited

get the next list entry

Returns
whether we found another entry
Guarantee
basic
Failures
i/o errors

Definition at line 46 of file DiskList.cxx.

48 {
50 switch (m_state)
51 {
52 case S_BLANK:
53 case S_VALID:
55 if (getNext())
57 else
59 return m_state == S_VALID;
60 case S_DONE:
61 RCU_THROW_MSG ("already finished processing list");
62 case S_BROKEN:
63 RCU_THROW_MSG ("list is in error state");
64 };
65 return false; // compiler dummy
66 }
#define RCU_THROW_MSG(message)
Definition PrintMsg.h:53
State m_state
the current state
Definition DiskList.h:166
virtual bool getNext()=0
get the next list entry

◆ openDir()

DiskList * SH::DiskList::openDir ( ) const
inherited

make a new list object for the sub-directory

Returns
a new list object for the sub-directory, or NULL if it is not a directory
Precondition
(soft) next() has been called successfully
Guarantee
strong
Failures
out of memory III

Definition at line 93 of file DiskList.cxx.

95 {
96 RCU_READ_INVARIANT (this);
97 RCU_REQUIRE2_SOFT (m_state == S_VALID, "getNext() has not been called successfully");
98 return doOpenDir();
99 }
#define RCU_REQUIRE2_SOFT(x, y)
Definition Assert.h:150
virtual DiskList * doOpenDir() const =0
make a new list object for the sub-directory

◆ path()

std::string SH::DiskList::path ( ) const
inherited

the path for the current entry.

Returns
the path for the current entry
Precondition
(soft) next() has been called successfully
Guarantee
strong failures: out of memory III

Definition at line 70 of file DiskList.cxx.

72 {
73 RCU_READ_INVARIANT (this);
74 RCU_REQUIRE2_SOFT (m_state == S_VALID, "getNext() has not been called successfully");
75 return getPath();
76 }
virtual std::string getPath() const =0
the path for the current entry.

◆ testInvariant()

void SH::DiskListXRD::testInvariant ( ) const

test the invariant of this object

Guarantee
no-fail

Definition at line 28 of file DiskListXRD.cxx.

30 {
31 }

Member Data Documentation

◆ m_context

std::string SH::DiskListXRD::m_context
private

the context (for error reporting)

Definition at line 96 of file DiskListXRD.h.

◆ m_directory

std::string SH::DiskListXRD::m_directory
private

the directory we are reading

Definition at line 88 of file DiskListXRD.h.

◆ m_file

std::string SH::DiskListXRD::m_file
private

the last file we read

Definition at line 104 of file DiskListXRD.h.

◆ m_isDir

bool SH::DiskListXRD::m_isDir = false
private

whether this is a directory

Definition at line 108 of file DiskListXRD.h.

◆ m_isRead

bool SH::DiskListXRD::m_isRead
private

whether the directory has been read

Definition at line 112 of file DiskListXRD.h.

◆ m_laxParser

bool SH::DiskListXRD::m_laxParser
private

whether we employ lax parsing

Definition at line 92 of file DiskListXRD.h.

◆ m_list

std::string SH::DiskListXRD::m_list
private

the result of the directory listing

Definition at line 100 of file DiskListXRD.h.

◆ m_server

std::string SH::DiskListXRD::m_server
private

the server from which we are reading

Definition at line 84 of file DiskListXRD.h.

◆ m_state

State SH::DiskList::m_state
privateinherited

the current state

Definition at line 166 of file DiskList.h.


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