/* This code is based on source provided under the terms of the Id Software LIMITED USE SOFTWARE LICENSE AGREEMENT, a copy of which is included with the GtkRadiant sources (see LICENSE_ID). If you did not receive a copy of LICENSE_ID, please contact Id Software immediately at info@idsoftware.com. All changes and additions to the original source which have been developed by other contributors (see CONTRIBUTORS) are provided under the terms of the license the contributors choose (see LICENSE), to the extent permitted by the LICENSE_ID. If you did not receive a copy of the contributor license, please contact the GtkRadiant maintainers at info@gtkradiant.com immediately. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ // // start of shared cmdlib stuff // #ifndef __CMDLIB__ #define __CMDLIB__ #include // TTimo started adding portability code: // return true if spawning was successful, false otherwise // on win32 we have a bCreateConsole flag to create a new console or run inside the current one //boolean Q_Exec(const char* pCmd, boolean bCreateConsole); // execute a system command: // cmd: the command to run // cmdline: the command line // NOTE TTimo following are win32 specific: // execdir: the directory to execute in // bCreateConsole: spawn a new console or not // return values; // if the spawn was fine // TODO TTimo add functionality to track the process until it dies bool Q_Exec( const char *cmd, char *cmdline, const char *execdir, bool bCreateConsole ); // some easy portability crap #define access_owner_read 0400 #define access_owner_write 0200 #define access_owner_execute 0100 #define access_owner_rw_ 0600 #define access_owner_r_x 0500 #define access_owner__wx 0300 #define access_owner_rwx 0700 #define access_group_read 0040 #define access_group_write 0020 #define access_group_execute 0010 #define access_group_rw_ 0060 #define access_group_r_x 0050 #define access_group__wx 0030 #define access_group_rwx 0070 #define access_others_read 0004 #define access_others_write 0002 #define access_others_execute 0001 #define access_others_rw_ 0006 #define access_others_r_x 0005 #define access_others__wx 0003 #define access_others_rwx 0007 #define access_rwxrwxr_x ( access_owner_rwx | access_group_rwx | access_others_r_x ) #define access_rwxrwxrwx ( access_owner_rwx | access_group_rwx | access_others_rwx ) // Q_mkdir // returns true if succeeded in creating directory #ifdef WIN32 #include inline bool Q_mkdir( const char* name ){ return _mkdir( name ) != -1; } #else #include inline bool Q_mkdir( const char* name ){ return mkdir( name, access_rwxrwxr_x ) != -1; } #endif inline double Sys_DoubleTime( void ){ return clock() / 1000.0; } #endif