diff --git a/src/Tizen.NUI.Physics2D/src/internal/chipmunk/cpSpaceDebugDrawOptions.cs b/src/Tizen.NUI.Physics2D/src/internal/chipmunk/cpSpaceDebugDrawOptions.cs index d787f6e8104..7b9afef9716 100644 --- a/src/Tizen.NUI.Physics2D/src/internal/chipmunk/cpSpaceDebugDrawOptions.cs +++ b/src/Tizen.NUI.Physics2D/src/internal/chipmunk/cpSpaceDebugDrawOptions.cs @@ -104,15 +104,13 @@ internal struct cpSpaceDebugDrawOptions private IntPtr ToPointer() { IntPtr drawOptionsPtr = NativeInterop.AllocStructure(); - try + if (Marshal.SizeOf(typeof(cpSpaceDebugDrawOptions)) == 0) { - Marshal.StructureToPtr(this, drawOptionsPtr, false); + throw new ArgumentNullException("The size of type cpSpaceDebugDrawOptions should not be 0."); } - catch (Exception exception) - { - Tizen.Log.Fatal("NUI", "[Error] got exception during Marshal.StructureToPtr, this should not occur, message : " + exception.Message); - } - + + Marshal.StructureToPtr(this, drawOptionsPtr, false); + return drawOptionsPtr; } diff --git a/src/Tizen.NUI/src/internal/Xaml/CreateValuesVisitor.cs b/src/Tizen.NUI/src/internal/Xaml/CreateValuesVisitor.cs index 266e0b4603e..a7b98c68939 100755 --- a/src/Tizen.NUI/src/internal/Xaml/CreateValuesVisitor.cs +++ b/src/Tizen.NUI/src/internal/Xaml/CreateValuesVisitor.cs @@ -202,9 +202,9 @@ public void Visit(ElementNode node, INode parentNode) Values[node] = value; } - - if (value != null && value is BindableObject) - NameScope.SetNameScope(value as BindableObject, node.Namescope); + var bindableObject = value as BindableObject; + if (bindableObject != null) + NameScope.SetNameScope(bindableObject, node.Namescope); } public void Visit(RootNode node, INode parentNode) diff --git a/src/Tizen.NUI/src/public/BaseComponents/DirectRenderingGLView.cs b/src/Tizen.NUI/src/public/BaseComponents/DirectRenderingGLView.cs index b2bf0d90560..2946cb4ebba 100644 --- a/src/Tizen.NUI/src/public/BaseComponents/DirectRenderingGLView.cs +++ b/src/Tizen.NUI/src/public/BaseComponents/DirectRenderingGLView.cs @@ -183,18 +183,23 @@ public void BindTextureResources(List textures) { unsafe { - if (textures != null && sizeof(IntPtr) * textures.Count > 0) + + if (textures != null) { - IntPtr unmanagedPointer = Marshal.AllocHGlobal(checked(sizeof(IntPtr) * textures.Count)); - IntPtr[] texturesArray = new IntPtr[textures.Count]; - for (int i = 0; i < textures.Count; i++) + int intptrBytes = checked(sizeof(IntPtr) * textures.Count); + if (intptrBytes>0) { - texturesArray[i] = HandleRef.ToIntPtr(Texture.getCPtr(textures[i])); - } - System.Runtime.InteropServices.Marshal.Copy(texturesArray, 0, unmanagedPointer, textures.Count); + IntPtr unmanagedPointer = Marshal.AllocHGlobal(intptrBytes); + IntPtr[] texturesArray = new IntPtr[textures.Count]; + for (int i = 0; i < textures.Count; i++) + { + texturesArray[i] = HandleRef.ToIntPtr(Texture.getCPtr(textures[i])); + } + System.Runtime.InteropServices.Marshal.Copy(texturesArray, 0, unmanagedPointer, textures.Count); - Interop.GLView.GlViewBindTextureResources(SwigCPtr, unmanagedPointer, textures.Count); - Marshal.FreeHGlobal(unmanagedPointer); + Interop.GLView.GlViewBindTextureResources(SwigCPtr, unmanagedPointer, textures.Count); + Marshal.FreeHGlobal(unmanagedPointer); + } } } }