Application.GetCacheStatusForProject property (Project)
Ruft den Status eines angegebenen Auftrags ab, den der aktive Cache in Project Professional an das Project Server-Warteschlangensystem sendet. Schreibgeschützter PjCacheJobState-Wert.
Syntax
Ausdruck. GetCacheStatusForProject
expression Eine Variable, die ein Application-Objekt darstellt.
Parameter
Name | Erforderlich/Optional | Datentyp | Beschreibung |
---|---|---|---|
ProjectName | Erforderlich | String | Der Name des Projekts; kann das aktive Projekt oder ein anderes geöffnetes Projekt sein. |
ProjectJobType | Erforderlich | PjJobType | Dies kann eine der PjJobType-Konstanten für den Speicher-, Veröffentlichungs- oder Eincheckvorgang sein. |
Hinweise
Wenn Sie Project Professional verwenden, um einen Vorgang auszuführen, der eine der Warteschlangenmethoden in Project Server verwendet, z. B. speichern, ein Update veröffentlichen oder ein Projekt einchecken, sendet der Project Professional Cache eine Auftragsanforderung an das Project Server-Warteschlangensystem. Die GetCacheStatusForProject-Eigenschaft gibt den Status für den Warteschlangenauftrag an.
Beispiel
Das Makro TestCacheStatus im folgenden Beispiel speichert das aktive Projekt, ruft WaitForJob auf, um auf den erfolgreichen Abschluss der Warteschlange zu warten, und veröffentlicht dann das Projekt. Das WaitForJob-Makro überprüft regelmäßig den Auftragsstatus durch Aufrufen von GetCacheStatusForProject und gibt den Auftrag status im Direktfenster aus. Wenn dasselbe status mehr als zehnMal hintereinander gefunden wird, geht das WaitForJob-Makro davon aus, dass ein Problem vorliegt, und wird beendet. Im Beispiel wird eine Sleep-Methode verwendet, die entweder in einer 64-Bit-Projektinstallation oder einer 32-Bit-Project-Installation ausgeführt werden kann.
Option Explicit
#If Win64 Then
Private Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As LongLong)
#Else
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
#End If
' Save and publish the active project; wait for the queue after each operation.
Sub TestCacheStatus()
Const millisec2Wait = 500 ' Number of milliseconds to sleep between status messages.
Application.FileSave
If WaitForJob(PjJobType.pjCacheProjectSave, millisec2Wait) Then
Debug.Print "Save completed ..."
Application.Publish
If WaitForJob(PjJobType.pjCacheProjectPublish, millisec2Wait) Then
Debug.Print "Publish completed: " & ActiveProject.Name
End If
Else
Debug.Print "Save job not completed"
End If
End Sub
' Check the cache job state for a save, publish, or check-in operation.
Function WaitForJob(job As PjJobType, msWait As Long) As Boolean
' Number of times the same job status is repeated until WaitForJob exits with error.
Const repeatedLimit = 10
Dim jobState As Integer
Dim previousJobState As Integer
Dim bail As Integer
Dim jobType As String
#If Win64 Then
Dim millisec As LongLong
millisec = CLngLng(msWait)
#Else
Dim millisec As Long
millisec = msWait
#End If
WaitForJob = True
Select Case job
Case PjJobType.pjCacheProjectSave
jobType = "Save"
Case PjJobType.pjCacheProjectPublish
jobType = "Publish"
Case PjJobType.pjCacheProjectCheckin
jobType = "Checkin"
Case Else
jobType = "unknown"
End Select
bail = 0
If (jobType = "unknown") Then
WaitForJob = False
Else
Do
jobState = Application.GetCacheStatusForProject(ActiveProject.Name, job)
Debug.Print jobType & " job state: " & jobState
' Bail out if something is wrong.
If jobState = previousJobState Then bail = bail + 1
If bail > repeatedLimit Then
WaitForJob = False
Exit Do
End If
previousJobState = jobState
Sleep (msWait)
Loop While Not (jobState = PjCacheJobState.pjCacheJobStateSuccess)
End If
End Function
Es folgt die Ausgabe für eine Wartezeit von 500 Millisekunden zwischen status Nachrichten. Wenn die Netzwerklatenz größer ist, legen Sie die Wartezeit für ein längeres Intervall fest. Informationen zur Bedeutung von Ausgabewerten finden Sie in der PjCacheJobState-Enumeration . Der Wert 4 ist beispielsweise die pjCacheJobStateSuccess-Konstante . Wenn Sie TestCacheStatus ausführen, wenn keine Änderungen am Projekt vorgenommen wurden, wird der Status des Speicherauftrags mehrmals als -1 wiederholt, was dem Wert der pjCacheJobStateInvalid-Konstante entspricht.
Save job state: 4
Save completed ...
Publish job state: -1
Publish job state: 3
Publish job state: 3
Publish job state: 4
Publish completed: WinProj test 1
Eigenschaftswert
PJCACHEJOBSTATE
Siehe auch
PjCacheJobState-EnumerationPjJobType-Enumeration
Support und Feedback
Haben Sie Fragen oder Feedback zu Office VBA oder zu dieser Dokumentation? Unter Office VBA-Support und Feedback finden Sie Hilfestellung zu den Möglichkeiten, wie Sie Support erhalten und Feedback abgeben können.