Comparison

net/dns.lua @ 4797:e239668aa6d2

Merge 0.9->trunk
author Matthew Wild <mwild1@gmail.com>
date Sun, 29 Apr 2012 02:10:55 +0100
parent 4422:c25dee24623f
child 5266:5c3a3ef6b769
comparison
equal deleted inserted replaced
4796:04a34287dc12 4797:e239668aa6d2
356 356
357 function resolver:name() -- - - - - - - - - - - - - - - - - - - - - - name 357 function resolver:name() -- - - - - - - - - - - - - - - - - - - - - - name
358 local remember, pointers = nil, 0; 358 local remember, pointers = nil, 0;
359 local len = self:byte(); 359 local len = self:byte();
360 local n = {}; 360 local n = {};
361 if len == 0 then return "." end -- Root label
361 while len > 0 do 362 while len > 0 do
362 if len >= 0xc0 then -- name is "compressed" 363 if len >= 0xc0 then -- name is "compressed"
363 pointers = pointers + 1; 364 pointers = pointers + 1;
364 if pointers >= 20 then error('dns error: 20 pointers'); end; 365 if pointers >= 20 then error('dns error: 20 pointers'); end;
365 local offset = ((len-0xc0)*0x100) + self:byte(); 366 local offset = ((len-0xc0)*0x100) + self:byte();