ICubeAttachmentManager.ReadAttachments

Syntax

ReadAttachments(Iterator: IMatrixModelIterator): ICubeAttachments;

ReadAttachments(Iterator: Prognoz.Platform.Interop.ForeSystem.IMatrixModelIterator): Prognoz.Platform.Interop.Cubes.ICubeAttachments;

Parameters

Iterator. Iterator of matrix with attachments.

Description

The ReadAttachments method returns the collection of attachments saved in cube.

Comments

The method returns the values that are available for the current iterator position. Obtained attachments will be read-only. To edit attachments, use the EditAttachments method.

Example

Executing the example requires that the repository contains a standard cube with the STD_CUBE identifier. Facts binding is set up in cube to store attachments. Attachments are saved by any cube coordinates.

Add links to the Cubes, Dal, Dimensions, Matrix, Metabase system assemblies. In Fore.NET add a link to the ForeSystem assembly.

Sub UserProc;
Var
    MB: IMetabase;
    CubeInst: ICubeInstance;
    Dest: ICubeInstanceDestination;
    Sels: IDimSelectionSet;
    Sel: IDimSelection;
    Exec: ICubeInstanceDestinationExecutor;
    Mat: IMatrix;
    MatEx: IMatrixEx;
    Ite: IMatrixIterator;
    ExecResult: ICubeExecuteResult;
    Manager: ICubeAttachmentManager;
    Ats: ICubeAttachments;
    At: ICubeAttachment;
    NameAttributeKey: Integer;
    i: integer;
Begin
    MB := MetabaseClass.Active;
    CubeInst := MB.ItemById(
"STD_CUBE").Open(NullAs ICubeInstance;
    Dest := CubeInst.Destinations.DefaultDestination;
    
//Cube selection
    Sels := Dest.CreateDimSelectionSet;
    
For Each Sel In Sels Do
        Sel.SelectAll;
    
End For;
    Exec := Dest.CreateExecutor;
    Exec.IncludeAttachments := 
True;
    Exec.PrepareExecute(Sels);
    Exec.PerformExecute;
    Mat := Exec.Matrix;
    
//Resulting cube matrix
    MatEx := Mat As IMatrixEx;
    
If MatEx.AttachmentValueIndex < 0 Then
        Debug.WriteLine(
"AttachmentValueIndex <0. Aborted ");
        
Return;
    
End If;
    ExecResult := CubeClass.ExecuteResult(Mat);
    
//Manager to work with cube attachments
    Manager := ExecResult.CreateAttachmentManager;
    
//Matrix iterator
    Ite := Mat.CreateIterator;
    Ite.Move(IteratorDirection.First);
    
While Ite.Valid Do
        
//Attachments by the current coordinate
        Ats := Manager.ReadAttachments(Ite);
        
If Ats <> Null Then
            Debug.WriteLine(
"There is attachment. The number = " + Ats.Count.ToString);
            NameAttributeKey := Ats.Attributes.FindById(
"Name").Key;
            
For i := 0 To Ats.Count - 1 Do
                At := Ats.Item(i);
                Debug.WriteLine(
"Key= " + At.Key.ToString + " Name = " + At.AttributeValueByKey(NameAttributeKey) + " Type = " + At.Type.ToString);
            
End For;
        
Else
            Debug.WriteLine(
"No attachments");
        
End If;
        Debug.WriteLine(
"  ");
        Ite.Move(IteratorDirection.Next);
    
End While;
End Sub UserProc;

Imports Prognoz.Platform.Interop.Cubes;
Imports Prognoz.Platform.Interop.Dal;
Imports Prognoz.Platform.Interop.Dimensions;
Imports Prognoz.Platform.Interop.ForeSystem;
Imports Prognoz.Platform.Interop.Matrix;
Imports Prognoz.Platform.Interop.Metabase;

Public Shared Sub Main(Params: StartParams);
Var
    MB: IMetabase;
    CubeInst: ICubeInstance;
    Dest: ICubeInstanceDestination;
    Sels: IDimSelectionSet;
    Sel: IDimSelection;
    Exec: ICubeInstanceDestinationExecutor;
    Mat: IMatrix;
    MatEx: IMatrixEx;
    CubeCls: CubeClassClass = 
New CubeClassClass();
    Ite: IMatrixIterator;
    ExecResult: ICubeExecuteResult;
    Manager: ICubeAttachmentManager;
    Ats: ICubeAttachments;
    At: ICubeAttachment;
    NameAttributeKey: UInteger;
    i: integer;
Begin
    MB := Params.Metabase;
    CubeInst := MB.ItemById[
"STD_CUBE"].Open(NullAs ICubeInstance;
    Dest := CubeInst.Destinations.DefaultDestination;
    
//Cube selection
    Sels := Dest.CreateDimSelectionSet();
    
For Each Sel In Sels Do
        Sel.SelectAll();
    
End For;
    Exec := Dest.CreateExecutor();
    Exec.IncludeAttachments := 
True;
    Exec.PrepareExecute(Sels);
    Exec.PerformExecute(
False);
    Mat := Exec.Matrix;
    
//Resulting cube matrix
    MatEx := Mat As IMatrixEx;
    
If MatEx.AttachmentValueIndex < 0 Then
        System.Diagnostics.Debug.WriteLine(
"AttachmentValueIndex <0. Aborted ");
        
Return;
    
End If;
    ExecResult := CubeCls.ExecuteResult[Mat];
    
//Manager to work with cube attachments
    Manager := ExecResult.CreateAttachmentManager();
    
//Matrix iterator
    Ite := Mat.CreateIterator();
    Ite.Move(IteratorDirection.itdFirst);
    
While Ite.Valid Do
        
//Attachments by the current coordinate
        Ats := Manager.ReadAttachments(Ite);
        
If Ats <> Null Then
            System.Diagnostics.Debug.WriteLine(
"Attachment available. Number = " + Ats.Count.ToString());
            NameAttributeKey := Ats.Attributes.FindById(
"Name").Key;
            
For i := 0 To Ats.Count - 1 Do
                At := Ats.Item[i];
                System.Diagnostics.Debug.WriteLine(
"Key= " + At.Key.ToString() +
                    
" Name = " + At.AttributeValueByKey[NameAttributeKey] + " Type = " + At.Type.ToString());
            
End For;
        
Else
            System.Diagnostics.Debug.WriteLine(
"No attachments");
        
End If;
        System.Diagnostics.Debug.WriteLine(
"  ");
        Ite.Move(IteratorDirection.itdNext);
    
End While;
End Sub;

On executing the example the resulting cube matrix will be calculated and manager to work with attachments will be obtained. Iterator will be created and traversal of all matrix coordinates will be executed. If attachments are stored by coordinate, information about them (key, name and type) will be displayed in the development environment console.

See also:

ICubeAttachmentManager