- Posted On the 2010-08-30 at 06:56 pm Member since 2001-10-28, 7581 posts
D'après la doc de TIGCC/GCC4TI,
int (*x[5])(); An array of pointers to a function which returns an integer

La version avec une taille indéfinie de tableau de cette écriture doit être
int (**x)()

Et un pointeur sur ce truc doit être
int (***x)()


(non testé)
avatar Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
Co-admin de TI-Planet.
- Posted On the 2010-08-30 at 06:57 pm Member since 2001-06-18, 30610 posts
Ah, ça s'écrit comme ça ? Un pointeur sur un pointeur de fonction en effet... Merci beaucoup !
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-30 at 06:59 pm Member since 2001-06-18, 30610 posts
Anéfé, ça marche comme ça :
int pdtlib__ManageArgs (CMDLINE* CmdLine, const char* OptList, void (**FuncList)(), void (*Fallback)())
{
FuncList[OptCount]();
}

Je vais lire le code pour voir si c'est bien ça que j'attends. smile
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 02:29 pm Member since 2001-06-18, 30610 posts
Pwic


J'ai écrit ce proto :
int pdtlib__ManageArgs (CMDLINE* CmdLine, const char* OptList, int (*Callback)(int Status), void (*SwitchFunc)(char Sign), ...)

Puis j'initialise la liste d'arguments variables ainsi :
	va_list FuncList;
va_start(FuncList, SwitchFunc);

Enfin, j'essaye d'appeler une des fonctions contenue dans cette liste variable :
    va_arg (FuncList, (*))(Sign);            // Sign est un char

Mais bon, visiblement, c'est pas comme ça qu'il faut lui parler... Peut-être que ma manière de passer le type à va_arg [(*)] est mauvais ?

C'est la première fois que j'utilise les va_*. J'y avais jamais pensé, mais si j'arrive à faire marcher ça, c'est surpuissant.

ps -> j'ai regardé les macro dans stdarg.h, j'ai... euh... pas tout compris ^^
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 02:37 pm Member since 2001-06-16, 60223 posts
ouais, tu vas arriver à des __builtin_va_arg grin

c'est quoi cette étoile toute seule entre parenthèses?

- Posted On the 2010-08-31 at 02:38 pm Member since 2001-06-18, 30610 posts
C'est, en soi, un pointeur sur une fonction (sans nom). Je sais pas comment lui dire que le type de donnée dans la liste, c'est "pointeur de fonction"
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 02:39 pm Member since 2001-06-16, 60223 posts
toute fonction implique une paire de parenthèses pour les arguments mon cher.

va_arg (FuncList, (*)())(Sign);

(je crois, hein)
- Posted On the 2010-08-31 at 02:44 pm Member since 2001-06-18, 30610 posts
Ca marche pas mieux.
Et même

va_arg(FuncList, void*)(Sign);

ne marche pas :/ Je suis vraiment pas fort pour exprimer en C ce que je pense grin
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 02:45 pm Member since 2001-06-16, 60223 posts
pour comprendre:

void (*ptr)(void) = va_arg(FuncList, void(*)(void));
ouzencor
void (*ptr)() = va_arg(FuncList, void(*)());

puis:
ptr();

?

donc le type c'est void(*)()

et tu dois pouvoir compacter en

va_arg(FuncList, void(*)())(Sign);

ou avec un cast

(void(*)())va_arg(FuncList,void*)();
- Posted On the 2010-08-31 at 02:49 pm Member since 2001-06-18, 30610 posts
Non plus. J'ai essayé au pif des dizaines d'écritures, je suis pas tombé sur la bonne encore triso

Je vais coder un générateur aléatoire d'écritures pifométriques pour me simplifier les choses trioui
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 02:51 pm - Edited by Folco On the 2010-08-31 at 03:02 pm Member since 2001-06-18, 30610 posts
./38 -> failed && failed :
args.c:71: error: called object '*((FuncList = (FuncList) + 4u) - 4u)' is not a function

Je suis "content" de voir que je ne suis pas le seul à galérer pour mettre en forme une simple écriture. Ca doit pas être évident en fait.
Dire qu'en asm, c'est un movea.l 0(sp,d0.w),a0 // jsr (a0)
Et après on dit que le C est simple et l'assembleur difficile black
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 02:58 pm Member since 2001-06-16, 60223 posts
non c'est très chiant les pointeurs de fonction en C

je suis trouducuté là sorry

- Posted On the 2010-08-31 at 03:05 pm Member since 2001-06-18, 30610 posts
stdarg.h :

#define va_arg(ap,type) (*(type*)((((char*)(ap))+=((sizeof(type)+1)&0xFFFE))-(((sizeof(type)+1)&0xFFFE))))

Si ça peut aider #triprie#
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 05:00 pm Member since 2001-06-18, 30610 posts
Et j'y arrive pas. Faut dire que google(va_arg, function, list) renvoie une plétore de réponses évidemment...
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 10:13 pm Member since 2001-06-18, 30610 posts
Bon, il est 23h passé, tous les poids lourds sont passés ici, et pas de réponse à ./33
J'en conclus que la réponse ne doit pas être si évidente grin
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 10:20 pm Member since 2001-06-11, 19256 posts
Folco (./33) :
Pwic


J'ai écrit ce proto :
int pdtlib__ManageArgs (CMDLINE* CmdLine, const char* OptList, int (*Callback)(int Status), void (*SwitchFunc)(char Sign), ...)

Puis j'initialise la liste d'arguments variables ainsi :
	va_list FuncList;
va_start(FuncList, SwitchFunc);

Enfin, j'essaye d'appeler une des fonctions contenue dans cette liste variable :
    va_arg (FuncList, (*))(Sign);            // Sign est un char

Mais bon, visiblement, c'est pas comme ça qu'il faut lui parler... Peut-être que ma manière de passer le type à va_arg [(*)] est mauvais ?

C'est la première fois que j'utilise les va_*. J'y avais jamais pensé, mais si j'arrive à faire marcher ça, c'est surpuissant.

ps -> j'ai regardé les macro dans stdarg.h, j'ai... euh... pas tout compris ^^

Tu veux faire quoi ?
Sign = va_arg (FuncList, (char));
(*SwitchFunc) (Sign);
?
- Posted On the 2010-08-31 at 10:26 pm Member since 2001-06-18, 30610 posts
Il y a sur la pile une liste d'adresse de fonctions, dont SwitchFunc est le premier élément. Je veux juste pouvoir appeler ces fonctions.

C'est comme si, en asm, je faisais ça :
programme appelant :

pea func3(pc)
pea func2(pc)
pea func1(pc)
jsr lib::ManageArgs

Et dans lib::ManageArgs :
 movea.l x(sp),a0
pea Sign(pc) ; à la rigueur, ça on s'en fout
jsr (a0)

C'est ce movea/jsr que je n'arrive pas à écrire.
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-08-31 at 11:10 pm Member since 2001-06-11, 19256 posts
- Posted On the 2010-08-31 at 11:27 pm Member since 2001-06-18, 30610 posts
hmmm merci beaucoup, encore un truc à apprendre, mais ça a l'air de ressembler à ce que je veux top

C'est con, trois lignes d'asm et c'est réglé, mais j'ai envie de rester portable (juste pour dire que c'est portable ^^)
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-09-01 at 08:53 am Member since 2001-06-30, 57855 posts
Folco: si tu as un doute sur les warning/errors de gcc & consorts, fait passer ton code dans clang, les messages risquent d'etre moins cryptique ^^ Et si ils le sont, il faut le leur dire ^^
avatar
Proud to be CAKE©®™
The cake is a lie! - Love your weighted companion cube

->986-Studio's Wonder Project!<-
- Posted On the 2010-09-01 at 09:29 am Member since 2001-10-28, 7581 posts
Oui, bonne suggestion.
avatar Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
Co-admin de TI-Planet.
- Posted On the 2010-09-01 at 09:54 am Member since 2001-06-16, 60223 posts
mission suivante: trouver/builder/installer/exécuter clang.
- Posted On the 2010-09-01 at 09:56 am Member since 2001-06-18, 30610 posts
Ah, un front-end de llvm... M'étonnerait que Debian le propose ce soft, on va voir si la Fée Dora peut me le faire apparaitre.
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-09-01 at 10:24 am Member since 2001-06-30, 57855 posts
Il est dans ubuntu au moins
avatar
Proud to be CAKE©®™
The cake is a lie! - Love your weighted companion cube

->986-Studio's Wonder Project!<-
- Posted On the 2010-09-01 at 10:28 am Member since 2001-10-28, 7581 posts
Debian testing peut te faire apparaître une version récente de ce soft. Debian stable, en revanche, pas du tout grin

http://clang.llvm.org/get_started.html#build pour compiler clang+llvm toi-même. Peu après la release 2.7, j'avais utilisé le tag 2.7 au lieu du trunk, mais maintenant que la release 2.8 est proche (création de la branche des pre-releases cette semaine), utiliser le trunk est moins aventureux grin
avatar Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
Co-admin de TI-Planet.
- Posted On the 2010-09-01 at 11:05 am Member since 2001-06-18, 30610 posts
Ouep... rah ça fait chier, ce code est fait pour être compilé par tigcc (_library etc...). il me faudra faire un fake main juste pour sa gueule. C'est quand même casse-couilles. Je me demande si je ne vais pas coder toute cette fonction en asm, ça sera bien plus simple, court et rapide.
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-09-01 at 11:53 am Member since 2001-06-16, 60223 posts
pourquoi il faudrait un fake main? compiler un programme pour voir l'asm généré ne requiert pas d'édition de liens, donc t'auras pas besoin de main...
- Posted On the 2010-09-01 at 12:56 pm Member since 2001-06-18, 30610 posts
c'est vrai, je suis con couic
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-09-01 at 02:28 pm Member since 2001-06-16, 60223 posts
meuh non, meuh non.
- Posted On the 2010-09-01 at 04:28 pm Member since 2001-06-18, 30610 posts
Putain de saloperie de bordel de mes trois.
En fouillant dans mon bouquin, je trouve ça :
void va_start (va_list params, identifiacteur); (stdarg.h)

Cette macro initialise le parcourT (sic) de la liste d'argument variables params, sachant que
identificateur est le nom du dernier argument muet fixe. Celui-ci ne doit pas être de la classe
registre, NI DE TYPE FONCTION, sous peine d'aboutir à un comportement indéterminé.

Fais chier de merde !
J'ai toujours moyen de remplir un handle avec des pointeurs de fonctions, mais si techniquement c'est faisable proprement, esthétiquement c'est immonde, et moralement répréhensible.

Auriez-vous une idée valable ?
avatar <<< Kernel Extremist©®™ >>>
Saint Qt, priez pour nous.
- Posted On the 2010-09-01 at 04:36 pm Member since 2001-06-16, 60223 posts
int pdtlib__ManageArgs (CMDLINE* CmdLine, int (*Callback)(int Status), void (*SwitchFunc)(char Sign), const char* OptList, ...)

?