Search code examples
vbacatia

catvba how to determine if catpart needs to be updated


I want to determine if something has changed in a catpart that would drive a change in a body, but the change hasnt been done because update is set to manual.

I have tried:

if part.product.update = true then
    'do something
else
  'do something else
endif

However this just forces an update and doesnt tell me if one was required.


Solution

  • I worked out a solution (see below) '@@@@@@@@@@@@@@@@@@@@@

    Function func_CheckNoModsSinceLastSaved() As Boolean
    
    func_CheckNoModsSinceLastSaved = False
    
    Dim flg_NoModsSinceLastSaved As Boolean
    
    flg_NoModsSinceLastSaved = False
    
    If Right(CATIA.ActiveDocument.FullName, 11) = ".CATProduct" Then
        Dim productDocument1 As ProductDocument
        Set productDocument1 = CATIA.ActiveDocument
    
        Dim product1 As Product
        Set product1 = productDocument1.Product
    
        flg_NoModsSinceLastSaved = productDocument1.Saved
        If flg_NoModsSinceLastSaved Then
            func_CheckNoModsSinceLastSaved = True
        Else
            func_CheckNoModsSinceLastSaved = False
            MsgBox "Modified Since Last Saved"
        End If
    
        product1.Update
    
        flg_NoModsSinceLastSaved = productDocument1.Saved
        If flg_NoModsSinceLastSaved Then
            func_CheckNoModsSinceLastSaved = True
        Else
            func_CheckNoModsSinceLastSaved = False
            MsgBox "Modified Since Last Saved"
        End If
    
        Set productDocument1 = Nothing
    
    
    ElseIf Right(CATIA.ActiveDocument.FullName, 8) = ".CATPart" Then
        Dim partDocument1 As PartDocument
        Set partDocument1 = CATIA.ActiveDocument
    
    
        flg_NoModsSinceLastSaved = partDocument1.Saved
        If flg_NoModsSinceLastSaved Then
            func_CheckNoModsSinceLastSaved = True
        Else
            func_CheckNoModsSinceLastSaved = False
            MsgBox "Modified Since Last Saved"
        End If
    
        partDocument1.Part.Update
    
        flg_NoModsSinceLastSaved = partDocument1.Saved
        If flg_NoModsSinceLastSaved Then
            func_CheckNoModsSinceLastSaved = True
        Else
            func_CheckNoModsSinceLastSaved = False
            MsgBox "Modified Since Last Saved"
        End If
        Set partDocument1 = Nothing
    
    
    ElseIf Right(CATIA.ActiveDocument.FullName, 11) = ".CATDrawing" Then
        Dim drawingDocument1 As DrawingDocument
        Set drawingDocument1 = CATIA.ActiveDocument
    
        flg_NoModsSinceLastSaved = drawingDocument1.Saved
         If flg_NoModsSinceLastSaved Then
            func_CheckNoModsSinceLastSaved = True
        Else
            func_CheckNoModsSinceLastSaved = False
            MsgBox "Modified Since Last Saved"
        End If
    
        drawingDocument1.Update
    
        flg_NoModsSinceLastSaved = drawingDocument1.Saved
        If flg_NoModsSinceLastSaved Then
            func_CheckNoModsSinceLastSaved = True
        Else
            func_CheckNoModsSinceLastSaved = False
            MsgBox "Modified Since Last Saved"
        End If
        Set drawingDocument1 = Nothing
    
    Else
        MsgBox "ERROR: Unidentified File Type!", vbCritical + vbOKOnly, ""
    End If
    End Function
    

    '@@@@@@@@@@@@@@@@@@@@@