Форум программистов, компьютерный форум CyberForum.ru

Как создать va_list для _vsntprintf ? - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Обработка исключений http://www.cyberforum.ru/cpp-beginners/thread22975.html
Как сделать обработку исключения так, чтобы, если, например, вводим количество координат больше, чем можно, программа предлагала, или выйти, или попробовать ввести ещё раз. Я пробовал с помощью switch, но там если ввести первый раз неправильно, то он запускается, если ещё раз неправильно, то уже обработка исключения не идёт, то есть, нужно под каждый неправильный ввод писать новый ввод объекта и...
C++ Лежит ли точка в круге и треугольнике Даны круг и треугольник на плоскости.Кординаты вводятся с клавиатуры.Даны кординаты точки. Узнать лежит ли точка в области пересечения 2ух фигур http://www.cyberforum.ru/cpp-beginners/thread22972.html
Чтобы звездочка бегала по краям экрана C++
Доброго времени суток, уважаемые программисты! Нужна помощь. Написал программу на Borland C++, которая заполняет экран ASCII символом * (звездочка), вся проблема в том что она заполняет экран от начала до конца а я хочу улучшить программу чтобы звездочка бегала по краям экрана притом чтобы не было видно предыдущую. Не могу понять как это сделать. Вот нынешний код: #include<stdio.h>...
C++ надо программу, в которой задача состоит в том, чтобы найти точку на двумерной сетке
Точка, безусловно, определяется координатами. Сетка должна иметь определенный размер, например, от 100 до 100 меш. Программа должна в начале своей деятельности выбирать точку на сетке(случайно), и задача пользователя будет,выбирать точку на сетке координат. В ответ, программа должна найти расстояние между точками и вывести на екран. Ето будет проиcходить до тех пор пока пользователь не угадает...
C++ Классы в Turbo C/Borland C http://www.cyberforum.ru/cpp-beginners/thread22951.html
Класс для объекта-вектора, что задается координатами концов. Создать операции сложения и отнимания. Можете написать как должен выглядеть этот класс?
C++ Сортировка массива структур Имеется массив структур, который необходимо отсортировать по числовому ключу. Я написал код, но он не работает, поэтому просьба указать на ошибку. #include <stdio.h> #include <stdlib.h> int i; typedef struct { подробнее

Показать сообщение отдельно
alex63
Сообщений: n/a
22.02.2009, 19:50     Как создать va_list для _vsntprintf ?
Все работает. Получилась такая функция
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
static int ads_ak_format(void)
{
        struct resbuf  *rb=acedGetArgs () ;             
        // TODO: add your code here
 TCHAR format[512];
 TCHAR buff[1024]; 
 int sizeofVa_list=0;
  
if(rb == NULL) return RTNORM;
 
if (rb->restype == RTSTR) wcscpy(format,rb->resval.rstring);
  else {  acdbFail(_T("\n first  Argument should be an string. Example \"A= %s s=%d\""));
       return (RTERROR); 
  }
 rb=rb->rbnext; 
struct resbuf *p=rb;
sizeofVa_list=sizeofListVal(p);
const char *m=(char *)malloc(sizeof(sizeofVa_list));// +   sizeof(char));
void *bm=(void *)m;
while (rb != NULL) 
{
switch(rb->restype)
   {
case RTREAL: 
    (*(ads_real*)m)=rb->resval.rreal; //puts the next value
    m += sizeof(ads_real);  //(double); // move forward again
    break;
case RTSHORT :
    (*(int*)m)=(int)rb->resval.rint; //puts the next value      
    m += sizeof(int);// move forward again      
    break;
case RTLONG :
    (*(int*)m)=(int)rb->resval.rlong; //puts the next value
    m += sizeof(int);
    break;
case RTSTR :
    (* (TCHAR **)m)=rb->resval.rstring;
    m += sizeof(TCHAR *);
    break;
default :
    acutPrintf(_T("\n only type {double int string} ."));   
    break;
     }   
    rb=rb->rbnext;
   }// while
int ii=(_tcslen(buff)+1)*sizeof(TCHAR);
vswprintf(buff,ii,format,(va_list)bm);
acedRetStr(strsave(buff));
acutRelRb(rb);
free(bm);
return (RSRSLT) ;
    }
Пользователь получил красную карточку за это сообщение.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru