// // aegis - project change supervisor // Copyright (C) 1997, 2002, 2005-2008, 2012 Peter Miller // // This program 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. // // This program 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 this program. If not, see // . // #ifndef AEFIND_FUNCTION_STAT_H #define AEFIND_FUNCTION_STAT_H #include class tree_list; // forward /** * The tree_atime class is used to represent an expression tree which * evatuates to the time-last-accessed of the file argument. */ class tree_atime: public tree_monadic { public: /** * The destructor. */ virtual ~tree_atime(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_atime(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_atime(); /** * The copy constructor. Do not use. */ tree_atime(const tree_atime &); /** * The assignment operator. Do not use. */ tree_atime &operator=(const tree_atime &); }; /** * The tree_ctime class is used to represent an expression tree which * evatuates to teh time-inode-last-modified of the file argument. */ class tree_ctime: public tree_monadic { public: /** * The destructor. */ virtual ~tree_ctime(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_ctime(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_ctime(); /** * The copy constructor. Do not use. */ tree_ctime(const tree_ctime &); /** * The assignment operator. Do not use. */ tree_ctime &operator=(const tree_ctime &); }; /** * The tree_gid class is used to represent an expression tree which * evatuates to the group ID of the filename argument. */ class tree_gid: public tree_monadic { public: /** * The destructor. */ virtual ~tree_gid(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_gid(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_gid(); /** * The copy constructor. Do not use. */ tree_gid(const tree_gid &); /** * The assignment operator. Do not use. */ tree_gid &operator=(const tree_gid &); }; /** * The tree_ino class is used to represent an expression tree which * evatuates to the inode number of the file argument. */ class tree_ino: public tree_monadic { public: /** * The destructor. */ virtual ~tree_ino(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_ino(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_ino(); /** * The copy constructor. Do not use. */ tree_ino(const tree_ino &); /** * The assignment operator. Do not use. */ tree_ino &operator=(const tree_ino &); }; /** * The tree_mode class is used to represent an expression tree which * evatuates to the file permissions mode bits of the argument file. */ class tree_mode: public tree_monadic { public: /** * The destructor. */ virtual ~tree_mode(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_mode(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_mode(); /** * The copy constructor. Do not use. */ tree_mode(const tree_mode &); /** * The assignment operator. Do not use. */ tree_mode &operator=(const tree_mode &); }; /** * The tree_mtime class is used to represent an expression tree which * evatuates to the last-time-modified of the file argument. */ class tree_mtime: public tree_monadic { public: /** * The destructor. */ virtual ~tree_mtime(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_mtime(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_mtime(); /** * The copy constructor. Do not use. */ tree_mtime(const tree_mtime &); /** * The assignment operator. Do not use. */ tree_mtime &operator=(const tree_mtime &); }; /** * The tree_nlink class is used to represent an expression tree which * evatuates to the number of links to the filename argument. */ class tree_nlink: public tree_monadic { public: /** * The destructor. */ virtual ~tree_nlink(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_nlink(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_nlink(); /** * The copy constructor. Do not use. */ tree_nlink(const tree_nlink &); /** * The assignment operator. Do not use. */ tree_nlink &operator=(const tree_nlink &); }; /** * The tree_size class is used to represent an expression tree which * evatuates to the size in bytes of the filename argument. */ class tree_size: public tree_monadic { public: /** * The destructor. */ virtual ~tree_size(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_size(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_size(); /** * The copy constructor. Do not use. */ tree_size(const tree_size &); /** * The assignment operator. Do not use. */ tree_size &operator=(const tree_size &); }; /** * The tree_uid class is used to represent an expression tree which * evatuates to the user ID of the owner of the filename argument. */ class tree_uid: public tree_monadic { public: /** * The destructor. */ virtual ~tree_uid(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_uid(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_uid(); /** * The copy constructor. Do not use. */ tree_uid(const tree_uid &); /** * The assignment operator. Do not use. */ tree_uid &operator=(const tree_uid &); }; /** * The tree_type class is used to represent an expression tree which * evatuates to the name of the type of the filename argument. */ class tree_type: public tree_monadic { public: /** * The destructor. */ virtual ~tree_type(); private: /** * The constructor. It is private on purpose, use the "create" * clas smethod instead. */ tree_type(const pointer &arg); public: /** * The create class method is used to create new dynamically * allocated instance of this class. * * @param arg * The singel argument to this function. */ static pointer create(const pointer &arg); /** * The create_l class method is used to create new dynamically * allocated instance of this class. * * @param args * The arguments to this function. */ static pointer create_l(const tree_list &args); protected: // See base class for documentation. const char *name() const; // See base class for documentation. rpt_value::pointer evaluate(string_ty *, string_ty *, string_ty *, struct stat *) const; // See base class for documentation. tree::pointer optimize() const; private: /** * The default constructor. Do not use. */ tree_type(); /** * The copy constructor. Do not use. */ tree_type(const tree_type &); /** * The assignment operator. Do not use. */ tree_type &operator=(const tree_type &); }; #endif // AEFIND_FUNCTION_STAT_H // vim: set ts=8 sw=4 et :