Решение может быть простым. С другой стороны, это может быть невозможно.
У меня есть базовый класс обратного вызова:
class CFCallback {
int command_;
int transfer_rate_;
public:
CFCallback(int command, int transfer_rate = 0) {
command_ = command; transfer_rate_ = transfer_rate; }
virtual ~CFCallback() {}
virtual void operator()(void *data) = 0;
int GetCommand() { return command_; }
int GetTransferRate() { return transfer_rate_; }
};
И вот один пример получения из CFCallback
:
void CFPacketVersion::InitiateVersion() {
class InitiateVersionCB : public CFCallback {
CFPacketVersion *visitor_;
public:
InitiateVersionCB(CFPacketVersion *v, int command) :
CFCallback(command) {
visitor_ = v;
}
void operator()(void *data) {
Packet *pkt = (Packet *)data;
unsigned char *pkt_data = pkt->GetData();
std::string version = "";
for(unsigned int i = 0; i < pkt->GetDataLength(); i++ )
version+= pkt_data[i];
delete []pkt_data;
boost::regex rex("CFA(.*?):h(.*?),v(.*?)$");
boost::smatch what;
if( boost::regex_match(version, what, rex) ) {
if(visitor_->GetModel()->GetName() != what[1].str() )
LCDInfo("Crystalfontz: Model mismatch");
visitor_->SetHardwareVersion(what[2]);
visitor_->SetFirmwareVersion(what[3]);
}
}
};
GetVersion(new InitiateVersionCB(this, 1));
}
GetVersion(CFCallback *)
предоставляется скриптовому движку.
Я хочу быть в состоянии сделать то же самое, что и в InitiateVersion
, но на стороне JavaScript. Это возможно?
Я знаю, что мне нужно зарегистрировать информацию мета-типа для CFCallback
. Но я не знаю, возможно ли использовать указатель на CFCallback
. То, что я пробовал изначально, не сработало.
Кроме того, учитывая, что CFCallback
является функтором, я не уверен, как перевести это в javascript. Я полагаю, что могу сделать CFCallback
a QObject
и обеспечить сигнал, излучаемый operator()
. Если у вас есть какие-либо советы, пожалуйста, поделитесь.