static qboolean OnChange_movie_dir(cvar_t *var, char *string) { if (Movie_IsCapturing()) { Com_Printf("Cannot change demo_capture_dir whilst capturing. Use 'demo_capture stop' to cease capturing first.\n"); return true; } else if (strlen(string) > 31) { Com_Printf("demo_capture_dir can only contain a maximum of 31 characters\n"); return true; } Util_Process_Filename(string); if (!(Util_Is_Valid_Filename(string))) { Com_Printf(Util_Invalid_Filename_Msg("demo_capture_dir")); return true; } return false; }
void Movie_Demo_Capture_f(void) { int argc; double time; char *error; #ifdef _WIN32 error = va("Usage: %s <start time [avifile] | stop>\n", Cmd_Argv(0)); if ((argc = Cmd_Argc()) != 2 && argc != 3 && argc != 4) { #else error = va("Usage: %s <start time | stop>\n", Cmd_Argv(0)); if ((argc = Cmd_Argc()) != 2 && argc != 3) { #endif Com_Printf(error); return; } if (argc == 2) { if (strncasecmp("stop", Cmd_Argv(1), 4)) Com_Printf(error); else if (Movie_IsCapturing()) Movie_Stop(); else Com_Printf("%s : Not capturing\n", Cmd_Argv(0)); return; } if (strncasecmp("start", Cmd_Argv(1), 5)) { Com_Printf(error); return; } else if (Movie_IsCapturing()) { Com_Printf("%s : Already capturing\n", Cmd_Argv(0)); return; } if (!cls.demoplayback || cls.timedemo) { Com_Printf("%s : Must be playing a demo to capture\n", Cmd_Argv(0)); return; } if ((time = Q_atof(Cmd_Argv(2))) <= 0) { Com_Printf("%s : Time argument must be positive\n", Cmd_Argv(0)); return; } #ifdef _WIN32 //joe: capturing to avi if (argc == 4) { avi_number = 0; strlcpy(movie_avi_filename, Cmd_Argv(3), sizeof(movie_avi_filename)-10); // Store user's requested filename if (!movie_avi_loaded) { Com_Printf_State (PRINT_FAIL, "Avi capturing not initialized\n"); return; } Movie_Start_AVI_Capture(movie_vid_maxlen.value > 0 && movie_vid_maxlen.value < time); } #endif Movie_Start(time); } #ifdef _WIN32 static void Movie_Start_AVI_Capture(qbool split) { ++avi_number; // If we're going to break up the movie, append number char aviname[MAX_OSPATH]; if (split) snprintf (aviname, sizeof(aviname), "%s-%03d", movie_avi_filename, avi_number); else strlcpy (aviname, movie_avi_filename, sizeof(aviname)); if (!(Util_Is_Valid_Filename(aviname))) { Com_Printf(Util_Invalid_Filename_Msg(aviname)); return; } COM_ForceExtensionEx (aviname, ".avi", sizeof (aviname)); snprintf (avipath, sizeof(avipath), "%s/%s/%s", com_basedir, movie_dir.string, aviname); if (!(avifile = fopen(avipath, "wb"))) { FS_CreatePath (avipath); if (!(avifile = fopen(avipath, "wb"))) { Com_Printf("Error: Couldn't open %s\n", aviname); return; } } }
static void Log_log_f(void) { char *fulllogname; FILE *templog; switch (Cmd_Argc()) { case 1: if (autologging) Com_Printf("Auto console logging is in progress\n"); else if (Log_IsLogging()) Com_Printf("Logging to %s\n", logfilename); else Com_Printf("Not logging\n"); return; case 2: if (!strcasecmp(Cmd_Argv(1), "stop")) { if (autologging) { Log_AutoLogging_StopMatch(); } else { if (Log_IsLogging()) { Log_Stop(); Com_Printf("Stopped logging to %s\n", logfilename); } else { Com_Printf("Not logging\n"); } } return; } if (autologging) { Com_Printf("Auto console logging must be stopped first!\n"); return; } if (Log_IsLogging()) { Log_Stop(); Com_Printf("Stopped logging to %s\n", logfilename); } strlcpy(logfilename, Cmd_Argv(1), sizeof(logfilename) - 4); Util_Process_Filename(logfilename); if (!Util_Is_Valid_Filename(logfilename)) { Com_Printf(Util_Invalid_Filename_Msg("filename")); return; } COM_ForceExtensionEx (logfilename, ".log", sizeof (logfilename)); fulllogname = va("%s/%s", Log_LogDirectory(), logfilename); if (!(templog = fopen (fulllogname, log_readable.value ? "w" : "wb"))) { FS_CreatePath(fulllogname); if (!(templog = fopen (fulllogname, log_readable.value ? "w" : "wb"))) { Com_Printf("Error: Couldn't open %s\n", logfilename); return; } } Com_Printf("Logging to %s\n", logfilename); logfile = templog; break; default: Com_Printf("Usage: %s [filename | stop]\n", Cmd_Argv(0)); return; } }
void Movie_Demo_Capture_f(void) { int argc; double time; char *error; #ifdef _WIN32 error = va("Usage: %s <start time [avifile] | stop>\n", Cmd_Argv(0)); if ((argc = Cmd_Argc()) != 2 && argc != 3 && argc != 4) { #else error = va("Usage: %s <start time | stop>\n", Cmd_Argv(0)); if ((argc = Cmd_Argc()) != 2 && argc != 3) { #endif Com_Printf(error); return; } if (argc == 2) { if (strncasecmp("stop", Cmd_Argv(1), 4)) Com_Printf(error); else if (Movie_IsCapturing()) Movie_Stop(); else Com_Printf("%s : Not capturing\n", Cmd_Argv(0)); return; } if (strncasecmp("start", Cmd_Argv(1), 5)) { Com_Printf(error); return; } else if (Movie_IsCapturing()) { Com_Printf("%s : Already capturing\n", Cmd_Argv(0)); return; } if (!cls.demoplayback || cls.timedemo) { Com_Printf("%s : Must be playing a demo to capture\n", Cmd_Argv(0)); return; } if ((time = Q_atof(Cmd_Argv(2))) <= 0) { Com_Printf("%s : Time argument must be positive\n", Cmd_Argv(0)); return; } #ifdef _WIN32 //joe: capturing to avi if (argc == 4) { char aviname[MAX_OSPATH]; if (!movie_avi_loaded) { Com_Printf_State (PRINT_FAIL, "Avi capturing not initialized\n"); return; } strlcpy (aviname, Cmd_Argv(3), sizeof(aviname)); if (!(Util_Is_Valid_Filename(aviname))) { Com_Printf(Util_Invalid_Filename_Msg(aviname)); return; } COM_ForceExtensionEx (aviname, ".avi", sizeof (aviname)); snprintf (avipath, sizeof(avipath), "%s/%s/%s", com_basedir, movie_dir.string, aviname); if (!(avifile = fopen(avipath, "wb"))) { FS_CreatePath (avipath); if (!(avifile = fopen(avipath, "wb"))) { Com_Printf("Error: Couldn't open %s\n", aviname); return; } } } #endif Movie_Start(time); } void Movie_Init(void) { Cvar_SetCurrentGroup(CVAR_GROUP_DEMO); Cvar_Register(&movie_fps); Cvar_Register(&movie_dir); Cvar_Register(&movie_steadycam); Cvar_ResetCurrentGroup(); Cmd_AddCommand("demo_capture", Movie_Demo_Capture_f); #ifdef _WIN32 Capture_InitAVI (); //joe: capturing to avi if (!movie_avi_loaded) return; captured_audio_samples = 0; Cvar_SetCurrentGroup(CVAR_GROUP_DEMO); Cvar_Register(&movie_codec); Cvar_ResetCurrentGroup(); Capture_InitACM (); if (!movie_acm_loaded) return; Cvar_SetCurrentGroup(CVAR_GROUP_DEMO); Cvar_Register(&movie_mp3); Cvar_Register(&movie_mp3_kbps); Cvar_ResetCurrentGroup(); #endif }