Myriad Blog 1.3.0 Friday, May 24th, 2013 at 03:39am 

Technical Tuesday, Apr 27th, 2010 at 05:26pm
Visual C++ 2008 Express et Windows 95/98/ME

 
Nous en avions parlé en décembre dernier, dans ce billet et celui-ci, les nouvelles versions des compilateurs Microsoft ne permettent pas de compiler des applications pour Windows 95, 98 et ME.
 
Apparemment, nous ne sommes pas les seuls à avoir planché sur le problème, qui a laissé perplexe la communauté des développeurs sous Windows.
 
Voici la solution que nous avons trouvée, en espérant qu'elle puisse aider les autres programmeurs.
 
- Récupérer dans un ancien compilateur (à l'époque ou Win9x était supporté) le répertoire des librairies système et des includes. Le garder au chaud.
 
- Dupliquer une solution qui fonctionne, et en créer une spécifique à Windows 9x
 
- Supprimer toutes les subtilités qui augmentent le niveau d'incompatibilité (protection de dépassement de buffer, etc) afin d'obtenir un projet le plus simple possible
 
- Dans la section "Input" du linker, mettre "Ignore All Default Libraries" à "Yes".
 
- Dans "Additional Dependencies", ajouter toutes les librairies nécessaires, depuis le répertoire récupéré au début. Il y aura besoin de LIBCMT.LIB ou LIBCMTD.LIB (debug), OLDNAMES.LIB, et probablement KERNEL32.LIB, COMCTL32.LIB, etc, selon votre projet.
 
- Une fois cela fait, essayer un "Rebuild". Le linker donnera la liste des fonctions qui n'étaient pas présentes dans les libraries précédentes et qui sont nécessaires pour faire tourner les nouveaux projets. Et là, pas d'autre moyen que de réécrire les fonctions manquantes.
 
- Donc, créer un nouveau fichier source (que j'ai appelé CompatW9x.c), et réécrire les fonctions manquantes, qui peuvent différer selon le projet. Il va ressembler à quelque chose comme ça:
Quote:
#include "\Old Libs\Include\stdio.h"
#include "\Old Libs\Include\time.h"
#include "\Old Libs\nclude\wchar.h"
 
FILE * _cdecl __iob_func(void) { return(_iob); }
long _ftol2_sse(float x) { return(_ftol(x));}
char * _ctime32(const time_t * t) {return(ctime(t));}

etc.
 
Normalement, si votre projet n'est pas trop compliqué, et idéalement s'il est constitué de sources C en non C++, vous devriez vous en sortir avec une douzaine de fonctions à réécrire.
 
A partir de là, vous obtenez un exécutable compatible Win9x. Encore faut-il modifier le numéro de version de Windows minimal nécessaire au programme. Ceci peut se faire grâce au petit programme pever, de Korosoft.
 
Et voila, vous devriez obtenir une version de votre programme qui tourne sur Windows 9x.
 
Nous avons fait cela avec succès pour tous nos programmes, en C et C++, sauf un.
Nous n'avons pas réussi à mettre cela en place pour notre produit "Myriad Music Plugin", qui contient un contrôle ActiveX. Celui-ci utilise en effet des fonctionnalités avancées en C++, qui demandent de réécrire d'autres fonctions: _SEH_prolog, _SEH_epilog, et les opérateurs delete[](void *) et new[](unsigned int).
Nous avons trouvé des sources assembleur pour les deux premières sur le net, et il doit être possible de bricoler les deux dernières, mais nous en avons eu un peu assez de passer du temps sur des versions du système datant d'une décennie.
 
Donc les utilisateurs de ces versions de Windows seront privés des dernières évolutions de notre plug-in, à moins qu'un développeur rencontrant le même problème soit disposé à échanger par mail ses fichiers source avec nous...
by Olivier Guillion


Full view
Reduced view
Most recent first
Oldest first
All
Didier Guillion
Olivier Guillion
Sylvie Ricard
All
Dev News
Technical
Mood
Memories
Myriad Life
To be seen
30 previous days
Apr 2006
May 2006
Jun 2006
Jul 2006
Aug 2006
Sep 2006
Oct 2006
Nov 2006
Dec 2006
Jan 2007
Feb 2007
Mar 2007
Apr 2007
May 2007
Jun 2007
Jul 2007
Aug 2007
Sep 2007
Oct 2007
Nov 2007
Dec 2007
Jan 2008
Feb 2008
Mar 2008
Apr 2008
May 2008
Jun 2008
Jul 2008
Aug 2008
Sep 2008
Oct 2008
Nov 2008
Dec 2008
Jan 2009
Feb 2009
Mar 2009
Apr 2009
May 2009
Jun 2009
Jul 2009
Aug 2009
Sep 2009
Oct 2009
Nov 2009
Dec 2009
Jan 2010
Feb 2010
Mar 2010
Apr 2010
May 2010
Jun 2010
Jul 2010
Aug 2010
Sep 2010
Oct 2010
Nov 2010
Dec 2010
Jan 2011
Feb 2011
Mar 2011
Apr 2011
May 2011
Jun 2011
Jul 2011
Aug 2011
Sep 2011
Oct 2011
Nov 2011
Dec 2011
Jan 2012
Feb 2012
Mar 2012
Apr 2012
May 2012
Jun 2012
Jul 2012
Aug 2012
Sep 2012
Oct 2012
Nov 2012
Dec 2012
Jan 2013
Feb 2013
Mar 2013
Apr 2013
May 2013
May 23rd, 2013 at 11:21pm 
Comment from jihel9
nuances
May 23rd, 2013 at 06:48pm 
Comment from Cri-Cri
Fil du forum sur la taille des objets tempo
May 23rd, 2013 at 06:48pm 
Comment from Cri-Cri
Fil du forum sur la taille des objets tempo
May 23rd, 2013 at 05:50pm 
Comment from Cri-Cri
Introuvable
May 23rd, 2013 at 05:50pm 
Comment from Cri-Cri
Introuvable
May 23rd, 2013 at 04:54pm 
Article from Olivier Guillion
Awalé 4.0 étape 3
May 23rd, 2013 at 03:08pm 
Comment from Didier Guillion
Re: Harmony 9.6  étape 506
May 23rd, 2013 at 01:32pm 
Comment from Cri-Cri
Un long couplet...
May 23rd, 2013 at 11:25am 
Comment from Antoine Bautista
Commentaire !
May 23rd, 2013 at 10:19am 
Comment from Olivier Guillion
Procédure

Top of page
Last update:  (c) Myriad 2013