Merci, exactement ce qu'il me fallait.
Je sais pas ce qui ne vas pas, mais getsn ne fonctionne pas.
Si je saisie une chaîne, et que je valide par enter, ca ne met pas fin à la saisie, ca saute simplement une ligne.
Sinon j'ai trouvé une autre méthode dans la FAQ avec ngetchx().
Tu utilises quoi comme compilateur? Et quelle version?
J'utilise l'IDE tigcc v 0.95 avec VTI.
La 0.95 est obsolète, essaie la 0.96 Beta 8.
Bien que l'upgrade depuis TIGCC 0.95 vers TIGCC 0.96 Beta 8 (ou plus récent) soit plutôt une bonne idée, il n'est pas garanti que cela change le comportement de son programme: ni getsn.s, ni fputchar.s, ni fgetchar.s, ni fgetchrc.s n'ont été modifiés depuis que le repository CVS de TIGCC existe (c'est à dire, depuis une date légèrement postérieure à TIGCC 0.95, mais antérieure à TIGCC 0.96 Beta 1).
Je déconseille fortement l'utilisation de ces hacks qui grossiront ton programme, il vaut mieux apprendre la programmation sur TI directement. Et puis, Thibaut, je ne comprends pas l'intérêt de ton histoire de curseur dans getsn.
S'il y a un problème avec notre fonction getsn, il faudra la corriger, pas la remplacer avec une autre implémentation qui pourrait avoir d'autres bogues.
Un truc qui me vient: essaierais-tu d'utiliser sizeof sur un tableau alloué dynamiquement? Ce n'est pas possible, ça donnera toujours la taille d'un pointeur (4 octets), donc forcément il n'acceptera que 3 caractères (4 - 1 pour le '\0'). Passe directement la taille que tu as allouée, pas sizeof(ptr).
Ta bidouille de _main est un hack, faire ça proprement demande beaucoup plus de travail, probablement aussi au niveau du linker.
Qu'est-ce qu'il faudrait changer pour que le _main de likeonpc soit propre selon tes critères (en supposant que tes critères soient bons) ? Tu parles beaucoup mais n'apportes rien, comme toujours.

Un site complet sur lequel vous trouverez des programmes et des jeux pour votre calculatrice TI 89 / Titanium / 92+ / Voyage 200 :
www.ti-fr.com.
Quelques idées personnelles
ici.
Bah, faudrait que je me plonge dessus et commence à coder, c'est comme ça que je vois comment faire les choses au mieux, c'est dur de le dire comme ça au préalable.
OK, tu ne sais même pas ce qui pourrait te déplaire. On va finir par croire que tu critiques le travail des gens juste pour le plaisir de te croire meilleur.

Un site complet sur lequel vous trouverez des programmes et des jeux pour votre calculatrice TI 89 / Titanium / 92+ / Voyage 200 :
www.ti-fr.com.
Quelques idées personnelles
ici.
Il faut un certain feeling pour coder quelque chose de bien pensé, et c'est souvent en essayant qu'on y arrive. Tout ce que je peux dire, c'est que ta solution ne me convient pas. Le problème principal est que certaines propriétés du wrapper devraient être configurables, par exemple la manière de gérer les codes d'erreurs retournés par main (et exit devrait adopter le même comportement pour être cohérent), ou encore le clrscr implicit. De plus, rajouter des fonctionnalités d'édition à stdio.h et avoir un main ISO sont 2 choses totalement différentes qui ne devraient pas dépendre l'une de l'autre. L'utilisation de tableaux de taille fixe est aussi un signe de mauvaise conception.
C'est un problème assez compliqué. S'il y avait une solution simple, elle serait déjà implémentée!
T'as toujours la même difficulté à discerner les principes généraux des cas particuliers. Va taper plus de 256 caractères dans les arguments... Ça passe sur PC ça d'ailleurs ? Si on augmente la taille maximale des arguments à 4000 octets, tu trouveras encore que ce ce sera trop peu ? Y'a un moment où il faut arrêter d'être ridicule. Une taille dynamique creuserait des trous dans le tas. J'appelle pas ça une solution convenable. Et toi ?
L'utilisation des nouvelles fonctions I/O n'a jamais été dépendante du _main. Tu parles sans savoir.

Un site complet sur lequel vous trouverez des programmes et des jeux pour votre calculatrice TI 89 / Titanium / 92+ / Voyage 200 :
www.ti-fr.com.
Quelques idées personnelles
ici.
Je viens de redécouvrir les possibilités assez spéciales que le TIOS offre sur les blocs de mémoire. On peut allouer un bloc flottant, le réallouer, etc, et finir par le monter tout en haut du tas en le bloquant. On est certain que cette séquence d'opérations ne laissera pas de trou dans le tas ?
Si oui, on peut faire comme ça :
- commencer à écrire argv sur le bloc alloué dans la pile
- en cas de dépassement, allocation d'un bloc pour poursuivre l'écriture (et réallocations au besoin).
- bloquage du bloc en tête de tas.
Il ne faudrait pas que le code qui fait tout ça dépasse 256 octets, sinon le gain de RAM obtenu grâce à l'allocation sur la pile serait perdu.

Un site complet sur lequel vous trouverez des programmes et des jeux pour votre calculatrice TI 89 / Titanium / 92+ / Voyage 200 :
www.ti-fr.com.
Quelques idées personnelles
ici.