123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- /*!
- \file list_subgp.c
- \brief Imagery Library - List subgroup
- (C) 2001-2008,2013 by the GRASS Development Team
- This program is free software under the GNU General Public License
- (>=v2). Read the file COPYING that comes with GRASS for details.
- \author USA CERL
- */
- #include <string.h>
- #include <grass/imagery.h>
- #include <grass/glocale.h>
- /*!
- * \brief Get list of subgroups which a group contatins.
- *
- * \param group group name
- * \param[out] subgs_num number of subgroups which the group contains
- * \return array of subgroup names
- */
- char **I_list_subgroups(const char *group, int *subgs_num)
- {
- /* Unlike I_list_subgroup and I_list_subgroup_simple this function
- returns array of subgroup names, it does not use fprintf.
- This approach should make the function usable in more cases. */
- char **subgs;
- char path[GPATH_MAX];
- char buf[GPATH_MAX];
- const char *mapset;
- struct stat sb;
- *subgs_num = 0;
- if (I_find_group(group) == 0)
- return NULL;
- mapset = G_mapset();
- sprintf(buf, "group/%s/subgroup", group);
- G_file_name(path, buf, "", mapset);
- if (!G_lstat(path, &sb) == 0 || !S_ISDIR(sb.st_mode))
- return NULL;
- subgs = G__ls(path, subgs_num);
- return subgs;
- }
- /*!
- * \brief Prints maps in a subgroup (fancy version)
- *
- * \param group group name
- * \param subgroup subgroup name
- * \param ref group reference (set with I_get_subgroup_ref())
- * \param fd where to print (typically stdout)
- * \return 0
- */
- int I_list_subgroup(const char *group,
- const char *subgroup, const struct Ref *ref, FILE * fd)
- {
- char buf[80];
- int i;
- int len, tot_len;
- int max;
- if (ref->nfiles <= 0) {
- fprintf(fd, _("subgroup <%s> of group <%s> is empty\n"),
- subgroup, group);
- return 0;
- }
- max = 0;
- for (i = 0; i < ref->nfiles; i++) {
- sprintf(buf, "<%s@%s>", ref->file[i].name, ref->file[i].mapset);
- len = strlen(buf) + 4;
- if (len > max)
- max = len;
- }
- fprintf(fd,
- _
- ("subgroup <%s> of group <%s> references the following raster maps\n"),
- subgroup, group);
- fprintf(fd, "-------------\n");
- tot_len = 0;
- for (i = 0; i < ref->nfiles; i++) {
- sprintf(buf, "<%s@%s>", ref->file[i].name, ref->file[i].mapset);
- tot_len += max;
- if (tot_len > 78) {
- fprintf(fd, "\n");
- tot_len = max;
- }
- fprintf(fd, "%-*s", max, buf);
- }
- if (tot_len)
- fprintf(fd, "\n");
- fprintf(fd, "-------------\n");
- return 0;
- }
- /*!
- * \brief Prints maps in a subgroup (simple version)
- *
- * Same as I_list_subgroup(), but without all the fancy stuff.
- * Prints one map per line in map@mapset form.
- *
- * \param ref group reference (set with I_get_subgroup_ref())
- * \param fd where to print (typically stdout)
- * \return 0
- */
- /* same as above, but one map per line in map@mapset form */
- int I_list_subgroup_simple(const struct Ref *ref, FILE * fd)
- {
- return I_list_group_simple(ref, fd);
- }
|