Pfx.band
You're seeing just the function
band
, go back to Pfx module for more information.
Specs
Returns a bitwise AND of pfx1
and pfx2
.
Both prefixes must have the same maxlen
. The resulting prefix will have
the same number of bits as the first argument.
Examples
iex> band("10.10.10.10", "255.255.0.0")
"10.10.0.0"
iex> band("10.10.10.0/24", "255.255.0.0")
"10.10.0.0/24"
iex> x = new(<<128, 129, 130, 131>>, 32)
iex> y = new(<<255, 255>>, 32)
iex> band(x, y)
%Pfx{bits: <<128, 129, 0, 0>>, maxlen: 32}
iex>
iex> band(y,x)
%Pfx{bits: <<128, 129>>, maxlen: 32}
# results adopt the format of the first argument
iex> band("1.2.3.4", {255, 255, 0, 0})
"1.2.0.0"
iex> band({1, 2, 3, 4}, "255.255.0.0")
{1, 2, 0, 0}
iex> band({{1, 2, 3, 4}, 24}, {255, 255, 0, 0})
{{1, 2, 0, 0}, 24}
# honoring the ancient tradition
iex> band("1.2.3.4", "255.255")
"1.0.0.4"
iex> band("10.10.0.0/16", "255.0.0.0/24")
"10.0.0.0/16"