ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/i-scream/projects/cms/source/ihost/libstatgrab/disk_stat.c
(Generate patch)

Comparing projects/cms/source/ihost/libstatgrab/disk_stat.c (file contents):
Revision 1.4 by pajs, Mon May 13 12:47:15 2002 UTC vs.
Revision 1.11 by tdb, Tue May 21 16:47:12 2002 UTC

# Line 1 | Line 1
1 + /*
2 + * i-scream central monitoring system
3 + * http://www.i-scream.org.uk
4 + * Copyright (C) 2000-2002 i-scream
5 + *
6 + * This program is free software; you can redistribute it and/or
7 + * modify it under the terms of the GNU General Public License
8 + * as published by the Free Software Foundation; either version 2
9 + * of the License, or (at your option) any later version.
10 + *
11 + * This program is distributed in the hope that it will be useful,
12 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 + * GNU General Public License for more details.
15 + *
16 + * You should have received a copy of the GNU General Public License
17 + * along with this program; if not, write to the Free Software
18 + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19 + */
20 +
21   #include <stdlib.h>
22   #include <stdio.h>
23   #include "ukcprog.h"
# Line 37 | Line 57 | char *get_disk_stats(){
57          system_disks_t *sd_ptr=sd;
58          int counter=0;
59          char *xml_disk_stats;
60 +        char *xml_disk_stats_ptr;
61   #ifdef SOLARIS
62          struct mnttab mp;
63          struct statvfs df;
# Line 90 | Line 111 | char *get_disk_stats(){
111  
112          }
113  
114 +        if((fclose(f))!=0){
115 +                errf("Failed to close mnttab");
116 +                return NULL;
117 +        }
118 +
119   #endif
120 < #ifdef linux
121 <        if ((f=fopen("/etc/mtab", "r" ))==NULL){
120 > #ifdef LINUX
121 >        if ((f=setmntent("/etc/mtab", "r" ))==NULL){
122                  errf("Failed to open mounts (%m)");
123                  return NULL;
124          }
# Line 128 | Line 154 | char *get_disk_stats(){
154                  sd_ptr->next_disk=sd;
155                  sd=sd_ptr;
156          }
157 +
158 +        if ((endmntent(f)) != 0) {
159 +                errf("Failed to close file (%m)");
160 +                return NULL;
161 +        }
162 +
163   #endif
164   #ifdef FREEBSD
165          nummnt=getmntinfo(&mp , MNT_LOCAL);
# Line 168 | Line 200 | char *get_disk_stats(){
200          sd_ptr=sd;
201          xml_disk_stats=strdup("<disk>");
202          
203 <        while(sd_ptr!=NULL){
203 >        for(counter=0;sd_ptr!=NULL;counter++){
204 >                xml_disk_stats_ptr=xml_disk_stats;
205                  if((xml_disk_stats=strf("%s<p%d name=\"%s\" mount=\"%s\" kbytes=\"%ld\" used=\"%ld\" avail=\"%ld\" totalinodes=\"%ld\" freeinodes=\"%ld\"></p%d>", xml_disk_stats, counter, sd_ptr->disk->device_name, sd_ptr->disk->mnt_point, sd_ptr->disk->size, sd_ptr->disk->used, sd_ptr->disk->avail, sd_ptr->disk->t_inodes, sd_ptr->disk->f_inodes, counter)) == NULL){
206                          errf("strf failed (%m)");
207                          return NULL;
208                  }
209 +                free(xml_disk_stats_ptr);
210                  sd_ptr=sd_ptr->next_disk;
177                counter++;
211          }
212 <
212 >        xml_disk_stats_ptr=xml_disk_stats;
213          xml_disk_stats=strf("%s</disk>",xml_disk_stats);
214 +        free(xml_disk_stats_ptr);      
215 +
216 +        /* Cleaning up */
217 +        sd_ptr=sd;
218 +        while(sd_ptr!=NULL){
219 +                sd=sd_ptr->next_disk;
220 +                free(sd_ptr->disk->device_name);
221 +                free(sd_ptr->disk->mnt_point);
222 +                free(sd_ptr->disk);
223 +                free(sd_ptr);
224 +                sd_ptr=sd;
225 +        }
226  
227          return xml_disk_stats;
228   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines