summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: ab53c66)
raw | patch | inline | side by side (parent: ab53c66)
| author | oetiker <oetiker@a5681a0c-68f1-0310-ab6d-d61299d08faa> | |
| Tue, 10 Jun 2008 09:35:03 +0000 (09:35 +0000) | ||
| committer | oetiker <oetiker@a5681a0c-68f1-0310-ab6d-d61299d08faa> | |
| Tue, 10 Jun 2008 09:35:03 +0000 (09:35 +0000) | 
| doc/rrdcreate.pod | patch | blob | history | |
| src/rrd_create.c | patch | blob | history | 
diff --git a/doc/rrdcreate.pod b/doc/rrdcreate.pod
index 86817bd4dbeb60bc0c9233244744cd41e7e20165..03012e035e2739ce6eae79584fcc191844d44acb 100644 (file)
--- a/doc/rrdcreate.pod
+++ b/doc/rrdcreate.pod
 a I<consolidated data point> which then goes into the archive.
 I<rows> defines how many generations of data values are kept in an B<RRA>.
+Obviously, this has to be greater than zero.
 =back
diff --git a/src/rrd_create.c b/src/rrd_create.c
index 028123ef46f4a65ce2704a755b8fd0d5e7dbf1fa..6d7cb18e977af78a55a2afc55069d5923e1084d8 100644 (file)
--- a/src/rrd_create.c
+++ b/src/rrd_create.c
             char     *argvcopy;
             char     *tokptr;
             size_t    old_size = sizeof(rra_def_t) * (rrd.stat_head->rra_cnt);
+            int       row_cnt;
             if ((rrd.rra_def = rrd_realloc(rrd.rra_def,
                                            old_size + sizeof(rra_def_t))) ==
                     case CF_SEASONAL:
                     case CF_DEVPREDICT:
                     case CF_FAILURES:
-                        rrd.rra_def[rrd.stat_head->rra_cnt].row_cnt =
-                            atoi(token);
+                        row_cnt = atoi(token);
+                        rrd.rra_def[rrd.stat_head->rra_cnt].row_cnt = row_cnt;
+                        if (row_cnt <= 0)
+                            rrd_set_error("Invalid row count: %i", row_cnt);
                         break;
                     default:
                         rrd.rra_def[rrd.stat_head->rra_cnt].
                             ("Unexpected extra argument for consolidation function DEVPREDICT");
                         break;
                     default:
-                        rrd.rra_def[rrd.stat_head->rra_cnt].row_cnt =
-                            atoi(token);
+                        row_cnt = atoi(token);
+                        rrd.rra_def[rrd.stat_head->rra_cnt].row_cnt = row_cnt;
+                        if (row_cnt <= 0)
+                            rrd_set_error("Invalid row count: %i", row_cnt);
                         break;
                     }
                     break;
![[tokkee]](http://tokkee.org/images/avatar.png)
