fix gethostbyname closure error

This commit is contained in:
Alon Zakai 2012-10-03 11:29:51 -07:00
Родитель cc14e2ad3a
Коммит 20cd14971f
2 изменённых файлов: 24 добавлений и 22 удалений

Просмотреть файл

@ -6352,37 +6352,39 @@ LibraryManager.library = {
// name resolving clientside in a browser.
// we do the aliasing in 172.29.*.*, giving us 65536 possibilities
// note: lots of leaking here!
__hostent_struct_layout: Runtime.generateStructInfo([
['i8*', 'h_name'],
['i8**', 'h_aliases'],
['i32', 'h_addrtype'],
['i32', 'h_length'],
['i8**', 'h_addr_list'],
]),
gethostbyname__deps: ['__hostent_struct_layout'],
gethostbyname: function(name) {
name = Pointer_stringify(name);
if (!_gethostbyname.hostent_layout) {
_gethostbyname.hostent_layout = Runtime.generateStructInfo([
['i8*', 'h_name'],
['i8**', 'h_aliases'],
['i32', 'h_addrtype'],
['i32', 'h_length'],
['i8**', 'h_addr_list'],
]);
_gethostbyname.table = {};
_gethostbyname.id = 0;
}
if (!_gethostbyname.id) {
_gethostbyname.id = 1;
_gethostbyname.table = {};
}
var id = _gethostbyname.id++;
assert(id < 65535);
var fakeAddr = 172 | (29 << 8) | ((id & 0xff) << 16) | ((id & 0xff00) << 24);
_gethostbyname.table[id] = name;
// generate hostent
var ret = _malloc(_gethostbyname.hostent_layout.__size__);
var ret = _malloc(___hostent_struct_layout.__size__);
var nameBuf = _malloc(name.length+1);
writeStringToMemory(name, nameBuf);
setValue(ret+_gethostbyname.hostent_layout.h_name, nameBuf, 'i8*');
setValue(ret+___hostent_struct_layout.h_name, nameBuf, 'i8*');
var aliasesBuf = _malloc(4);
setValue(aliasesBuf, 0, 'i8*');
setValue(ret+_gethostbyname.hostent_layout.h_aliases, aliasesBuf, 'i8**');
setValue(ret+_gethostbyname.hostent_layout.h_addrtype, {{{ cDefine("AF_INET") }}}, 'i32');
setValue(ret+_gethostbyname.hostent_layout.h_length, 4, 'i32');
setValue(ret+___hostent_struct_layout.h_aliases, aliasesBuf, 'i8**');
setValue(ret+___hostent_struct_layout.h_addrtype, {{{ cDefine("AF_INET") }}}, 'i32');
setValue(ret+___hostent_struct_layout.h_length, 4, 'i32');
var addrListBuf = _malloc(12);
setValue(addrListBuf, addrListBuf+8, 'i32*');
setValue(addrListBuf+4, 0, 'i32*');
setValue(addrListBuf+8, 172 | (29 << 8) | ((id & 0xff) << 16) | ((id & 0xff00) << 24), 'i32');
setValue(ret+_gethostbyname.hostent_layout.h_addr_list, addrListBuf, 'i8**');
setValue(addrListBuf+8, fakeAddr, 'i32');
setValue(ret+___hostent_struct_layout.h_addr_list, addrListBuf, 'i8**');
return ret;
},

Просмотреть файл

@ -5114,11 +5114,11 @@ def process(filename):
}
'''
self.do_run(src, '''www.cheezburger.com : 1 : 4
* -84.29.0.0.
fail.on.this.never.work : 1 : 4
* -84.29.1.0.
localhost : 1 : 4
fail.on.this.never.work : 1 : 4
* -84.29.2.0.
localhost : 1 : 4
* -84.29.3.0.
''')
def test_ctype(self):
@ -8798,7 +8798,7 @@ elif 'browser' in str(sys.argv):
def test_zz_websockets_gethostbyname(self):
try:
with self.WebsockHarness(7000):
self.btest('websockets_gethostbyname.c', expected='571')
self.btest('websockets_gethostbyname.c', expected='571', args=['-O2'])
finally:
self.clean_pids()