Version 5.7: Jobverarbeitung mit Events

Seit der 5.6.06 können Prozeduren im Standard- und Advanced-Client auch parallel zueinander ablaufen. Die Nebenläufigkeit wird durch die sogenannten Jobs erreicht, die ja schon seit längerem Bestandteil des SOA-Service sind. Im Client wird eine im Hintergrund laufende Jobprozedur fast immer aus einem Dialog heraus gestartet, bisher gab es jedoch keine direkte Möglichkeit, das Beenden des Jobs im Dialog mitzubekommen – beispielsweise für die Anzeige des Jobresultats.


Zu diesem Zweck verfügt die Version 5.7 über das neue Frame-Ereignis EvtJob, das auf der Seite der Jobprozedur mit dem Befehl JobEvent() ausgelöst wird.

Seite des Frames

Beim Dialog muss zunächst eine Ereignisprozedur für EvtJob definiert sein. Die Weiterleitung eines JobEvents an den Dialog erfolgt über das Job-Kontroll-Objekt. Beim Öffnen dieses Objekts mit JobOpen() wird der Deskriptor des Fensters einfach als zweites optionales Argument mit übergeben.


tJobID # JobStart(_JobThread,10,'JobTest:Work','','');
if (tJobID > 0)
{
  tJobHdl # JobOpen(tJobID,aEvt:Obj->WinInfo(_WinFrame))
  ...
}

Analog zu anderen Ereignisprozeduren erhält die EvtJob-Prozedur zwei Argumente, die die Deskriptoren von Frame und Job-Kontroll-Objekt enthalten:


sub EvtJob
(
  aEvt          : event;   // Ereignis
  aJobCtrlHdl   : handle;  // Job-Kontroll-Objekt
)

Über das Kontroll-Objekt kann dann beispielsweise die Job-Eigenschaft _SysPropJobStatus abgefragt oder Job-Daten per MsxRead() gelesen werden.

Seite des Jobs

Innerhalb der Jobprozedur kann an jeder Stelle ein Ereignis ausgelöst werden, wobei lediglich der Job-Deskriptor benötigt wird. Die Funktion JobEvent() liefert einen Fehlercode zurück, der das Resultat der Ereignisweiterleitung darstellt.

Das Resultat _ErrUnavailable entsteht, wenn kein Job-Kontroll-Objekt geöffnet ist oder kein Frame für den Empfang des Ereigniss angegeben wurde. Sofern bereits ein JobEvent-Ereignis an den Frame gesendet und noch nicht verarbeitet wurde, gibt die Funktion das Ergebnis _ErrInProgress zurück.

Per JobEvent() ist auch der Verarbeitungsfortschritt des Jobs im Dialog visualisierbar, dabei ist jedoch eine übermäßig häufige Generierung von Events im Frame zu vermeiden. Durch die optionale Angabe eines zeitlichen Mindestabstands zwischen zwei Ereignissen lässt sich JobEvent() auch in Programmschleifen problemlos verwenden:


sub Work
(
  aObjHdl  : handle;    // Jobobjekt
  aEvtType : int;       // Event-type
)
...
{
  while (!aObjHdl->spStopRequest)
  {
    ...
    // Fortschritt signalisieren
    aObjHdl->spJobStatus # tProzent;
    aObjHdl->JobEvent(125);
  }
  // 100% signalisieren
  aObjHdl->spJobStatus # 100;
  do
  {
    SysSleep(50);
    tError # aObjHdl->JobEvent();
  }
  while (tError = _ErrInProgress or tError = _ErrLocked)
}

Sofern bei JobEvent() mit Angabe einer Mindestabstandszeit (Millisekunden) diese Zeit noch nicht verstrichen ist, wird _ErrLocked als Resultat geliefert.

Klicken Sie hier, um die Nutzungsbedingungen für unseren Blog zu lesen.

2 Antworten

Schreiben Sie einen Kommentar

Ihre E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Leave the field below empty!

Wünsche, Fragen oder Feedback sind willkommen:

Nutzungsbedingungen der Kommentarfunktion im Blog

1. Allgemeines

Vectorsoft AG („Anbieter“) stellt für Internetnutzer („Nutzer“) auf der Website
vectorsoft.de einen öffentlichen Blog bereit. Der öffentliche Blog dient dem
Informations- und Gedankenaustausch. Die Nutzer, welche sich mit Beiträgen und
Kommentaren beteiligen, verpflichten sich dazu, die Blog-Nutzungsbedingungen
einzuhalten und tragen die Verantwortung für die Richtigkeit und Angemessenheit
sowie Freiheit von Rechtsverletzungen ihrer Beiträge. Mit Nutzung der
Kommentarfunktion in unserem Blog akzeptieren Sie diese Nutzungsbedingungen.

2. Netiquette

Wir bitten Sie von persönlichen Angriffen und Provokationen aufgrund anderer
Meinungen abzusehen. Bitte argumentieren Sie sachlich und bewegen Sie sich auf
der Basis einer konstruktiven Diskussionskultur. Ihr Kommentar sollte stets im
Zusammenhang mit dem jeweiligen Thema sein, um Ausschweifungen in andere
Themenbereiche zu vermeiden. Das mehrmalige Posten desselben Kommentars
oder mehrerer ähnlicher Kommentare ist nicht erlaubt.

3. Verbot rechtswidriger Inhalte

Mit Absenden Ihres Kommentars bestätigen Sie, dass Sie keine Urheberrechte oder andere Rechte Dritter verletzen. Volksverhetzende, rassistische Äußerungen, Anleitungen zu Straftaten und deren Verherrlichung, Gewaltdarstellungen, pornografische Inhalte und Äußerungen, die Persönlichkeitsrechte verletzen sind untersagt.

4. Keine Werbung

Die Nutzung der Kommentarfunktion ist für kommerzielle oder parteipolitische
Zwecke nicht erlaubt. Werbliche Beiträge aller Art werden von uns umgehend
gelöscht.

5. Angaben zum Namen

Bei der Eingabe Ihres Namens achten Sie auf die zuvor genannten Grundsätze.

6. Quellenangaben

Bitte geben Sie bei der beabsichtigten Veröffentlichung von Zitaten oder Beiträgen
Dritter die jeweiligen Quellen an und erläutern dessen Bezug zum Blogbeitrag.

7. Verstoß gegen die Nutzungsbedingungen

Beiträge, die gegen diese Richtlinie verstoßen werden umgehend gelöscht. Sollten
Sie selbst Verstöße bemerken, so senden Sie uns bitte den Link des betreffenden
Kommentars per E-Mail an . Wir weisen ausdrücklich daraufhin, dass wir einzelne Nutzer bei wiederholten oder schweren Verstößen gegen diese
Nutzungsbedingungen ausschließen werden.

Stand: Sept. 2024

Deine Trial Version - jetzt anfordern!

Teste yeet - unverbindlich und kostenfrei

IHRE EVALUIERUNGSLIZENZ - JETZT ANFORDERN!

TESTEN SIE DIE CONZEPT 16 VOLLVERSION - UNVERBINDLICH und KOSTENFREI

Melden Sie sich bei unserem Newsletter an

Anrede*
     
Zustimmung zur Datenverarbeitung gem. DSGVO*



WordPress Cookie-Hinweis von Real Cookie Banner