Hi Bastian, the short answer for all your questions is: Because all the existing functions in network.sh are written this way. The function I would like to introduce is a dupe of network_get_ipaddrs6() which is a dupe of network_get_ipaddr6(). All three functions only differ by the value which is passed to jsonfilter later on.
2014-10-06 20:54 GMT+02:00 Bastian Bittorf <bitt...@bluebottle.com>: > 1) > is there a special reason for starting everything with '__'? > (the vars are local anyway). To be honest. I don't know why its done this way. Maybe someone can enlighten me. > 2) > is there a special reason not to name the vars $1 and $2? e.g. > > local dest_var="$1" > local interface="$2" > > 3) > why you append a '1' to the list if it's IPv6? (make it clear in the code) > > 4) > use a special var for the list and for the element of the list. > ("for __addr in $__addr; do" -> for ELEMENT in $LIST) > >> + if __network_ifstatus "__addr" "$2" >> "['ipv4-address','ipv6-address','ipv6-prefix-assignment'][*].address"; then >> + for __addr in $__addr; do >> + case "$__addr" in >> + *:) __list="${__list:+$__list }${__addr}1" ;; >> + *) __list="${__list:+$__list }${__addr}" ;; >> + esac >> + done >> + >> + export "$1=$__list" >> + return 0 >> + fi >> + >> + unset "$1" >> + return 1 >> +} I'm with you. It would improve the readability. But as already said, that's the coding style of the existing functions... > > bye, bastian Mathias _______________________________________________ openwrt-devel mailing list openwrt-devel@lists.openwrt.org https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel