diff --git a/.idea/.idea.DiscImageChef/.idea/contentModel.xml b/.idea/.idea.DiscImageChef/.idea/contentModel.xml index da6491e77..f615a6225 100644 --- a/.idea/.idea.DiscImageChef/.idea/contentModel.xml +++ b/.idea/.idea.DiscImageChef/.idea/contentModel.xml @@ -92,8 +92,12 @@ + + + + diff --git a/DiscImageChef.CommonTypes/Attributes/MarshallingPropertiesAttribute.cs b/DiscImageChef.CommonTypes/Attributes/MarshallingPropertiesAttribute.cs new file mode 100644 index 000000000..e03f042d8 --- /dev/null +++ b/DiscImageChef.CommonTypes/Attributes/MarshallingPropertiesAttribute.cs @@ -0,0 +1,65 @@ +// /*************************************************************************** +// The Disc Image Chef +// ---------------------------------------------------------------------------- +// +// Filename : MarshallingPropertiesAttribute.cs +// Author(s) : Natalia Portillo +// +// Component : Common types. +// +// --[ Description ] ---------------------------------------------------------- +// +// Declares properties of structs for marshalling. +// +// --[ License ] -------------------------------------------------------------- +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to +// permit persons to whom the Software is furnished to do so, subject to +// the following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +// +// ---------------------------------------------------------------------------- +// Copyright © 2011-2019 Natalia Portillo +// ****************************************************************************/ + +using System; +using DiscImageChef.CommonTypes.Enums; + +namespace DiscImageChef.CommonTypes.Attributes +{ + /// + /// Defines properties to help marshalling structs from binary data + /// + [AttributeUsage(AttributeTargets.Struct)] + public class MarshallingPropertiesAttribute : Attribute + { + /// c + public BitEndian Endian { get; } + /// + /// Tells if the structure, or any nested structure, has any non-value type (e.g. arrays, strings, etc). + /// + public bool HasReferences { get; set; } + + /// Defines properties to help marshalling structs from binary data + /// Defines properties to help marshalling structs from binary data + public MarshallingPropertiesAttribute(BitEndian endian) + { + Endian = endian; + HasReferences = true; + } + } +} \ No newline at end of file diff --git a/DiscImageChef.CommonTypes/DiscImageChef.CommonTypes.csproj b/DiscImageChef.CommonTypes/DiscImageChef.CommonTypes.csproj index 40460a732..8b8e00786 100644 --- a/DiscImageChef.CommonTypes/DiscImageChef.CommonTypes.csproj +++ b/DiscImageChef.CommonTypes/DiscImageChef.CommonTypes.csproj @@ -49,6 +49,7 @@ Metadata/cicm.cs + diff --git a/DiscImageChef.CommonTypes/Enums/BitEndian.cs b/DiscImageChef.CommonTypes/Enums/BitEndian.cs index 1cae44872..ed156504f 100644 --- a/DiscImageChef.CommonTypes/Enums/BitEndian.cs +++ b/DiscImageChef.CommonTypes/Enums/BitEndian.cs @@ -35,24 +35,17 @@ // ---------------------------------------------------------------------------- // Copyright © 2011-2019 Natalia Portillo // ****************************************************************************/ + namespace DiscImageChef.CommonTypes.Enums { - /// - /// Describes the endianness of bits on a data structure - /// + /// Describes the endianness of bits on a data structure public enum BitEndian { - /// - /// Little-endian, or least significant bit - /// + /// Little-endian, or least significant bit Little, - /// - /// Big-endian, or most significant bit - /// + /// Big-endian, or most significant bit Big, - /// - /// PDP-11 endian, little endian except for 32-bit integers where the 16 halves are swapped between them - /// + /// PDP-11 endian, little endian except for 32-bit integers where the 16 halves are swapped between them Pdp } } \ No newline at end of file