Objectes App i Error (només projectes visuals)



En temps d'execució, podeu tenir accés a aquests dos útils i interressants objectes
:


Objecte
App

    L'objecte App conté informació sobre l'aplicació i disposa dels següents membres:

Accel El "handle" de la taula principal d'acceleradors, si n'hi ha algun, o NULL
CommandLine La línia de comandes de l'aplicació (exclöent-hi el nom y la ubicació del programa)
FileName El nom del fitxer executable
Header La capçalera o títol de l'aplicació (el text del camp Capçalera de les propietats del projecte)
Instance El "handle" de la instància de l'aplicació
Main El "handle" de la finestra principal (finestra d'inici) de l'aplicació
Major El número major de la versió
Minor El número menor de la versió
Path La ubicació de l'aplicació
Previous El "handle" de la finestra principal de la instància previa, si n'hi ha alguna, o NULL
ProcessID L'identificador del procés (no el handle del procés). Per obtenir el handle del procés, crideu la funció de l'API GetCurrentProcess.
Revision La revisió de la versió
ThreadID L'identificador del "thread" que ha creat la finestra principal.

Algunes aplicacions només poden tenir una instància en marxa al mateix temps (p.e un reproductor de CD). Per tal de saber si ja hi ha alguna altra instància corrent quan inicieu l'aplicació, comproveu la variable App.Previous en el missatge WM_CREATE. Si App.Previous no és NULL i no voleu iniciar una altra instància, retorneu -1. El valor d'App.Previous és el "handle" de la finestra principal de la instància que ja està en marxa (si n'hi ha alguna), o NULL.


AVÍS: No haurieu de CANVIAR MAI cap dels valors de l'objecte App o l'aplicació podría bloquejar-se.

OBSERVACIONS: El membre CommandLine apunta a una cadena de text acabada en zero que conté només la línia de comandes de l'aplicació (si n'hi ha alguna), és a dir, sense incloure ni el nom ni la ubicació del programa ("path"). Per tal d'obtenir la línia de comandes sencera, utiitzeu la funció de l'API GetCommandLine.


Objecte Error

    L'objecte Error sempre conté informació sobre l'última excepció produïda i disposa d'un membre:

Code

Error.Code és una variable DD que emmagatzema el codi de l'excepció. El valor del membre Code es posa a zero en iniciar-se l'aplicació. Quan es produeix una excepció, el codi s'emmagatzema a Error.Code que romandrà sense modificar fins que es produeixi una altra excepció. Si voleu, podeu posar Error.Code a zero abans de portar a terme una operació.

OBSERVACIONS: Tots dos objectes només estan disponibles en temps d'execució.