* [PATCH] perl: Add function to perform AS number lookups.
@ 2019-10-01 6:16 Stefan Schantl
2019-10-01 11:59 ` Michael Tremer
0 siblings, 1 reply; 2+ messages in thread
From: Stefan Schantl @ 2019-10-01 6:16 UTC (permalink / raw)
To: location
[-- Attachment #1: Type: text/plain, Size: 947 bytes --]
Signed-off-by: Stefan Schantl <stefan.schantl(a)ipfire.org>
---
src/perl/Location.xs | 26 ++++++++++++++++++++++++++
1 file changed, 26 insertions(+)
diff --git a/src/perl/Location.xs b/src/perl/Location.xs
index ab27f0b..63410c4 100644
--- a/src/perl/Location.xs
+++ b/src/perl/Location.xs
@@ -117,6 +117,32 @@ lookup_country_code(db, address)
OUTPUT:
RETVAL
+unsigned int
+lookup_asn(db, address)
+ struct loc_database* db;
+ char* address;
+
+ CODE:
+ // Lookup network
+ struct loc_network *network;
+ int err = loc_database_lookup_from_string(db, address, &network);
+ if (err) {
+ croak("Could not look up for %s\n", address);
+ }
+
+ // Extract the ASN
+ unsigned int as_number = loc_network_get_asn(network);
+ loc_network_unref(network);
+
+ if (as_number) {
+ RETVAL = as_number;
+ } else {
+ //RETVAL = NULL;
+ RETVAL = 0;
+ }
+ OUTPUT:
+ RETVAL
+
void
DESTROY(db)
struct loc_database* db;
--
2.20.1
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH] perl: Add function to perform AS number lookups.
2019-10-01 6:16 [PATCH] perl: Add function to perform AS number lookups Stefan Schantl
@ 2019-10-01 11:59 ` Michael Tremer
0 siblings, 0 replies; 2+ messages in thread
From: Michael Tremer @ 2019-10-01 11:59 UTC (permalink / raw)
To: location
[-- Attachment #1: Type: text/plain, Size: 1503 bytes --]
> On 1 Oct 2019, at 07:16, Stefan Schantl <stefan.schantl(a)ipfire.org> wrote:
>
> Signed-off-by: Stefan Schantl <stefan.schantl(a)ipfire.org>
> ---
> src/perl/Location.xs | 26 ++++++++++++++++++++++++++
> 1 file changed, 26 insertions(+)
>
> diff --git a/src/perl/Location.xs b/src/perl/Location.xs
> index ab27f0b..63410c4 100644
> --- a/src/perl/Location.xs
> +++ b/src/perl/Location.xs
> @@ -117,6 +117,32 @@ lookup_country_code(db, address)
> OUTPUT:
> RETVAL
>
> +unsigned int
> +lookup_asn(db, address)
> + struct loc_database* db;
> + char* address;
> +
> + CODE:
> + // Lookup network
> + struct loc_network *network;
I like to initialise variables like this with NULL.
Not sure if that is only considered style.
> + int err = loc_database_lookup_from_string(db, address, &network);
> + if (err) {
> + croak("Could not look up for %s\n", address);
> + }
> +
> + // Extract the ASN
> + unsigned int as_number = loc_network_get_asn(network);
> + loc_network_unref(network);
> +
> + if (as_number) {
> + RETVAL = as_number;
> + } else {
> + //RETVAL = NULL;
> + RETVAL = 0;
> + }
So either you just put the return value of loc_network_get_asn into RETVAL, or you use NULL.
I would prefer NULL here, because 0 is a reserved ASN. Will most likely never be used, but we should follow the RFCs here.
-Michael
> + OUTPUT:
> + RETVAL
> +
> void
> DESTROY(db)
> struct loc_database* db;
> --
> 2.20.1
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2019-10-01 11:59 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-10-01 6:16 [PATCH] perl: Add function to perform AS number lookups Stefan Schantl
2019-10-01 11:59 ` Michael Tremer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox