summaryrefslogtreecommitdiff
path: root/lib/if.c
diff options
context:
space:
mode:
authorpaul <paul>2004-07-17 11:51:29 +0000
committerpaul <paul>2004-07-17 11:51:29 +0000
commit3a0391a9a1a6946eb58c723630f29f760f122bc9 (patch)
treed1d5e516de05d04df0b9ed684d7b6c75c4e03141 /lib/if.c
parent59ea14c6c9c877a7b9c9cc1555e3079acd9200e9 (diff)
2004-07-17 Paul Jakma <paul@dishone.st>
* if.c: (if_cmp_func) Add comment suggested by Greg Troxel.
Diffstat (limited to 'lib/if.c')
-rw-r--r--lib/if.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/lib/if.c b/lib/if.c
index 2e36eff3..d80e2347 100644
--- a/lib/if.c
+++ b/lib/if.c
@@ -46,7 +46,14 @@ struct if_master
int (*if_delete_hook) (struct interface *);
} if_master;
-/* Compare interface names */
+/* Compare interface names, returning an integer greater than, equal to, or
+ * less than 0, (following the strcmp convention), according to the
+ * relationship between ifp1 and ifp2. Interface names consist of an
+ * alphabetic prefix and a numeric suffix. The primary sort key is
+ * lexicographic by name, and then numeric by number. No number sorts
+ * before all numbers. Examples: de0 < de1, de100 < fxp0 < xl0, devpty <
+ * devpty0, de0 < del0
+ */
int
if_cmp_func (struct interface *ifp1, struct interface *ifp2)
{
@@ -67,6 +74,9 @@ if_cmp_func (struct interface *ifp1, struct interface *ifp2)
if (l1 != l2)
return (strcmp(p1, p2));
+ /* Note that this relies on all numbers being less than all letters, so
+ * that de0 < del0.
+ */
res = strncmp(p1, p2, l1);
/* names are different -> compare them */