/*- * Copyright (c) 2008-2009 Juan Romero Pardines. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include #include #include #include #include #include #include #include "defs.h" void show_pkg_info_only_repo(prop_dictionary_t dict) { prop_object_t obj; char size[64]; int rv = 0; obj = prop_dictionary_get(dict, "filename"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) { printf("Filename: %s", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "filename-size"); if (obj && prop_object_type(obj) == PROP_TYPE_NUMBER) { rv = xbps_humanize_number(size, 5, (int64_t)prop_number_unsigned_integer_value(obj), "", HN_AUTOSCALE, HN_B|HN_DECIMAL|HN_NOSPACE); if (rv == -1) printf(" (size: %ju)\n", prop_number_unsigned_integer_value(obj)); else printf(" (size: %s)\n", size); } else printf("\n"); } obj = prop_dictionary_get(dict, "filename-sha256"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("SHA256: %s\n", prop_string_cstring_nocopy(obj)); } void show_pkg_info(prop_dictionary_t dict) { prop_object_t obj; const char *sep; char size[64]; int rv = 0; assert(dict != NULL); assert(prop_dictionary_count(dict) != 0); obj = prop_dictionary_get(dict, "archive-compression-type"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("Compression type: %s\n", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "pkgname"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("Package: %s\n", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "installed_size"); if (obj && prop_object_type(obj) == PROP_TYPE_NUMBER) { printf("Installed size: "); rv = xbps_humanize_number(size, 5, (int64_t)prop_number_unsigned_integer_value(obj), "", HN_AUTOSCALE, HN_B|HN_DECIMAL|HN_NOSPACE); if (rv == -1) printf("%ju\n", prop_number_unsigned_integer_value(obj)); else printf("%s\n", size); } obj = prop_dictionary_get(dict, "maintainer"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("Maintainer: %s\n", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "architecture"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("Architecture: %s\n", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "version"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("Version: %s\n", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "essential"); if (obj && prop_object_type(obj) == PROP_TYPE_BOOL) printf("Essential: %s\n", prop_bool_true(obj) ? "yes" : "no"); obj = prop_dictionary_get(dict, "replaces"); if (obj && prop_object_type(obj) == PROP_TYPE_ARRAY) { printf("Replaces: "); (void)xbps_callback_array_iter_in_dict(dict, "replaces", list_strings_sep_in_array, NULL); } obj = prop_dictionary_get(dict, "conf_files"); if (obj && prop_object_type(obj) == PROP_TYPE_ARRAY) { printf("Configuration files:\n"); sep = " "; (void)xbps_callback_array_iter_in_dict(dict, "conf_files", list_strings_sep_in_array, __UNCONST(sep)); printf("\n"); } obj = prop_dictionary_get(dict, "short_desc"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf("Description: %s", prop_string_cstring_nocopy(obj)); obj = prop_dictionary_get(dict, "long_desc"); if (obj && prop_object_type(obj) == PROP_TYPE_STRING) printf(" %s\n", prop_string_cstring_nocopy(obj)); } int show_pkg_files(prop_dictionary_t filesd) { prop_array_t array; prop_object_iterator_t iter = NULL; prop_object_t obj; const char *file; char *array_str = "files"; int i = 0; /* Links. */ array = prop_dictionary_get(filesd, "links"); if (array && prop_array_count(array) > 0) { iter = xbps_get_array_iter_from_dict(filesd, "links"); if (iter == NULL) return EINVAL; while ((obj = prop_object_iterator_next(iter))) { if (!prop_dictionary_get_cstring_nocopy(obj, "file", &file)) { prop_object_iterator_release(iter); return errno; } printf("%s\n", file); } prop_object_iterator_release(iter); } /* Files and configuration files. */ for (i = 0; i < 2; i++) { if (i == 0) array_str = "conf_files"; else array_str = "files"; array = prop_dictionary_get(filesd, array_str); if (array == NULL || prop_array_count(array) == 0) continue; iter = xbps_get_array_iter_from_dict(filesd, array_str); if (iter == NULL) return EINVAL; while ((obj = prop_object_iterator_next(iter))) { if (!prop_dictionary_get_cstring_nocopy(obj, "file", &file)) { prop_object_iterator_release(iter); return errno; } printf("%s\n", file); } prop_object_iterator_release(iter); } return 0; } int show_pkg_namedesc(prop_object_t obj, void *arg, bool *loop_done) { const char *pkgver, *desc; char *pattern = arg; (void)loop_done; assert(prop_object_type(obj) == PROP_TYPE_DICTIONARY); assert(pattern != NULL); prop_dictionary_get_cstring_nocopy(obj, "pkgver", &pkgver); prop_dictionary_get_cstring_nocopy(obj, "short_desc", &desc); if (xbps_pkgdep_match(pkgver, pattern) == 1) printf(" %s - %s\n", pkgver, desc); return 0; } int list_strings_in_array(prop_object_t obj, void *arg, bool *loop_done) { static size_t cols; static bool first; (void)arg; (void)loop_done; assert(prop_object_type(obj) == PROP_TYPE_STRING); cols += strlen(prop_string_cstring_nocopy(obj)) + 4; if (cols <= 80) { if (first == false) { printf(" "); first = true; } } else { printf("\n "); cols = strlen(prop_string_cstring_nocopy(obj)) + 4; } printf("%s ", prop_string_cstring_nocopy(obj)); return 0; } int list_strings_sep_in_array(prop_object_t obj, void *arg, bool *loop_done) { const char *sep = arg; (void)loop_done; assert(prop_object_type(obj) == PROP_TYPE_STRING); printf("%s%s\n", sep ? sep : "", prop_string_cstring_nocopy(obj)); return 0; }