Мы с вами работали некоторое время назад. Он предназначен для использования с js-ctypes. В Linux есть эти макросы для работы с добавлением списка файловых дескрипторов (uint32) в массив байтов: FD_SET
и FD_IS_SET
. Документы здесь - http://linux.die.net/man/2/selectМакросы FD_SET и FD_ISSET, написанные на javascript
Мне было интересно, сможет ли кто-нибудь проверить, правильно ли я сделал это или кто-нибудь знает кого-либо, кто сделал это в javascript? Мне нужно завершить 32-битную/64-битную поддержку для большого и маленького endian, но если она уже там, мне бы очень хотелось ее увидеть, так как когда мы работали над этим, у нас было так много неопределенностей.
Код, fd_set_get_idx
был вспомогательной функцией, это все на основе.
var MACROS = {
fd_set_set: function(fdset, fd) {
let { elem8, bitpos8 } = MACROS.fd_set_get_idx(fd);
console.info('elem8:', elem8.toString());
console.info('bitpos8:', bitpos8.toString());
fdset[elem8] = 1 << bitpos8;
},
fd_set_isset: function(fdset, fd) {
let { elem8, bitpos8 } = MACROS.fd_set_get_idx(fd);
console.info('elem8:', elem8.toString());
console.info('bitpos8:', bitpos8.toString());
return !!(fdset[elem8] & (1 << bitpos8));
},
fd_set_get_idx: function(fd) {
if (osname == 'darwin' /*is_mac*/) {
// We have an array of int32. This should hopefully work on Darwin
// 32 and 64 bit.
let elem32 = Math.floor(fd/32);
let bitpos32 = fd % 32;
let elem8 = elem32 * 8;
let bitpos8 = bitpos32;
if (bitpos8 >= 8) { // 8
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 16
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 24
bitpos8 -= 8;
elem8++;
}
return {'elem8': elem8, 'bitpos8': bitpos8};
} else { // else if (osname == 'linux' /*is_linux*/) { // removed the else if so this supports bsd and solaris now
// :todo: add 32bit support
// Unfortunately, we actually have an array of long ints, which is
// a) platform dependent and b) not handled by typed arrays. We manually
// figure out which byte we should be in. We assume a 64-bit platform
// that is little endian (aka x86_64 linux).
let elem64 = Math.floor(fd/64);
let bitpos64 = fd % 64;
let elem8 = elem64 * 8;
let bitpos8 = bitpos64;
if (bitpos8 >= 8) { // 8
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 16
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 24
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 32
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 40
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 48
bitpos8 -= 8;
elem8++;
}
if (bitpos8 >= 8) { // 56
bitpos8 -= 8;
elem8++;
}
return {'elem8': elem8, 'bitpos8': bitpos8};
}
}
};
Что не так с добрыми старыми '>>', '<<' и '&', '|' –
Кроме того, можно использовать цикл 'for' ... –
Я не могу понять, если вы просто хотите эмулировать функции «FD_XXX» или если вам что-то нужно.JS, особенно ES6, имеет [DataView] (https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/DataView) и [типизированные массивы] (https://developer.mozilla.org/ ru-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray), если вы хотите их использовать. Во всяком случае, если семантика 'FD_SET (i, set)' просто 'set [i] = i' Я не вижу никаких проблем при ее реализации, в любой endianess или размере, с нуля. Вы можете уточнить? Кроме того, это 'fdset [elem8] = 1 << bitpos8', скорее всего, неверно. –