You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			62 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			62 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   |  | |||
|  | namespace System.ComponentModel.DataAnnotations { | |||
|  |     /// <summary> | |||
|  |     /// Indicates whether the consumer of a field or property, such as a client application, | |||
|  |     /// should allow editing of the value. | |||
|  |     /// </summary> | |||
|  |     /// <remarks> | |||
|  |     /// This attribute neither enforces nor guarantees editability; the underlying data | |||
|  |     /// store might allow changing the data regardless of this attribute.  The presence | |||
|  |     /// of this attribute signals intent to the consumer of the attribute whethere or not | |||
|  |     /// the end user should be allowed to change the value via the client application. | |||
|  |     /// </remarks> | |||
|  |     [AttributeUsage(AttributeTargets.Field | AttributeTargets.Property, AllowMultiple = false, Inherited = true)] | |||
|  |     public sealed class EditableAttribute : Attribute { | |||
|  |         /// <summary> | |||
|  |         /// Indicates whether or not the field/property allows editing of the | |||
|  |         /// value. | |||
|  |         /// </summary> | |||
|  |         /// <value> | |||
|  |         /// When <c>true</c>, the field/property is editable. | |||
|  |         /// <para> | |||
|  |         /// When <c>false</c>, the field/property is not editable. | |||
|  |         /// </para> | |||
|  |         /// </value> | |||
|  |         public bool AllowEdit { get; private set; } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Indicates whether or not the field/property allows an initial value | |||
|  |         /// to be specified. | |||
|  |         /// </summary> | |||
|  |         /// <remarks> | |||
|  |         /// The value of this property defaults to match the <see cref="AllowEdit"/> | |||
|  |         /// property value specified in the constructor. | |||
|  |         /// </remarks> | |||
|  |         /// <value> | |||
|  |         /// When <c>true</c>, the field/property can have its value set for | |||
|  |         /// newly constructed instances, such as during an insert operation. | |||
|  |         /// <para> | |||
|  |         /// When <c>false</c>, the field/property cannot have its | |||
|  |         /// value provided for newly constructed instances, such as during | |||
|  |         /// an insert operation.  This will often indicate that the value | |||
|  |         /// is auto-generated by the persistence store. | |||
|  |         /// </para> | |||
|  |         /// </value> | |||
|  |         public bool AllowInitialValue { get; set; } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Indicate whether or not a field/property is editable. | |||
|  |         /// </summary> | |||
|  |         /// <param name="allowEdit"> | |||
|  |         /// Indicates whether the field/property is editable.  The value provided | |||
|  |         /// will apply to both <see cref="AllowEdit"/> and | |||
|  |         /// <see cref="AllowInitialValue"/> unless the <see cref="AllowInitialValue"/> | |||
|  |         /// property is explicitly specified. | |||
|  |         /// </param> | |||
|  |         public EditableAttribute(bool allowEdit) { | |||
|  |             this.AllowEdit = allowEdit; | |||
|  |             this.AllowInitialValue = allowEdit; | |||
|  |         } | |||
|  |     } | |||
|  | } |