summaryrefslogtreecommitdiff
path: root/recordmydesktop/src/parseargs.c
diff options
context:
space:
mode:
Diffstat (limited to 'recordmydesktop/src/parseargs.c')
-rw-r--r--recordmydesktop/src/parseargs.c586
1 files changed, 0 insertions, 586 deletions
diff --git a/recordmydesktop/src/parseargs.c b/recordmydesktop/src/parseargs.c
deleted file mode 100644
index 863f34f..0000000
--- a/recordmydesktop/src/parseargs.c
+++ /dev/null
@@ -1,586 +0,0 @@
-/******************************************************************************
-* recordMyDesktop *
-*******************************************************************************
-* *
-* Copyright (C) 2006,2007,2008 John Varouhakis *
-* *
-* *
-* 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 2 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, write to the Free Software *
-* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
-* *
-* *
-* *
-* For further information contact me at johnvarouhakis@gmail.com *
-******************************************************************************/
-
-#include "config.h"
-
-#include "rmdtypes.h"
-
-#include "rmd_rescue.h"
-#include "rmdmacro.h"
-
-
-static void PrintConfig(void) {
- fprintf(stderr,"\nrecordMyDesktop was compiled with"
- " the following options:\n\n");
-#ifdef HAVE_JACK_H
- fprintf(stdout,"Jack\t\t\t:Enabled\n");
-#else
- fprintf(stdout,"Jack\t\t\t:Disabled\n");
-#endif
-#ifdef HAVE_LIBASOUND
- fprintf(stdout,"Default Audio Backend\t:ALSA\n");
-#else
- fprintf(stdout,"Default Audio Backend\t:OSS\n");
-#endif
- fprintf(stderr,"\n\n");
-}
-
-boolean ParseArgs(int argc, char **argv, ProgArgs *arg_return) {
- int i;
- char *usage="\nUsage:\n"
- "\trecordmydesktop [OPTIONS]^filename\n\n\n"
-
- "General Options:\n"
- "\t-h or --help\t\tPrint this help and exit.\n"
- "\t--version\t\tPrint program version and exit.\n"
- "\t--print-config\t\tPrint info about options "
- "selected during compilation and exit.\n\n"
-
- "Image Options:\n"
- "\t-windowid id_of_window\tid of window to be recorded.\n"
- "\t-display DISPLAY\tDisplay to connect to.\n"
- "\t-x X\t\t\tOffset in x direction.\n"
- "\t-y Y\t\t\tOffset in y direction.\n"
- "\t-width N\t\tWidth of recorded window.\n"
- "\t-height N\t\tHeight of recorded window.\n\n"
-
- "\t-dummy-cursor color\tColor of the dummy cursor [black|white]\n"
- "\t--no-cursor\t\tDisable drawing of the cursor.\n"
- "\t--no-shared\t\tDisable usage of"
- " MIT-shared memory extension(Not Recommended!).\n"
-
- "\t--full-shots\t\tTake full screenshot at every frame(Not recomended!).\n"
- "\t--quick-subsampling\tDo subsampling"
- " of the chroma planes by discarding,not averaging.\n"
-
- "\t-fps N(number>0.0)\tA positive number denoting desired framerate.\n\n"
-
- "Sound Options:\n"
- "\t-channels N\t\t\tA positive number denoting"
- " desired sound channels in recording.\n"
-
- "\t-freq N\t\t\t\tA positive number denoting desired sound frequency.\n"
- "\t-buffer-size N\t\t\tA positive number denoting the desired"
- " sound buffer size (in frames,when using ALSA or OSS)\n"
- "\t-ring-buffer-size N\t\tA float number denoting the desired"
- " ring buffer size (in seconds,when using JACK only).\n"
-
- "\t-device SOUND_DEVICE\t\tSound device(default "
- DEFAULT_AUDIO_DEVICE
- ").\n"
- "\t-use-jack port1 port2... portn\tRecord audio from the specified\n"
- "\t\t\t\t\tlist of space-separated jack ports.\n"
- "\t--no-sound\t\t\tDo not record sound.\n\n"
-
- "Encoding Options\n"
- "\t--on-the-fly-encoding\tEncode the audio-video data, while recording.\n"
- "\t-v_quality n\t\tA number from 0 to 63 for"
- " desired encoded video quality(default 63).\n"
-
- "\t-v_bitrate n\t\tA number from 45000 to 2000000"
- " for desired encoded video bitrate(default 45000).\n"
-
- "\t-s_quality n\t\tDesired audio quality(-1 to 10).\n\n"
-
- "Misc Options:\n"
- "\t-rescue path_to_data\tEncode data from a previous, crashed, session.\n"
- "\t--no-wm-check\t\tDo not try to detect"
- " the window manager(and set options according to it)\n"
-
- "\t-pause-shortcut MOD+KEY\tShortcut that will be used for (un)pausing"
- "(default Control+Mod1+p).\n"
- "\t-stop-shortcut MOD+KEY\tShortcut that will be used to stop the "
- "recording (default Control+Mod1+s).\n"
-
- "\t--compress-cache\tImage data are cached with light compression.\n"
- "\t-workdir DIR\t\tLocation where a temporary directory"
- " will be created to hold project files(default $HOME).\n"
-
- "\t-delay n[H|h|M|m]\tNumber of secs(default),minutes or hours"
- " before capture starts(number can be float)\n"
-
- "\t--overwrite\t\tIf there is already a file with the same name,"
- " delete it\n"
-
- "\t\t\t\t(default is to add a number postfix to the new one).\n"
- "\t-o filename\t\tName of recorded video(default out.ogv).\n"
- "\n\tIf no other options are specified, filename can be given "
- "without the -o switch.\n\n\n";
-
- if(argc==2){
- if(argv[1][0]!='-'){
- free(arg_return->filename);
- arg_return->filename=malloc(strlen(argv[1])+1);
- strcpy(arg_return->filename,argv[1]);
- return TRUE;
- }
- }
- for(i=1;i<argc;i++){
- if(!strcmp(argv[i],"-delay")){
- if(i+1<argc){
- float num=atof(argv[i+1]);
- if(num>0.0){
- int k;
- for(k=0;k<strlen(argv[i+1]);k++){
- if((argv[i+1][k]=='M')||(argv[i+1][k]=='m')){
- num*=60.0;
- break;
- }
- else if((argv[i+1][k]=='H')||(argv[i+1][k]=='h')){
- num*=3600.0;
- break;
- }
- }
- arg_return->delay=(int)num;
- }
- else{
- fprintf(stderr,"Argument Usage: -delay n[H|h|M|m]\n"
- "where n is a float number\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -delay n[H|h|M|m]\n"
- "where n is a float number\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-windowid")){
- if(i+1<argc){
- Window num=strtod(argv[i+1],NULL);
- if(num>0)
- arg_return->windowid=num;
- else{
- fprintf(stderr,"Argument Usage:"
- " -windowid id_of_window(number)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage:"
- " -windowid id_of_window(number)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-display")){
- if(i+1<argc){
- if(arg_return->display!=NULL)
- free(arg_return->display);
- arg_return->display=malloc(strlen(argv[i+1])+1);
- strcpy(arg_return->display,argv[i+1]);
- }
- else{
- fprintf(stderr,"Argument Usage: -display DISPLAY\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-x")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->x=num;
- else{
- fprintf(stderr,"Argument Usage: -x X(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -x X(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-y")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->y=num;
- else{
- fprintf(stderr,"Argument Usage: -y Y(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -y Y(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-width")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->width=num;
- else{
- fprintf(stderr,"Argument Usage: -width N(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -width N(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-height")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->height=num;
- else{
- fprintf(stderr,"Argument Usage: -height N(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -height N(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-o")){
- if(i+1<argc){
- free(arg_return->filename);
- arg_return->filename=malloc(strlen(argv[i+1])+1);
- strcpy(arg_return->filename,argv[i+1]);
- }
- else{
- fprintf(stderr,"Argument Usage: -o filename\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-fps")){
- if(i+1<argc){
- float num=atof(argv[i+1]);
- if(num>0.0)
- arg_return->fps=num;
- else{
- fprintf(stderr,"Argument Usage: -fps N(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -fps N(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-v_quality")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if((num>=0)&&(num<64))
- arg_return->v_quality=num;
- else{
- fprintf(stderr,"Argument Usage:"
- " -v_quality n(number 0-63)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage:"
- " -v_quality n(number 0-63)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-v_bitrate")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if((num>=45000)&&(num<=2000000))
- arg_return->v_bitrate=num;
- else{
- fprintf(stderr,"Argument Usage:"
- " -v_bitrate n(number 45000-2000000)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage:"
- " -v_bitrate n(number 45000-2000000)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-dummy-cursor")){
- if(i+1<argc){
- if(!strcmp(argv[i+1],"white"))
- arg_return->cursor_color=0;
- else if(!strcmp(argv[i+1],"black"))
- arg_return->cursor_color=1;
- else{
- fprintf(stderr,"Argument Usage:"
- " -dummy-cursor [black|white]\n");
- return FALSE;
- }
- arg_return->have_dummy_cursor=1;
- arg_return->xfixes_cursor=0;
- }
- else{
- fprintf(stderr,"Argument Usage:"
- " -dummy-cursor [black|white]\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"--no-cursor"))
- arg_return->xfixes_cursor=0;
- else if(!strcmp(argv[i],"-freq")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->frequency=num;
- else{
- fprintf(stderr,"Argument Usage: -freq N(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -freq N(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-channels")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->channels=num;
- else{
- fprintf(stderr,"Argument Usage: -channels N(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -channels N(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-s_quality")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if((num>=-1)&&(num<=10))
- arg_return->s_quality=num;
- else{
- fprintf(stderr,"Argument Usage:"
- " -s_quality n(number -1 to 10)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage:"
- " -s_quality n(number -1 to 10)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-device")){
- if(i+1<argc){
- free(arg_return->device);
- arg_return->device=malloc(strlen(argv[i+1])+1);
- strcpy(arg_return->device,argv[i+1]);
- }
- else{
- fprintf(stderr,"Argument Usage: -device SOUND_DEVICE\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-workdir")){
- if(i+1<argc){
- free(arg_return->workdir);
- arg_return->workdir=malloc(strlen(argv[i+1])+1);
- strcpy(arg_return->workdir,argv[i+1]);
- }
- else{
- fprintf(stderr,"Argument Usage: -workdir DIR\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-pause-shortcut")){
- if(i+1<argc){
- free(arg_return->pause_shortcut);
- arg_return->pause_shortcut=malloc(strlen(argv[i+1])+1);
- strcpy(arg_return->pause_shortcut,argv[i+1]);
- }
- else{
- fprintf(stderr,"Argument Usage: -pause-shortcut MOD+KEY\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-stop-shortcut")){
- if(i+1<argc){
- free(arg_return->stop_shortcut);
- arg_return->stop_shortcut=malloc(strlen(argv[i+1])+1);
- strcpy(arg_return->stop_shortcut,argv[i+1]);
- }
- else{
- fprintf(stderr,"Argument Usage: -stop-shortcut MOD+KEY\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-buffer-size")){
- if(i+1<argc){
- int num=atoi(argv[i+1]);
- if(num>0)
- arg_return->buffsize=num;
- else{
- fprintf(stderr,"Argument Usage:"
- " -buffer-size N(number>0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: -buffer-size N(number>0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-use-jack")){
- if(i+1<argc){
-#ifdef HAVE_JACK_H
- int k=i+1;
- arg_return->jack_nports=0;
- while((k<argc)&&(argv[k][0]!='-')){
- arg_return->jack_nports++;
- k++;
- }
- if(arg_return->jack_nports>0){
- arg_return->jack_port_names=malloc(sizeof(char*)*
- arg_return->jack_nports);
- for(k=i+1;k<i+1+arg_return->jack_nports;k++){
- arg_return->jack_port_names[k-i-1]=
- malloc(strlen(argv[k])+1);
- strcpy(arg_return->jack_port_names[k-i-1],
- argv[k]);
- }
- i+=arg_return->jack_nports;
- arg_return->use_jack=1;
- }
- else{
- fprintf(stderr,"Argument Usage: -use-jack port1"
- " port2... portn\n");
- return FALSE;
- }
-#else
- fprintf(stderr,"recordMyDesktop is not compiled"
- " with Jack support!\n");
- return FALSE;
-#endif
- }
- else{
- fprintf(stderr,"Argument Usage: -use-jack port1"
- " port2... portn\n");
- return FALSE;
- }
- }
- else if(!strcmp(argv[i],"-ring-buffer-size")){
- if(i+1<argc){
- float num=atof(argv[i+1]);
- if(num>0.0)
- arg_return->jack_ringbuffer_secs=num;
- else{
- fprintf(stderr,"Argument Usage: --ring-buffer-size"
- " N(floating point number>0.0)\n");
- return FALSE;
- }
- }
- else{
- fprintf(stderr,"Argument Usage: --ring-buffer-size"
- " N(floating point number>0.0)\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"-rescue")){
- if(i+1<argc){
- int ex_st=rmdRescue(argv[i+1]);
- exit(ex_st);
- }
- else{
- fprintf(stderr,"Argument Usage: -rescue path_to_data\n");
- return FALSE;
- }
- i++;
- }
- else if(!strcmp(argv[i],"--no-sound"))
- arg_return->nosound=1;
- else if(!strcmp(argv[i],"--no-shared")){
- arg_return->noshared=1;
- }
- else if(!strcmp(argv[i],"--full-shots")){
- arg_return->full_shots=1;
- }
- else if(!strcmp(argv[i],"--no-frame")){
- arg_return->noframe=1;
- }
- else if(!strcmp(argv[i],"--follow-mouse")){
- arg_return->full_shots=1;
- arg_return->follow_mouse=1;
- }
- else if(!strcmp(argv[i],"--no-encode"))
- arg_return->no_encode=1;
- else if(!strcmp(argv[i],"--quick-subsampling")){
- arg_return->no_quick_subsample=0;
- }
- else if(!strcmp(argv[i],"--on-the-fly-encoding")){
- arg_return->encOnTheFly=1;
- }
- else if(!strcmp(argv[i],"--overwrite"))
- arg_return->overwrite=1;
- else if(!strcmp(argv[i],"--no-wm-check"))
- arg_return->nowmcheck=1;
- else if(!strcmp(argv[i],"--compress-cache")){
- arg_return->zerocompression=0;
- }
- else if(!strcmp(argv[i],"--help")||!strcmp(argv[i],"-h")){
- fprintf(stderr,"%s",usage);
- exit(0);
- }
- else if(!strcmp(argv[i],"--version")){
- fprintf(stderr,"recordMyDesktop v%s\n\n",VERSION);
- exit(0);
- }
- else if(!strcmp(argv[i],"--print-config")){
- PrintConfig();
- exit(0);
- }
- else{
- fprintf(stderr,"\n\tError parsing arguments.\n\t"
- "Type --help or -h for usage.\n\n");
- return FALSE;
- }
- }
-
- return TRUE;
-}
© All Rights Reserved