當前位置: 首頁>>代碼示例>>C++>>正文


C++ DIAG函數代碼示例

本文整理匯總了C++中DIAG函數的典型用法代碼示例。如果您正苦於以下問題:C++ DIAG函數的具體用法?C++ DIAG怎麽用?C++ DIAG使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了DIAG函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: settings_restore

int settings_restore(settings_location location) {
    int i;
    lock();
    EEFS_ERROR err;
    DIAG(" %d\n", 0);
    int addr = SETTINGS_START_ADDRESS + location * sizeof (settings);
    for (i = 0; i < ADC_NUMBER_OF_INPUTS; i++) {
        err = eefs_object_restore(addr + i, &settings[i], sizeof (settings_t));
        DIAG("iperiod: %d", settings[i].integration_period);
        if (err != EEFS_OK) {
            DIAG("error loading settings");
            settings_set_default();
            unlock();
            return 1;
        }
    }
    actual_settings = settings;
    DIAG("");
//    err = eefs_object_restore(addr + i, &actual_settings, sizeof(settings_t*));
//    if(err != EEFS_OK){
//        actual_settings = settings;
//        DIAG("error loading actual setting");
//    }
    unlock();
    return 0;
}
開發者ID:asanza,項目名稱:keithley_199,代碼行數:26,代碼來源:settings.c

示例2: set_desktop_widget

/* HR 270801
 * Attach a desktop to a window
 */
global
void set_desktop_widget(XA_WINDOW *wind,
					    XA_TREE *desktop)		/* HR tree --> widget */
{
	XA_TREE *nt = xcalloc(1,sizeof(XA_TREE),103);		/* HR: use calloc */
	XA_WIDGET *wi = get_widget(wind, XAW_TOOLBAR);		/* HR */
	XA_WIDGET_LOCATION loc;

	DIAG((D_widg,nil,"set_desktop_widget(wind=%d):[email protected]%lx\n", wind->handle, nt));

	if (!nt)
	{
		DIAG((D_widg,nil," - unable to allocate widget.\n"));
		return;
	}

	*nt = *desktop;			/* HR desktop widget.tree */

	loc.relative_type = LT;
	loc.r = wind->r;
	loc.r.y += MENU_H + 1;
	loc.r.w -= MENU_H + 1;

	wi->display = display_object_widget;
	wi->click   = click_desktop_widget;
	wi->dclick  = click_desktop_widget;
	wi->drag    = click_desktop_widget;
	wi->loc   = loc;
	wi->state = NONE;
	wi->stuff = nt;
	wi->start = 0;
}
開發者ID:daemqn,項目名稱:Atari_ST_Sources,代碼行數:35,代碼來源:DESKTOP.C

示例3: stream

static int stream()
{
	unsigned iter = 0;
	int id_buf[16];
	int fp = dev->getDeviceHandle();
	int ifirst = MAXINT;
	int nbuf = 0;

	int rc = ioctl(fp, RTM_T_START_STREAM_MAX, &transfer_buffers);
	if (rc != 0){
		perror("ioctl RTM_T_START_STREAM failed");
		exit(errno);
	}

	while (iter < MAXITER){
		DIAG("CALLING read\n");
		int nread = read(fp, id_buf, NELEMS*sizeof(int));
		int ibuf;

		DIAG("	read returned %d\n", nread);

		if (nread > 0){
			for (ibuf = 0; ibuf < nread/sizeof(int); ++ibuf){
				int nwrite =  sizeof(int)*1;

				if (id_buf[ibuf] <= ifirst ){
					ifirst = id_buf[ibuf];
					if (RECYCLE == 0){
						++CYCLE;
					}else{
						if (++CYCLE >= RECYCLE){
							CYCLE=0;
						}
					}
				}
				DIAG("CALLING process\n");
				process(id_buf[ibuf], ++nbuf);
			
				dbg(2, "write [%d] %d\n", ibuf, id_buf[ibuf]);

				DIAG("CALLING write\n");
				if (write(fp, id_buf+ibuf, nwrite) != nwrite ){
					perror("write failed");
					return -1;
				}
			}
		}else{
			perror("read error");
			return nread;
		}

		iter = ++iter&MAXITER_MASK;
	}

	DIAG("all done\n");
	return 0;
}
開發者ID:petermilne,項目名稱:ks-2G-4G-llc,代碼行數:57,代碼來源:rtm-t-stream-disk.cpp

示例4: validate

bool validate(int M, vector<string>& nodes, int T, vector<string>& tags) {
    if (M != nodes.size()) {
        DIAG("ERROR: Specified node count is not same as actual node count !" << endl);
        return false;
    }
    if (T * M != tags.size()) {
        DIAG("ERROR: Specified total tag count is not same as expected tag count, NodeCount * TagCount !" << endl);
        return false;
    }
    return true;
    
}
開發者ID:melkote,項目名稱:ns_server_rebalancer,代碼行數:12,代碼來源:rebalance.cpp

示例5: system_read_input

double system_read_input(system_flags_t* flag)
{
    if(xSemaphoreTake(syslock, 1000) == pdFALSE){
        DIAG("Cannot obtain sysmutex");
        return 0;
    }
    /* get lock before doing a measurement. It guarantees that no settings changes
     * are done while using the adc. */
    double value, temperature;
    *flag = 0;
    if(is_temp_mode){
        temperature = tmp245_read_temp_double();
        value = temperature;
    } else{
        value = gain * adc_read_value(channel, (int*)flag) + offset;
        if(resln == ADC_RESOLUTION_6_5){
            if(fabs(value - acc_value) <= wn_delta){
                acc_value = acc_value + (value - acc_value)/RESLN_6_5_FILTER_SIZE;
                value = acc_value;
            }else{
                *flag |= SYS_FLAG_FILTER_OUT_WINDOW;
                acc_value = value;
            }
        }
    }
    /* release semaphore when done. */
    xSemaphoreGive(syslock);
    assert(!isnan(value));
    assert(!isinf(value));
    return value;
}
開發者ID:asanza,項目名稱:keithley_199,代碼行數:31,代碼來源:system.c

示例6: stab_types_eq

bool stab_types_eq(struct stab *st, size_t a, size_t b) {
    // todo: when cache in place, just check a == b
    struct stab_type *at = STAB_TYPE(st, a), *bt = STAB_TYPE(st, b);
    if (at->ty.tag != bt->ty.tag) {
        return false;
    } else {
        switch (at->ty.tag) {
            case TYPE_BOOLEAN:
            case TYPE_CHAR:
            case TYPE_INTEGER:
            case TYPE_REAL:
            case TYPE_STRING:
                return true;
            case TYPE_ARRAY:
                return (at->ty.array.upper == bt->ty.array.upper
                    &&  at->ty.array.lower == bt->ty.array.lower
                    &&  at->ty.array.elt_type == bt->ty.array.elt_type);
            case TYPE_FUNCTION:
            case TYPE_RECORD:
                return a == b;
            case TYPE_POINTER:
                return stab_types_eq(st, at->ty.pointer, bt->ty.pointer);

            case TYPE_REF:
            default:
                DIAG("bad type for comparison!\n");
                abort();
        }
    }
}
開發者ID:richteer,項目名稱:cs445,代碼行數:30,代碼來源:symbol.c

示例7: pointersize

void pointersize(int size)
{
	if (prm_nasm && skipsize)
		return;
/*	if (needpointer)
*/		switch (size) {		
			case 10:
				fprintf(outputFile,"TBYTE ");
				break;
			case 8:                      
       	fprintf(outputFile,"QWORD ");
				break;
			case 6:
				if (!uses_float) {
					fprintf(outputFile,"FWORD ");
					break;
				}
			case 4:                      
				fprintf(outputFile,"DWORD ");
				break;
			case 2:
				fprintf(outputFile,"WORD ");
				break;
			case 1:
				fprintf(outputFile,"BYTE ");
				break;
			default:
				DIAG("Bad pointer");
		}	
		if (!prm_nasm)
			fprintf(outputFile,"PTR ");
}
開發者ID:BGCX261,項目名稱:zlmtank-svn-to-git,代碼行數:32,代碼來源:OUTAS386.C

示例8: rtopxy

global
void *form_save(int d, RECT r, void *area)
{
	MFDB Mscreen={0};
	MFDB Mpreserve;
	G_i pnt[8];
	
	r.x-=d, r.y-=d, r.w+=2*d, r.h+=2*d;

	rtopxy(pnt, &r);
	ritopxy(pnt+4,0,0,r.w,r.h);
DIAG((D_menu,nil,"form_save %d/%d,%d/%d\n",r.x,r.y,r.w,r.h));
	Mpreserve.fd_w = r.w;
	Mpreserve.fd_h = r.h;
	Mpreserve.fd_wdwidth = (r.w + 15) / 16;
	Mpreserve.fd_nplanes = screen.planes;
	Mpreserve.fd_stand = 0;

	if (area == nil)
		area = xmalloc(calc_back(&r,screen.planes),210);

	if (area)
	{
		Mpreserve.fd_addr = area;
		vro_cpyfm(C.vh, S_ONLY, pnt, &Mscreen, &Mpreserve);
	}
	return area;
}
開發者ID:daemqn,項目名稱:Atari_ST_Sources,代碼行數:28,代碼來源:DRAW_OBJ.C

示例9: seg_number_of_tribs

int seg_number_of_tribs(int r, int c, SEGMENT *streams, SEGMENT *dirs)
{

    int trib = 0;
    int i, j;
    int streams_cell = 0;
    int dirs_cell = 0;

    for (i = 1; i < 9; ++i) {
	if (NOT_IN_REGION(i))
	    continue;

	j = DIAG(i);

	Segment_get(streams, &streams_cell, NR(i), NC(i));
	Segment_get(dirs, &dirs_cell, NR(i), NC(i));

	if (streams_cell && dirs_cell == j)
	    trib++;
    }

    if (trib > 5)
	G_fatal_error(_("Error finding nodes. "
                        "Stream and direction maps probably do not match."));
    if (trib > 3)
	G_warning(_("Stream network may be too dense"));

    return trib;
}
開發者ID:caomw,項目名稱:grass,代碼行數:29,代碼來源:stream_topology.c

示例10: seg_trib_nums

int seg_trib_nums(int r, int c, SEGMENT *streams, SEGMENT *dirs)
{				/* calculate number of tributaries */

    int trib_num = 0;
    int i, j;
    int next_r, next_c;
    int streams_cell, streams_next_cell, dirs_next_cell;

    Segment_get(streams, &streams_cell, r, c);
    for (i = 1; i < 9; ++i) {
	if (NOT_IN_REGION(i))
	    continue;

	j = DIAG(i);
	next_r = NR(i);
	next_c = NC(i);

	Segment_get(streams, &streams_next_cell, next_r, next_c);
	Segment_get(dirs, &dirs_next_cell, next_r, next_c);

	if (streams_next_cell > 0 && dirs_next_cell == j)
	    trib_num++;
    }

    if (trib_num > 1)
	for (i = 1; i < 9; ++i) {
	    if (NOT_IN_REGION(i))
		continue;

	    j = DIAG(i);
	    next_r = NR(i);
	    next_c = NC(i);

	    Segment_get(streams, &streams_next_cell, next_r, next_c);
	    Segment_get(dirs, &dirs_next_cell, next_r, next_c);

	    if (streams_next_cell == streams_cell && dirs_next_cell == j)
		trib_num--;
	}

    if (trib_num > 5)
	G_fatal_error(_("Error finding inits. Stream and direction maps probably do not match"));
    if (trib_num > 3)
	G_warning(_("Stream network may be too dense"));

    return trib_num;
}				/* end trib_num */
開發者ID:caomw,項目名稱:grass,代碼行數:47,代碼來源:stream_topology.c

示例11: putlen

void putlen(int l)
/*
 *      append the length field to an instruction.
 */
{ 
	if (l!= 10 && l != 8 && l != 6 && l != 4 && l != 1 && l != 2 && l != 0)
     DIAG("illegal length field.");
}
開發者ID:BGCX261,項目名稱:zlmtank-svn-to-git,代碼行數:8,代碼來源:OUTAS386.C

示例12: stab_resolve_complex_type

static size_t stab_resolve_complex_type(struct stab *st, char *name, struct ast_type *ty) {
    struct stab_type *t = M(struct stab_type);
    t->defn = NULL;
    t->name = name;
    t->ty.tag = ty->tag;
    t->magic = 0;

    switch (ty->tag) {
        case TYPE_POINTER:
            t->ty.pointer = stab_resolve_type(st, strdup(name), ty->pointer);
            t->size = ABI_POINTER_SIZE; // XHAZARD
            t->align = ABI_POINTER_ALIGN; // XHAZARD
            break;

        case TYPE_RECORD:
            t->ty.record.fields = list_empty(CB free_stab_record_field);

            LFOREACH(struct ast_record_field *field, ty->record)
                // todo: check that field name is unique
                list_add(t->ty.record.fields, YOLO stab_record_field(field->name, stab_resolve_type(st, strdup(field->name), field->type)));
            ENDLFOREACH;

            break;

        case TYPE_ARRAY:
            t->ty.array.lower = atoi(ty->array.lower);
            t->ty.array.upper = atoi(ty->array.upper);
            t->ty.array.elt_type = stab_resolve_type(st, strdup("<array elts>"), ty->array.elt_type);
            t->size = STAB_TYPE(st, t->ty.array.elt_type)->size * (t->ty.array.upper - t->ty.array.lower);
            break;

        case TYPE_FUNCTION:
            t->ty.func.type = ty->func.type;
            t->ty.func.retty = stab_resolve_type(st, strdup("<func ret>"), ty->func.retty);
            t->ty.func.args = list_empty(CB dummy_free);
            t->ty.func.ret_assigned = false;
            t->magic = 0;

            LFOREACH(struct ast_decls *decl, ty->func.args)
                LFOREACH(char *name, decl->names)
                    size_t id = stab_resolve_type(st, strdup(name), decl->type);
                    list_add(t->ty.func.args, YOLO stab_add_var(st, strdup(name), id, NULL, NULL, false));
                ENDLFOREACH;
            ENDLFOREACH;

            t->size = ABI_CLOSURE_SIZE; // XHAZARD
            t->align = ABI_CLOSURE_ALIGN; // XHAZARD
            break;

        default:
            DIAG("resolve_complex_type given simple type!\n");
            abort();
            return -1;
    }

    return ptrvec_push(st->types, YOLO t);
}
開發者ID:richteer,項目名稱:cs445,代碼行數:57,代碼來源:symbol.c

示例13: process

static void process(int ibuf, int nbuf){
	if (VERBOSE){
		fprintf(stderr, "%02d\n", ibuf);
	}

	char buf[80];

	
	sprintf(buf, "%s/%06d/", OUTROOT, CYCLE);
	mkdir(buf, 0777);
	sprintf(buf, "%s/%06d/%d.%02d", OUTROOT, CYCLE, dev->getDevnum(), ibuf);

	if (NO_OVERWRITE){
		struct stat stat_buf;
		int rc = stat(buf, &stat_buf);
		DIAG("stat:rc %d errno %d\n", rc, errno);
		if (rc == 0){
			err("OVERRUN: NO_OVERWRITE SET and \"%s\" exists",
					buf);
			exit(1);
		}else if (errno != ENOENT){
			err("OVERRUN: NO_OVERWRITE SET and \"%s\" exists",
					buf);
			perror("buf");
			exit(errno);
		}else{
			;	/* ENOENT - that's good! */
		}
	}
	int outfp = open(buf, O_MODE, PERM);

	if (outfp == -1){
		perror(buf);
		_exit(errno);
	}
	write(outfp, dev->getHostBufferMapping(ibuf), maxlen);

	strcat(buf, ".id");
	int out_meta = open(buf, O_MODE, PERM);
	write_meta(out_meta, ibuf, nbuf);

	close(out_meta);		
	close(outfp);		/* close data last - we monitor this one */

	if (PUT_DATA){
		char *cp = strstr(buf, ".id");
		if (cp){
			*cp = '\0';
		}
	}
	puts(buf);

	if (USLEEP){
		usleep(USLEEP);
	}
}
開發者ID:petermilne,項目名稱:ks-2G-4G-llc,代碼行數:56,代碼來源:rtm-t-stream-disk.cpp

示例14: DIAG

/* HR 021101: new function to make the code orthogonal.
*/
static
G_i *transform_icon_bitmap(XA_CLIENT *client, CICONBLK *icon, G_i *map, long len, int planes)
{
	MFDB src, dst;
	G_i *new_data = map, *tmp = nil;
	long icon_len = len * planes,
	     new_len = len * screen.planes;

DIAG((D_s,client,"icon_len %ld, new_len %ld\n", icon_len, new_len));

	if (planes < screen.planes)
	{
		DIAG((D_x,client,"XA_calloc 3 %ld\n", new_len));
		new_data = XA_calloc(&client->base, 1, new_len, 3, client->rsct);		/* HR: and put in a list. */
		if (new_data == nil)					/* HR 021101: check */
			return map;
		memcpy(new_data, map, icon_len);
	}

	src.fd_w = icon->monoblk.ic.w;			/* Transform MFDB's */
	src.fd_h = icon->monoblk.ic.h;
	src.fd_wdwidth = (src.fd_w + 15) / 16;		/* HR: round up */
	src.fd_stand = 1;
	src.fd_r1 = src.fd_r2 = src.fd_r3 = 0;
	src.fd_nplanes = screen.planes;			/* HR */
	dst = src;

	dst.fd_addr = new_data;
	dst.fd_stand = 0;

	DIAG((D_x,client,"XA_calloc %d*%ld\n", 1, new_len));
	tmp = XA_calloc(nil, 1, new_len, 0, 0);
	if (tmp)								/* HR 021101: check */
	{
		memcpy(tmp, new_data, new_len);
		src.fd_addr = tmp;
		transform_gem_bitmap_data(src, dst, planes, screen.planes);
/*		vr_trnfm( C.vh, &src, &dst );  */
		free(tmp);
	}

	return new_data;
}
開發者ID:daemqn,項目名稱:Atari_ST_Sources,代碼行數:45,代碼來源:XA_RSRC.C

示例15: EventLoop

static void
EventLoop (void)
{
    EventType	event;
    SDWord	timeout;
    UInt32	timer_next;
    Word	error;

    do
    {
        timeout = evtWaitForever;
        timer_next = 0;
        if (needRedisplay)
            timeout = 0;
        else if (game.timer_running)
        {
            UInt32  now = TimGetTicks ();
            int	    sec = (now - game.timer_start) / sysTicksPerSecond;

            timer_next = ((sec + 1) * sysTicksPerSecond + game.timer_start);
            timeout = timer_next - now;
        }
        EvtGetEvent (&event, timeout);
        DIAG (("Event %d\n", event.eType));
        if (timer_next && TimGetTicks () <= timer_next)
            DamageCount ();
        if (needRedisplay && event.eType == nilEvent)
            FrmUpdateForm (mainForm, frmRedrawUpdateCode);
        if (event.eType == nilEvent)
            continue;

        /* Give the system a chance to handle the event. */
        if (! SysHandleEvent (&event))
        {
            if (!MenuHandleEvent (0, &event, &error))
            {
                /* Give the application a chance to handle the event. */
                if (!ApplicationHandleEvent (&event))
                {
                    /* Let the form object provide default handling of the event. */
                    FrmDispatchEvent (&event);
                }
            }
        }
    }
    while (event.eType != appStopEvent);
    // ** SPECIAL NOTE **
    // In order for the Emulator to exit
    // cleanly when the File|Quit menu option is
    // selected, the running application
    // must exit.  The emulator will generate an
    // ÒappStopEventÓ when Quit is selected.
}
開發者ID:ricochet-robotics,項目名稱:rr-palmpilot-c,代碼行數:53,代碼來源:main.c


注:本文中的DIAG函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。