// // aegis - project change supervisor // Copyright (C) 2004-2006, 2008 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 AECVSSERVER_MODULE_PROJECT_H #define AECVSSERVER_MODULE_PROJECT_H #include class project_ty; // forward /** * The module_project class is used to represent a CVS module * synthesized from an Aegis project baseline. */ class module_project: public module_ty { public: /** * The destructor. */ virtual ~module_project(); /** * The constructor. */ module_project(project_ty *arg); // See base class for documentation. void modified(server_ty *sp, string_ty *file_name, file_info_ty *fip, input &contents); // See base class for documentation. bool checkin(server_ty *sp, string_ty *client_side, string_ty *server_side); // See base class for documentation. bool update(server_ty *sp, string_ty *client_side, string_ty *server_side, const options &opt); // See base class for documentation. bool add(server_ty *sp, string_ty *client_side, string_ty *server_side, const options &opt); // See base class for documentation. bool remove(server_ty *sp, string_ty *client_side, string_ty *server_side, const options &opt); // See base class for documentation. string_ty *calculate_canonical_name() const; private: project_ty *pp; /** * The groan method is used to output an error when an * inappropriate request is made of this module. */ void groan(server_ty *sp, const char *request_name); /** * The default constructor. Do not use. */ module_project(); /** * The copy constructor. Do not use. */ module_project(const module_project &); /** * The assignment operator. Do not use. */ module_project &operator=(const module_project &); }; /** * The module_project_new fucntion is used to dynamically allocate a * module based on the projet name. * * You should rarely use the "new module_project(pp)" expression, * because this function takes care of allocating module_project_bogus * for projects which don't exist. */ module_ty *module_project_new(string_ty *projname); #endif // AECVSSERVER_MODULE_PROJECT_H