projects
/
ppastats.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
(no commit message)
[ppastats.git]
/
src
/
main.c
diff --git
a/src/main.c
b/src/main.c
index
94f6f8d
..
cc7f625
100644
(file)
--- a/
src/main.c
+++ b/
src/main.c
@@
-1,5
+1,5
@@
/*
/*
- * Copyright (C) 2011-201
2
jeanfi@gmail.com
+ * Copyright (C) 2011-201
4
jeanfi@gmail.com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
@@
-26,17
+26,20
@@
#include <string.h>
#include "cache.h"
#include <string.h>
#include "cache.h"
+#include <fcache.h>
#include "html.h"
#include "html.h"
+#include "http.h"
#include "lp_ws.h"
#include "config.h"
#include "lp_ws.h"
#include "config.h"
+#include <plog.h>
#include "ppastats.h"
#include "ppastats.h"
-int debug;
static const char *program_name;
static void display_published_binaries(const char *owner,
const char *ppa,
static const char *program_name;
static void display_published_binaries(const char *owner,
const char *ppa,
- const char *package_status)
+ const char *package_status,
+ int ws_size)
{
struct ppa_stats *ppastats;
struct package_stats **packages;
{
struct ppa_stats *ppastats;
struct package_stats **packages;
@@
-44,7
+47,7
@@
static void display_published_binaries(const char *owner,
struct distro_stats **distros;
struct arch_stats **archs;
struct distro_stats **distros;
struct arch_stats **archs;
- ppastats = create_ppa_stats(owner, ppa, package_status);
+ ppastats = create_ppa_stats(owner, ppa, package_status
, ws_size
);
packages = ppastats->packages;
while (packages && *packages) {
struct package_stats *p = *packages;
packages = ppastats->packages;
while (packages && *packages) {
struct package_stats *p = *packages;
@@
-93,49
+96,52
@@
static struct option long_options[] = {
{"debug", no_argument, 0, 'd'},
{"status", required_argument, 0, 's'},
{"skip-js-css", no_argument, 0, 'S'},
{"debug", no_argument, 0, 'd'},
{"status", required_argument, 0, 's'},
{"skip-js-css", no_argument, 0, 'S'},
+ {"get-bpph-size", required_argument, 0, 0},
+ {"theme-dir", required_argument, 0, 't'},
{0, 0, 0, 0}
};
static void print_version()
{
printf("ppastats %s\n", VERSION);
{0, 0, 0, 0}
};
static void print_version()
{
printf("ppastats %s\n", VERSION);
- printf(_("Copyright (C) %s jeanfi@gmail.com\n
\
-License GPLv2: GNU GPL version 2 or later \
-<http://www.gnu.org/licenses/old-licenses/gpl-2.0.html>\n\
-This is free software: you are free to change and redistribute it.\n\
-There is NO WARRANTY, to the extent permitted by law.\n"),
-
"2011-2012
");
+ printf(_("Copyright (C) %s jeanfi@gmail.com\n
"
+"License GPLv2: GNU GPL version 2 or later\n"
+"<http://www.gnu.org/licenses/old-licenses/gpl-2.0.html>\n"
+"This is free software: you are free to change and redistribute it.\n"
+
"
There is NO WARRANTY, to the extent permitted by law.\n"),
+
"2011-2014
");
}
static void print_help()
{
printf(_("Usage: %s [OPTION]... PPA_OWNER PPA_NAME\n"), program_name);
}
static void print_help()
{
printf(_("Usage: %s [OPTION]... PPA_OWNER PPA_NAME\n"), program_name);
- puts(_("ppastats is a command application"
- " for generating PPA statistics.\n"));
-
- puts(_("Prints number of downloads for each published packages of a "
- "PPA or generates an HTML page containing a graph "
- "representation."));
+ puts(_(
+"ppastats is a command application for generating PPA statistics.\n"));
+ puts(_(
+"Prints number of downloads for each published packages of a PPA or generates\n"
+"an HTML page containing a graph representation."));
puts("");
puts(_("Options:"));
puts("");
puts(_("Options:"));
- puts(_("\
- -h, --help display this help and exit\n\
- -v, --version display version information and exit"));
+ puts(_(" -h, --help display this help and exit"));
+ puts(_(" -v, --version display version information and exit"));
puts("");
puts("");
- puts(_("
\
-
-o, --output-dir=[PATH] generates HTML pages into 'PATH'.
"));
+ puts(_("
-o, --output-dir=[PATH] generates HTML pages into 'PATH'"));
+
puts(_(" -t, --theme-dir=[PATH] set theme dir to 'PATH'
"));
- puts(_(
"\
- -s, --status=[STATUS] retrieves only package of the given status\n\
- (possible values are: Pending, Published, \n\
-
Superseded, Deleted or Obsolete).
"));
+ puts(_(
+" -s, --status=[STATUS] retrieves only package of the given status\n"
+" (possible values are: Pending, Published,\n"
+
" Superseded, Deleted or Obsolete)
"));
- puts(_("\
- -S, --skip-js-css skip installation of js and css files"));
+ puts(_(
+" -S, --skip-js-css skip installation of js and css files"));
+ puts(_(
+" --get-bpph-size=[s] size of the replies of webservice requests to get\n"
+" the list of binary packages. Between 1 and 300."));
puts("");
printf(_("Report bugs to: %s\n"), PACKAGE_BUGREPORT);
puts("");
printf(_("Report bugs to: %s\n"), PACKAGE_BUGREPORT);
@@
-145,8
+151,8
@@
static void print_help()
int main(int argc, char **argv)
{
int main(int argc, char **argv)
{
- char *owner, *ppa, *package_status, *output_dir;
- int optc, output_html, cmdok, install_static_files;
+ char *owner, *ppa, *package_status, *output_dir
, *theme_dir
;
+ int optc, output_html, cmdok, install_static_files
, ws_size, opti
;
program_name = argv[0];
program_name = argv[0];
@@
-159,16
+165,22
@@
int main(int argc, char **argv)
output_dir = NULL;
package_status = NULL;
output_html = 0;
output_dir = NULL;
package_status = NULL;
output_html = 0;
+ ws_size = -1;
+ theme_dir = NULL;
- while ((optc = getopt_long(argc, argv, "vho:ds:S", long_options,
-
NULL
)) != -1) {
+ while ((optc = getopt_long(argc, argv, "vho:
t:
ds:S", long_options,
+
&opti
)) != -1) {
switch (optc) {
switch (optc) {
+ case 0:
+ if (!strcmp(long_options[opti].name, "get-bpph-size"))
+ ws_size = atoi(optarg);
+ break;
case 'o':
output_html = 1;
output_dir = strdup(optarg);
break;
case 'd':
case 'o':
output_html = 1;
output_dir = strdup(optarg);
break;
case 'd':
-
debug = 1
;
+
log_level = LOG_DEBUG
;
break;
case 'h':
print_help();
break;
case 'h':
print_help();
@@
-180,6
+192,10
@@
int main(int argc, char **argv)
if (optarg)
package_status = strdup(optarg);
break;
if (optarg)
package_status = strdup(optarg);
break;
+ case 't':
+ if (optarg)
+ theme_dir = strdup(optarg);
+ break;
case 'S':
install_static_files = 0;
break;
case 'S':
install_static_files = 0;
break;
@@
-190,25
+206,39
@@
int main(int argc, char **argv)
}
if (!cmdok || optind + 2 != argc) {
}
if (!cmdok || optind + 2 != argc) {
- fprintf(stderr, _("Try `%s --help' for more information.\n"),
+ fprintf(stderr,
+ _("Try `%s --help' for more information.\n"),
program_name);
exit(EXIT_FAILURE);
}
program_name);
exit(EXIT_FAILURE);
}
+ log_open("ppastats.log");
+
owner = argv[optind];
ppa = argv[optind+1];
owner = argv[optind];
ppa = argv[optind+1];
- if (output_html)
- ppa_to_html(owner, ppa, package_status, output_dir,
- install_static_files);
- else
- display_published_binaries(owner, ppa, package_status);
+ if (output_html) {
+ if (theme_dir)
+ html_set_theme_dir(theme_dir);
+ else
+ html_set_theme_dir(DEFAULT_THEME_DIR);
+ ppa_to_html(owner,
+ ppa,
+ package_status,
+ output_dir,
+ install_static_files,
+ ws_size);
+ } else {
+ display_published_binaries(owner, ppa, package_status, ws_size);
+ }
/* for valgrind.... */
free(package_status);
free(output_dir);
/* for valgrind.... */
free(package_status);
free(output_dir);
-
lp_ws
_cleanup();
+
http
_cleanup();
cache_cleanup();
cache_cleanup();
+ fcache_cleanup();
+ html_cleanup();
exit(EXIT_SUCCESS);
}
exit(EXIT_SUCCESS);
}