Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
efbb4196
Commit
efbb4196
authored
Sep 23, 2011
by
Nikolay Sivov
Committed by
Alexandre Julliard
Sep 23, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
comctl32/monthcal: Fix some day state problems.
parent
b11208e5
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
140 additions
and
77 deletions
+140
-77
monthcal.c
dlls/comctl32/monthcal.c
+88
-77
monthcal.c
dlls/comctl32/tests/monthcal.c
+52
-0
No files found.
dlls/comctl32/monthcal.c
View file @
efbb4196
...
...
@@ -130,7 +130,6 @@ typedef struct
BOOL
isUnicode
;
/* value set with MCM_SETUNICODE format */
int
monthRange
;
MONTHDAYSTATE
*
monthdayState
;
SYSTEMTIME
todaysDate
;
BOOL
todaySet
;
/* Today was forced with MCM_SETTODAY */
...
...
@@ -657,6 +656,56 @@ static inline void MONTHCAL_GetDayRect(const MONTHCAL_INFO *infoPtr, const SYSTE
MONTHCAL_GetDayRectI
(
infoPtr
,
r
,
col
,
row
,
calIdx
);
}
static
LRESULT
MONTHCAL_GetMonthRange
(
const
MONTHCAL_INFO
*
infoPtr
,
DWORD
flag
,
SYSTEMTIME
*
st
)
{
INT
range
;
TRACE
(
"flag=%d, st=%p
\n
"
,
flag
,
st
);
switch
(
flag
)
{
case
GMR_VISIBLE
:
{
if
(
st
)
{
st
[
0
]
=
infoPtr
->
calendars
[
0
].
month
;
st
[
1
]
=
infoPtr
->
calendars
[
MONTHCAL_GetCalCount
(
infoPtr
)
-
1
].
month
;
if
(
st
[
0
].
wMonth
==
min_allowed_date
.
wMonth
&&
st
[
0
].
wYear
==
min_allowed_date
.
wYear
)
{
st
[
0
].
wDay
=
min_allowed_date
.
wDay
;
}
else
st
[
0
].
wDay
=
1
;
MONTHCAL_CalculateDayOfWeek
(
&
st
[
0
],
TRUE
);
st
[
1
].
wDay
=
MONTHCAL_MonthLength
(
st
[
1
].
wMonth
,
st
[
1
].
wYear
);
MONTHCAL_CalculateDayOfWeek
(
&
st
[
1
],
TRUE
);
}
range
=
MONTHCAL_GetCalCount
(
infoPtr
);
break
;
}
case
GMR_DAYSTATE
:
{
if
(
st
)
{
MONTHCAL_GetMinDate
(
infoPtr
,
&
st
[
0
]);
MONTHCAL_GetMaxDate
(
infoPtr
,
&
st
[
1
]);
}
/* include two partially visible months */
range
=
MONTHCAL_GetCalCount
(
infoPtr
)
+
2
;
break
;
}
default:
WARN
(
"Unknown flag value, got %d
\n
"
,
flag
);
range
=
0
;
}
return
range
;
}
/* Focused day helper:
- set focused date to given value;
...
...
@@ -1013,7 +1062,7 @@ static void MONTHCAL_PaintFocusAndCircle(const MONTHCAL_INFO *infoPtr, HDC hdc,
/* months before first calendar month and after last calendar month */
static
void
MONTHCAL_PaintLeadTrailMonths
(
const
MONTHCAL_INFO
*
infoPtr
,
HDC
hdc
,
const
PAINTSTRUCT
*
ps
)
{
INT
mask
,
length
;
INT
mask
,
length
,
index
;
SYSTEMTIME
st_max
,
st
;
if
(
infoPtr
->
dwStyle
&
MCS_NOTRAILINGDATES
)
return
;
...
...
@@ -1026,9 +1075,10 @@ static void MONTHCAL_PaintLeadTrailMonths(const MONTHCAL_INFO *infoPtr, HDC hdc,
/* December and January both 31 days long, so no worries if wrapped */
length
=
MONTHCAL_MonthLength
(
infoPtr
->
calendars
[
0
].
month
.
wMonth
-
1
,
infoPtr
->
calendars
[
0
].
month
.
wYear
);
index
=
0
;
while
(
st
.
wDay
<=
length
)
{
MONTHCAL_DrawDay
(
infoPtr
,
hdc
,
&
st
,
infoPtr
->
monthdayState
[
0
]
&
mask
,
ps
);
MONTHCAL_DrawDay
(
infoPtr
,
hdc
,
&
st
,
infoPtr
->
monthdayState
[
index
]
&
mask
,
ps
);
mask
<<=
1
;
st
.
wDay
++
;
}
...
...
@@ -1039,10 +1089,10 @@ static void MONTHCAL_PaintLeadTrailMonths(const MONTHCAL_INFO *infoPtr, HDC hdc,
MONTHCAL_GetNextMonth
(
&
st
);
MONTHCAL_GetMaxDate
(
infoPtr
,
&
st_max
);
mask
=
1
;
index
=
MONTHCAL_GetMonthRange
(
infoPtr
,
GMR_DAYSTATE
,
0
)
-
1
;
while
(
st
.
wDay
<=
st_max
.
wDay
)
{
MONTHCAL_DrawDay
(
infoPtr
,
hdc
,
&
st
,
infoPtr
->
monthdayState
[
2
]
&
mask
,
ps
);
MONTHCAL_DrawDay
(
infoPtr
,
hdc
,
&
st
,
infoPtr
->
monthdayState
[
index
]
&
mask
,
ps
);
mask
<<=
1
;
st
.
wDay
++
;
}
...
...
@@ -1100,7 +1150,7 @@ static void MONTHCAL_PaintCalendar(const MONTHCAL_INFO *infoPtr, HDC hdc, const
length
=
MONTHCAL_MonthLength
(
date
->
wMonth
,
date
->
wYear
);
while
(
st
.
wDay
<=
length
)
{
MONTHCAL_DrawDay
(
infoPtr
,
hdc
,
&
st
,
infoPtr
->
monthdayState
[
1
]
&
mask
,
ps
);
MONTHCAL_DrawDay
(
infoPtr
,
hdc
,
&
st
,
infoPtr
->
monthdayState
[
calIdx
+
1
]
&
mask
,
ps
);
mask
<<=
1
;
st
.
wDay
++
;
}
...
...
@@ -1326,65 +1376,12 @@ MONTHCAL_SetFirstDayOfWeek(MONTHCAL_INFO *infoPtr, INT day)
return
prev
;
}
static
LRESULT
MONTHCAL_GetMonthRange
(
const
MONTHCAL_INFO
*
infoPtr
,
DWORD
flag
,
SYSTEMTIME
*
st
)
{
INT
range
;
TRACE
(
"flag=%d, st=%p
\n
"
,
flag
,
st
);
switch
(
flag
)
{
case
GMR_VISIBLE
:
{
if
(
st
)
{
st
[
0
]
=
infoPtr
->
calendars
[
0
].
month
;
st
[
1
]
=
infoPtr
->
calendars
[
MONTHCAL_GetCalCount
(
infoPtr
)
-
1
].
month
;
if
(
st
[
0
].
wMonth
==
min_allowed_date
.
wMonth
&&
st
[
0
].
wYear
==
min_allowed_date
.
wYear
)
{
st
[
0
].
wDay
=
min_allowed_date
.
wDay
;
}
else
st
[
0
].
wDay
=
1
;
MONTHCAL_CalculateDayOfWeek
(
&
st
[
0
],
TRUE
);
st
[
1
].
wDay
=
MONTHCAL_MonthLength
(
st
[
1
].
wMonth
,
st
[
1
].
wYear
);
MONTHCAL_CalculateDayOfWeek
(
&
st
[
1
],
TRUE
);
}
range
=
MONTHCAL_GetCalCount
(
infoPtr
);
break
;
}
case
GMR_DAYSTATE
:
{
if
(
st
)
{
MONTHCAL_GetMinDate
(
infoPtr
,
&
st
[
0
]);
MONTHCAL_GetMaxDate
(
infoPtr
,
&
st
[
1
]);
}
/* include two partially visible months */
range
=
MONTHCAL_GetCalCount
(
infoPtr
)
+
2
;
break
;
}
default:
WARN
(
"Unknown flag value, got %d
\n
"
,
flag
);
range
=
0
;
}
return
range
;
}
static
LRESULT
MONTHCAL_GetMaxTodayWidth
(
const
MONTHCAL_INFO
*
infoPtr
)
{
return
(
infoPtr
->
todayrect
.
right
-
infoPtr
->
todayrect
.
left
);
}
static
LRESULT
MONTHCAL_SetRange
(
MONTHCAL_INFO
*
infoPtr
,
SHORT
limits
,
SYSTEMTIME
*
range
)
{
...
...
@@ -1460,7 +1457,9 @@ static LRESULT
MONTHCAL_SetDayState
(
const
MONTHCAL_INFO
*
infoPtr
,
INT
months
,
MONTHDAYSTATE
*
states
)
{
TRACE
(
"%p %d %p
\n
"
,
infoPtr
,
months
,
states
);
if
(
months
!=
infoPtr
->
monthRange
)
return
0
;
if
(
!
(
infoPtr
->
dwStyle
&
MCS_DAYSTATE
))
return
0
;
if
(
months
!=
MONTHCAL_GetMonthRange
(
infoPtr
,
GMR_DAYSTATE
,
0
))
return
0
;
memcpy
(
infoPtr
->
monthdayState
,
states
,
months
*
sizeof
(
MONTHDAYSTATE
));
...
...
@@ -1884,16 +1883,15 @@ static void MONTHCAL_NotifyDayState(MONTHCAL_INFO *infoPtr)
nmds
.
nmhdr
.
hwndFrom
=
infoPtr
->
hwndSelf
;
nmds
.
nmhdr
.
idFrom
=
GetWindowLongPtrW
(
infoPtr
->
hwndSelf
,
GWLP_ID
);
nmds
.
nmhdr
.
code
=
MCN_GETDAYSTATE
;
nmds
.
cDayState
=
infoPtr
->
monthRange
;
nmds
.
prgDayState
=
Alloc
(
infoPtr
->
monthRang
e
*
sizeof
(
MONTHDAYSTATE
));
nmds
.
cDayState
=
MONTHCAL_GetMonthRange
(
infoPtr
,
GMR_DAYSTATE
,
0
)
;
nmds
.
prgDayState
=
Alloc
(
nmds
.
cDayStat
e
*
sizeof
(
MONTHDAYSTATE
));
nmds
.
stStart
=
infoPtr
->
todaysDate
;
nmds
.
stStart
.
wYear
=
infoPtr
->
minSel
.
wYear
;
nmds
.
stStart
.
wMonth
=
infoPtr
->
minSel
.
wMonth
;
MONTHCAL_GetMinDate
(
infoPtr
,
&
nmds
.
stStart
);
nmds
.
stStart
.
wDay
=
1
;
SendMessageW
(
infoPtr
->
hwndNotify
,
WM_NOTIFY
,
nmds
.
nmhdr
.
idFrom
,
(
LPARAM
)
&
nmds
);
memcpy
(
infoPtr
->
monthdayState
,
nmds
.
prgDayState
,
infoPtr
->
monthRange
*
sizeof
(
MONTHDAYSTATE
));
memcpy
(
infoPtr
->
monthdayState
,
nmds
.
prgDayState
,
MONTHCAL_GetMonthRange
(
infoPtr
,
GMR_DAYSTATE
,
0
)
*
sizeof
(
MONTHDAYSTATE
));
Free
(
nmds
.
prgDayState
);
}
...
...
@@ -2515,9 +2513,16 @@ static void MONTHCAL_UpdateSize(MONTHCAL_INFO *infoPtr)
if
(
x
==
0
)
x
=
1
;
if
(
y
==
0
)
y
=
1
;
infoPtr
->
dim
.
cx
=
x
;
infoPtr
->
dim
.
cy
=
y
;
infoPtr
->
calendars
=
ReAlloc
(
infoPtr
->
calendars
,
MONTHCAL_GetCalCount
(
infoPtr
)
*
sizeof
(
CALENDAR_INFO
));
if
(
x
*
y
!=
MONTHCAL_GetCalCount
(
infoPtr
))
{
infoPtr
->
dim
.
cx
=
x
;
infoPtr
->
dim
.
cy
=
y
;
infoPtr
->
calendars
=
ReAlloc
(
infoPtr
->
calendars
,
MONTHCAL_GetCalCount
(
infoPtr
)
*
sizeof
(
CALENDAR_INFO
));
infoPtr
->
monthdayState
=
ReAlloc
(
infoPtr
->
monthdayState
,
MONTHCAL_GetMonthRange
(
infoPtr
,
GMR_DAYSTATE
,
0
)
*
sizeof
(
MONTHDAYSTATE
));
MONTHCAL_NotifyDayState
(
infoPtr
);
}
for
(
i
=
1
;
i
<
MONTHCAL_GetCalCount
(
infoPtr
);
i
++
)
{
...
...
@@ -2646,6 +2651,15 @@ static INT MONTHCAL_StyleChanging(MONTHCAL_INFO *infoPtr, WPARAM wStyleType,
lpss
->
styleNew
&=
~
MCS_MULTISELECT
;
}
/* block MCS_DAYSTATE change */
if
((
lpss
->
styleNew
^
lpss
->
styleOld
)
&
MCS_DAYSTATE
)
{
if
(
lpss
->
styleOld
&
MCS_DAYSTATE
)
lpss
->
styleNew
|=
MCS_DAYSTATE
;
else
lpss
->
styleNew
&=
~
MCS_DAYSTATE
;
}
return
0
;
}
...
...
@@ -2666,11 +2680,12 @@ MONTHCAL_Create(HWND hwnd, LPCREATESTRUCTW lpcs)
infoPtr
->
hwndSelf
=
hwnd
;
infoPtr
->
hwndNotify
=
lpcs
->
hwndParent
;
infoPtr
->
dwStyle
=
GetWindowLongW
(
hwnd
,
GWL_STYLE
);
infoPtr
->
dwStyle
=
GetWindowLongW
(
hwnd
,
GWL_STYLE
);
infoPtr
->
dim
.
cx
=
infoPtr
->
dim
.
cy
=
1
;
infoPtr
->
calendars
=
Alloc
(
sizeof
(
CALENDAR_INFO
));
if
(
!
infoPtr
->
calendars
)
goto
fail
;
MONTHCAL_SetFont
(
infoPtr
,
GetStockObject
(
DEFAULT_GUI_FONT
),
FALSE
)
;
infoPtr
->
monthdayState
=
Alloc
(
3
*
sizeof
(
MONTHDAYSTATE
));
if
(
!
infoPtr
->
monthdayState
)
goto
fail
;
/* initialize info structure */
/* FIXME: calculate systemtime ->> localtime(subtract timezoneinfo) */
...
...
@@ -2679,10 +2694,6 @@ MONTHCAL_Create(HWND hwnd, LPCREATESTRUCTW lpcs)
MONTHCAL_SetFirstDayOfWeek
(
infoPtr
,
-
1
);
infoPtr
->
maxSelCount
=
(
infoPtr
->
dwStyle
&
MCS_MULTISELECT
)
?
7
:
1
;
infoPtr
->
monthRange
=
3
;
infoPtr
->
monthdayState
=
Alloc
(
infoPtr
->
monthRange
*
sizeof
(
MONTHDAYSTATE
));
if
(
!
infoPtr
->
monthdayState
)
goto
fail
;
infoPtr
->
colors
[
MCSC_BACKGROUND
]
=
comctl32_color
.
clrWindow
;
infoPtr
->
colors
[
MCSC_TEXT
]
=
comctl32_color
.
clrWindowText
;
...
...
@@ -2703,7 +2714,7 @@ MONTHCAL_Create(HWND hwnd, LPCREATESTRUCTW lpcs)
infoPtr
->
calendars
[
0
].
month
=
infoPtr
->
todaysDate
;
infoPtr
->
isUnicode
=
TRUE
;
/* set
all control dimensions
*/
/* set
up control layout and day state data
*/
MONTHCAL_UpdateSize
(
infoPtr
);
/* today auto update timer, to be freed only on control destruction */
...
...
dlls/comctl32/tests/monthcal.c
View file @
efbb4196
...
...
@@ -1817,6 +1817,57 @@ static void test_MCM_GETCALENDARCOUNT(void)
DestroyWindow
(
hwnd
);
}
static
void
test_daystate
(
void
)
{
MONTHDAYSTATE
state
[
4
];
DWORD
ret
,
style
;
HWND
hwnd
;
/* without MCS_DAYSTATE */
hwnd
=
create_monthcal_control
(
0
);
ret
=
SendMessageA
(
hwnd
,
MCM_GETMONTHRANGE
,
GMR_DAYSTATE
,
0
);
expect
(
4
,
ret
);
ret
=
SendMessageA
(
hwnd
,
MCM_SETDAYSTATE
,
4
,
(
LPARAM
)
&
state
);
expect
(
0
,
ret
);
ret
=
SendMessageA
(
hwnd
,
MCM_SETDAYSTATE
,
2
,
(
LPARAM
)
&
state
);
expect
(
0
,
ret
);
ret
=
SendMessageA
(
hwnd
,
MCM_SETDAYSTATE
,
0
,
0
);
expect
(
0
,
ret
);
/* try to switch on */
SetWindowLongA
(
hwnd
,
GWL_STYLE
,
GetWindowLongA
(
hwnd
,
GWL_STYLE
)
|
MCS_DAYSTATE
);
style
=
GetWindowLongA
(
hwnd
,
GWL_STYLE
);
ok
((
style
&
MCS_DAYSTATE
)
==
0
,
"got 0x%08x
\n
"
,
style
);
DestroyWindow
(
hwnd
);
/* with MCS_DAYSTATE */
hwnd
=
create_monthcal_control
(
MCS_DAYSTATE
);
ret
=
SendMessageA
(
hwnd
,
MCM_GETMONTHRANGE
,
GMR_DAYSTATE
,
0
);
expect
(
4
,
ret
);
ret
=
SendMessageA
(
hwnd
,
MCM_SETDAYSTATE
,
4
,
(
LPARAM
)
&
state
);
expect
(
1
,
ret
);
ret
=
SendMessageA
(
hwnd
,
MCM_SETDAYSTATE
,
2
,
(
LPARAM
)
&
state
);
expect
(
0
,
ret
);
ret
=
SendMessageA
(
hwnd
,
MCM_SETDAYSTATE
,
0
,
0
);
expect
(
0
,
ret
);
/* try to switch off */
SetWindowLongA
(
hwnd
,
GWL_STYLE
,
GetWindowLongA
(
hwnd
,
GWL_STYLE
)
&
~
MCS_DAYSTATE
);
style
=
GetWindowLongA
(
hwnd
,
GWL_STYLE
);
ok
((
style
&
MCS_DAYSTATE
)
==
MCS_DAYSTATE
,
"got 0x%08x
\n
"
,
style
);
DestroyWindow
(
hwnd
);
}
START_TEST
(
monthcal
)
{
BOOL
(
WINAPI
*
pInitCommonControlsEx
)(
const
INITCOMMONCONTROLSEX
*
);
...
...
@@ -1859,6 +1910,7 @@ START_TEST(monthcal)
test_maxselday
();
test_selrange
();
test_killfocus
();
test_daystate
();
if
(
!
load_v6_module
(
&
ctx_cookie
,
&
hCtx
))
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment