Free cookie consent management tool by TermsFeed Policy Generator

source: branches/PersistenceOverhaul/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/Storable/StorableHookAttribute.cs @ 16724

Last change on this file since 16724 was 14711, checked in by gkronber, 8 years ago

#2520

  • renamed StorableClass -> StorableType
  • changed persistence to use GUIDs instead of type names
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.Default.CompositeSerializers.Storable {
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  public sealed class StorableHookAttribute : Attribute {
54    public static bool IsStorableHook(MethodInfo methodInfo) {
55      return Attribute.IsDefined(methodInfo, typeof(StorableHookAttribute), false);
56    }
57    public static StorableHookAttribute[] GetStorableHookAttributes(MethodInfo methodInfo) {
58      return Attribute.GetCustomAttributes(methodInfo, false).OfType<StorableHookAttribute>().ToArray();
59    }
60
61    private readonly HookType hookType;
62    /// <summary>
63    /// Gets the type of the hook.
64    /// </summary>
65    /// <value>The type of the hook.</value>
66    public HookType HookType {
67      get { return hookType; }
68    }
69
70    /// <summary>
71    /// Mark method as <c>StorableSerializer</c> hook to be run
72    /// at the <c>HookType</c> time.
73    /// </summary>
74    /// <param name="hookType">MemberSelection of the hook.</param>
75    public StorableHookAttribute(HookType hookType) {
76      this.hookType = hookType;
77    }
78  }
79}
Note: See TracBrowser for help on using the repository browser.