/*
 * $Id: cdk_int.h,v 1.19 2005/04/15 00:01:49 tom Exp $
 */

#ifndef CDKINCLUDES
#ifndef CDK_INT_H
#define CDK_INT_H

#ifdef __cplusplus
extern "C" {
#endif

#include <cdk.h>

/*
 * Copyright 2003-2004,2005 Thomas E. Dickey
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. All advertising materials mentioning features or use of this software
 *    must display the following acknowledgment:
 * 	This product includes software developed by Thomas Dickey
 * 	and contributors.
 * 4. Neither the name of Thomas Dickey, nor the names of contributors
 *    may be used to endorse or promote products derived from this software
 *    without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THOMAS DICKEY AND CONTRIBUTORS ``AS IS'' AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED.  IN NO EVENT SHALL THOMAS DICKEY OR CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 */

#define typeCallocN(type,n)     (type*)calloc(n, sizeof(type))
#define typeCalloc(type)        typeCallocN(type,1)

#define typeReallocN(type,p,n)  (type*)realloc(p, (n) * sizeof(type))

#define typeMallocN(type,n)     (type*)malloc((n) * sizeof(type))
#define typeMalloc(type)        typeMallocN(type,1)

#define freeChecked(p)		if ((p) != 0) free (p)
#define freeAndNull(p)		if ((p) != 0) { free (p); p = 0; }

#define isChar(c)		((int)(c) >= 0 && (int)(c) < KEY_MIN)
#define CharOf(c)               ((unsigned char)(c))

#define SIZEOF(v)		(sizeof(v)/sizeof((v)[0]))

/*
 * Macros to check if caller is attempting to make the widget as high (or wide)
 * as the screen.
 */
#define isFullWidth(n)		((n) == FULL || (COLS != 0 && ((n) >= COLS)))
#define isFullHeight(n)		((n) == FULL || (LINES != 0 && ((n) >= LINES)))

/*
 * Hide details of modifying widget->exitType
 */
#define storeExitType(d)	ObjOf(d)->exitType = (d)->exitType
#define initExitType(d)		storeExitType(d) = vNEVER_ACTIVATED
#define setExitType(w,c)	setCdkExitType(ObjOf(w), &((w)->exitType), c)
#define copyExitType(d,s)	storeExitType(d) = ExitTypeOf(s)

/*
 * Use this if checkCDKObjectBind() returns true, use this function to
 * decide if the exitType should be set as a side-effect.
 */
#define checkEarlyExit(w)	if (EarlyExitOf(w) != vNEVER_ACTIVATED) \
				    storeExitType(w) = EarlyExitOf(w)

/*
 * Simplify case-statements for scrollers
 */
#define scroller_KEY_UP(w) \
		if ((w)->listSize > 0) { \
		   if ((w)->currentItem > 0) { \
		      if ((w)->currentHigh == 0) { \
			 if ((w)->currentTop != 0) { \
			    (w)->currentTop--; \
			    (w)->currentItem--; \
			 } else { \
			    Beep(); \
			 } \
		      } else { \
			 (w)->currentItem--; \
			 (w)->currentHigh--; \
		      } \
		   } else { \
		      Beep(); \
		   } \
		} else { \
		    Beep(); \
		}

#define scroller_KEY_DOWN(w) \
		if ((w)->listSize > 0) { \
		   if ((w)->currentItem < (w)->listSize-1) { \
		      if ((w)->currentHigh == (w)->viewSize - 1) { \
			 if ((w)->currentTop < (w)->maxTopItem) { \
			    (w)->currentTop++; \
			    (w)->currentItem++; \
			 } else { \
			    Beep(); \
			 } \
		      } else { \
			 (w)->currentItem++; \
			 (w)->currentHigh++; \
		      } \
		   } else { \
		      Beep(); \
		   } \
		} else { \
		   Beep(); \
		}

#define scroller_KEY_LEFT(w) \
		if ((w)->listSize > 0) { \
		   if ((w)->leftChar == 0) { \
		      Beep(); \
		   } else { \
		      (w)->leftChar --; \
		   } \
		} else { \
		   Beep(); \
		}

#define scroller_KEY_RIGHT(w) \
		if ((w)->listSize > 0) { \
		   if ((w)->leftChar >= (w)->maxLeftChar) { \
		      Beep(); \
		   } else { \
		      (w)->leftChar ++; \
		   } \
		} else { \
		   Beep(); \
		}

#define scroller_KEY_PPAGE(w) \
		if ((w)->listSize > 0) { \
		   if ((w)->currentTop > 0) { \
		      if ((w)->currentTop >= ((w)->viewSize -1)) { \
			 (w)->currentTop -= ((w)->viewSize - 1); \
			 (w)->currentItem -= ((w)->viewSize - 1); \
		      } else { \
			 scroller_KEY_HOME(w); \
		      } \
		   } else { \
		      Beep(); \
		   } \
		} else { \
		   Beep(); \
		}

#define scroller_KEY_NPAGE(w) \
		if ((w)->listSize > 0) { \
		   if ((w)->currentTop < (w)->maxTopItem) { \
		      if (((w)->currentTop + (w)->viewSize - 1) <= (w)->maxTopItem) { \
			 (w)->currentTop += ((w)->viewSize - 1); \
			 (w)->currentItem += ((w)->viewSize - 1); \
		      } else { \
			 (w)->currentTop = (w)->maxTopItem; \
			 (w)->currentItem = (w)->lastItem; \
			 (w)->currentHigh = (w)->viewSize-1; \
		      } \
		   } else { \
		      Beep(); \
		   } \
		} else { \
		   Beep(); \
		}

#define scroller_KEY_HOME(w) \
		(w)->currentTop	= 0; \
		(w)->currentItem = 0; \
		(w)->currentHigh = 0

#define scroller_KEY_END(w) \
		if ((w)->maxTopItem == -1) { \
		   (w)->currentTop = 0; \
		   (w)->currentItem = (w)->lastItem - 1; \
		} else { \
		   (w)->currentTop = (w)->maxTopItem; \
		   (w)->currentItem = (w)->lastItem; \
		} \
		(w)->currentHigh = (w)->viewSize - 1

#define scroller_SetPosition(w, item) \
		if (item <= 0) { \
		   scroller_KEY_HOME((w)); \
		} else if (item > (w)->listSize-1) { \
		   (w)->currentTop = (w)->maxTopItem; \
		   (w)->currentItem = (w)->listSize - 1; \
		   (w)->currentHigh = (w)->viewSize - 1; \
		} else if (item >= (w)->currentTop \
			&& item < (w)->currentTop + (w)->viewSize) { \
		   (w)->currentItem = item; \
		   (w)->currentHigh = item - (w)->currentTop; \
		} else { \
		   (w)->currentTop = item; \
		   (w)->currentItem = item; \
		   (w)->currentHigh = 0; \
		}

#define scroller_MaxViewSize(w) \
		((w)->boxHeight - (2*BorderOf(w) + TitleLinesOf(w)))

#define scroller_SetViewSize(w, size) \
		(w)->viewSize = maxViewSize(w); \
		(w)->listSize = listSize; \
		(w)->lastItem = listSize - 1; \
		(w)->maxTopItem = listSize - (w)->viewSize; \
 \
		if (listSize < (w)->viewSize) { \
		   (w)->viewSize = listSize; \
		   (w)->maxTopItem = 0; \
		} \
 \
		if ((w)->listSize > 0 && maxViewSize((w)) > 0) { \
		   (w)->step = (maxViewSize((w)) / (float)(w)->listSize); \
		   (w)->toggleSize = ((w)->listSize > (maxViewSize((w))) ?  1 : ceilCDK((w)->step)); \
		} else { \
		   (w)->step = 1; \
		   (w)->toggleSize = 1; \
		}

/*
 * Position within the data area of a widget, accounting for border and title.
 */
#define SCREEN_XPOS(w,n) ((n) + BorderOf(w))
#define SCREEN_YPOS(w,n) ((n) + BorderOf(w) + TitleLinesOf(w))

/*
 * Miscellaneous definitions.
 */
#define CDK_PATHMAX		256

extern char *GPasteBuffer;

#ifdef __cplusplus
}
#endif

#endif /* CDK_INT_H */
#endif /* CDKINCLUDES */


syntax highlighted by Code2HTML, v. 0.9.1