Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

125 lines
3.8 KiB

  1. /*
  2. * Windows Calendar
  3. * Copyright (c) 1985 by Microsoft Corporation, all rights reserved.
  4. * Written by Mark L. Chamberlin, consultant to Microsoft.
  5. *
  6. */
  7. /*
  8. *****
  9. ***** caldata2.c
  10. *****
  11. */
  12. #include "cal.h"
  13. CHAR *vrgsz [CSTRINGS+1]; /* Strings loaded in from the resource file. */
  14. D3 vd3Sel; /* Selected date. */
  15. WORD vwDaySticky; /* The sticky selected day. */
  16. INT vrgbMonth [CBMONTHARRAY]; /* Days of the month being displayed.
  17. Changed from BYTE to int */
  18. INT vcDaysMonth; /* Number of days in the month being displayed. */
  19. INT vcWeeksMonth; /* Number of weeks in the month being displayed. */
  20. WORD vwWeekdayFirst; /* The weekday of the first day of the month. */
  21. INT vrgxcoGrid [8]; /* Month grid xco - maximum of 7 days, so 8 lines. */
  22. INT vrgycoGrid [7]; /* Month grid yco - maximum of 6 weeks, so 7 lines. */
  23. WORD votqrPrev;
  24. WORD votqrCur;
  25. WORD votqrNext;
  26. WORD vidrCur; /* The index into vrghlmdr for the current DR. */
  27. LOCALHANDLE vrghlmDr [CDR]; /* The handles of the DRs. */
  28. LOCALHANDLE vhlmTdd = 0; /* Handle to table of date descriptors. */
  29. INT vcddAllocated = 0; /* Count of allocated date descriptors. */
  30. INT vcddUsed = 0; /* Count of date descriptors in use. */
  31. /* Used for passing dates from dialogs to command handlers. */
  32. DT vdtFrom;
  33. D3 vd3To;
  34. DT vdtTo;
  35. INT vitddFirst;
  36. INT vitddMax;
  37. /* The handle of the window that should get the focus when we get
  38. activated via a WM_ACTIVATE with wParam == TRUE. When the
  39. appointment description edit control or the notes area
  40. edit control notifies us that it is getting the focus, we store
  41. its window handle in vhwndFocus. When we set focus to the monthly
  42. calendar, we also set up vhwndFocus.
  43. */
  44. HWND vhwndFocus = (HWND)NULL;
  45. /* File handles. */
  46. INT hFile[CFILE];
  47. /* ReOpen Buffers. */
  48. OFSTRUCT OFStruct [CFILE];
  49. BOOL vfChangeFile = FALSE; /* FALSE if couldn't create the change file,
  50. TRUE if change file exists.
  51. Must be initialized to FALSE so the first
  52. call to CreateChangeFile doesn't attempt
  53. to delete an old change file (since there
  54. isn't one).
  55. */
  56. INT vobkEODChange; /* Offset in blocks of the end of data in the
  57. change file.
  58. */
  59. CHAR vszFileSpec [CCHFILESPECMAX]; /* Name of original file. */
  60. CHAR vszFilterSpec [CCHFILTERMAX]; /* Filter string for File Open */
  61. CHAR vszCustFilterSpec [CCHFILTERMAX];/* custom Filter string for File Open */
  62. BOOL vfOriginalFile; /* FALSE means untitled, TRUE means there
  63. is an original file.
  64. */
  65. INT vobkEODNew; /* Offset in blocks of the end of data in the
  66. new file.
  67. */
  68. BOOL vfDirty; /* FALSE means no changes since the last Save. */
  69. /* This is the magic number we put at the beginning of a calendar file
  70. so no one fools us into using some other sort of file.
  71. */
  72. BYTE vrgbMagic [CBMAGIC] =
  73. {
  74. 'C' + 'r',
  75. 'A' + 'a',
  76. 'L' + 'd',
  77. 'E' + 'n',
  78. 'N' + 'e',
  79. 'D' + 'l',
  80. 'A' + 'a',
  81. 'R' + 'c'
  82. };
  83. HDC vhDCMemory = 0; /* Memory DC for BitBlts. */
  84. HBITMAP vhbmLeftArrow = 0; /* Handle to bitmap for left arrow. */
  85. HBITMAP vhbmRightArrow = 0; /* Handle to bitmap for left arrow. */
  86. HBITMAP vhbmBell = 0; /* Handle to alarm bell bitmap. */
  87. /* x coordinates within Wnd2A of the day switching arrows. */
  88. INT vxcoLeftArrowFirst;
  89. INT vxcoLeftArrowMax;
  90. INT vxcoRightArrowFirst;
  91. INT vxcoRightArrowMax;
  92. /* Merge spec - two byte string */
  93. //- Merge Bytes: This is used to grab two chars from a string, make it string.
  94. char vszMergeStr [3];
  95. INT vmScrollPos=0; /* Thumb position for vertical month scroll */
  96. INT vmScrollInc=0; /* step size for vertical month scroll */
  97. INT vmScrollMax=0; /* maximum vertical scroll position */
  98. INT hmScrollPos=0; /* Thumb position for horiz. month scroll */
  99. INT hmScrollInc=0; /* step size for horiz. month scroll */
  100. INT hmScrollMax=0; /* maximum horiz. scroll position */