Free cookie consent management tool by TermsFeed Policy Generator

source: branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/StorableHookAttribute.cs @ 15689

Last change on this file since 15689 was 14927, checked in by gkronber, 8 years ago

#2520: changed all usages of StorableClass to use StorableType with an auto-generated GUID (did not add StorableType to other type definitions yet)

File size: 2.7 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System;
23using System.Linq;
24using System.Reflection;
25
26namespace HeuristicLab.Persistence {
27
28
29  /// <summary>
30  /// Indicates the time at which the hook should be invoked.
31  /// </summary>
32  public enum HookType {
33
34    /// <summary>
35    /// States that this hook should be called before the storable
36    /// serializer starts decomposing the object.
37    /// </summary>
38    BeforeSerialization,
39
40    /// <summary>
41    /// States that this hook should be called after the storable
42    /// serializer hast complete re-assembled the object.
43    /// </summary>
44    AfterDeserialization
45  };
46
47
48  /// <summary>
49  /// Mark methods that should be called at certain times during
50  /// serialization/deserialization by the <c>StorableSerializer</c>.
51  /// </summary>
52  [AttributeUsage(AttributeTargets.Method, Inherited = false, AllowMultiple = true)]
53  [StorableType("983bf558-1458-4129-b018-7e121ac3840e")]
54  public sealed class StorableHookAttribute : Attribute {
55    public static bool IsStorableHook(MethodInfo methodInfo) {
56      return Attribute.IsDefined(methodInfo, typeof(StorableHookAttribute), false);
57    }
58    public static StorableHookAttribute[] GetStorableHookAttributes(MethodInfo methodInfo) {
59      return Attribute.GetCustomAttributes(methodInfo, false).OfType<StorableHookAttribute>().ToArray();
60    }
61
62    private readonly HookType hookType;
63    /// <summary>
64    /// Gets the type of the hook.
65    /// </summary>
66    /// <value>The type of the hook.</value>
67    public HookType HookType {
68      get { return hookType; }
69    }
70
71    /// <summary>
72    /// Mark method as <c>StorableSerializer</c> hook to be run
73    /// at the <c>HookType</c> time.
74    /// </summary>
75    /// <param name="hookType">MemberSelection of the hook.</param>
76    public StorableHookAttribute(HookType hookType) {
77      this.hookType = hookType;
78    }
79  }
80}
Note: See TracBrowser for help on using the repository browser.