diff options
author | Timo Teräs <timo.teras@iki.fi> | 2012-02-24 18:27:55 +0200 |
---|---|---|
committer | Timo Teräs <timo.teras@iki.fi> | 2012-02-24 18:29:30 +0200 |
commit | 12bdec38a376f787a8aa621c965b561387b445ce (patch) | |
tree | 055074fe2eb53047f62282ab11dc8ecc4dadd06a /src/dot.c | |
parent | 99145e2c0dc0b5b3b5a2a72fb1bff140d1f583f3 (diff) | |
download | apk-tools-12bdec38a376f787a8aa621c965b561387b445ce.tar.gz apk-tools-12bdec38a376f787a8aa621c965b561387b445ce.tar.bz2 apk-tools-12bdec38a376f787a8aa621c965b561387b445ce.tar.xz apk-tools-12bdec38a376f787a8aa621c965b561387b445ce.zip |
solver, dot: elementary provides fixes
implementation is still not near finished, but now at least it
can handle it to a minimum degree. many cases are not done right
yet, though. ref #574.
Diffstat (limited to 'src/dot.c')
-rw-r--r-- | src/dot.c | 70 |
1 files changed, 38 insertions, 32 deletions
@@ -49,6 +49,19 @@ static void start_graph(struct dot_ctx *ctx) " node [shape=box];\n"); } +static void dump_name(struct dot_ctx *ctx, struct apk_name *name) +{ + if (name->state_int) + return; + name->state_int = 1; + + if (name->providers->num == 0) { + start_graph(ctx); + printf(" \"%s\" [style=dashed, color=red, fontcolor=red, shape=octagon];\n", + name->name); + } +} + static int dump_pkg(struct dot_ctx *ctx, struct apk_package *pkg) { int i, j, r, ret = 0; @@ -66,40 +79,33 @@ static int dump_pkg(struct dot_ctx *ctx, struct apk_package *pkg) struct apk_dependency *dep = &pkg->depends->item[i]; struct apk_name *name = dep->name; + dump_name(ctx, name); + if (name->providers->num == 0) { - start_graph(ctx); printf(" \"" PKG_VER_FMT "\" -> \"%s\" [color=red];\n", - PKG_VER_PRINTF(pkg), - name->name); - if (!name->state_int) { - printf(" \"%s\" [style=dashed, color=red, fontcolor=red, shape=octagon];\n", - name->name); - name->state_int = 1; - } - } else { - for (j = 0; j < name->providers->num; j++) { - struct apk_provider *p0 = &name->providers->item[j]; - - if (!apk_dep_is_provided(dep, p0)) - continue; - - r = dump_pkg(ctx, p0->pkg); - ret += r; - if (r || (!ctx->errors_only)) { - start_graph(ctx); - - if (p0->pkg->name != dep->name) { - /* provided package */ - printf(" \"" PROVIDER_FMT "\" -> \"" PKG_VER_FMT "\"[arrowhead=inv,color=green];\n", - PROVIDER_PRINTF(p0), - PKG_VER_PRINTF(p0->pkg)); - } - - printf(" \"" PKG_VER_FMT "\" -> \"" PROVIDER_FMT "\"%s;\n", - PKG_VER_PRINTF(pkg), - PROVIDER_PRINTF(p0), - r ? "[color=red]" : ""); - } + PKG_VER_PRINTF(pkg), name->name); + continue; + } + + for (j = 0; j < name->providers->num; j++) { + struct apk_provider *p0 = &name->providers->item[j]; + + if (!apk_dep_is_provided(dep, p0)) + continue; + + r = dump_pkg(ctx, p0->pkg); + ret += r; + if (r || (!ctx->errors_only)) { + start_graph(ctx); + + printf(" \"" PKG_VER_FMT "\" -> \"" PKG_VER_FMT "\"[", + PKG_VER_PRINTF(pkg), + PKG_VER_PRINTF(p0->pkg)); + if (r) + printf("color=red,"); + if (p0->pkg->name != dep->name) + printf("arrowhead=inv,label=\"%s\",", dep->name->name); + printf("];\n"); } } } |