Aide Collabora Office 24.04
Une propriété, également appelée champ ou attribut, caractérise un objet ou une information donné. Les propriétés peuvent être utilisées pour contrôler l'accès aux données. Il est courant d'inclure des instructions pour définir ou lire l'heure des propriétés. Le code peut varier d'une simple affectation à des routines complexes dépendant du contexte. L'utilisation des accesseurs Get, Let ou Set renforce la cohérence des propriétés lorsque cela est nécessaire.
Cette instruction nécessite que Option Compatible soit placée avant le code du programme exécutable dans un module.
[Private | Public] Property Get name[char | As typename]
End Property
[Private | Public] Property [Let | Set] name[char] [([Optional [ByRef | ByVal]]value[char | As typename])] [As typename]
End Property
name: le nom de la propriété
argument: valeur à transmettre à la routine de définition de Property.
Les définitions de Property utilisent souvent un seul argument. Les arguments multiples sont également acceptés.
Option Compatible
Sub Main
ProductName = "Office"
Print ProductName ' affiche "Collabora Office"
End Sub
Private _office As String
Property Get ProductName As String
ProductName = _office
End Property
Property Let ProductName(value As String)
_office = "Libre"& value
End Property
En l'absence de Property Let ou Property Set, Property Get permet de définir les informations protégées, qui ne peuvent pas être accidentellement modifiées par un module étranger :
Option Compatible
Public Property Get PathDelimiter As String ' variable en lecture seule
Static this As String
If this = "" Then : Select Case GetGuiType()
Case 1 : this = ";" ' Windows
Case 4 : this = ":" ' Linux ou macOS
Case Else : Error 423 ' Propriété ou méthode non définie : PathDelimiter
End Select : End If
PathDelimiter = this
End Property ' PathDelimiter en lecture seule
Sub Main
PathDelimiter = "a sentence" ' ne fait rien
End Sub
Utilisez Let ou Set lors de la gestion de services UNO ou objets de classe :
Option Compatible
Sub Main
'Set anObject = CreateUnoService( "com.sun.star.frame.Desktop" )
anObject = CreateUnoService( "com.sun.star.frame.Desktop" )
Print anObject.SupportedServiceNames(0) ' displays "com.sun.star.frame.Frame"
End Sub
Property Get anObject As Object
Set anObject = _obj
End Property
Private _obj As Object
'Property Set anObject(value As Object)
'Set _obj = value.CurrentFrame
'End Property
Property Let anObject(value As Object)
Set _obj = value.CurrentFrame
End Property