Skip to content

Gendarme.Rules.Interoperability.DoNotAssumeIntPtrSizeRule(git)

Sebastien Pouliot edited this page Mar 2, 2011 · 1 revision

DoNotAssumeIntPtrSizeRule

Assembly: Gendarme.Rules.Interoperability
Version: git

Description

This rule checks for code which casts an IntPtr or UIntPtr into a 32-bit (or smaller) value. It will also check if memory read with the Marshal.ReadInt32 and Marshal.ReadInt64 methods is being cast into an IntPtr or UIntPtr. IntPtr is generally used to reference a memory location and downcasting them to 32-bits will make the code fail on 64-bit CPUs.

Examples

Bad example (cast):

int ptr = dest.ToInt32 ();
for (int i = 0; i < 16; i++) {
    Marshal.StructureToPtr (this, (IntPtr)ptr, false);
    ptr += 4;
}

Bad example (Marshal.Read*):

// that won't work on 64 bits platforms
IntPtr p = (IntPtr) Marshal.ReadInt32 (p);

Good example (cast):

long ptr = dest.ToInt64 ();
for (int i = 0; i < 16; i++) {
    Marshal.StructureToPtr (this, (IntPtr) ptr, false);
    ptr += IntPtr.Size;
}

Good example (Marshal.Read*):

IntPtr p = (IntPtr) Marshal.ReadIntPtr (p);

Notes

  • This rule is available since Gendarme 2.0 but was named DoNotCastIntPtrToInt32Rule before 2.2

Source code

You can browse the latest source code of this rule on github.com

Clone this wiki locally