1 /*************************************************************************** 2 * Copyright (c) 2024 Microsoft Corporation 3 * 4 * This program and the accompanying materials are made available under the 5 * terms of the MIT License which is available at 6 * https://opensource.org/licenses/MIT. 7 * 8 * SPDX-License-Identifier: MIT 9 **************************************************************************/ 10 11 12 /**************************************************************************/ 13 /**************************************************************************/ 14 /** */ 15 /** GUIX Component */ 16 /** */ 17 /** Canvas Management (Canvas) */ 18 /** */ 19 /**************************************************************************/ 20 21 #define GX_SOURCE_CODE 22 23 24 /* Include necessary system files. */ 25 26 #include "gx_api.h" 27 #include "gx_canvas.h" 28 29 30 /* Bring in externs for caller checking code. */ 31 GX_CALLER_CHECKING_EXTERNS 32 33 /**************************************************************************/ 34 /* */ 35 /* FUNCTION RELEASE */ 36 /* */ 37 /* _gxe_canvas_drawing_initiate PORTABLE C */ 38 /* 6.1 */ 39 /* AUTHOR */ 40 /* */ 41 /* Kenneth Maxwell, Microsoft Corporation */ 42 /* */ 43 /* DESCRIPTION */ 44 /* */ 45 /* This function checks for errors in the canvas drawing initiate */ 46 /* function call. */ 47 /* */ 48 /* INPUT */ 49 /* */ 50 /* canvas Canvas control block */ 51 /* who Widget control block pointer */ 52 /* dirty_area Area to draw on */ 53 /* */ 54 /* OUTPUT */ 55 /* */ 56 /* status Completion status */ 57 /* */ 58 /* CALLS */ 59 /* */ 60 /* _gx_canvas_drawing_initiate Actual canvas drawing */ 61 /* initiate call */ 62 /* */ 63 /* CALLED BY */ 64 /* */ 65 /* Application Code */ 66 /* */ 67 /* RELEASE HISTORY */ 68 /* */ 69 /* DATE NAME DESCRIPTION */ 70 /* */ 71 /* 05-19-2020 Kenneth Maxwell Initial Version 6.0 */ 72 /* 09-30-2020 Kenneth Maxwell Modified comment(s), */ 73 /* resulting in version 6.1 */ 74 /* */ 75 /**************************************************************************/ _gxe_canvas_drawing_initiate(GX_CANVAS * canvas,GX_WIDGET * who,GX_RECTANGLE * dirty_area)76UINT _gxe_canvas_drawing_initiate(GX_CANVAS *canvas, GX_WIDGET *who, GX_RECTANGLE *dirty_area) 77 { 78 UINT status; 79 80 /* Check for appropriate caller. */ 81 GX_INIT_AND_THREADS_CALLER_CHECKING 82 83 /* Check for the invalid input pointers. */ 84 if ((canvas == GX_NULL) || 85 (dirty_area == GX_NULL)) 86 { 87 return(GX_PTR_ERROR); 88 } 89 90 if (canvas -> gx_canvas_id != GX_CANVAS_ID) 91 { 92 return(GX_INVALID_CANVAS); 93 } 94 95 /* Call the actual canvas drawing initiate function. */ 96 status = _gx_canvas_drawing_initiate(canvas, who, dirty_area); 97 98 /* Return completion status. */ 99 return status; 100 } 101 102