la classe Map
Rappresenta una mappa di oggetti generici (dataclass) con uno spazio di levels x gsize. Cioè 4 x 256.
Ricorda che il livello 0 indica i singoli nodi, mentre il livello 3 è l'intero dominio di IPv4.
Ogni spazio è creato solo quando viene esplicitamente usato per la prima volta. Ogni spazio viene creato usando il costruttore dataclass con i parametri lvl e id, così che l'informazione di dove si trova nella mappa ce l'ha lo stesso nodo (al momento la classe RouteNode non ne fa uso).
La dataclass deve avere il metodo is_free per dire se lo spazio in questione è usato o no.
E' possibile segnalare la presenza di un nuovo nodo nella mappa. Si fa con il metodo node_add. In questo momento viene emesso il signal NODE_NEW.
E' possibile anche rimuovere un elemento dalla mappa. Si fa con il metodo node_del. In questo caso viene anche emesso il signal NODE_DELETED.
E' possibile anche resettare un intero livello o l'intera mappa senza far emettere alcun segnale (map_reset, level_reset). Questa tecnica è usata dopo aver fatto un re-hook in un diverso gnodo e aver reimpostato il nuovo IP su tutti i Nic attivi (vedi la classe Hook).
Nella classe Map c'è anche l'indicazione del proprio spazio, cioè <il mio Netsukuku-IP>. Quindi si ha un metodo che dice se un certo nodo o gnodo appartiene allo stesso nostro gnodo di livello x.
Il proprio indirizzo è indicato nella forma di una sequenza di ID per i vari livelli dallo 0 al più alto. (un Netsukuku-IP o nip)
self.me = [1,1,168,192] (notare che il primo elemento della sequenza è il livello 0 (gnodo = nodo))
Un altro nodo da confrontare è sempre fornito nella stessa forma. Se si ha l'identificativo nella forma di un unico intero (=192*2563+168*2562+1*2561+*2560 detto semplicemente ip) si possono usare i metodi ip_to_nip e nip_to_ip.
nip = [2,2,168,192]
In questo caso self.is_in_level(nip,0) darebbe False;
invece self.is_in_level(nip,1) darebbe True.
Un altro confronto si può fare per dire di 2 Netsukuku-IP quale sia il primo livello differente. La ricerca parte dall'ultimo elemento delle sequenze (levels -1). Tra i 2 nip citati prima dovrebbe restituire 1.
Il metodo lvlid_to_nip partendo da lvl e id guarda nella mappa e restituisce il nip equivalente. Lo fa partendo dal proprio nip (self.me) azzerando i livelli sotto lvl.