本文整理汇总了C++中frame类的典型用法代码示例。如果您正苦于以下问题:C++ frame类的具体用法?C++ frame怎么用?C++ frame使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了frame类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: hasResult
bool hasResult(frame &cur_frame, uint64_t target) {
if (!cur_frame.has_std_frame()) return false;
const ::std_frame& cur_std_frame = cur_frame.std_frame();
if (!cur_std_frame.has_operand_post_list()) return false;
const operand_value_list& operand_list = cur_std_frame.operand_post_list();
for (int i = 0; i < operand_list.elem_size(); i++) {
const ::operand_info& cur_element = operand_list.elem(i);
const ::operand_info_specific& cur_specific = cur_element.operand_info_specific();
if (!cur_specific.has_mem_operand())
continue;
uint64_t curr = cur_specific.mem_operand().address();
if (curr == target) {
std::cout << cur_frame_counter << " " << i << std::endl;
return true;
}
}
return false;
}
示例2: equal
inline bool frame::equal(frame other) const {
// Seems close enough
return sp() == other.sp()
&& fp() == other.fp()
&& pc_addr() == other.pc_addr()
&& pc() == other.pc();
}
示例3: unpack_first_frame
inline void unpack_first_frame(char* ¤t_pc, frame ¤t, CodeIterator &c) {
// first vframe in the array
if (nlr_through_unpacking) {
// NLR is comming through unpacked vframes
current_pc = c.interpreter_return_point();
// current_pc points to a normal return point in the interpreter.
// To find the nlr return point we first compute the nlr offset.
current_pc = ic_info_at(current_pc)->NLR_target();
current.set_hp(c.next_hp());
} else if (redo_the_send) {
// Deoptimizing uncommon trap
current_pc = Interpreter::redo_bytecode_after_deoptimization();
current.set_hp(c.next_hp());
redo_send_offset = c.next_hp() - c.hp();
redo_the_send = false;
} else {
// Normal case
current_pc = c.interpreter_return_point(true);
current.set_hp(c.next_hp());
if (c.is_message_send()) {
number_of_arguments_through_unpacking = c.ic()->nof_arguments();
} else if (c.is_primitive_call()) {
number_of_arguments_through_unpacking = c.prim_cache()->number_of_parameters();
} else if (c.is_dll_call()) {
// The callee should not pop the argument since a DLL call is like a c function call.
// The continuation code for the DLL call will pop the arguments!
number_of_arguments_through_unpacking = 0;
}
}
}
示例4: traceDeltaFrame
void traceDeltaFrame(frame& f) {
if (f.is_compiled_frame()) {
traceCompiledFrame(f);
} else if (f.is_interpreted_frame()) {
traceInterpretedFrame(f);
}
}
示例5: ReadFile
bool RS485::receive(frame &frame_receive){
//读取的字节数
DWORD wCount;
//读取状态
int bReadStat = 0;
char byte_buf = 0;
char *frame_length = new char[2];
char frame_type = 0;
// printf("开始读取\n");
//读取起始位
ReadFile(hCom,&byte_buf,1,&wCount,NULL);
if (byte_buf != 0x10)
{
// printf("未读取到起始位0x10\n");
return false;
}
ReadFile(hCom,&byte_buf,1,&wCount,NULL);
if(byte_buf != 0x02){
// printf("未读取到到起始位0x02\n");
return false;
}
//读取帧长度
ReadFile(hCom,frame_length,2,&wCount,NULL);
//读取帧类型
ReadFile(hCom, &frame_type, 1,&wCount,NULL);
frame_receive.set_type(frame_type);
//读取帧
ReadFile(hCom, frame_receive.getFrame() + 5, frame_receive.getLength() -5,&wCount,NULL);
return true;
}
示例6: get_level
size_t layer_raster::get_level(const frame& fr)
{
const projection pj_rast(get_pj());
const projection pj_fr(fr.get_pj());
const double scale(pj_rast == pj_fr? fr.scale(): fr.transform(pj_rast).scale());
return m_raster.snap_to_level(scale * scale);
}
示例7: equal
inline bool frame::equal(frame other) const {
bool ret = sp() == other.sp()
&& fp() == other.fp()
&& pc() == other.pc();
assert(!ret || ret && cb() == other.cb() && _deopt_state == other._deopt_state, "inconsistent construction");
return ret;
}
示例8: is_in_expression_stack
static bool is_in_expression_stack(const frame& fr, const intptr_t* const addr) {
assert(addr != NULL, "invariant");
// Ensure to be 'inside' the expresion stack (i.e., addr >= sp for Intel).
// In case of exceptions, the expression stack is invalid and the sp
// will be reset to express this condition.
if (frame::interpreter_frame_expression_stack_direction() > 0) {
return addr <= fr.interpreter_frame_tos_address();
}
return addr >= fr.interpreter_frame_tos_address();
}
示例9: found_bad_method_frame
inline void vframeStreamCommon::fill_from_interpreter_frame() {
methodOop method = _frame.interpreter_frame_method();
intptr_t bcx = _frame.interpreter_frame_bcx();
int bci = method->validate_bci_from_bcx(bcx);
// 6379830 AsyncGetCallTrace sometimes feeds us wild frames.
if (bci < 0) {
found_bad_method_frame();
bci = 0; // pretend it's on the point of entering
}
_mode = interpreted_mode;
_method = method;
_bci = bci;
}
示例10: write_to
point string_stencil::write_to(frame& frame_, const std::string& str) const {
auto dim =frame_.get_dimension();
auto rows =required_y(dim.x, str.size());
if(rows <= dim.y) {
frame_.write({0, 0}, str);
return { dim.x, rows };
}
else {
frame_.write({0, 0}, str.cbegin(), str.cbegin()+dim.y*dim.x-1);
return dim;
}
}
示例11:
bool RS485::send(frame &frm){
DWORD dwBytesWrite=frm.getLength();
COMSTAT ComStat;
DWORD dwErrorFlags;
BOOL bWriteStat;
ClearCommError(hCom,&dwErrorFlags,&ComStat);
bWriteStat=WriteFile(hCom,frm.getFrame(),dwBytesWrite,& dwBytesWrite,NULL);
if(!bWriteStat)
{
std::cout<<"写串口失败"<<std::endl;
return false;
}
return true;
}
示例12: do_oop
void do_oop(oop* o) {
oop obj = *o;
if (!obj->verify()) {
lprintf("Verify failed in frame:\n");
fr->print();
}
}
示例13: getTarget
void sections::getTarget(accumTarget& inTarget,const int& inID,const units& inUnits,const frame& inFrame)
{
inTarget.size++;
ID=inID;
for(int i=0;i<=8;i++)
{
if(surroundingSections[i]!=0 && i!=4)
{
if(surroundingSections[i]->getID()!=inID)
{
surroundingSections[i]->getTarget(inTarget,inID,inUnits,inFrame);
}
}
}
inTarget.locX+=locationX;
inTarget.locY+=locationY;
const unsigned char* newData=inFrame.getData();
unsigned long pixCounter=0,i=0,j=0,y=0,x=0;
int intUnitSize=inUnits.getUnitSize();
double unitHeight=inUnits.getUnitHeight();
double unitWidth=inUnits.getUnitWidth();
double unitSize=inUnits.getUnitSize();
i=locationY;
j=locationX;
y=0;
while(y<unitHeight-1)
{
x=0;
while(x<unitWidth)
{
unsigned long temp=i*unitSize*unitHeight*unitWidth*3+j*unitWidth*3+y*unitSize*unitWidth*3+x*3;
for(unsigned long location=temp;location<=temp+2;location++)
{
switch(location%3)
{
case 0:
inTarget.blue+=newData[location];
break;
case 1:
inTarget.green+=newData[location];
break;
case 2:
inTarget.red+=newData[location];
break;
default:
break;
}
}
inTarget.totalPixilCount++;
x++;
}
y++;
}
}
示例14: receive_data
int tcp_connect::receive_data(frame &f)
{
char buf[256];
struct sockaddr_in client_addr;
socklen_t len = sizeof(struct sockaddr_in);
recvfrom(this->csock, buf, BUFLEN, 0, (struct sockaddr *) &(client_addr), &len);
f.parse(buf,client_addr);
}
示例15: next
// Iteration
void next() {
// handle frames with inlining
if (_mode == compiled_mode && fill_in_compiled_inlined_sender()) return;
// handle general case
do {
_frame = _frame.sender(&_reg_map);
} while (!fill_from_frame());
}