Difference between revisions of "Chelper/fr"
Line 50: | Line 50: | ||
=== Comment l'utiliser === | === Comment l'utiliser === | ||
− | ==== | + | ==== Raccourcis ==== |
− | * ctrl+b - | + | * ctrl+b - convertit une déclaration C simple en Pascal. |
− | * ctrl+shift+b - | + | * ctrl+shift+b - convertit toutes les déclarations C vers Pascal depuis la position courante du curseur jusqu'à la fin du fichier. |
− | ==== | + | ==== Général ==== |
− | * | + | * Ouvrez un fichier avec des déclarations C dans l'EDI Lazarus ou démarrer un nouveau fichier en y copiant les déclarations. |
− | * | + | * Placez le curseur sur la ligne où se trouve la déclaration c et pressez sur Ctrl+B (ce raccourci pourra être modifié à l'avenir). |
− | + | Par exemple: | |
int c; | int c; | ||
int b; | int b; | ||
− | + | Si le curseur estplacé sur la ligne 'inc c;' et que ctrl+b est enfoncé, le résultat serait: | |
var | var | ||
c : Integer; | c : Integer; | ||
int b; | int b; | ||
− | + | exactement une déclaration est convertie. Le curseur serait placé juste après la définition convertie. Vous pouvez appuyer à nouveau sur ctrl+b, et le résultat serait: | |
var | var | ||
c : Integer; | c : Integer; | ||
Line 73: | Line 73: | ||
b : Integer; | b : Integer; | ||
− | + | L'analyse des définitions une par une préparera vos en-têtes C en très peu de temps, tout en les gardant propres et correctes du point de vue de Pascal. | |
− | * | + | * Si vous êtes sûr que vos définitions (expliquées ci-dessous) sont suffisamment bien configurées. Vous pouvez essayer de convertir le reste du fichier en un seul appel en appuyant sur ctrl+shift+b |
− | i.e. | + | i.e. vous avez 2 déclarations dans le fichier: |
int fn(int, float); | int fn(int, float); | ||
extern int v; | extern int v; | ||
− | + | En plaçant le curseur avant eux puis en pressant sur ctrl+shift+b, cela générera: | |
− | |||
function fn(par0: Integer; par1: Single): Integer; cdecl; external; | function fn(par0: Integer; par1: Single): Integer; cdecl; external; | ||
Line 88: | Line 87: | ||
v : Integer; external; | v : Integer; external; | ||
− | ''' | + | '''Vous devez être prudent, car il est courant d'utiliser des macros dans les en-têtes C. Laisser l'une des macros non définie peut produire une mauvaise déclaration pascal'''. La section suivante explique comment définir une macro pour le chelper. |
==== Defines ==== | ==== Defines ==== |
Revision as of 12:18, 30 April 2022
│
English (en) │
français (fr) │
A propos
Chelper est un outil d'extension de Lazarus, qui aide à convertir les fichiers d'entête C en Pascal. Oui c'est un autre outil de conversion C vers Pascal comme beaucoup qui lui sont similaires (H2Pas, ToPas), mais on pourrait le trouver plus utile.
L'extension n'essaie pas de convertir un en-tête pour l'utilisateur, c'est plutôt un outil d'aide à la traduction manuelle, faisant presque tout le "sale boulot" pour l'utilisateur.
Chelper supporte aussi la conversion des déclarations Objective-C vers Objective-P.
Auteur
Dmitry 'skalogryz' Boyarintsev
Licence
modified LGPL (comme pour les FPC RTL et Lazarus LCL). Vous pouvez contacter l'auteur si la LGPL ne convient pas à la licence de votre projet.
Téléchargement
Il n'y a pas encore de paquet téléchargeable", vous pouvez accéder à louil depuis SVN: https://sourceforge.net/p/lazarus-ccr/svn/HEAD/tree/components/chelper/
svn checkout https://svn.code.sf.net/p/lazarus-ccr/svn/components/chelper/
Journal des modifications
- Version 0.8, 8 août 2010
Dependencies / System Requirements
- Lazarus 0.9.29 ou supérieur
Etat: Beta
Problèmes
Aucun analyseur d'expression complet pour construire l'arborescence d'expression.
i vous trouvez un bug dans la convertisseur, veuillez le rapporter dans bugs.freepascal.org pour le projet Lazarus-CCR. Merci d'attacher le fichier d'entête C et les explications sur ce qui ne fonctionne pas comme voulu.
Installation
- Obtenez le paquet depuis SVN.
- Installez le paquet Chelper.lpk depuis Lazarus.
- Allez vers Outils->C to Pascal Options->Converter, décochez Use external converter si vous voulez utiliser le paquet de convertisseur intégré.
L'utilisation du convertisseur intégré présente un avantage en termes de performances. Cependant, si vous devez mettre à jour le convertisseur, vous devrez reconstruire l'intégralité de l'IDE. Il est également possible que le convertisseur provoque des plantages ou des blocages. Vous devriez le signaler, mais vous risquez de perdre toutes vos données.
Il est beaucoup plus sûr d'utiliser l'outil externe cconvert. Il est également plus facile de mettre à jour le convertisseur si de nouvelles fonctionnalités sont ajoutées ou si des bogues sont corrigés. Tout ce dont vous avez besoin est de reconstruire l'exécutable cconverter beaucoup plus rapidement que de reconstruire Lazarus.
Pour utiliser l'outil externe, vous devez faire ce qui suit:
- Ouvrir et construire le projet cconvert.lpi (placé dans le répertoire du paquet). Vous devriez obtenir le fichier exécutable "cconvert".
- Ouvrir Outils->C to Pascal Options->Converter, pressez sur Select et choisissez le fichier exécutable cconvert.
- Contrôlez Use external converter depuis Tools->C to Pascal Options->Converter.
Comment l'utiliser
Raccourcis
- ctrl+b - convertit une déclaration C simple en Pascal.
- ctrl+shift+b - convertit toutes les déclarations C vers Pascal depuis la position courante du curseur jusqu'à la fin du fichier.
Général
- Ouvrez un fichier avec des déclarations C dans l'EDI Lazarus ou démarrer un nouveau fichier en y copiant les déclarations.
- Placez le curseur sur la ligne où se trouve la déclaration c et pressez sur Ctrl+B (ce raccourci pourra être modifié à l'avenir).
Par exemple:
int c; int b;
Si le curseur estplacé sur la ligne 'inc c;' et que ctrl+b est enfoncé, le résultat serait:
var c : Integer; int b;
exactement une déclaration est convertie. Le curseur serait placé juste après la définition convertie. Vous pouvez appuyer à nouveau sur ctrl+b, et le résultat serait:
var c : Integer; var b : Integer;
L'analyse des définitions une par une préparera vos en-têtes C en très peu de temps, tout en les gardant propres et correctes du point de vue de Pascal.
- Si vous êtes sûr que vos définitions (expliquées ci-dessous) sont suffisamment bien configurées. Vous pouvez essayer de convertir le reste du fichier en un seul appel en appuyant sur ctrl+shift+b
i.e. vous avez 2 déclarations dans le fichier:
int fn(int, float); extern int v;
En plaçant le curseur avant eux puis en pressant sur ctrl+shift+b, cela générera:
function fn(par0: Integer; par1: Single): Integer; cdecl; external; var v : Integer; external;
Vous devez être prudent, car il est courant d'utiliser des macros dans les en-têtes C. Laisser l'une des macros non définie peut produire une mauvaise déclaration pascal. La section suivante explique comment définir une macro pour le chelper.
Defines
In most cases parameterless macro definitions, like
#define VALUE 1 << 2;
are used like constant values. Chelper translates them as constants trying to convert the define expression.
const VALUE = 1 shr 2;
In other cases defines are used for some "special" markings or additional information for external tools.
#define LIB_DEPRECATED LIB_DEPRECATED int somefunc(int p);
without the knowledge of LIB_DEPRECATED being the macro (of nothing), it's impossible to parse function declaration correctly. You can specify macros used by Chelper in the special defines file.
Select Tools->C to Pascal options->Main select the defines file and press Edit.
This would open the custom defines file in Lazarus IDE. All macros declared at this file are used by Chelper. After adding/editing macro defines save the file and you can return to the C header converting.
Chelper handles parameter macros as well.
int somefunc SAFE_PARAMS( (int i))
adding the the following declaration into defines file
#define SAFE_PARAMS(x) x
will allow to parse the declaration correctly
function somefunc(i: Integer): Integer;
Fichier de configuration
Configuration file represents itself a simple .ini file. Following section are used in the file:
- Main - for general declarations, that effects
- Types - custom type conversion section. Name=Value, where Name is the c-type name, Value is resulting pascal type
example:
[Types] int=integer int*=PInteger float=single float*=PSingle