gmStudio's code analysis and translation capabilities may be extended and modified through various rules files and scripts. In order to provide for higher control, precision, and accuracy , the specification of These custom transformation is are specified using various types of configuration files that extend and modify the definitions of various language and API descriptionselements and also allow activating dynamic translation rules. This page contains many samples of different types of these configuration files. The concepts and techniques for creating and using these types of files is customizations are described in other articles:
A collection of sample rules files and script is cataloged here; you may download these and experiment with them in your environment. Please You may visit the full list of gmStudio Extension files in the attachments to this page. Please Contact Us or post your questions here.
API Migration Rules Files (RefactorLibraries)
Migration Rules Files (RefactorLibrary Files) are the preferred means of mapping a COM API to its replacement in .NET.
Best practice is to load an API Migration Rules file using a registry-migfile command, however they can be loaded by convention when by naming the migration file mig.libfile.xml (for example mig.scrrun.dll.xml will be loaded automatically for codes that references scrrun.dll.xml). The The file mig.vb7lang.xml is a special case: it may be used to modify the mapping of VB6/ASP language elements to .NET.
The recommended naming convention for these files is libfile.[target].Refactor.xml where libfile is the name of the type library (e.g. scrrun.dll) \[target] is a user-defined descriptive name. For example scrrun.dll.SystemIO.Refactor.xml contains rules for migrating scrrun.dll (Scripting Runtime) to System.IO. Which may be activated with a registry command.
Code Block |
---|
<registry type="MigFile" source="scrrun.dll" target="scrrun.dll.SystemIO.Refactor" />
or
<registry type="MigFile" source="scrrun.dll" target="..\usr\scrrun.dll.SystemIO.Refactor.xml" /> |
Note: the first example above uses Metalanguage file path resolution and will look through the metalanguage folders for a .XML file. The second example uses an actual file path specification relative to the working folder.
Attachments |
---|
upload | false |
---|
patterns | mig.*.xml,Refactor.*.xml,*.Refactor.*.xml |
---|
|
sortOrderdescendingCustom Interface Description Files (IDFs)
Custom IDFs allow you to migrate COM APIs to .NET replacements. This is a powerful and fairly intuitive technique, but it is not as maintainable as Migration Rules files.
The gmStudio samples use custom IDFs files, but this approach will be phased out in favor of using Migration Rules files. See Custom COM Replacement.
Attachments |
---|
upload | false |
---|
patterns | GM.*.xml,gm.*.xml |
---|
|
sortOrderdescendinggmSL Scripts
gmSL scripts may be used to implement dynamic translation rules for various COM migrations in concert with custom IDFs and RefactorLibrary files. gmSL Scripts may also be used for special purpose analysis and transformation on their own. Learn more about gmsl here: gmSLIntroduction.
Note we also offer a .NET API that has all of the power of gmSL and may be used to build custom translation engines as .NET executables.
Attachments |
---|
upload | false |
---|
patterns | *.gmsl,*.gmSL |
---|
|
sortOrder | descendingSpecial Purpose Scripts
Samples of various special purpose scripts are distributed with the tool
Attachments |
---|
preview | false |
---|
sortBy | name |
---|
labels | specialextension |
---|
|