Foreach pattern (langage)

De Wiki1000
(Différences entre les versions)
(ForEachP pattern)
(ForEachP pattern)
Ligne 21 : Ligne 21 :
 
|in
 
|in
 
|Get
 
|Get
|L'instance est obtenue de l'énumération
+
|L'instance est obtenue de l'énumération.
 
|-
 
|-
 
|from
 
|from
 
|GetAndRemove
 
|GetAndRemove
|L'instance est obtenue puis retirée de l'énumération
+
|L'instance est obtenue puis retirée de l'énumération.
 
|}
 
|}
 +
 +
{{tip|in et from sont équivalent pour un curseur.}}
  
 
*C
 
*C

Version du 27 septembre 2011 à 10:44

versionthaoe-48x48.png

ForEachP pattern

Le pattern foreachP permet de réaliser une énumération sur une collection supportant les énumérations.

Les différentes syntaxes de ce pattern sont :

foreachP V in|from C [index I] [with [distinct|global|long] transaction] [on except break|continue]  do Statement 
  • V variable de boucle
Doit être du type de l'énumération
Tip-20px.png Tip : Certains énumérateurs supportent un type par défaut pour la variable de boucle, ceci permet de définir la variable de boucle dans l'instruction sans définir son type en utilisant la syntaxe : foreachP var inst in ....
  • in | from
Mode de gestion de l'énumération
in Get L'instance est obtenue de l'énumération.
from GetAndRemove L'instance est obtenue puis retirée de l'énumération.
Tip-20px.png Tip : in et from sont équivalent pour un curseur.
  • C
Collection énumérable
  • index I
Index de boucle
  • with transaction
Mode de gestion de transaction
aucun Pas de gestion de transaction
distinct Une transaction par corps de boucle.
global Une transaction pour l'ensemble de la boucle.
long Une transaction longue pour l'ensemble du corps de boucle.
  • on except
Mode de gestion des exceptions
aucun Une exception arrête l'instruction et est propagée.
break Une exception arrête l'instruction et est propagée.
continue Une exception est trappée et n'arrête pas l'instruction.

Exemple :

var list:WFClasseAList; inst:WFClasseA; cursor:WFClasseACursor; count:Integer; tk:Int64;
begin
  List := WFClasseA.CreateList;
  Cursor := WFClasseA.CreateCursorWhere('','',true,['A',1]);
 
  with long transaction do
   foreachP inst in cursor index count do
    begin
      List.AddRef(inst);
      if List.Count=100 then
       begin
         parallel doProcessList(List);
         List.Clear;
       end;
    end;
end;

Avec gestion de la transaction :

var inst:WFClasseA; cursor:WFClasseACursor; count:Integer; tk:Int64;
begin
  List := WFClasseA.CreateList;
  Cursor := WFClasseA.CreateCursorWhere('','',true,['A',1]);
 
  foreachP inst in cursor index count with long(100) transaction do
    begin
      parallel doProcessInstance(inst);
    end;
end;


Variable de boucle définie dans l'instruction :

var list:WFClasseAList; cursor:WFClasseACursor; count:Integer; tk:Int64;
begin
  List := WFClasseA.CreateList;
  Cursor := WFClasseA.CreateCursorWhere('','',true,['A',1]);
 
  with long transaction do 
   foreachP var inst:WFClasseA in cursor index count do
    begin
      List.AddRef(inst);
      if List.Count=100 then
       begin
         parallel doProcessList(List);
         List.Clear;
       end;
    end;
end;

Variable de boucle typée par l'énumération :

var list:WFClasseAList; cursor:WFClasseACursor; count:Integer; tk:Int64;
begin
  List := WFClasseA.CreateList;
  Cursor := WFClasseA.CreateCursorWhere('','',true,['A',1]);
 
  foreachP var inst in cursor index count with long transaction do
   begin
     List.AddRef(inst);
     if List.Count=100 then
      begin
        parallel doProcessList(List);
        List.Clear;
      end;
   end;
end;
Info-20px.png Note : La portée des variable de boucle définie dans l'instruction est limitée à l'instruction
Outils personnels