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
d9591d69
Commit
d9591d69
authored
Jan 30, 2011
by
Stefan Dösinger
Committed by
Alexandre Julliard
Feb 01, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
d3d9: Use a proper window class in the device tests.
parent
ddb36691
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
23 deletions
+27
-23
device.c
dlls/d3d9/tests/device.c
+27
-23
No files found.
dlls/d3d9/tests/device.c
View file @
d9591d69
...
@@ -166,7 +166,7 @@ static void test_mipmap_levels(void)
...
@@ -166,7 +166,7 @@ static void test_mipmap_levels(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -213,7 +213,7 @@ static void test_checkdevicemultisampletype(void)
...
@@ -213,7 +213,7 @@ static void test_checkdevicemultisampletype(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -275,7 +275,7 @@ static void test_swapchain(void)
...
@@ -275,7 +275,7 @@ static void test_swapchain(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -460,7 +460,7 @@ static void test_refcount(void)
...
@@ -460,7 +460,7 @@ static void test_refcount(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -773,7 +773,7 @@ static void test_cursor(void)
...
@@ -773,7 +773,7 @@ static void test_cursor(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -866,7 +866,7 @@ static void test_reset(void)
...
@@ -866,7 +866,7 @@ static void test_reset(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -1332,7 +1332,7 @@ static void test_scene(void)
...
@@ -1332,7 +1332,7 @@ static void test_scene(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -1489,7 +1489,7 @@ static void test_limits(void)
...
@@ -1489,7 +1489,7 @@ static void test_limits(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -1561,7 +1561,7 @@ static void test_depthstenciltest(void)
...
@@ -1561,7 +1561,7 @@ static void test_depthstenciltest(void)
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
pD3d
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
pD3d
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
if
(
!
pD3d
||
!
hwnd
)
goto
cleanup
;
...
@@ -1740,7 +1740,7 @@ static void test_draw_indexed(void)
...
@@ -1740,7 +1740,7 @@ static void test_draw_indexed(void)
HWND
hwnd
;
HWND
hwnd
;
void
*
ptr
;
void
*
ptr
;
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
0
,
0
,
0
,
10
,
10
,
0
,
0
,
0
,
0
);
0
,
0
,
0
,
10
,
10
,
0
,
0
,
0
,
0
);
if
(
!
hwnd
)
if
(
!
hwnd
)
{
{
...
@@ -1862,7 +1862,7 @@ static void test_null_stream(void)
...
@@ -1862,7 +1862,7 @@ static void test_null_stream(void)
d3d9
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
d3d9
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
d3d9
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
d3d9
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
d3d9
||
!
hwnd
)
goto
cleanup
;
if
(
!
d3d9
||
!
hwnd
)
goto
cleanup
;
...
@@ -1946,7 +1946,7 @@ static void test_lights(void)
...
@@ -1946,7 +1946,7 @@ static void test_lights(void)
d3d9
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
d3d9
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
d3d9
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
d3d9
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
d3d9
||
!
hwnd
)
goto
cleanup
;
if
(
!
d3d9
||
!
hwnd
)
goto
cleanup
;
...
@@ -2011,7 +2011,7 @@ static void test_set_stream_source(void)
...
@@ -2011,7 +2011,7 @@ static void test_set_stream_source(void)
d3d9
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
d3d9
=
pDirect3DCreate9
(
D3D_SDK_VERSION
);
ok
(
d3d9
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
ok
(
d3d9
!=
NULL
,
"Failed to create IDirect3D9 object
\n
"
);
hwnd
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
ok
(
hwnd
!=
NULL
,
"Failed to create window
\n
"
);
if
(
!
d3d9
||
!
hwnd
)
goto
cleanup
;
if
(
!
d3d9
||
!
hwnd
)
goto
cleanup
;
...
@@ -2227,14 +2227,9 @@ static void test_scissor_size(void)
...
@@ -2227,14 +2227,9 @@ static void test_scissor_size(void)
IDirect3DDevice9
*
device_ptr
=
0
;
IDirect3DDevice9
*
device_ptr
=
0
;
D3DPRESENT_PARAMETERS
present_parameters
;
D3DPRESENT_PARAMETERS
present_parameters
;
HRESULT
hr
;
HRESULT
hr
;
WNDCLASS
wc
=
{
0
};
HWND
hwnd
=
0
;
HWND
hwnd
=
0
;
RECT
scissorrect
;
RECT
scissorrect
;
wc
.
lpfnWndProc
=
DefWindowProc
;
wc
.
lpszClassName
=
"d3d9_test_wc"
;
RegisterClass
(
&
wc
);
hwnd
=
CreateWindow
(
"d3d9_test_wc"
,
"d3d9_test"
,
hwnd
=
CreateWindow
(
"d3d9_test_wc"
,
"d3d9_test"
,
WS_MAXIMIZE
|
WS_VISIBLE
|
WS_CAPTION
,
0
,
0
,
scts
[
i
].
winx
,
scts
[
i
].
winy
,
0
,
0
,
0
,
0
);
WS_MAXIMIZE
|
WS_VISIBLE
|
WS_CAPTION
,
0
,
0
,
scts
[
i
].
winx
,
scts
[
i
].
winy
,
0
,
0
,
0
,
0
);
...
@@ -2309,7 +2304,7 @@ static void test_multi_device(void)
...
@@ -2309,7 +2304,7 @@ static void test_multi_device(void)
ok
(
d3d9
!=
NULL
,
"Failed to create a d3d9 object.
\n
"
);
ok
(
d3d9
!=
NULL
,
"Failed to create a d3d9 object.
\n
"
);
if
(
!
d3d9
)
goto
fail
;
if
(
!
d3d9
)
goto
fail
;
hwnd1
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd1
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd1
!=
NULL
,
"Failed to create a window.
\n
"
);
ok
(
hwnd1
!=
NULL
,
"Failed to create a window.
\n
"
);
if
(
!
hwnd1
)
goto
fail
;
if
(
!
hwnd1
)
goto
fail
;
...
@@ -2331,7 +2326,7 @@ static void test_multi_device(void)
...
@@ -2331,7 +2326,7 @@ static void test_multi_device(void)
ok
(
d3d9
!=
NULL
,
"Failed to create a d3d9 object.
\n
"
);
ok
(
d3d9
!=
NULL
,
"Failed to create a d3d9 object.
\n
"
);
if
(
!
d3d9
)
goto
fail
;
if
(
!
d3d9
)
goto
fail
;
hwnd2
=
CreateWindow
(
"
stati
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
hwnd2
=
CreateWindow
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_OVERLAPPEDWINDOW
,
100
,
100
,
160
,
160
,
NULL
,
NULL
,
NULL
,
NULL
);
ok
(
hwnd2
!=
NULL
,
"Failed to create a window.
\n
"
);
ok
(
hwnd2
!=
NULL
,
"Failed to create a window.
\n
"
);
if
(
!
hwnd2
)
goto
fail
;
if
(
!
hwnd2
)
goto
fail
;
...
@@ -2835,7 +2830,7 @@ static void test_fpu_setup(void)
...
@@ -2835,7 +2830,7 @@ static void test_fpu_setup(void)
ok
(
!!
d3d9
,
"Failed to create a d3d9 object.
\n
"
);
ok
(
!!
d3d9
,
"Failed to create a d3d9 object.
\n
"
);
if
(
!
d3d9
)
return
;
if
(
!
d3d9
)
return
;
window
=
CreateWindowA
(
"
stati
c"
,
"d3d9_test"
,
WS_CAPTION
,
0
,
0
,
640
,
480
,
0
,
0
,
0
,
0
);
window
=
CreateWindowA
(
"
d3d9_test_w
c"
,
"d3d9_test"
,
WS_CAPTION
,
0
,
0
,
640
,
480
,
0
,
0
,
0
,
0
);
ok
(
!!
window
,
"Failed to create a window.
\n
"
);
ok
(
!!
window
,
"Failed to create a window.
\n
"
);
if
(
!
window
)
goto
done
;
if
(
!
window
)
goto
done
;
...
@@ -2887,10 +2882,16 @@ done:
...
@@ -2887,10 +2882,16 @@ done:
START_TEST
(
device
)
START_TEST
(
device
)
{
{
HMODULE
d3d9_handle
=
LoadLibraryA
(
"d3d9.dll"
);
HMODULE
d3d9_handle
=
LoadLibraryA
(
"d3d9.dll"
);
WNDCLASS
wc
=
{
0
};
wc
.
lpfnWndProc
=
DefWindowProc
;
wc
.
lpszClassName
=
"d3d9_test_wc"
;
RegisterClass
(
&
wc
);
if
(
!
d3d9_handle
)
if
(
!
d3d9_handle
)
{
{
skip
(
"Could not load d3d9.dll
\n
"
);
skip
(
"Could not load d3d9.dll
\n
"
);
return
;
goto
out
;
}
}
pDirect3DCreate9
=
(
void
*
)
GetProcAddress
(
d3d9_handle
,
"Direct3DCreate9"
);
pDirect3DCreate9
=
(
void
*
)
GetProcAddress
(
d3d9_handle
,
"Direct3DCreate9"
);
...
@@ -2901,7 +2902,7 @@ START_TEST(device)
...
@@ -2901,7 +2902,7 @@ START_TEST(device)
if
(
!
d3d9
)
if
(
!
d3d9
)
{
{
skip
(
"could not create D3D9 object
\n
"
);
skip
(
"could not create D3D9 object
\n
"
);
return
;
goto
out
;
}
}
IDirect3D9_Release
(
d3d9
);
IDirect3D9_Release
(
d3d9
);
...
@@ -2926,4 +2927,7 @@ START_TEST(device)
...
@@ -2926,4 +2927,7 @@ START_TEST(device)
test_wndproc
();
test_wndproc
();
test_wndproc_windowed
();
test_wndproc_windowed
();
}
}
out
:
UnregisterClassA
(
"d3d9_test_wc"
,
GetModuleHandleA
(
NULL
));
}
}
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