char *proxy;
char *time;
char *homedir;
+ char *logfile;
int bash;
enum host host;
};
fprintf(stdout, " --password password\n");
fprintf(stdout, " --proxy PROXY:PORT\n");
fprintf(stdout, " --host HOST\n");
+ fprintf(stdout, " --logfile logfile\n");
fprintf(stdout, " --bash\n");
fprintf(stdout, " --debug\n");
fprintf(stdout, " --version\n");
char *password = NULL;
char *host = NULL;
char *proxy = NULL;
+ char *logfile = NULL;
char *file;
/* config file is ~/.bti */
c += 6;
if (c[0] != '\0')
proxy = strdup(c);
+ } else if (!strncasecmp(c, "logfile", 7) &&
+ (c[7] == '=')) {
+ c += 8;
+ if (c[0] != '\0')
+ logfile = strdup(c);
}
} while (!feof(config_file));
free(session->proxy);
session->proxy = proxy;
}
+ if (logfile)
+ session->logfile = logfile;
/* Free buffer and close file. */
free(line);
char *filename;
char *host;
- /* logfile is ~/.bti.log */
- filename = alloca(strlen(session->homedir) + 10);
+ /* Only log something if we have a log file set */
+ if (!session->logfile)
+ return;
- sprintf(filename, "%s/.bti.log", session->homedir);
+ filename = alloca(strlen(session->homedir) +
+ strlen(session->logfile) + 3);
+
+ sprintf(filename, "%s/%s", session->homedir, session->logfile);
log_file = fopen(filename, "a+");
if (log_file == NULL)
{ "password", 1, NULL, 'p' },
{ "host", 1, NULL, 'H' },
{ "proxy", 1, NULL, 'P' },
+ { "logfile", 1, NULL, 'L' },
{ "help", 0, NULL, 'h' },
{ "bash", 0, NULL, 'b' },
{ "version", 0, NULL, 'v' },
session->proxy = strdup(optarg);
dbg("proxy = %s\n", session->proxy);
break;
+ case 'L':
+ if (session->logfile)
+ free(session->logfile);
+ session->logfile = strdup(optarg);
+ dbg("logfile = %s\n", session->logfile);
+ break;
case 'H':
if (strcasecmp(optarg, "twitter") == 0)
session->host = HOST_TWITTER;
if (retval && !session->bash)
fprintf(stderr, "tweet failed\n");
-// log_session(session, retval);
+ log_session(session, retval);
exit:
session_free(session);
return retval;;