// // aegis - project change supervisor // Copyright (C) 2004-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_CHANGE_H #define AECVSSERVER_MODULE_CHANGE_H #include #include #include struct project_ty; // forward struct string_ty; // forward /** * The module_change class is used to represent a CVS module * synthesized from an Aegis change set. */ class module_change: public module_ty { public: /** * The destructor. */ virtual ~module_change(); /** * The constructor. * * @param arg * The change being managed. */ module_change(change::pointer 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: change::pointer cp; project_ty *pp; user_ty::pointer up; /** * The default constructor. */ module_change(); /** * The copy constructor. Do not use. */ module_change(const module_change &); /** * The assignment operator. Do not use. */ module_change &operator=(const module_change &); }; /** * The module_change_new function is used to create a new module based * on the project name and the change number. You rarely want to use * "new module_change(cp)" directly because this function will allocate * suitable bogus modules if there is an error in the project name or * change number. */ module_ty *module_change_new(string_ty *projname, long change_number); #endif // AECVSSERVER_MODULE_CHANGE_H