diff --git a/test data sets/.gitkeep b/executables/.gitkeep
similarity index 100%
rename from test data sets/.gitkeep
rename to executables/.gitkeep
diff --git a/executables/4C_22_linux.exe b/executables/4C_22_linux.exe
new file mode 100644
index 0000000000000000000000000000000000000000..a3a435351f843bd08a39866d77d63c7a02e22cce
Binary files /dev/null and b/executables/4C_22_linux.exe differ
diff --git a/executables/4C_22_windows.exe b/executables/4C_22_windows.exe
new file mode 100644
index 0000000000000000000000000000000000000000..6c9de9341e6d348fb4adfa6fe4fcc0d06320cdfc
Binary files /dev/null and b/executables/4C_22_windows.exe differ
diff --git a/test data sets/4C testing/.gitkeep b/source_code/version2.2_unix_linux/.gitkeep
similarity index 100%
rename from test data sets/4C testing/.gitkeep
rename to source_code/version2.2_unix_linux/.gitkeep
diff --git a/source_code/version2.2_unix_linux/4c22linux.tar b/source_code/version2.2_unix_linux/4c22linux.tar
new file mode 100644
index 0000000000000000000000000000000000000000..74b13b920884b85c1dafc73d780cdd3dee0a1a0b
Binary files /dev/null and b/source_code/version2.2_unix_linux/4c22linux.tar differ
diff --git a/source_code/version2.2_windows/4C_dialogs.fd b/source_code/version2.2_windows/4C_dialogs.fd
new file mode 100644
index 0000000000000000000000000000000000000000..6f886f57a0dedb612f1139c1c48390b59030d4b8
--- /dev/null
+++ b/source_code/version2.2_windows/4C_dialogs.fd
@@ -0,0 +1,250 @@
+!MS$FREEFORM
+! Microsoft Developer Studio generated include file.
+! Used by script1.rc
+!
+      integer, parameter :: IDD_4C                          = 101
+      integer, parameter :: IDD_4C_ctr                      = 102
+      integer, parameter :: IDD_4C_flags                    = 109
+      integer, parameter :: IDD_4C_files                    = 111
+      integer, parameter :: IDB_BITMAP3                     = 115
+      integer, parameter :: IDD_4C_out                      = 116
+      integer, parameter :: IDD_4C_yearly                   = 118
+      integer, parameter :: IDD_4C_daily                    = 119
+      integer, parameter :: IDD_4C_coh_yearly               = 120
+      integer, parameter :: IDD_4C_coh_daily                = 121
+      integer, parameter :: IDD_default_dir                 = 122
+      integer, parameter :: IDD_4C_default_dir              = 122
+      integer, parameter :: IDD_4C_main                     = 123
+      integer, parameter :: IDD_4C_ids                      = 126
+      integer, parameter :: IDB_BITMAP1                     = 131
+      integer, parameter :: IDC_STATIC_Control              = 1005
+      integer, parameter :: IDC_STATIC_4C                   = 1017
+      integer, parameter :: IDC_COMBO_runv                  = 1019
+      integer, parameter :: IDC_RADIO_ctrfile               = 1020
+      integer, parameter :: IDC_COMBO_runv3                 = 1020
+      integer, parameter :: IDC_RADIO_ctredit               = 1024
+      integer, parameter :: IDC_STATIC_simul                = 1034
+      integer, parameter :: IDC_STATIC_runv                 = 1036
+      integer, parameter :: IDC_STATIC_runnr                = 1037
+      integer, parameter :: IDC_STATIC_runv3                = 1038
+      integer, parameter :: IDC_EDIT_runnr                  = 1044
+      integer, parameter :: IDC_STATIC_runo                 = 1046
+      integer, parameter :: IDC_STATIC_runo3                = 1047
+      integer, parameter :: IDC_EDIT_yearn                  = 1048
+      integer, parameter :: IDC_EDIT_start                  = 1049
+      integer, parameter :: IDC_STATIC_yearn                = 1050
+      integer, parameter :: IDC_STATIC_start                = 1051
+      integer, parameter :: IDC_EDIT_patch                  = 1052
+      integer, parameter :: IDC_STATIC_patch                = 1053
+      integer, parameter :: IDC_STATIC_model                = 1055
+      integer, parameter :: IDC_EDIT_thickf                 = 1056
+      integer, parameter :: IDC_EDIT_timeph                 = 1057
+      integer, parameter :: IDC_STATIC_thickf               = 1058
+      integer, parameter :: IDC_STATIC_timeph               = 1059
+      integer, parameter :: IDC_STATIC_mort                 = 1060
+      integer, parameter :: IDC_STATIC_reg                  = 1061
+      integer, parameter :: IDC_STATIC_forska               = 1062
+      integer, parameter :: IDC_COMBO_mort                  = 1063
+      integer, parameter :: IDC_COMBO_reg                   = 1064
+      integer, parameter :: IDC_COMBO_forska                = 1065
+      integer, parameter :: IDC_STATIC_stand                = 1066
+      integer, parameter :: IDC_STATIC_sveg                 = 1067
+      integer, parameter :: IDC_STATIC_mg                   = 1068
+      integer, parameter :: IDC_STATIC_dis                  = 1069
+      integer, parameter :: IDC_STATIC_light                = 1070
+      integer, parameter :: IDC_STATIC_folhei               = 1071
+      integer, parameter :: IDC_COMBO_stand                 = 1072
+      integer, parameter :: IDC_COMBO_sveg                  = 1073
+      integer, parameter :: IDC_COMBO_mg                    = 1074
+      integer, parameter :: IDC_COMBO_dis                   = 1075
+      integer, parameter :: IDC_COMBO_light                 = 1076
+      integer, parameter :: IDC_COMBO_folhei                = 1077
+      integer, parameter :: IDC_COMBO_volfunc               = 1078
+      integer, parameter :: IDC_STATIC_volfunc              = 1079
+      integer, parameter :: IDC_STATIC_resp                 = 1080
+      integer, parameter :: IDC_STATIC_limi                 = 1081
+      integer, parameter :: IDC_STATIC_decomp               = 1082
+      integer, parameter :: IDC_STATIC_sign                 = 1083
+      integer, parameter :: IDC_STATIC_wred                 = 1084
+      integer, parameter :: IDC_STATIC_wurz                 = 1085
+      integer, parameter :: IDC_STATIC_cond                 = 1086
+      integer, parameter :: IDC_COMBO_resp                  = 1088
+      integer, parameter :: IDC_COMBO_limi                  = 1089
+      integer, parameter :: IDC_COMBO_decomp                = 1090
+      integer, parameter :: IDC_COMBO_sign                  = 1091
+      integer, parameter :: IDC_COMBO_wred                  = 1092
+      integer, parameter :: IDC_COMBO_wurz                  = 1093
+      integer, parameter :: IDC_COMBO_cond                  = 1094
+      integer, parameter :: IDC_COMBO_int                   = 1095
+      integer, parameter :: IDC_COMBO_eva                   = 1096
+      integer, parameter :: IDC_STATIC_int                  = 1097
+      integer, parameter :: IDC_STATIC_eva                  = 1098
+      integer, parameter :: IDC_STATIC_sort                 = 1099
+      integer, parameter :: IDC_STATIC_wpm                  = 1100
+      integer, parameter :: IDC_COMBO_CO2                   = 1101
+      integer, parameter :: IDC_STATIC_stat                 = 1102
+      integer, parameter :: IDC_COMBO_sort                  = 1103
+      integer, parameter :: IDC_COMBO_wpm                   = 1104
+      integer, parameter :: IDC_COMBO_stat                  = 1105
+      integer, parameter :: IDC_STATIC_files                = 1108
+      integer, parameter :: IDC_STATIC_specpar              = 1109
+      integer, parameter :: IDC_EDIT_specpar                = 1110
+      integer, parameter :: IDC_BUTTON_specpar              = 1111
+      integer, parameter :: IDC_BUTTON_ini                  = 1112
+      integer, parameter :: IDC_BUTTON_sop                  = 1113
+      integer, parameter :: IDC_STATIC_dir1                 = 1114
+      integer, parameter :: IDC_STATIC_dirin                = 1114
+      integer, parameter :: IDC_BUTTON_soi                  = 1115
+      integer, parameter :: IDC_STATIC_dirout               = 1115
+      integer, parameter :: IDC_STATIC_soi                  = 1116
+      integer, parameter :: IDC_EDIT_sop                    = 1117
+      integer, parameter :: IDC_EDIT_soi                    = 1118
+      integer, parameter :: IDC_STATIC_ini                  = 1119
+      integer, parameter :: IDC_EDIT_ini                    = 1120
+      integer, parameter :: IDC_STATIC_ini1                 = 1121
+      integer, parameter :: IDC_BUTTON_man                  = 1122
+      integer, parameter :: IDC_STATIC_cli                  = 1123
+      integer, parameter :: IDC_BUTTON_dep                  = 1124
+      integer, parameter :: IDC_BUTTON_red                  = 1125
+      integer, parameter :: IDC_BUTTON_lit                  = 1126
+      integer, parameter :: IDC_RADIO_single_ini            = 1127
+      integer, parameter :: IDC_RADIO_multi_ini             = 1128
+      integer, parameter :: IDC_STATIC_standid              = 1129
+      integer, parameter :: IDC_EDIT_standid                = 1130
+      integer, parameter :: IDC_STATIC_man                  = 1131
+      integer, parameter :: IDC_EDIT_man                    = 1132
+      integer, parameter :: IDC_STATIC_dep                  = 1133
+      integer, parameter :: IDC_EDIT_dep                    = 1134
+      integer, parameter :: IDC_EDIT_red                    = 1135
+      integer, parameter :: IDC_EDIT_lit                    = 1136
+      integer, parameter :: IDC_STATIC_lit                  = 1137
+      integer, parameter :: IDC_STATIC_red                  = 1138
+      integer, parameter :: IDC_STATIC_dir2                 = 1139
+      integer, parameter :: IDC_STATIC_sop                  = 1140
+      integer, parameter :: IDC_EDIT_cli                    = 1141
+      integer, parameter :: IDC_BUTTON_cli                  = 1142
+      integer, parameter :: IDC_BUTTON_DIR                  = 1143
+      integer, parameter :: IDC_EDIT_cli2                   = 1144
+      integer, parameter :: IDC_EDIT_DIR                    = 1144
+      integer, parameter :: IDC_EDIT_DIR_IN                 = 1144
+      integer, parameter :: IDC_STATIC_name                 = 1145
+      integer, parameter :: IDC_EDIT_DIR_OUT                = 1145
+      integer, parameter :: IDC_EDIT_sitename               = 1147
+      integer, parameter :: IDC_STATIC_nameall              = 1148
+      integer, parameter :: IDC_RADIO_idy                   = 1149
+      integer, parameter :: IDC_RADIO_idn                   = 1150
+      integer, parameter :: IDC_STATIC_id                   = 1151
+      integer, parameter :: IDC_STATIC_year                 = 1152
+      integer, parameter :: IDC_STATIC_yearly               = 1153
+      integer, parameter :: IDC_CHECK_y1                    = 1161
+      integer, parameter :: IDC_CHECK_y2                    = 1162
+      integer, parameter :: IDC_CHECK_y3                    = 1163
+      integer, parameter :: IDC_CHECK_y4                    = 1164
+      integer, parameter :: IDC_CHECK_y5                    = 1165
+      integer, parameter :: IDC_CHECK_y6                    = 1166
+      integer, parameter :: IDC_CHECK_y7                    = 1167
+      integer, parameter :: IDC_CHECK_y8                    = 1168
+      integer, parameter :: IDC_CHECK_y9                    = 1169
+      integer, parameter :: IDC_CHECK_y10                   = 1170
+      integer, parameter :: IDC_CHECK_y11                   = 1171
+      integer, parameter :: IDC_CHECK_y12                   = 1172
+      integer, parameter :: IDC_CHECK_y13                   = 1173
+      integer, parameter :: IDC_CHECK_y14                   = 1174
+      integer, parameter :: IDC_CHECK_y15                   = 1175
+      integer, parameter :: IDC_CHECK_y16                   = 1176
+      integer, parameter :: IDC_CHECK_y17                   = 1177
+      integer, parameter :: IDC_CHECK_y18                   = 1178
+      integer, parameter :: IDC_CHECK_y19                   = 1179
+      integer, parameter :: IDC_CHECK_y20                   = 1180
+      integer, parameter :: IDC_CHECK_y21                   = 1181
+      integer, parameter :: IDC_CHECK_y22                   = 1182
+      integer, parameter :: IDC_CHECK_y23                   = 1183
+      integer, parameter :: IDC_CHECK_y24                   = 1184
+      integer, parameter :: IDC_CHECK_y25                   = 1185
+      integer, parameter :: IDC_CHECK_y26                   = 1186
+      integer, parameter :: IDC_CHECK_y27                   = 1187
+      integer, parameter :: IDC_CHECK_y28                   = 1188
+      integer, parameter :: IDC_STATIC_yfile                = 1189
+      integer, parameter :: IDC_BUTTON_yearly               = 1190
+      integer, parameter :: IDC_CHECK_y29                   = 1190
+      integer, parameter :: IDC_BUTTON_daily                = 1191
+      integer, parameter :: IDC_CHECK_y30                   = 1191
+      integer, parameter :: IDC_BUTTON_coh_yearly           = 1192
+      integer, parameter :: IDC_CHECK_y31                   = 1192
+      integer, parameter :: IDC_BUTTON_coh_daily            = 1193
+      integer, parameter :: IDC_CHECK_y32                   = 1193
+      integer, parameter :: IDC_STATIC_choice_out           = 1194
+      integer, parameter :: IDC_CHECK_y33                   = 1194
+      integer, parameter :: IDC_STATIC_daily                = 1195
+      integer, parameter :: IDC_CHECK_y34                   = 1195
+      integer, parameter :: IDC_COMBO_daily                 = 1196
+      integer, parameter :: IDC_CHECK_y35                   = 1196
+      integer, parameter :: IDC_STATIC_coh_daily            = 1197
+      integer, parameter :: IDC_CHECK_y36                   = 1197
+      integer, parameter :: IDC_COMBO_coh_daily             = 1198
+      integer, parameter :: IDC_CHECK_y37                   = 1198
+      integer, parameter :: IDC_CHECK_y38                   = 1199
+      integer, parameter :: IDC_CHECK_y39                   = 1200
+      integer, parameter :: IDC_CHECK_y40                   = 1201
+      integer, parameter :: IDC_CHECK_y41                   = 1202
+      integer, parameter :: IDC_CHECK_y42                   = 1203
+      integer, parameter :: IDC_COMBO_coh_yearly            = 1204
+      integer, parameter :: IDC_STATIC_coh_yearly           = 1205
+      integer, parameter :: IDC_STATIC_SUM                  = 1206
+      integer, parameter :: IDC_CHECK_y43                   = 1206
+      integer, parameter :: ID4C_BUTTON_OK                  = 1208
+      integer, parameter :: ID_CTR_BUTTON_FLAGS             = 1209
+      integer, parameter :: ID_CTR_BUTTON_OK                = 1210
+      integer, parameter :: ID_FILES_BUTTON_OK              = 1211
+      integer, parameter :: ID_CTR_BUTTON_FILES             = 1212
+      integer, parameter :: ID_OUT_BUTTON_BACK              = 1213
+      integer, parameter :: ID_START                        = 1214
+      integer, parameter :: ID_SAVE                         = 1215
+      integer, parameter :: ID_YEARLY_BUTTON_OK             = 1216
+      integer, parameter :: ID_DAILY_BUTTON_OK              = 1217
+      integer, parameter :: ID_YEARLYCOH_BUTTON_OK          = 1218
+      integer, parameter :: ID_FLAGS_BUTTON_OK              = 1219
+      integer, parameter :: ID_DAILYCOH_BUTTON_OK           = 1220
+      integer, parameter :: ID_CTR_BUTTON_RUNNR             = 1221
+      integer, parameter :: ID_DEFAULT_DIR_BUTTON_OK        = 1222
+      integer, parameter :: ID_START_4C                     = 1226
+      integer, parameter :: IDSTOP                          = 1227
+      integer, parameter :: IDC_RADIO_start                 = 1229
+      integer, parameter :: IDC_RADIO_start_dir             = 1230
+      integer, parameter :: IDC_RADIO_edit                  = 1231
+      integer, parameter :: ID_CANCEL_FLAGS                 = 1232
+      integer, parameter :: IDC_EDIT_ID                     = 1233
+      integer, parameter :: ID_CANCEL_FILES                 = 1233
+      integer, parameter :: IDC_COMBO_standid               = 1234
+      integer, parameter :: ID_CANCEL_IDS                   = 1234
+      integer, parameter :: IDC_STATIC_spinup               = 1235
+      integer, parameter :: IDC_EDIT_spinup                 = 1236
+      integer, parameter :: IDC_EDIT_wpm                    = 1236
+      integer, parameter :: ID_CANCEL_OUTF                  = 1236
+      integer, parameter :: IDC_BUTTON_spinup               = 1237
+      integer, parameter :: IDC_STATIC_mes                  = 1237
+      integer, parameter :: ID_CTR_BUTTON_IDS               = 1238
+      integer, parameter :: IDC_EDIT_mes                    = 1238
+      integer, parameter :: IDC_COMBO_yearly                = 1239
+      integer, parameter :: IDC_COMBO_sum                   = 1240
+      integer, parameter :: ID_IDS_BUTTON_OK                = 1242
+      integer, parameter :: ID_YEARLY_BUTTON_SELECT         = 1248
+      integer, parameter :: ID_YEARLY_BUTTON_DESELECT       = 1249
+      integer, parameter :: IDC_BUTTON_wpm                  = 1250
+      integer, parameter :: ID_DAILY_BUTTON_SELECT          = 1250
+      integer, parameter :: IDC_BUTTON_mes                  = 1251
+      integer, parameter :: ID_DAILY_BUTTON_DESELECT        = 1251
+      integer, parameter :: ID_DAILYCOH_BUTTON_SELECT       = 1252
+      integer, parameter :: ID_DAILYCOH_BUTTON_DESELECT     = 1253
+      integer, parameter :: ID_YEARLYCOH_BUTTON_SELECT      = 1254
+      integer, parameter :: ID_YEARLYCOH_BUTTON_DESELECT    = 1255
+      integer, parameter :: IDC_CHECK_y44                   = 1256
+      integer, parameter :: IDC_STATIC_CO2                  = 1256
+      integer, parameter :: IDC_CHECK_y45                   = 1257
+      integer, parameter :: IDC_CHECK_y46                   = 1258
+      integer, parameter :: IDC_CHECK_y47                   = 1259
+      integer, parameter :: IDC_CHECK_y48                   = 1260
+      integer, parameter :: IDC_CHECK_y49                   = 1261
+      integer, parameter :: IDC_REBAR1                      = 1262
+      integer, parameter :: IDC_CHECK_y50                   = 1001
+      integer, parameter :: IDC_CHECK_y51                   = 1002
diff --git a/source_code/version2.2_windows/4C_dialogs.h b/source_code/version2.2_windows/4C_dialogs.h
new file mode 100644
index 0000000000000000000000000000000000000000..ac1e4a62807b777f46320a91e0b8786ed0838547
--- /dev/null
+++ b/source_code/version2.2_windows/4C_dialogs.h
@@ -0,0 +1,227 @@
+#ifndef IDC_STATIC
+#define IDC_STATIC (-1)
+#endif
+
+#define IDD_4C_ctr                              102
+#define IDD_4C_flags                            109
+#define IDD_4C_files                            111
+#define IDD_4C_out                              116
+#define IDD_4C_yearly                           118
+#define IDD_4C_daily                            119
+#define IDD_4C_coh_yearly                       120
+#define IDD_4C_coh_daily                        121
+#define IDD_4C_default_dir                      122
+#define IDD_4C_main                             123
+#define IDD_4C_ids                              126
+#define IDB_BITMAP1                             131
+#define IDD_DIALOG1                             136
+#define IDC_STATIC_day                          1000
+#define IDC_CHECK_y50                           1001
+#define IDC_CHECK_y51                           1002
+#define IDC_REBAR1                              1002
+#define IDC_STATIC_pic                          1003
+#define IDC_STATIC_Control                      1005
+#define IDC_STATIC_4C                           1017
+#define IDC_COMBO_runv                          1019
+#define IDC_COMBO_runv3                         1020
+#define IDC_STATIC_simul                        1034
+#define IDC_STATIC_runv                         1036
+#define IDC_STATIC_runnr                        1037
+#define IDC_STATIC_runv3                        1038
+#define IDC_EDIT_runnr                          1044
+#define IDC_STATIC_runo                         1046
+#define IDC_STATIC_runo3                        1047
+#define IDC_EDIT_yearn                          1048
+#define IDC_EDIT_start                          1049
+#define IDC_STATIC_yearn                        1050
+#define IDC_STATIC_start                        1051
+#define IDC_EDIT_patch                          1052
+#define IDC_STATIC_patch                        1053
+#define IDC_STATIC_model                        1055
+#define IDC_EDIT_thickf                         1056
+#define IDC_EDIT_timeph                         1057
+#define IDC_STATIC_thickf                       1058
+#define IDC_STATIC_timeph                       1059
+#define IDC_STATIC_mort                         1060
+#define IDC_STATIC_reg                          1061
+#define IDC_STATIC_forska                       1062
+#define IDC_COMBO_mort                          1063
+#define IDC_COMBO_reg                           1064
+#define IDC_COMBO_forska                        1065
+#define IDC_STATIC_stand                        1066
+#define IDC_STATIC_sveg                         1067
+#define IDC_STATIC_mg                           1068
+#define IDC_STATIC_dis                          1069
+#define IDC_STATIC_light                        1070
+#define IDC_STATIC_folhei                       1071
+#define IDC_COMBO_stand                         1072
+#define IDC_COMBO_sveg                          1073
+#define IDC_COMBO_mg                            1074
+#define IDC_COMBO_dis                           1075
+#define IDC_COMBO_light                         1076
+#define IDC_COMBO_folhei                        1077
+#define IDC_COMBO_volfunc                       1078
+#define IDC_STATIC_volfunc                      1079
+#define IDC_STATIC_resp                         1080
+#define IDC_STATIC_limi                         1081
+#define IDC_STATIC_decomp                       1082
+#define IDC_STATIC_sign                         1083
+#define IDC_STATIC_wred                         1084
+#define IDC_STATIC_wurz                         1085
+#define IDC_STATIC_cond                         1086
+#define IDC_COMBO_resp                          1088
+#define IDC_COMBO_limi                          1089
+#define IDC_COMBO_decomp                        1090
+#define IDC_COMBO_sign                          1091
+#define IDC_COMBO_wred                          1092
+#define IDC_COMBO_wurz                          1093
+#define IDC_COMBO_cond                          1094
+#define IDC_COMBO_int                           1095
+#define IDC_COMBO_eva                           1096
+#define IDC_STATIC_int                          1097
+#define IDC_STATIC_eva                          1098
+#define IDC_STATIC_sort                         1099
+#define IDC_STATIC_wpm                          1100
+#define IDC_COMBO_CO2                           1101
+#define IDC_STATIC_stat                         1102
+#define IDC_COMBO_sort                          1103
+#define IDC_COMBO_wpm                           1104
+#define IDC_COMBO_stat                          1105
+#define IDC_STATIC_files                        1108
+#define IDC_STATIC_specpar                      1109
+#define IDC_EDIT_specpar                        1110
+#define IDC_BUTTON_specpar                      1111
+#define IDC_BUTTON_ini                          1112
+#define IDC_BUTTON_sop                          1113
+#define IDC_STATIC_dirin                        1114
+#define IDC_BUTTON_soi                          1115
+#define IDC_STATIC_dirout                       1115
+#define IDC_STATIC_soi                          1116
+#define IDC_EDIT_sop                            1117
+#define IDC_EDIT_soi                            1118
+#define IDC_STATIC_ini                          1119
+#define IDC_EDIT_ini                            1120
+#define IDC_STATIC_ini1                         1121
+#define IDC_BUTTON_man                          1122
+#define IDC_STATIC_cli                          1123
+#define IDC_BUTTON_dep                          1124
+#define IDC_BUTTON_red                          1125
+#define IDC_BUTTON_lit                          1126
+#define IDC_STATIC_standid                      1129
+#define IDC_EDIT_standid                        1130
+#define IDC_STATIC_man                          1131
+#define IDC_EDIT_man                            1132
+#define IDC_STATIC_dep                          1133
+#define IDC_EDIT_dep                            1134
+#define IDC_EDIT_red                            1135
+#define IDC_EDIT_lit                            1136
+#define IDC_STATIC_lit                          1137
+#define IDC_STATIC_red                          1138
+#define IDC_STATIC_sop                          1140
+#define IDC_EDIT_cli                            1141
+#define IDC_BUTTON_cli                          1142
+#define IDC_EDIT_DIR_IN                         1144
+#define IDC_EDIT_DIR_OUT                        1145
+#define IDC_STATIC_year                         1152
+#define IDC_CHECK_y1                            1161
+#define IDC_CHECK_y2                            1162
+#define IDC_CHECK_y3                            1163
+#define IDC_CHECK_y4                            1164
+#define IDC_CHECK_y5                            1165
+#define IDC_CHECK_y6                            1166
+#define IDC_CHECK_y7                            1167
+#define IDC_CHECK_y8                            1168
+#define IDC_CHECK_y9                            1169
+#define IDC_CHECK_y10                           1170
+#define IDC_CHECK_y11                           1171
+#define IDC_CHECK_y12                           1172
+#define IDC_CHECK_y13                           1173
+#define IDC_CHECK_y14                           1174
+#define IDC_CHECK_y15                           1175
+#define IDC_CHECK_y16                           1176
+#define IDC_CHECK_y17                           1177
+#define IDC_CHECK_y18                           1178
+#define IDC_CHECK_y19                           1179
+#define IDC_CHECK_y20                           1180
+#define IDC_CHECK_y21                           1181
+#define IDC_CHECK_y22                           1182
+#define IDC_CHECK_y23                           1183
+#define IDC_CHECK_y24                           1184
+#define IDC_CHECK_y25                           1185
+#define IDC_CHECK_y26                           1186
+#define IDC_CHECK_y27                           1187
+#define IDC_CHECK_y28                           1188
+#define IDC_STATIC_yfile                        1189
+#define IDC_BUTTON_yearly                       1190
+#define IDC_CHECK_y29                           1190
+#define IDC_BUTTON_daily                        1191
+#define IDC_CHECK_y30                           1191
+#define IDC_BUTTON_coh_yearly                   1192
+#define IDC_CHECK_y31                           1192
+#define IDC_BUTTON_coh_daily                    1193
+#define IDC_CHECK_y32                           1193
+#define IDC_CHECK_y33                           1194
+#define IDC_STATIC_choice_out                   1194
+#define IDC_CHECK_y34                           1195
+#define IDC_CHECK_y35                           1196
+#define IDC_COMBO_daily                         1196
+#define IDC_CHECK_y36                           1197
+#define IDC_CHECK_y37                           1198
+#define IDC_COMBO_coh_daily                     1198
+#define IDC_CHECK_y38                           1199
+#define IDC_CHECK_y39                           1200
+#define IDC_CHECK_y40                           1201
+#define IDC_CHECK_y41                           1202
+#define IDC_CHECK_y42                           1203
+#define IDC_COMBO_coh_yearly                    1204
+#define IDC_CHECK_y43                           1206
+#define IDC_STATIC_SUM                          1206
+#define ID_CTR_BUTTON_FLAGS                     1209
+#define ID_CTR_BUTTON_OK                        1210
+#define ID_FILES_BUTTON_OK                      1211
+#define ID_CTR_BUTTON_FILES                     1212
+#define ID_OUT_BUTTON_BACK                      1213
+#define ID_START                                1214
+#define ID_SAVE                                 1215
+#define ID_YEARLY_BUTTON_OK                     1216
+#define ID_DAILY_BUTTON_OK                      1217
+#define ID_YEARLYCOH_BUTTON_OK                  1218
+#define ID_FLAGS_BUTTON_OK                      1219
+#define ID_DAILYCOH_BUTTON_OK                   1220
+#define ID_CTR_BUTTON_RUNNR                     1221
+#define ID_DEFAULT_DIR_BUTTON_OK                1222
+#define ID_START_4C                             1226
+#define IDSTOP                                  1227
+#define IDC_RADIO_start                         1229
+#define IDC_RADIO_edit                          1231
+#define ID_CANCEL_FLAGS                         1232
+#define IDC_EDIT_ID                             1233
+#define ID_CANCEL_FILES                         1233
+#define IDC_COMBO_standid                       1234
+#define ID_CANCEL_IDS                           1234
+#define IDC_STATIC_spinup                       1235
+#define IDC_EDIT_wpm                            1236
+#define ID_CANCEL_OUTF                          1236
+#define IDC_STATIC_mes                          1237
+#define IDC_EDIT_mes                            1238
+#define ID_CTR_BUTTON_IDS                       1238
+#define IDC_COMBO_yearly                        1239
+#define IDC_COMBO_sum                           1240
+#define ID_IDS_BUTTON_OK                        1242
+#define ID_YEARLY_BUTTON_SELECT                 1248
+#define ID_YEARLY_BUTTON_DESELECT               1249
+#define IDC_BUTTON_wpm                          1250
+#define ID_DAILY_BUTTON_SELECT                  1250
+#define IDC_BUTTON_mes                          1251
+#define ID_DAILY_BUTTON_DESELECT                1251
+#define ID_DAILYCOH_BUTTON_SELECT               1252
+#define ID_DAILYCOH_BUTTON_DESELECT             1253
+#define ID_YEARLYCOH_BUTTON_SELECT              1254
+#define ID_YEARLYCOH_BUTTON_DESELECT            1255
+#define IDC_CHECK_y44                           1256
+#define IDC_STATIC_CO2                          1256
+#define IDC_CHECK_y45                           1257
+#define IDC_CHECK_y46                           1258
+#define IDC_CHECK_y47                           1259
+#define IDC_CHECK_y48                           1260
+#define IDC_CHECK_y49                           1261
diff --git a/source_code/version2.2_windows/4c_logo_klein.bmp b/source_code/version2.2_windows/4c_logo_klein.bmp
new file mode 100644
index 0000000000000000000000000000000000000000..d3d2562e5f3692ed38e3324397c60c3ae5bfe025
Binary files /dev/null and b/source_code/version2.2_windows/4c_logo_klein.bmp differ
diff --git a/source_code/version2.2_windows/4c_logo_klein.ico b/source_code/version2.2_windows/4c_logo_klein.ico
new file mode 100644
index 0000000000000000000000000000000000000000..d3d2562e5f3692ed38e3324397c60c3ae5bfe025
Binary files /dev/null and b/source_code/version2.2_windows/4c_logo_klein.ico differ
diff --git a/source_code/version2.2_windows/COMMCTRL.H b/source_code/version2.2_windows/COMMCTRL.H
new file mode 100644
index 0000000000000000000000000000000000000000..6574a413eb1e85059788bb2648eb691d12ea0dc5
--- /dev/null
+++ b/source_code/version2.2_windows/COMMCTRL.H
@@ -0,0 +1,5911 @@
+
+/*****************************************************************************\
+*                                                                             *
+* commctrl.h - - Interface for the Windows Common Controls                    *
+*                                                                             *
+* Version 1.2                                                                 *
+*                                                                             *
+* Copyright 1991-1998, Microsoft Corp.      All rights reserved.          *
+*                                                                             *
+\*****************************************************************************/
+
+
+#ifndef _INC_COMMCTRL
+#define _INC_COMMCTRL
+
+#ifndef _WIN32_IE
+#define _WIN32_IE 0x0400
+#else
+#if (_WIN32_IE < 0x0400) && defined(_WIN32_WINNT) && (_WIN32_WINNT >= 0x0500)
+#error _WIN32_IE setting conflicts with _WIN32_WINNT setting
+#endif
+#endif
+
+#ifndef _HRESULT_DEFINED
+#define _HRESULT_DEFINED
+typedef LONG HRESULT;
+#endif // _HRESULT_DEFINED
+
+#ifndef NOUSER
+
+
+//
+// Define API decoration for direct importing of DLL references.
+//
+#ifndef WINCOMMCTRLAPI
+#if !defined(_COMCTL32_) && defined(_WIN32)
+#define WINCOMMCTRLAPI DECLSPEC_IMPORT
+#else
+#define WINCOMMCTRLAPI
+#endif
+#endif // WINCOMMCTRLAPI
+
+//
+// For compilers that don't support nameless unions
+//
+#ifndef DUMMYUNIONNAME
+#ifdef NONAMELESSUNION
+#define DUMMYUNIONNAME          u
+#define DUMMYUNIONNAME2         u2
+#define DUMMYUNIONNAME3         u3
+#define DUMMYUNIONNAME4         u4
+#define DUMMYUNIONNAME5         u5
+#else
+#define DUMMYUNIONNAME
+#define DUMMYUNIONNAME2
+#define DUMMYUNIONNAME3
+#define DUMMYUNIONNAME4
+#define DUMMYUNIONNAME5
+#endif
+#endif // DUMMYUNIONNAME
+
+#ifdef _WIN32
+#include <pshpack1.h>
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//
+// Users of this header may define any number of these constants to avoid
+// the definitions of each functional group.
+//
+//    NOTOOLBAR    Customizable bitmap-button toolbar control.
+//    NOUPDOWN     Up and Down arrow increment/decrement control.
+//    NOSTATUSBAR  Status bar control.
+//    NOMENUHELP   APIs to help manage menus, especially with a status bar.
+//    NOTRACKBAR   Customizable column-width tracking control.
+//    NODRAGLIST   APIs to make a listbox source and sink drag&drop actions.
+//    NOPROGRESS   Progress gas gauge.
+//    NOHOTKEY     HotKey control
+//    NOHEADER     Header bar control.
+//    NOIMAGEAPIS  ImageList apis.
+//    NOLISTVIEW   ListView control.
+//    NOTREEVIEW   TreeView control.
+//    NOTABCONTROL Tab control.
+//    NOANIMATE    Animate control.
+//
+//=============================================================================
+
+#include <prsht.h>
+
+#ifndef SNDMSG
+#ifdef __cplusplus
+#ifndef _MAC
+#define SNDMSG ::SendMessage
+#else
+#define SNDMSG ::AfxSendMessage
+#endif
+#else
+#ifndef _MAC
+#define SNDMSG SendMessage
+#else
+#define SNDMSG AfxSendMessage
+#endif //_MAC
+#endif
+#endif // ifndef SNDMSG
+
+#ifdef _MAC
+#ifndef RC_INVOKED
+#ifndef _WLM_NOFORCE_LIBS
+
+#ifndef _WLMDLL
+    #ifdef _DEBUG
+        #pragma comment(lib, "comctld.lib")
+    #else
+        #pragma comment(lib, "comctl.lib")
+    #endif
+    #pragma comment(linker, "/macres:comctl.rsc")
+    #else
+    #ifdef _DEBUG
+        #pragma comment(lib, "msvcctld.lib")
+    #else
+        #pragma comment(lib, "msvcctl.lib")
+    #endif
+#endif // _WLMDLL
+
+#endif // _WLM_NOFORCE_LIBS
+#endif // RC_INVOKED
+#endif //_MAC
+
+WINCOMMCTRLAPI void WINAPI InitCommonControls(void);
+
+#if (_WIN32_IE >= 0x0300)
+typedef struct tagINITCOMMONCONTROLSEX {
+    DWORD dwSize;             // size of this structure
+    DWORD dwICC;              // flags indicating which classes to be initialized
+} INITCOMMONCONTROLSEX, *LPINITCOMMONCONTROLSEX;
+#define ICC_LISTVIEW_CLASSES 0x00000001 // listview, header
+#define ICC_TREEVIEW_CLASSES 0x00000002 // treeview, tooltips
+#define ICC_BAR_CLASSES      0x00000004 // toolbar, statusbar, trackbar, tooltips
+#define ICC_TAB_CLASSES      0x00000008 // tab, tooltips
+#define ICC_UPDOWN_CLASS     0x00000010 // updown
+#define ICC_PROGRESS_CLASS   0x00000020 // progress
+#define ICC_HOTKEY_CLASS     0x00000040 // hotkey
+#define ICC_ANIMATE_CLASS    0x00000080 // animate
+#define ICC_WIN95_CLASSES    0x000000FF
+#define ICC_DATE_CLASSES     0x00000100 // month picker, date picker, time picker, updown
+#define ICC_USEREX_CLASSES   0x00000200 // comboex
+#define ICC_COOL_CLASSES     0x00000400 // rebar (coolbar) control
+#if (_WIN32_IE >= 0x0400)
+#define ICC_INTERNET_CLASSES 0x00000800
+#define ICC_PAGESCROLLER_CLASS 0x00001000   // page scroller
+#define ICC_NATIVEFNTCTL_CLASS 0x00002000   // native font control
+#endif
+WINCOMMCTRLAPI BOOL WINAPI InitCommonControlsEx(LPINITCOMMONCONTROLSEX);
+#endif      // _WIN32_IE >= 0x0300
+
+#define ODT_HEADER              100
+#define ODT_TAB                 101
+#define ODT_LISTVIEW            102
+
+
+//====== Ranges for control message IDs =======================================
+
+#define LVM_FIRST               0x1000      // ListView messages
+#define TV_FIRST                0x1100      // TreeView messages
+#define HDM_FIRST               0x1200      // Header messages
+#define TCM_FIRST               0x1300      // Tab control messages
+
+#if (_WIN32_IE >= 0x0400)
+#define PGM_FIRST               0x1400      // Pager control messages
+#define CCM_FIRST               0x2000      // Common control shared messages
+
+
+#define CCM_SETBKCOLOR          (CCM_FIRST + 1) // lParam is bkColor
+
+typedef struct tagCOLORSCHEME {
+   DWORD            dwSize;
+   COLORREF         clrBtnHighlight;       // highlight color
+   COLORREF         clrBtnShadow;          // shadow color
+} COLORSCHEME, *LPCOLORSCHEME;
+
+#define CCM_SETCOLORSCHEME      (CCM_FIRST + 2) // lParam is color scheme
+#define CCM_GETCOLORSCHEME      (CCM_FIRST + 3) // fills in COLORSCHEME pointed to by lParam
+#define CCM_GETDROPTARGET       (CCM_FIRST + 4)
+#define CCM_SETUNICODEFORMAT    (CCM_FIRST + 5)
+#define CCM_GETUNICODEFORMAT    (CCM_FIRST + 6)
+
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+// for tooltips
+#define INFOTIPSIZE 1024
+#endif
+
+//====== WM_NOTIFY Macros =====================================================
+
+#define HANDLE_WM_NOTIFY(hwnd, wParam, lParam, fn) \
+    (fn)((hwnd), (int)(wParam), (NMHDR FAR*)(lParam))
+#define FORWARD_WM_NOTIFY(hwnd, idFrom, pnmhdr, fn) \
+    (LRESULT)(fn)((hwnd), WM_NOTIFY, (WPARAM)(int)(idFrom), (LPARAM)(NMHDR FAR*)(pnmhdr))
+
+
+//====== Generic WM_NOTIFY notification codes =================================
+
+#define NM_OUTOFMEMORY          (NM_FIRST-1)
+#define NM_CLICK                (NM_FIRST-2)    // uses NMCLICK struct
+#define NM_DBLCLK               (NM_FIRST-3)
+#define NM_RETURN               (NM_FIRST-4)
+#define NM_RCLICK               (NM_FIRST-5)    // uses NMCLICK struct
+#define NM_RDBLCLK              (NM_FIRST-6)
+#define NM_SETFOCUS             (NM_FIRST-7)
+#define NM_KILLFOCUS            (NM_FIRST-8)
+#if (_WIN32_IE >= 0x0300)
+#define NM_CUSTOMDRAW           (NM_FIRST-12)
+#define NM_HOVER                (NM_FIRST-13)
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define NM_NCHITTEST            (NM_FIRST-14)   // uses NMMOUSE struct
+#define NM_KEYDOWN              (NM_FIRST-15)   // uses NMKEY struct
+#define NM_RELEASEDCAPTURE      (NM_FIRST-16)
+#define NM_SETCURSOR            (NM_FIRST-17)   // uses NMMOUSE struct
+#define NM_CHAR                 (NM_FIRST-18)   // uses NMCHAR struct
+#endif
+
+
+#ifndef CCSIZEOF_STRUCT
+#define CCSIZEOF_STRUCT(structname, member)  (((int)((LPBYTE)(&((structname*)0)->member) - ((LPBYTE)((structname*)0)))) + sizeof(((structname*)0)->member))
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+//====== Generic WM_NOTIFY notification structures ============================
+
+typedef struct tagNMMOUSE {
+    NMHDR   hdr;
+    DWORD   dwItemSpec;
+    DWORD   dwItemData;
+    POINT   pt;
+    DWORD   dwHitInfo; // any specifics about where on the item or control the mouse is
+} NMMOUSE, FAR* LPNMMOUSE;
+
+typedef NMMOUSE NMCLICK;
+typedef LPNMMOUSE LPNMCLICK;
+
+// Generic structure to request an object of a specific type.
+
+typedef struct tagNMOBJECTNOTIFY {
+    NMHDR   hdr;
+    int     iItem;
+#ifdef __IID_DEFINED__
+    const IID *piid;
+#else
+    const void *piid;
+#endif
+    void *pObject;
+    HRESULT hResult;
+    DWORD dwFlags;    // control specific flags (hints as to where in iItem it hit)
+} NMOBJECTNOTIFY, *LPNMOBJECTNOTIFY;
+
+// Generic structure for a key
+
+typedef struct tagNMKEY
+{
+    NMHDR hdr;
+    UINT  nVKey;
+    UINT  uFlags;
+} NMKEY, FAR *LPNMKEY;
+
+// Generic structure for a character
+
+typedef struct tagNMCHAR {
+    NMHDR   hdr;
+    UINT    ch;
+    DWORD   dwItemPrev;     // Item previously selected 
+    DWORD   dwItemNext;     // Item to be selected
+} NMCHAR, FAR* LPNMCHAR;
+
+#endif           // _WIN32_IE >= 0x0400
+
+//====== WM_NOTIFY codes (NMHDR.code values) ==================================
+
+#define NM_FIRST                (0U-  0U)       // generic to all controls
+#define NM_LAST                 (0U- 99U)
+
+#define LVN_FIRST               (0U-100U)       // listview
+#define LVN_LAST                (0U-199U)
+
+#define HDN_FIRST               (0U-300U)       // header
+#define HDN_LAST                (0U-399U)
+
+#define TVN_FIRST               (0U-400U)       // treeview
+#define TVN_LAST                (0U-499U)
+
+#define TTN_FIRST               (0U-520U)       // tooltips
+#define TTN_LAST                (0U-549U)
+
+#define TCN_FIRST               (0U-550U)       // tab control
+#define TCN_LAST                (0U-580U)
+
+// Shell reserved               (0U-580U) -  (0U-589U)
+
+#define CDN_FIRST               (0U-601U)       // common dialog (new)
+#define CDN_LAST                (0U-699U)
+
+#define TBN_FIRST               (0U-700U)       // toolbar
+#define TBN_LAST                (0U-720U)
+
+#define UDN_FIRST               (0U-721)        // updown
+#define UDN_LAST                (0U-740)
+#if (_WIN32_IE >= 0x0300)
+#define MCN_FIRST               (0U-750U)       // monthcal
+#define MCN_LAST                (0U-759U)
+
+#define DTN_FIRST               (0U-760U)       // datetimepick
+#define DTN_LAST                (0U-799U)
+
+#define CBEN_FIRST              (0U-800U)       // combo box ex
+#define CBEN_LAST               (0U-830U)
+
+#define RBN_FIRST               (0U-831U)       // rebar
+#define RBN_LAST                (0U-859U)
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+#define IPN_FIRST               (0U-860U)       // internet address
+#define IPN_LAST                (0U-879U)       // internet address
+
+#define SBN_FIRST               (0U-880U)       // status bar
+#define SBN_LAST                (0U-899U)
+
+#define PGN_FIRST               (0U-900U)       // Pager Control
+#define PGN_LAST                (0U-950U)
+
+#endif
+
+#define MSGF_COMMCTRL_BEGINDRAG     0x4200
+#define MSGF_COMMCTRL_SIZEHEADER    0x4201
+#define MSGF_COMMCTRL_DRAGSELECT    0x4202
+#define MSGF_COMMCTRL_TOOLBARCUST   0x4203
+
+#if (_WIN32_IE >= 0x0300)
+//==================== CUSTOM DRAW ==========================================
+
+
+// custom draw return flags
+// values under 0x00010000 are reserved for global custom draw values.
+// above that are for specific controls
+#define CDRF_DODEFAULT          0x00000000
+#define CDRF_NEWFONT            0x00000002
+#define CDRF_SKIPDEFAULT        0x00000004
+
+
+#define CDRF_NOTIFYPOSTPAINT    0x00000010
+#define CDRF_NOTIFYITEMDRAW     0x00000020
+#if (_WIN32_IE >= 0x0400)
+#define CDRF_NOTIFYSUBITEMDRAW  0x00000020  // flags are the same, we can distinguish by context
+#endif
+#define CDRF_NOTIFYPOSTERASE    0x00000040
+
+// drawstage flags
+// values under 0x00010000 are reserved for global custom draw values.
+// above that are for specific controls
+#define CDDS_PREPAINT           0x00000001
+#define CDDS_POSTPAINT          0x00000002
+#define CDDS_PREERASE           0x00000003
+#define CDDS_POSTERASE          0x00000004
+// the 0x000010000 bit means it's individual item specific
+#define CDDS_ITEM               0x00010000
+#define CDDS_ITEMPREPAINT       (CDDS_ITEM | CDDS_PREPAINT)
+#define CDDS_ITEMPOSTPAINT      (CDDS_ITEM | CDDS_POSTPAINT)
+#define CDDS_ITEMPREERASE       (CDDS_ITEM | CDDS_PREERASE)
+#define CDDS_ITEMPOSTERASE      (CDDS_ITEM | CDDS_POSTERASE)
+#if (_WIN32_IE >= 0x0400)
+#define CDDS_SUBITEM            0x00020000
+#endif
+
+
+// itemState flags
+#define CDIS_SELECTED       0x0001
+#define CDIS_GRAYED         0x0002
+#define CDIS_DISABLED       0x0004
+#define CDIS_CHECKED        0x0008
+#define CDIS_FOCUS          0x0010
+#define CDIS_DEFAULT        0x0020
+#define CDIS_HOT            0x0040
+#define CDIS_MARKED         0x0080
+#define CDIS_INDETERMINATE  0x0100
+
+typedef struct tagNMCUSTOMDRAWINFO
+{
+    NMHDR hdr;
+    DWORD dwDrawStage;
+    HDC hdc;
+    RECT rc;
+    DWORD dwItemSpec;  // this is control specific, but it's how to specify an item.  valid only with CDDS_ITEM bit set
+    UINT  uItemState;
+    LPARAM lItemlParam;
+} NMCUSTOMDRAW, FAR * LPNMCUSTOMDRAW;
+
+
+
+typedef struct tagNMTTCUSTOMDRAW
+{
+    NMCUSTOMDRAW nmcd;
+    UINT uDrawFlags;
+} NMTTCUSTOMDRAW, FAR * LPNMTTCUSTOMDRAW;
+
+#endif      // _WIN32_IE >= 0x0300
+
+
+//====== IMAGE APIS ===========================================================
+
+#ifndef NOIMAGEAPIS
+
+#define CLR_NONE                0xFFFFFFFFL
+#define CLR_DEFAULT             0xFF000000L
+
+struct _IMAGELIST;
+typedef struct _IMAGELIST NEAR* HIMAGELIST;
+
+#if (_WIN32_IE >= 0x0300)
+typedef struct _IMAGELISTDRAWPARAMS {
+    DWORD       cbSize;
+    HIMAGELIST  himl;
+    int         i;
+    HDC         hdcDst;
+    int         x;
+    int         y;
+    int         cx;
+    int         cy;
+    int         xBitmap;        // x offest from the upperleft of bitmap
+    int         yBitmap;        // y offset from the upperleft of bitmap
+    COLORREF    rgbBk;
+    COLORREF    rgbFg;
+    UINT        fStyle;
+    DWORD       dwRop;
+} IMAGELISTDRAWPARAMS, FAR * LPIMAGELISTDRAWPARAMS;
+#endif      // _WIN32_IE >= 0x0300
+
+#define ILC_MASK                0x0001
+#define ILC_COLOR               0x0000
+#define ILC_COLORDDB            0x00FE
+#define ILC_COLOR4              0x0004
+#define ILC_COLOR8              0x0008
+#define ILC_COLOR16             0x0010
+#define ILC_COLOR24             0x0018
+#define ILC_COLOR32             0x0020
+#define ILC_PALETTE             0x0800      // (not implemented)
+
+WINCOMMCTRLAPI HIMAGELIST  WINAPI ImageList_Create(int cx, int cy, UINT flags, int cInitial, int cGrow);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_Destroy(HIMAGELIST himl);
+WINCOMMCTRLAPI int         WINAPI ImageList_GetImageCount(HIMAGELIST himl);
+#if (_WIN32_IE >= 0x0300)
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_SetImageCount(HIMAGELIST himl, UINT uNewCount);
+#endif
+WINCOMMCTRLAPI int         WINAPI ImageList_Add(HIMAGELIST himl, HBITMAP hbmImage, HBITMAP hbmMask);
+WINCOMMCTRLAPI int         WINAPI ImageList_ReplaceIcon(HIMAGELIST himl, int i, HICON hicon);
+WINCOMMCTRLAPI COLORREF    WINAPI ImageList_SetBkColor(HIMAGELIST himl, COLORREF clrBk);
+WINCOMMCTRLAPI COLORREF    WINAPI ImageList_GetBkColor(HIMAGELIST himl);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_SetOverlayImage(HIMAGELIST himl, int iImage, int iOverlay);
+
+#define     ImageList_AddIcon(himl, hicon) ImageList_ReplaceIcon(himl, -1, hicon)
+
+#define ILD_NORMAL              0x0000
+#define ILD_TRANSPARENT         0x0001
+#define ILD_MASK                0x0010
+#define ILD_IMAGE               0x0020
+#if (_WIN32_IE >= 0x0300)
+#define ILD_ROP                 0x0040
+#endif
+#define ILD_BLEND25             0x0002
+#define ILD_BLEND50             0x0004
+#define ILD_OVERLAYMASK         0x0F00
+#define INDEXTOOVERLAYMASK(i)   ((i) << 8)
+
+#define ILD_SELECTED            ILD_BLEND50
+#define ILD_FOCUS               ILD_BLEND25
+#define ILD_BLEND               ILD_BLEND50
+#define CLR_HILIGHT             CLR_DEFAULT
+
+WINCOMMCTRLAPI BOOL WINAPI ImageList_Draw(HIMAGELIST himl, int i, HDC hdcDst, int x, int y, UINT fStyle);
+
+
+#ifdef _WIN32
+
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_Replace(HIMAGELIST himl, int i, HBITMAP hbmImage, HBITMAP hbmMask);
+WINCOMMCTRLAPI int         WINAPI ImageList_AddMasked(HIMAGELIST himl, HBITMAP hbmImage, COLORREF crMask);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_DrawEx(HIMAGELIST himl, int i, HDC hdcDst, int x, int y, int dx, int dy, COLORREF rgbBk, COLORREF rgbFg, UINT fStyle);
+#if (_WIN32_IE >= 0x0300)
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_DrawIndirect(IMAGELISTDRAWPARAMS* pimldp);
+#endif
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_Remove(HIMAGELIST himl, int i);
+WINCOMMCTRLAPI HICON       WINAPI ImageList_GetIcon(HIMAGELIST himl, int i, UINT flags);
+WINCOMMCTRLAPI HIMAGELIST  WINAPI ImageList_LoadImageA(HINSTANCE hi, LPCSTR lpbmp, int cx, int cGrow, COLORREF crMask, UINT uType, UINT uFlags);
+WINCOMMCTRLAPI HIMAGELIST  WINAPI ImageList_LoadImageW(HINSTANCE hi, LPCWSTR lpbmp, int cx, int cGrow, COLORREF crMask, UINT uType, UINT uFlags);
+
+#ifdef UNICODE
+#define ImageList_LoadImage     ImageList_LoadImageW
+#else
+#define ImageList_LoadImage     ImageList_LoadImageA
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define ILCF_MOVE   (0x00000000)
+#define ILCF_SWAP   (0x00000001)
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_Copy(HIMAGELIST himlDst, int iDst, HIMAGELIST himlSrc, int iSrc, UINT uFlags);
+#endif
+
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_BeginDrag(HIMAGELIST himlTrack, int iTrack, int dxHotspot, int dyHotspot);
+WINCOMMCTRLAPI void        WINAPI ImageList_EndDrag();
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_DragEnter(HWND hwndLock, int x, int y);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_DragLeave(HWND hwndLock);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_DragMove(int x, int y);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_SetDragCursorImage(HIMAGELIST himlDrag, int iDrag, int dxHotspot, int dyHotspot);
+
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_DragShowNolock(BOOL fShow);
+WINCOMMCTRLAPI HIMAGELIST  WINAPI ImageList_GetDragImage(POINT FAR* ppt,POINT FAR* pptHotspot);
+
+#define     ImageList_RemoveAll(himl) ImageList_Remove(himl, -1)
+#define     ImageList_ExtractIcon(hi, himl, i) ImageList_GetIcon(himl, i, 0)
+#define     ImageList_LoadBitmap(hi, lpbmp, cx, cGrow, crMask) ImageList_LoadImage(hi, lpbmp, cx, cGrow, crMask, IMAGE_BITMAP, 0)
+
+#ifdef __IStream_INTERFACE_DEFINED__
+WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_Read(LPSTREAM pstm);
+WINCOMMCTRLAPI BOOL       WINAPI ImageList_Write(HIMAGELIST himl, LPSTREAM pstm);
+#endif
+
+typedef struct _IMAGEINFO
+{
+    HBITMAP hbmImage;
+    HBITMAP hbmMask;
+    int     Unused1;
+    int     Unused2;
+    RECT    rcImage;
+} IMAGEINFO, FAR *LPIMAGEINFO;
+
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_GetIconSize(HIMAGELIST himl, int FAR *cx, int FAR *cy);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_SetIconSize(HIMAGELIST himl, int cx, int cy);
+WINCOMMCTRLAPI BOOL        WINAPI ImageList_GetImageInfo(HIMAGELIST himl, int i, IMAGEINFO FAR* pImageInfo);
+WINCOMMCTRLAPI HIMAGELIST  WINAPI ImageList_Merge(HIMAGELIST himl1, int i1, HIMAGELIST himl2, int i2, int dx, int dy);
+#if (_WIN32_IE >= 0x0400)
+WINCOMMCTRLAPI HIMAGELIST  WINAPI ImageList_Duplicate(HIMAGELIST himl);
+#endif
+
+
+#endif
+
+#endif
+
+
+//====== HEADER CONTROL =======================================================
+
+#ifndef NOHEADER
+
+#ifdef _WIN32
+#define WC_HEADERA              "SysHeader32"
+#define WC_HEADERW              L"SysHeader32"
+
+#ifdef UNICODE
+#define WC_HEADER               WC_HEADERW
+#else
+#define WC_HEADER               WC_HEADERA
+#endif
+
+#else
+#define WC_HEADER               "SysHeader"
+#endif
+
+// begin_r_commctrl
+
+#define HDS_HORZ                0x0000
+#define HDS_BUTTONS             0x0002
+#if (_WIN32_IE >= 0x0300)
+#define HDS_HOTTRACK            0x0004
+#endif
+#define HDS_HIDDEN              0x0008
+
+#if (_WIN32_IE >= 0x0300)
+#define HDS_DRAGDROP            0x0040
+#define HDS_FULLDRAG            0x0080
+#endif
+
+// end_r_commctrl
+
+#if (_WIN32_IE >= 0x0300)
+#define HD_ITEMA HDITEMA
+#define HD_ITEMW HDITEMW
+#else
+#define HDITEMW  HD_ITEMW
+#define HDITEMA  HD_ITEMA
+#endif
+#define HD_ITEM HDITEM
+
+typedef struct _HD_ITEMA
+{
+    UINT    mask;
+    int     cxy;
+    LPSTR   pszText;
+    HBITMAP hbm;
+    int     cchTextMax;
+    int     fmt;
+    LPARAM  lParam;
+#if (_WIN32_IE >= 0x0300)
+    int     iImage;        // index of bitmap in ImageList
+    int     iOrder;        // where to draw this item
+#endif
+} HDITEMA, FAR * LPHDITEMA;
+
+#define HDITEMA_V1_SIZE CCSIZEOF_STRUCT(HDITEMA, lParam)
+#define HDITEMW_V1_SIZE CCSIZEOF_STRUCT(HDITEMW, lParam)
+
+
+typedef struct _HD_ITEMW
+{
+    UINT    mask;
+    int     cxy;
+    LPWSTR   pszText;
+    HBITMAP hbm;
+    int     cchTextMax;
+    int     fmt;
+    LPARAM  lParam;
+#if (_WIN32_IE >= 0x0300)
+    int     iImage;        // index of bitmap in ImageList
+    int     iOrder;
+#endif
+} HDITEMW, FAR * LPHDITEMW;
+
+#ifdef UNICODE
+#define HDITEM HDITEMW
+#define LPHDITEM LPHDITEMW
+#define HDITEM_V1_SIZE HDITEMW_V1_SIZE
+#else
+#define HDITEM HDITEMA
+#define LPHDITEM LPHDITEMA
+#define HDITEM_V1_SIZE HDITEMA_V1_SIZE
+#endif
+
+
+#define HDI_WIDTH               0x0001
+#define HDI_HEIGHT              HDI_WIDTH
+#define HDI_TEXT                0x0002
+#define HDI_FORMAT              0x0004
+#define HDI_LPARAM              0x0008
+#define HDI_BITMAP              0x0010
+#if (_WIN32_IE >= 0x0300)
+#define HDI_IMAGE               0x0020
+#define HDI_DI_SETITEM          0x0040
+#define HDI_ORDER               0x0080
+#endif
+
+#define HDF_LEFT                0
+#define HDF_RIGHT               1
+#define HDF_CENTER              2
+#define HDF_JUSTIFYMASK         0x0003
+#define HDF_RTLREADING          4
+
+#define HDF_OWNERDRAW           0x8000
+#define HDF_STRING              0x4000
+#define HDF_BITMAP              0x2000
+#if (_WIN32_IE >= 0x0300)
+#define HDF_BITMAP_ON_RIGHT     0x1000
+#define HDF_IMAGE               0x0800
+#endif
+
+#define HDM_GETITEMCOUNT        (HDM_FIRST + 0)
+#define Header_GetItemCount(hwndHD) \
+    (int)SNDMSG((hwndHD), HDM_GETITEMCOUNT, 0, 0L)
+
+
+#define HDM_INSERTITEMA         (HDM_FIRST + 1)
+#define HDM_INSERTITEMW         (HDM_FIRST + 10)
+
+#ifdef UNICODE
+#define HDM_INSERTITEM          HDM_INSERTITEMW
+#else
+#define HDM_INSERTITEM          HDM_INSERTITEMA
+#endif
+
+#define Header_InsertItem(hwndHD, i, phdi) \
+    (int)SNDMSG((hwndHD), HDM_INSERTITEM, (WPARAM)(int)(i), (LPARAM)(const HD_ITEM FAR*)(phdi))
+
+
+#define HDM_DELETEITEM          (HDM_FIRST + 2)
+#define Header_DeleteItem(hwndHD, i) \
+    (BOOL)SNDMSG((hwndHD), HDM_DELETEITEM, (WPARAM)(int)(i), 0L)
+
+
+#define HDM_GETITEMA            (HDM_FIRST + 3)
+#define HDM_GETITEMW            (HDM_FIRST + 11)
+
+#ifdef UNICODE
+#define HDM_GETITEM             HDM_GETITEMW
+#else
+#define HDM_GETITEM             HDM_GETITEMA
+#endif
+
+#define Header_GetItem(hwndHD, i, phdi) \
+    (BOOL)SNDMSG((hwndHD), HDM_GETITEM, (WPARAM)(int)(i), (LPARAM)(HD_ITEM FAR*)(phdi))
+
+
+#define HDM_SETITEMA            (HDM_FIRST + 4)
+#define HDM_SETITEMW            (HDM_FIRST + 12)
+
+#ifdef UNICODE
+#define HDM_SETITEM             HDM_SETITEMW
+#else
+#define HDM_SETITEM             HDM_SETITEMA
+#endif
+
+#define Header_SetItem(hwndHD, i, phdi) \
+    (BOOL)SNDMSG((hwndHD), HDM_SETITEM, (WPARAM)(int)(i), (LPARAM)(const HD_ITEM FAR*)(phdi))
+
+#if (_WIN32_IE >= 0x0300)
+#define HD_LAYOUT  HDLAYOUT
+#else
+#define HDLAYOUT   HD_LAYOUT
+#endif
+
+typedef struct _HD_LAYOUT
+{
+    RECT FAR* prc;
+    WINDOWPOS FAR* pwpos;
+} HDLAYOUT, FAR *LPHDLAYOUT;
+
+
+#define HDM_LAYOUT              (HDM_FIRST + 5)
+#define Header_Layout(hwndHD, playout) \
+    (BOOL)SNDMSG((hwndHD), HDM_LAYOUT, 0, (LPARAM)(HD_LAYOUT FAR*)(playout))
+
+
+#define HHT_NOWHERE             0x0001
+#define HHT_ONHEADER            0x0002
+#define HHT_ONDIVIDER           0x0004
+#define HHT_ONDIVOPEN           0x0008
+#define HHT_ABOVE               0x0100
+#define HHT_BELOW               0x0200
+#define HHT_TORIGHT             0x0400
+#define HHT_TOLEFT              0x0800
+
+#if (_WIN32_IE >= 0x0300)
+#define HD_HITTESTINFO HDHITTESTINFO
+#else
+#define HDHITTESTINFO  HD_HITTESTINFO
+#endif
+
+typedef struct _HD_HITTESTINFO
+{
+    POINT pt;
+    UINT flags;
+    int iItem;
+} HDHITTESTINFO, FAR *LPHDHITTESTINFO;
+
+
+#define HDM_HITTEST             (HDM_FIRST + 6)
+
+#if (_WIN32_IE >= 0x0300)
+
+#define HDM_GETITEMRECT         (HDM_FIRST + 7)
+#define Header_GetItemRect(hwnd, iItem, lprc) \
+        (BOOL)SNDMSG((hwnd), HDM_GETITEMRECT, (WPARAM)iItem, (LPARAM)lprc)
+
+#define HDM_SETIMAGELIST        (HDM_FIRST + 8)
+#define Header_SetImageList(hwnd, himl) \
+        (HIMAGELIST)SNDMSG((hwnd), HDM_SETIMAGELIST, 0, (LPARAM)himl)
+
+#define HDM_GETIMAGELIST        (HDM_FIRST + 9)
+#define Header_GetImageList(hwnd) \
+        (HIMAGELIST)SNDMSG((hwnd), HDM_GETIMAGELIST, 0, 0)
+
+
+#define HDM_ORDERTOINDEX        (HDM_FIRST + 15)
+#define Header_OrderToIndex(hwnd, i) \
+        (int)SNDMSG((hwnd), HDM_ORDERTOINDEX, (WPARAM)i, 0)
+
+#define HDM_CREATEDRAGIMAGE     (HDM_FIRST + 16)  // wparam = which item (by index)
+#define Header_CreateDragImage(hwnd, i) \
+        (HIMAGELIST)SNDMSG((hwnd), HDM_CREATEDRAGIMAGE, (WPARAM)i, 0)
+
+#define HDM_GETORDERARRAY       (HDM_FIRST + 17)
+#define Header_GetOrderArray(hwnd, iCount, lpi) \
+        (BOOL)SNDMSG((hwnd), HDM_GETORDERARRAY, (WPARAM)iCount, (LPARAM)lpi)
+
+#define HDM_SETORDERARRAY       (HDM_FIRST + 18)
+#define Header_SetOrderArray(hwnd, iCount, lpi) \
+        (BOOL)SNDMSG((hwnd), HDM_SETORDERARRAY, (WPARAM)iCount, (LPARAM)lpi)
+// lparam = int array of size HDM_GETITEMCOUNT
+// the array specifies the order that all items should be displayed.
+// e.g.  { 2, 0, 1}
+// says the index 2 item should be shown in the 0ths position
+//      index 0 should be shown in the 1st position
+//      index 1 should be shown in the 2nd position
+
+
+#define HDM_SETHOTDIVIDER          (HDM_FIRST + 19)
+#define Header_SetHotDivider(hwnd, fPos, dw) \
+        (int)SNDMSG((hwnd), HDM_SETHOTDIVIDER, (WPARAM)fPos, (LPARAM)dw)
+// convenience message for external dragdrop
+// wParam = BOOL  specifying whether the lParam is a dwPos of the cursor
+//              position or the index of which divider to hotlight
+// lParam = depends on wParam  (-1 and wParm = FALSE turns off hotlight)
+#endif      // _WIN32_IE >= 0x0300
+
+#if (_WIN32_IE >= 0x0400)
+#define HDM_SETUNICODEFORMAT   CCM_SETUNICODEFORMAT
+#define Header_SetUnicodeFormat(hwnd, fUnicode)  \
+    (BOOL)SNDMSG((hwnd), HDM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0)
+
+#define HDM_GETUNICODEFORMAT   CCM_GETUNICODEFORMAT
+#define Header_GetUnicodeFormat(hwnd)  \
+    (BOOL)SNDMSG((hwnd), HDM_GETUNICODEFORMAT, 0, 0)
+#endif
+
+#define HDN_ITEMCHANGINGA       (HDN_FIRST-0)
+#define HDN_ITEMCHANGINGW       (HDN_FIRST-20)
+#define HDN_ITEMCHANGEDA        (HDN_FIRST-1)
+#define HDN_ITEMCHANGEDW        (HDN_FIRST-21)
+#define HDN_ITEMCLICKA          (HDN_FIRST-2)
+#define HDN_ITEMCLICKW          (HDN_FIRST-22)
+#define HDN_ITEMDBLCLICKA       (HDN_FIRST-3)
+#define HDN_ITEMDBLCLICKW       (HDN_FIRST-23)
+#define HDN_DIVIDERDBLCLICKA    (HDN_FIRST-5)
+#define HDN_DIVIDERDBLCLICKW    (HDN_FIRST-25)
+#define HDN_BEGINTRACKA         (HDN_FIRST-6)
+#define HDN_BEGINTRACKW         (HDN_FIRST-26)
+#define HDN_ENDTRACKA           (HDN_FIRST-7)
+#define HDN_ENDTRACKW           (HDN_FIRST-27)
+#define HDN_TRACKA              (HDN_FIRST-8)
+#define HDN_TRACKW              (HDN_FIRST-28)
+#if (_WIN32_IE >= 0x0300)
+#define HDN_GETDISPINFOA        (HDN_FIRST-9)
+#define HDN_GETDISPINFOW        (HDN_FIRST-29)
+#define HDN_BEGINDRAG           (HDN_FIRST-10)
+#define HDN_ENDDRAG             (HDN_FIRST-11)
+#endif
+
+#ifdef UNICODE
+#define HDN_ITEMCHANGING         HDN_ITEMCHANGINGW
+#define HDN_ITEMCHANGED          HDN_ITEMCHANGEDW
+#define HDN_ITEMCLICK            HDN_ITEMCLICKW
+#define HDN_ITEMDBLCLICK         HDN_ITEMDBLCLICKW
+#define HDN_DIVIDERDBLCLICK      HDN_DIVIDERDBLCLICKW
+#define HDN_BEGINTRACK           HDN_BEGINTRACKW
+#define HDN_ENDTRACK             HDN_ENDTRACKW
+#define HDN_TRACK                HDN_TRACKW
+#if (_WIN32_IE >= 0x0300)
+#define HDN_GETDISPINFO          HDN_GETDISPINFOW
+#endif
+#else
+#define HDN_ITEMCHANGING         HDN_ITEMCHANGINGA
+#define HDN_ITEMCHANGED          HDN_ITEMCHANGEDA
+#define HDN_ITEMCLICK            HDN_ITEMCLICKA
+#define HDN_ITEMDBLCLICK         HDN_ITEMDBLCLICKA
+#define HDN_DIVIDERDBLCLICK      HDN_DIVIDERDBLCLICKA
+#define HDN_BEGINTRACK           HDN_BEGINTRACKA
+#define HDN_ENDTRACK             HDN_ENDTRACKA
+#define HDN_TRACK                HDN_TRACKA
+#if (_WIN32_IE >= 0x0300)
+#define HDN_GETDISPINFO          HDN_GETDISPINFOA
+#endif
+#endif
+
+
+
+#if (_WIN32_IE >= 0x0300)
+#define HD_NOTIFYA              NMHEADERA
+#define HD_NOTIFYW              NMHEADERW
+#else
+#define tagNMHEADERA            _HD_NOTIFY
+#define NMHEADERA               HD_NOTIFYA
+#define tagHMHEADERW            _HD_NOTIFYW
+#define NMHEADERW               HD_NOTIFYW
+#endif
+#define HD_NOTIFY               NMHEADER
+
+typedef struct tagNMHEADERA
+{
+    NMHDR   hdr;
+    int     iItem;
+    int     iButton;
+    HDITEMA FAR* pitem;
+}  NMHEADERA, FAR* LPNMHEADERA;
+
+
+typedef struct tagNMHEADERW
+{
+    NMHDR   hdr;
+    int     iItem;
+    int     iButton;
+    HDITEMW FAR* pitem;
+} NMHEADERW, FAR* LPNMHEADERW;
+
+#ifdef UNICODE
+#define NMHEADER                NMHEADERW
+#define LPNMHEADER              LPNMHEADERW
+#else
+#define NMHEADER                NMHEADERA
+#define LPNMHEADER              LPNMHEADERA
+#endif
+
+typedef struct tagNMHDDISPINFOW
+{
+    NMHDR   hdr;
+    int     iItem;
+    UINT    mask;
+    LPWSTR  pszText;
+    int     cchTextMax;
+    int     iImage;
+    LPARAM  lParam;
+} NMHDDISPINFOW, FAR* LPNMHDDISPINFOW;
+
+typedef struct tagNMHDDISPINFOA
+{
+    NMHDR   hdr;
+    int     iItem;
+    UINT    mask;
+    LPSTR   pszText;
+    int     cchTextMax;
+    int     iImage;
+    LPARAM  lParam;
+} NMHDDISPINFOA, FAR* LPNMHDDISPINFOA;
+
+
+#ifdef UNICODE
+#define NMHDDISPINFO            NMHDDISPINFOW
+#define LPNMHDDISPINFO          LPNMHDDISPINFOW
+#else
+#define NMHDDISPINFO            NMHDDISPINFOA
+#define LPNMHDDISPINFO          LPNMHDDISPINFOA
+#endif
+
+#endif      // NOHEADER
+
+
+//====== TOOLBAR CONTROL ======================================================
+
+#ifndef NOTOOLBAR
+
+#ifdef _WIN32
+#define TOOLBARCLASSNAMEW       L"ToolbarWindow32"
+#define TOOLBARCLASSNAMEA       "ToolbarWindow32"
+
+#ifdef  UNICODE
+#define TOOLBARCLASSNAME        TOOLBARCLASSNAMEW
+#else
+#define TOOLBARCLASSNAME        TOOLBARCLASSNAMEA
+#endif
+
+#else
+#define TOOLBARCLASSNAME        "ToolbarWindow"
+#endif
+
+typedef struct _TBBUTTON {
+    int iBitmap;
+    int idCommand;
+    BYTE fsState;
+    BYTE fsStyle;
+#ifdef _WIN32
+    BYTE bReserved[2];
+#endif
+    DWORD dwData;
+    int iString;
+} TBBUTTON, NEAR* PTBBUTTON, FAR* LPTBBUTTON;
+typedef const TBBUTTON FAR* LPCTBBUTTON;
+
+
+typedef struct _COLORMAP {
+    COLORREF from;
+    COLORREF to;
+} COLORMAP, FAR* LPCOLORMAP;
+
+WINCOMMCTRLAPI HWND WINAPI CreateToolbarEx(HWND hwnd, DWORD ws, UINT wID, int nBitmaps,
+                        HINSTANCE hBMInst, UINT wBMID, LPCTBBUTTON lpButtons,
+                        int iNumButtons, int dxButton, int dyButton,
+                        int dxBitmap, int dyBitmap, UINT uStructSize);
+
+WINCOMMCTRLAPI HBITMAP WINAPI CreateMappedBitmap(HINSTANCE hInstance, int idBitmap,
+                                  UINT wFlags, LPCOLORMAP lpColorMap,
+                                  int iNumMaps);
+
+#define CMB_MASKED              0x02
+
+#define TBSTATE_CHECKED         0x01
+#define TBSTATE_PRESSED         0x02
+#define TBSTATE_ENABLED         0x04
+#define TBSTATE_HIDDEN          0x08
+#define TBSTATE_INDETERMINATE   0x10
+#define TBSTATE_WRAP            0x20
+#if (_WIN32_IE >= 0x0300)
+#define TBSTATE_ELLIPSES        0x40
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TBSTATE_MARKED          0x80
+#endif
+
+#define TBSTYLE_BUTTON          0x0000
+#define TBSTYLE_SEP             0x0001
+#define TBSTYLE_CHECK           0x0002
+#define TBSTYLE_GROUP           0x0004
+#define TBSTYLE_CHECKGROUP      (TBSTYLE_GROUP | TBSTYLE_CHECK)
+#if (_WIN32_IE >= 0x0300)
+#define TBSTYLE_DROPDOWN        0x0008
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TBSTYLE_AUTOSIZE        0x0010 // automatically calculate the cx of the button
+#define TBSTYLE_NOPREFIX        0x0020 // if this button should not have accel prefix
+#endif
+
+#define TBSTYLE_TOOLTIPS        0x0100
+#define TBSTYLE_WRAPABLE        0x0200
+#define TBSTYLE_ALTDRAG         0x0400
+#if (_WIN32_IE >= 0x0300)
+#define TBSTYLE_FLAT            0x0800
+#define TBSTYLE_LIST            0x1000
+#define TBSTYLE_CUSTOMERASE     0x2000
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TBSTYLE_REGISTERDROP    0x4000
+#define TBSTYLE_TRANSPARENT     0x8000
+#define TBSTYLE_EX_DRAWDDARROWS 0x00000001
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+// Custom Draw Structure
+typedef struct _NMTBCUSTOMDRAW {
+    NMCUSTOMDRAW nmcd;
+    HBRUSH hbrMonoDither;
+    HBRUSH hbrLines;                // For drawing lines on buttons
+    HPEN hpenLines;                 // For drawing lines on buttons
+
+    COLORREF clrText;               // Color of text
+    COLORREF clrMark;               // Color of text bk when marked. (only if TBSTATE_MARKED)
+    COLORREF clrTextHighlight;      // Color of text when highlighted
+    COLORREF clrBtnFace;            // Background of the button
+    COLORREF clrBtnHighlight;       // 3D highlight
+    COLORREF clrHighlightHotTrack;  // In conjunction with fHighlightHotTrack
+                                    // will cause button to highlight like a menu
+    RECT rcText;                    // Rect for text
+
+    int nStringBkMode;
+    int nHLStringBkMode;
+} NMTBCUSTOMDRAW, * LPNMTBCUSTOMDRAW;
+
+// Toolbar custom draw return flags
+#define TBCDRF_NOEDGES              0x00010000  // Don't draw button edges
+#define TBCDRF_HILITEHOTTRACK       0x00020000  // Use color of the button bk when hottracked
+#define TBCDRF_NOOFFSET             0x00040000  // Don't offset button if pressed
+#define TBCDRF_NOMARK               0x00080000  // Don't draw default highlight of image/text for TBSTATE_MARKED
+#define TBCDRF_NOETCHEDEFFECT       0x00100000  // Don't draw etched effect for disabled items
+
+#endif
+
+#define TB_ENABLEBUTTON         (WM_USER + 1)
+#define TB_CHECKBUTTON          (WM_USER + 2)
+#define TB_PRESSBUTTON          (WM_USER + 3)
+#define TB_HIDEBUTTON           (WM_USER + 4)
+#define TB_INDETERMINATE        (WM_USER + 5)
+#if (_WIN32_IE >= 0x0400)
+#define TB_MARKBUTTON           (WM_USER + 6)
+#endif
+#define TB_ISBUTTONENABLED      (WM_USER + 9)
+#define TB_ISBUTTONCHECKED      (WM_USER + 10)
+#define TB_ISBUTTONPRESSED      (WM_USER + 11)
+#define TB_ISBUTTONHIDDEN       (WM_USER + 12)
+#define TB_ISBUTTONINDETERMINATE (WM_USER + 13)
+#if (_WIN32_IE >= 0x0400)
+#define TB_ISBUTTONHIGHLIGHTED  (WM_USER + 14)
+#endif
+#define TB_SETSTATE             (WM_USER + 17)
+#define TB_GETSTATE             (WM_USER + 18)
+#define TB_ADDBITMAP            (WM_USER + 19)
+
+#ifdef _WIN32
+typedef struct tagTBADDBITMAP {
+        HINSTANCE       hInst;
+        UINT            nID;
+} TBADDBITMAP, *LPTBADDBITMAP;
+
+#define HINST_COMMCTRL          ((HINSTANCE)-1)
+#define IDB_STD_SMALL_COLOR     0
+#define IDB_STD_LARGE_COLOR     1
+#define IDB_VIEW_SMALL_COLOR    4
+#define IDB_VIEW_LARGE_COLOR    5
+#if (_WIN32_IE >= 0x0300)
+#define IDB_HIST_SMALL_COLOR    8
+#define IDB_HIST_LARGE_COLOR    9
+#endif
+
+// icon indexes for standard bitmap
+
+#define STD_CUT                 0
+#define STD_COPY                1
+#define STD_PASTE               2
+#define STD_UNDO                3
+#define STD_REDOW               4
+#define STD_DELETE              5
+#define STD_FILENEW             6
+#define STD_FILEOPEN            7
+#define STD_FILESAVE            8
+#define STD_PRINTPRE            9
+#define STD_PROPERTIES          10
+#define STD_HELP                11
+#define STD_FIND                12
+#define STD_REPLACE             13
+#define STD_PRINT               14
+
+// icon indexes for standard view bitmap
+
+#define VIEW_LARGEICONS         0
+#define VIEW_SMALLICONS         1
+#define VIEW_LIST               2
+#define VIEW_DETAILS            3
+#define VIEW_SORTNAME           4
+#define VIEW_SORTSIZE           5
+#define VIEW_SORTDATE           6
+#define VIEW_SORTTYPE           7
+#define VIEW_PARENTFOLDER       8
+#define VIEW_NETCONNECT         9
+#define VIEW_NETDISCONNECT      10
+#define VIEW_NEWFOLDER          11
+#if (_WIN32_IE >= 0x0400)
+#define VIEW_VIEWMENU           12
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define HIST_BACK               0
+#define HIST_FORWARD            1
+#define HIST_FAVORITES          2
+#define HIST_ADDTOFAVORITES     3
+#define HIST_VIEWTREE           4
+#endif
+
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+#define TB_ADDBUTTONSA          (WM_USER + 20)
+#define TB_INSERTBUTTONA        (WM_USER + 21)
+#else
+#define TB_ADDBUTTONS           (WM_USER + 20)
+#define TB_INSERTBUTTON         (WM_USER + 21)
+#endif
+
+#define TB_DELETEBUTTON         (WM_USER + 22)
+#define TB_GETBUTTON            (WM_USER + 23)
+#define TB_BUTTONCOUNT          (WM_USER + 24)
+#define TB_COMMANDTOINDEX       (WM_USER + 25)
+
+#ifdef _WIN32
+
+typedef struct tagTBSAVEPARAMSA {
+    HKEY hkr;
+    LPCSTR pszSubKey;
+    LPCSTR pszValueName;
+} TBSAVEPARAMSA, FAR* LPTBSAVEPARAMSA;
+
+typedef struct tagTBSAVEPARAMSW {
+    HKEY hkr;
+    LPCWSTR pszSubKey;
+    LPCWSTR pszValueName;
+} TBSAVEPARAMSW, FAR *LPTBSAVEPARAMW;
+
+#ifdef UNICODE
+#define TBSAVEPARAMS            TBSAVEPARAMSW
+#define LPTBSAVEPARAMS          LPTBSAVEPARAMSW
+#else
+#define TBSAVEPARAMS            TBSAVEPARAMSA
+#define LPTBSAVEPARAMS          LPTBSAVEPARAMSA
+#endif
+
+#endif  // _WIN32
+
+#define TB_SAVERESTOREA         (WM_USER + 26)
+#define TB_SAVERESTOREW         (WM_USER + 76)
+#define TB_CUSTOMIZE            (WM_USER + 27)
+#define TB_ADDSTRINGA           (WM_USER + 28)
+#define TB_ADDSTRINGW           (WM_USER + 77)
+#define TB_GETITEMRECT          (WM_USER + 29)
+#define TB_BUTTONSTRUCTSIZE     (WM_USER + 30)
+#define TB_SETBUTTONSIZE        (WM_USER + 31)
+#define TB_SETBITMAPSIZE        (WM_USER + 32)
+#define TB_AUTOSIZE             (WM_USER + 33)
+#define TB_GETTOOLTIPS          (WM_USER + 35)
+#define TB_SETTOOLTIPS          (WM_USER + 36)
+#define TB_SETPARENT            (WM_USER + 37)
+#define TB_SETROWS              (WM_USER + 39)
+#define TB_GETROWS              (WM_USER + 40)
+#define TB_SETCMDID             (WM_USER + 42)
+#define TB_CHANGEBITMAP         (WM_USER + 43)
+#define TB_GETBITMAP            (WM_USER + 44)
+#define TB_GETBUTTONTEXTA       (WM_USER + 45)
+#define TB_GETBUTTONTEXTW       (WM_USER + 75)
+#define TB_REPLACEBITMAP        (WM_USER + 46)
+#if (_WIN32_IE >= 0x0300)
+#define TB_SETINDENT            (WM_USER + 47)
+#define TB_SETIMAGELIST         (WM_USER + 48)
+#define TB_GETIMAGELIST         (WM_USER + 49)
+#define TB_LOADIMAGES           (WM_USER + 50)
+#define TB_GETRECT              (WM_USER + 51) // wParam is the Cmd instead of index
+#define TB_SETHOTIMAGELIST      (WM_USER + 52)
+#define TB_GETHOTIMAGELIST      (WM_USER + 53)
+#define TB_SETDISABLEDIMAGELIST (WM_USER + 54)
+#define TB_GETDISABLEDIMAGELIST (WM_USER + 55)
+#define TB_SETSTYLE             (WM_USER + 56)
+#define TB_GETSTYLE             (WM_USER + 57)
+#define TB_GETBUTTONSIZE        (WM_USER + 58)
+#define TB_SETBUTTONWIDTH       (WM_USER + 59)
+#define TB_SETMAXTEXTROWS       (WM_USER + 60)
+#define TB_GETTEXTROWS          (WM_USER + 61)
+#endif      // _WIN32_IE >= 0x0300
+
+#ifdef UNICODE
+#define TB_GETBUTTONTEXT        TB_GETBUTTONTEXTW
+#define TB_SAVERESTORE          TB_SAVERESTOREW
+#define TB_ADDSTRING            TB_ADDSTRINGW
+#else
+#define TB_GETBUTTONTEXT        TB_GETBUTTONTEXTA
+#define TB_SAVERESTORE          TB_SAVERESTOREA
+#define TB_ADDSTRING            TB_ADDSTRINGA
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TB_GETOBJECT            (WM_USER + 62)  // wParam == IID, lParam void **ppv
+#define TB_GETHOTITEM           (WM_USER + 71)
+#define TB_SETHOTITEM           (WM_USER + 72)  // wParam == iHotItem
+#define TB_SETANCHORHIGHLIGHT   (WM_USER + 73)  // wParam == TRUE/FALSE
+#define TB_GETANCHORHIGHLIGHT   (WM_USER + 74)
+#define TB_MAPACCELERATORA      (WM_USER + 78)  // wParam == ch, lParam int * pidBtn
+
+typedef struct {
+    int   iButton;
+    DWORD dwFlags;
+} TBINSERTMARK, * LPTBINSERTMARK;
+#define TBIMHT_AFTER      0x00000001 // TRUE = insert After iButton, otherwise before
+#define TBIMHT_BACKGROUND 0x00000002 // TRUE iff missed buttons completely
+
+#define TB_GETINSERTMARK        (WM_USER + 79)  // lParam == LPTBINSERTMARK
+#define TB_SETINSERTMARK        (WM_USER + 80)  // lParam == LPTBINSERTMARK
+#define TB_INSERTMARKHITTEST    (WM_USER + 81)  // wParam == LPPOINT lParam == LPTBINSERTMARK
+#define TB_MOVEBUTTON           (WM_USER + 82)
+#define TB_GETMAXSIZE           (WM_USER + 83)  // lParam == LPSIZE
+#define TB_SETEXTENDEDSTYLE     (WM_USER + 84)  // For TBSTYLE_EX_*
+#define TB_GETEXTENDEDSTYLE     (WM_USER + 85)  // For TBSTYLE_EX_*
+#define TB_GETPADDING           (WM_USER + 86)
+#define TB_SETPADDING           (WM_USER + 87)
+#define TB_SETINSERTMARKCOLOR   (WM_USER + 88)
+#define TB_GETINSERTMARKCOLOR   (WM_USER + 89)
+
+#define TB_SETCOLORSCHEME       CCM_SETCOLORSCHEME  // lParam is color scheme
+#define TB_GETCOLORSCHEME       CCM_GETCOLORSCHEME	// fills in COLORSCHEME pointed to by lParam
+
+#define TB_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define TB_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+
+#define TB_MAPACCELERATORW      (WM_USER + 90)  // wParam == ch, lParam int * pidBtn
+#ifdef UNICODE
+#define TB_MAPACCELERATOR       TB_MAPACCELERATORW      
+#else
+#define TB_MAPACCELERATOR       TB_MAPACCELERATORA
+#endif
+#endif  // _WIN32_IE >= 0x0400
+
+typedef struct {
+    HINSTANCE       hInstOld;
+    UINT            nIDOld;
+    HINSTANCE       hInstNew;
+    UINT            nIDNew;
+    int             nButtons;
+} TBREPLACEBITMAP, *LPTBREPLACEBITMAP;
+
+#ifdef _WIN32
+
+#define TBBF_LARGE              0x0001
+
+#define TB_GETBITMAPFLAGS       (WM_USER + 41)
+
+#if (_WIN32_IE >= 0x0400)
+#define TBIF_IMAGE              0x00000001
+#define TBIF_TEXT               0x00000002
+#define TBIF_STATE              0x00000004
+#define TBIF_STYLE              0x00000008
+#define TBIF_LPARAM             0x00000010
+#define TBIF_COMMAND            0x00000020
+#define TBIF_SIZE               0x00000040
+
+typedef struct {
+    UINT cbSize;
+    DWORD dwMask;
+    int idCommand;
+    int iImage;
+    BYTE fsState;
+    BYTE fsStyle;
+    WORD cx;
+    DWORD lParam;
+    LPSTR pszText;
+    int cchText;
+} TBBUTTONINFOA, *LPTBBUTTONINFOA;
+
+typedef struct {
+    UINT cbSize;
+    DWORD dwMask;
+    int idCommand;
+    int iImage;
+    BYTE fsState;
+    BYTE fsStyle;
+    WORD cx;
+    DWORD lParam;
+    LPWSTR pszText;
+    int cchText;
+} TBBUTTONINFOW, *LPTBBUTTONINFOW;
+
+#ifdef UNICODE
+#define TBBUTTONINFO TBBUTTONINFOW
+#define LPTBBUTTONINFO LPTBBUTTONINFOW
+#else
+#define TBBUTTONINFO TBBUTTONINFOA
+#define LPTBBUTTONINFO LPTBBUTTONINFOA
+#endif
+
+
+// BUTTONINFO APIs do NOT support the string pool.
+#define TB_GETBUTTONINFOW        (WM_USER + 63)
+#define TB_SETBUTTONINFOW        (WM_USER + 64)
+#define TB_GETBUTTONINFOA        (WM_USER + 65)
+#define TB_SETBUTTONINFOA        (WM_USER + 66)
+#ifdef UNICODE
+#define TB_GETBUTTONINFO        TB_GETBUTTONINFOW
+#define TB_SETBUTTONINFO        TB_SETBUTTONINFOW
+#else
+#define TB_GETBUTTONINFO        TB_GETBUTTONINFOA
+#define TB_SETBUTTONINFO        TB_SETBUTTONINFOA
+#endif
+
+
+#define TB_INSERTBUTTONW        (WM_USER + 67)
+#define TB_ADDBUTTONSW          (WM_USER + 68)
+
+#define TB_HITTEST              (WM_USER + 69)
+
+// New post Win95/NT4 for InsertButton and AddButton.  if iString member
+// is a pointer to a string, it will be handled as a string like listview
+// (although LPSTR_TEXTCALLBACK is not supported).
+#ifdef UNICODE
+#define TB_INSERTBUTTON         TB_INSERTBUTTONW
+#define TB_ADDBUTTONS           TB_ADDBUTTONSW
+#else
+#define TB_INSERTBUTTON         TB_INSERTBUTTONA
+#define TB_ADDBUTTONS           TB_ADDBUTTONSA
+#endif
+
+#define TB_SETDRAWTEXTFLAGS     (WM_USER + 70)  // wParam == mask lParam == bit values
+
+#endif         // _WIN32_IE >= 0x0400
+
+#define TBN_GETBUTTONINFOA      (TBN_FIRST-0)
+#define TBN_GETBUTTONINFOW      (TBN_FIRST-20)
+#define TBN_BEGINDRAG           (TBN_FIRST-1)
+#define TBN_ENDDRAG             (TBN_FIRST-2)
+#define TBN_BEGINADJUST         (TBN_FIRST-3)
+#define TBN_ENDADJUST           (TBN_FIRST-4)
+#define TBN_RESET               (TBN_FIRST-5)
+#define TBN_QUERYINSERT         (TBN_FIRST-6)
+#define TBN_QUERYDELETE         (TBN_FIRST-7)
+#define TBN_TOOLBARCHANGE       (TBN_FIRST-8)
+#define TBN_CUSTHELP            (TBN_FIRST-9)
+#if (_WIN32_IE >= 0x0300)
+#define TBN_DROPDOWN            (TBN_FIRST - 10)
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TBN_GETOBJECT           (TBN_FIRST - 12)
+
+// Structure for TBN_HOTITEMCHANGE notification
+//
+typedef struct tagNMTBHOTITEM
+{
+    NMHDR   hdr;
+    int     idOld;
+    int     idNew;
+    DWORD   dwFlags;           // HICF_*
+} NMTBHOTITEM, * LPNMTBHOTITEM;
+
+// Hot item change flags
+#define HICF_OTHER          0x00000000
+#define HICF_MOUSE          0x00000001          // Triggered by mouse
+#define HICF_ARROWKEYS      0x00000002          // Triggered by arrow keys
+#define HICF_ACCELERATOR    0x00000004          // Triggered by accelerator
+#define HICF_DUPACCEL       0x00000008          // This accelerator is not unique
+#define HICF_ENTERING       0x00000010          // idOld is invalid
+#define HICF_LEAVING        0x00000020          // idNew is invalid
+#define HICF_RESELECT       0x00000040          // hot item reselected
+
+
+#define TBN_HOTITEMCHANGE       (TBN_FIRST - 13)
+#define TBN_DRAGOUT             (TBN_FIRST - 14) // this is sent when the user clicks down on a button then drags off the button
+#define TBN_DELETINGBUTTON      (TBN_FIRST - 15) // uses TBNOTIFY
+#define TBN_GETDISPINFOA        (TBN_FIRST - 16) // This is sent when the  toolbar needs  some display information
+#define TBN_GETDISPINFOW        (TBN_FIRST - 17) // This is sent when the  toolbar needs  some display information
+#define TBN_GETINFOTIPA         (TBN_FIRST - 18)
+#define TBN_GETINFOTIPW         (TBN_FIRST - 19)
+
+
+typedef struct tagNMTBGETINFOTIPA
+{
+    NMHDR hdr;
+    LPSTR pszText;
+    int cchTextMax;
+    int iItem;
+    LPARAM lParam;
+} NMTBGETINFOTIPA, *LPNMTBGETINFOTIPA;
+
+typedef struct tagNMTBGETINFOTIPW
+{
+    NMHDR hdr;
+    LPWSTR pszText;
+    int cchTextMax;
+    int iItem;
+    LPARAM lParam;
+} NMTBGETINFOTIPW, *LPNMTBGETINFOTIPW;
+
+#ifdef UNICODE
+#define TBN_GETINFOTIP          TBN_GETINFOTIPW
+#define NMTBGETINFOTIP          NMTBGETINFOTIPW
+#define LPNMTBGETINFOTIP        LPNMTBGETINFOTIPW
+#else
+#define TBN_GETINFOTIP          TBN_GETINFOTIPA
+#define NMTBGETINFOTIP          NMTBGETINFOTIPA
+#define LPNMTBGETINFOTIP        LPNMTBGETINFOTIPA
+#endif
+
+#define TBNF_IMAGE              0x00000001
+#define TBNF_TEXT               0x00000002
+#define TBNF_DI_SETITEM         0x10000000
+
+typedef struct {
+    NMHDR  hdr;
+    DWORD dwMask;     // [in] Specifies the values requested .[out] Client ask the data to be set for future use
+    int idCommand;    // [in] id of button we're requesting info for
+    DWORD lParam;     // [in] lParam of button
+    int iImage;       // [out] image index
+    LPSTR pszText;    // [out] new text for item
+    int cchText;      // [in] size of buffer pointed to by pszText
+} NMTBDISPINFOA, *LPNMTBDISPINFOA;
+
+typedef struct {
+    NMHDR hdr;
+    DWORD dwMask;      //[in] Specifies the values requested .[out] Client ask the data to be set for future use
+    int idCommand;    // [in] id of button we're requesting info for
+    DWORD lParam;     // [in] lParam of button
+    int iImage;       // [out] image index
+    LPWSTR pszText;   // [out] new text for item
+    int cchText;      // [in] size of buffer pointed to by pszText
+} NMTBDISPINFOW, *LPNMTBDISPINFOW;
+
+
+#ifdef UNICODE
+#define TBN_GETDISPINFO       TBN_GETDISPINFOW
+#define NMTBDISPINFO	      NMTBDISPINFOW
+#define LPNMTBDISPINFO        LPNMTBDISPINFOW
+#else
+#define TBN_GETDISPINFO       TBN_GETDISPINFOA
+#define NMTBDISPINFO          NMTBDISPINFOA
+#define LPNMTBDISPINFO        LPNMTBDISPINFOA
+#endif
+
+// Return codes for TBN_DROPDOWN
+#define TBDDRET_DEFAULT         0
+#define TBDDRET_NODEFAULT       1
+#define TBDDRET_TREATPRESSED    2       // Treat as a standard press button
+
+#endif
+
+
+#ifdef UNICODE
+#define TBN_GETBUTTONINFO       TBN_GETBUTTONINFOW
+#else
+#define TBN_GETBUTTONINFO       TBN_GETBUTTONINFOA
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define TBNOTIFYA NMTOOLBARA
+#define TBNOTIFYW NMTOOLBARW
+#define LPTBNOTIFYA LPNMTOOLBARA
+#define LPTBNOTIFYW LPNMTOOLBARW
+#else
+#define tagNMTOOLBARA  tagTBNOTIFYA
+#define NMTOOLBARA     TBNOTIFYA
+#define LPNMTOOLBARA   LPTBNOTIFYA
+#define tagNMTOOLBARW  tagTBNOTIFYW
+#define NMTOOLBARW     TBNOTIFYW
+#define LPNMTOOLBARW   LPTBNOTIFYW
+#endif
+
+#define TBNOTIFY       NMTOOLBAR
+#define LPTBNOTIFY     LPNMTOOLBAR
+
+#if (_WIN32_IE >= 0x0300)
+typedef struct tagNMTOOLBARA {
+    NMHDR   hdr;
+    int     iItem;
+    TBBUTTON tbButton;
+    int     cchText;
+    LPSTR   pszText;
+} NMTOOLBARA, FAR* LPNMTOOLBARA;
+#endif
+
+
+#if (_WIN32_IE >= 0x0300)
+typedef struct tagNMTOOLBARW {
+    NMHDR   hdr;
+    int     iItem;
+    TBBUTTON tbButton;
+    int     cchText;
+    LPWSTR   pszText;
+} NMTOOLBARW, FAR* LPNMTOOLBARW;
+#endif
+
+
+#ifdef UNICODE
+#define NMTOOLBAR               NMTOOLBARW
+#define LPNMTOOLBAR             LPNMTOOLBARW
+#else
+#define NMTOOLBAR               NMTOOLBARA
+#define LPNMTOOLBAR             LPNMTOOLBARA
+#endif
+
+#endif
+
+#endif      // NOTOOLBAR
+
+
+#if (_WIN32_IE >= 0x0300)
+//====== REBAR CONTROL ========================================================
+
+#ifndef NOREBAR
+
+#ifdef _WIN32
+#define REBARCLASSNAMEW         L"ReBarWindow32"
+#define REBARCLASSNAMEA         "ReBarWindow32"
+
+#ifdef  UNICODE
+#define REBARCLASSNAME          REBARCLASSNAMEW
+#else
+#define REBARCLASSNAME          REBARCLASSNAMEA
+#endif
+
+#else
+#define REBARCLASSNAME          "ReBarWindow"
+#endif
+
+#define RBIM_IMAGELIST  0x00000001
+
+#if (_WIN32_IE >= 0x0400)
+#define RBS_TOOLTIPS        0x0100
+#define RBS_VARHEIGHT       0x0200
+#define RBS_BANDBORDERS     0x0400
+#define RBS_FIXEDORDER      0x0800
+#define RBS_REGISTERDROP    0x1000
+#define RBS_AUTOSIZE        0x2000
+#define RBS_VERTICALGRIPPER 0x4000  // this always has the vertical gripper (default for horizontal mode)
+#define RBS_DBLCLKTOGGLE    0x8000
+#else
+#define RBS_TOOLTIPS        0x00000100
+#define RBS_VARHEIGHT       0x00000200
+#define RBS_BANDBORDERS     0x00000400
+#define RBS_FIXEDORDER      0x00000800
+#endif      // _WIN32_IE >= 0x0400
+
+
+typedef struct tagREBARINFO
+{
+    UINT        cbSize;
+    UINT        fMask;
+#ifndef NOIMAGEAPIS
+    HIMAGELIST  himl;
+#else
+    HANDLE      himl;
+#endif
+}   REBARINFO, FAR *LPREBARINFO;
+
+#define RBBS_BREAK          0x00000001  // break to new line
+#define RBBS_FIXEDSIZE      0x00000002  // band can't be sized
+#define RBBS_CHILDEDGE      0x00000004  // edge around top & bottom of child window
+#define RBBS_HIDDEN         0x00000008  // don't show
+#define RBBS_NOVERT         0x00000010  // don't show when vertical
+#define RBBS_FIXEDBMP       0x00000020  // bitmap doesn't move during band resize
+#if (_WIN32_IE >= 0x0400)
+#define RBBS_VARIABLEHEIGHT 0x00000040  // allow autosizing of this child vertically
+#define RBBS_GRIPPERALWAYS  0x00000080  // always show the gripper
+#define RBBS_NOGRIPPER      0x00000100  // never show the gripper
+#endif
+
+#define RBBIM_STYLE         0x00000001
+#define RBBIM_COLORS        0x00000002
+#define RBBIM_TEXT          0x00000004
+#define RBBIM_IMAGE         0x00000008
+#define RBBIM_CHILD         0x00000010
+#define RBBIM_CHILDSIZE     0x00000020
+#define RBBIM_SIZE          0x00000040
+#define RBBIM_BACKGROUND    0x00000080
+#define RBBIM_ID            0x00000100
+#if (_WIN32_IE >= 0x0400)
+#define RBBIM_IDEALSIZE     0x00000200
+#define RBBIM_LPARAM        0x00000400
+#define RBBIM_HEADERSIZE    0x00000800  // control the size of the header
+#endif
+
+typedef struct tagREBARBANDINFOA
+{
+    UINT        cbSize;
+    UINT        fMask;
+    UINT        fStyle;
+    COLORREF    clrFore;
+    COLORREF    clrBack;
+    LPSTR       lpText;
+    UINT        cch;
+    int         iImage;
+    HWND        hwndChild;
+    UINT        cxMinChild;
+    UINT        cyMinChild;
+    UINT        cx;
+    HBITMAP     hbmBack;
+    UINT        wID;
+#if (_WIN32_IE >= 0x0400)
+    UINT        cyChild;
+    UINT        cyMaxChild;
+    UINT        cyIntegral;
+    UINT        cxIdeal;
+    LPARAM      lParam;
+    UINT        cxHeader;
+#endif
+}   REBARBANDINFOA, FAR *LPREBARBANDINFOA;
+typedef REBARBANDINFOA CONST FAR *LPCREBARBANDINFOA;
+
+#define REBARBANDINFOA_V3_SIZE CCSIZEOF_STRUCT(REBARBANDINFOA, wID)
+#define REBARBANDINFOW_V3_SIZE CCSIZEOF_STRUCT(REBARBANDINFOW, wID)
+
+typedef struct tagREBARBANDINFOW
+{
+    UINT        cbSize;
+    UINT        fMask;
+    UINT        fStyle;
+    COLORREF    clrFore;
+    COLORREF    clrBack;
+    LPWSTR      lpText;
+    UINT        cch;
+    int         iImage;
+    HWND        hwndChild;
+    UINT        cxMinChild;
+    UINT        cyMinChild;
+    UINT        cx;
+    HBITMAP     hbmBack;
+    UINT        wID;
+#if (_WIN32_IE >= 0x0400)
+    UINT        cyChild;
+    UINT        cyMaxChild;
+    UINT        cyIntegral;
+    UINT        cxIdeal;
+    LPARAM      lParam;
+    UINT        cxHeader;
+#endif
+}   REBARBANDINFOW, FAR *LPREBARBANDINFOW;
+typedef REBARBANDINFOW CONST FAR *LPCREBARBANDINFOW;
+
+#ifdef UNICODE
+#define REBARBANDINFO       REBARBANDINFOW
+#define LPREBARBANDINFO     LPREBARBANDINFOW
+#define LPCREBARBANDINFO    LPCREBARBANDINFOW
+#define REBARBANDINFO_V3_SIZE REBARBANDINFOW_V3_SIZE
+#else
+#define REBARBANDINFO       REBARBANDINFOA
+#define LPREBARBANDINFO     LPREBARBANDINFOA
+#define LPCREBARBANDINFO    LPCREBARBANDINFOA
+#define REBARBANDINFO_V3_SIZE REBARBANDINFOA_V3_SIZE
+#endif
+
+#define RB_INSERTBANDA  (WM_USER +  1)
+#define RB_DELETEBAND   (WM_USER +  2)
+#define RB_GETBARINFO   (WM_USER +  3)
+#define RB_SETBARINFO   (WM_USER +  4)
+#if (_WIN32_IE < 0x0400)
+#define RB_GETBANDINFO  (WM_USER +  5)
+#endif
+#define RB_SETBANDINFOA (WM_USER +  6)
+#define RB_SETPARENT    (WM_USER +  7)
+#if (_WIN32_IE >= 0x0400)
+#define RB_HITTEST      (WM_USER +  8)
+#define RB_GETRECT      (WM_USER +  9)
+#endif
+#define RB_INSERTBANDW  (WM_USER +  10)
+#define RB_SETBANDINFOW (WM_USER +  11)
+#define RB_GETBANDCOUNT (WM_USER +  12)
+#define RB_GETROWCOUNT  (WM_USER +  13)
+#define RB_GETROWHEIGHT (WM_USER +  14)
+#if (_WIN32_IE >= 0x0400)
+#define RB_IDTOINDEX    (WM_USER +  16) // wParam == id
+#define RB_GETTOOLTIPS  (WM_USER +  17)
+#define RB_SETTOOLTIPS  (WM_USER +  18)
+#define RB_SETBKCOLOR   (WM_USER +  19) // sets the default BK color
+#define RB_GETBKCOLOR   (WM_USER +  20) // defaults to CLR_NONE
+#define RB_SETTEXTCOLOR (WM_USER +  21)
+#define RB_GETTEXTCOLOR (WM_USER +  22) // defaults to 0x00000000
+#define RB_SIZETORECT   (WM_USER +  23) // resize the rebar/break bands and such to this rect (lparam)
+#endif      // _WIN32_IE >= 0x0400
+
+#define RB_SETCOLORSCHEME   CCM_SETCOLORSCHEME  // lParam is color scheme
+#define RB_GETCOLORSCHEME   CCM_GETCOLORSCHEME  // fills in COLORSCHEME pointed to by lParam
+
+#ifdef UNICODE
+#define RB_INSERTBAND   RB_INSERTBANDW
+#define RB_SETBANDINFO   RB_SETBANDINFOW
+#else
+#define RB_INSERTBAND   RB_INSERTBANDA
+#define RB_SETBANDINFO   RB_SETBANDINFOA
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+// for manual drag control
+// lparam == cursor pos
+        // -1 means do it yourself.
+        // -2 means use what you had saved before
+#define RB_BEGINDRAG    (WM_USER + 24)
+#define RB_ENDDRAG      (WM_USER + 25)
+#define RB_DRAGMOVE     (WM_USER + 26)
+#define RB_GETBARHEIGHT (WM_USER + 27)
+#define RB_GETBANDINFOW (WM_USER + 28)
+#define RB_GETBANDINFOA (WM_USER + 29)
+
+#ifdef UNICODE
+#define RB_GETBANDINFO   RB_GETBANDINFOW
+#else
+#define RB_GETBANDINFO   RB_GETBANDINFOA
+#endif
+
+#define RB_MINIMIZEBAND (WM_USER + 30)
+#define RB_MAXIMIZEBAND (WM_USER + 31)
+
+#define RB_GETDROPTARGET (CCM_GETDROPTARGET)
+
+#define RB_GETBANDBORDERS (WM_USER + 34)  // returns in lparam = lprc the amount of edges added to band wparam
+
+#define RB_SHOWBAND     (WM_USER + 35)      // show/hide band
+#define RB_SETPALETTE   (WM_USER + 37)
+#define RB_GETPALETTE   (WM_USER + 38)
+#define RB_MOVEBAND     (WM_USER + 39)
+
+#define RB_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define RB_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+
+#endif      // _WIN32_IE >= 0x0400
+
+#define RBN_HEIGHTCHANGE    (RBN_FIRST - 0)
+
+#if (_WIN32_IE >= 0x0400)
+#define RBN_GETOBJECT       (RBN_FIRST - 1)
+#define RBN_LAYOUTCHANGED   (RBN_FIRST - 2)
+#define RBN_AUTOSIZE        (RBN_FIRST - 3)
+#define RBN_BEGINDRAG       (RBN_FIRST - 4)
+#define RBN_ENDDRAG         (RBN_FIRST - 5)
+#define RBN_DELETINGBAND    (RBN_FIRST - 6)     // Uses NMREBAR
+#define RBN_DELETEDBAND     (RBN_FIRST - 7)     // Uses NMREBAR
+#define RBN_CHILDSIZE       (RBN_FIRST - 8)
+
+
+typedef struct tagNMREBARCHILDSIZE
+{
+    NMHDR hdr;
+    UINT uBand;
+    UINT wID;
+    RECT rcChild;
+    RECT rcBand;
+} NMREBARCHILDSIZE, *LPNMREBARCHILDSIZE;
+
+typedef struct tagNMREBAR
+{
+    NMHDR   hdr;
+    DWORD   dwMask;           // RBNM_*
+    UINT    uBand;
+    UINT    fStyle;
+    UINT    wID;
+    LPARAM  lParam;
+} NMREBAR, *LPNMREBAR;
+
+// Mask flags for NMREBAR
+#define RBNM_ID         0x00000001
+#define RBNM_STYLE      0x00000002
+#define RBNM_LPARAM     0x00000004
+
+
+typedef struct tagNMRBAUTOSIZE
+{
+    NMHDR hdr;
+    BOOL fChanged;
+    RECT rcTarget;
+    RECT rcActual;
+} NMRBAUTOSIZE, *LPNMRBAUTOSIZE;
+
+#define RBHT_NOWHERE    0x0001
+#define RBHT_CAPTION    0x0002
+#define RBHT_CLIENT     0x0003
+#define RBHT_GRABBER    0x0004
+
+typedef struct _RB_HITTESTINFO
+{
+    POINT pt;
+    UINT flags;
+    int iBand;
+} RBHITTESTINFO, FAR *LPRBHITTESTINFO;
+
+#endif      // _WIN32_IE >= 0x0400
+
+#endif      // NOREBAR
+
+#endif      // _WIN32_IE >= 0x0300
+
+//====== TOOLTIPS CONTROL =====================================================
+
+#ifndef NOTOOLTIPS
+
+#ifdef _WIN32
+
+#define TOOLTIPS_CLASSW         L"tooltips_class32"
+#define TOOLTIPS_CLASSA         "tooltips_class32"
+
+#ifdef UNICODE
+#define TOOLTIPS_CLASS          TOOLTIPS_CLASSW
+#else
+#define TOOLTIPS_CLASS          TOOLTIPS_CLASSA
+#endif
+
+#else
+#define TOOLTIPS_CLASS          "tooltips_class"
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define LPTOOLINFOA   LPTTTOOLINFOA
+#define LPTOOLINFOW   LPTTTOOLINFOW
+#define TOOLINFOA       TTTOOLINFOA
+#define TOOLINFOW       TTTOOLINFOW
+#else
+#define   TTTOOLINFOA   TOOLINFOA
+#define LPTTTOOLINFOA LPTOOLINFOA
+#define   TTTOOLINFOW   TOOLINFOW
+#define LPTTTOOLINFOW LPTOOLINFOW
+#endif
+
+#define LPTOOLINFO    LPTTTOOLINFO
+#define TOOLINFO        TTTOOLINFO
+
+#define TTTOOLINFOA_V1_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA, lpszText)
+#define TTTOOLINFOW_V1_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW, lpszText)
+
+typedef struct tagTOOLINFOA {
+    UINT cbSize;
+    UINT uFlags;
+    HWND hwnd;
+    UINT uId;
+    RECT rect;
+    HINSTANCE hinst;
+    LPSTR lpszText;
+#if (_WIN32_IE >= 0x0300)
+    LPARAM lParam;
+#endif
+} TTTOOLINFOA, NEAR *PTOOLINFOA, FAR *LPTTTOOLINFOA;
+
+typedef struct tagTOOLINFOW {
+    UINT cbSize;
+    UINT uFlags;
+    HWND hwnd;
+    UINT uId;
+    RECT rect;
+    HINSTANCE hinst;
+    LPWSTR lpszText;
+#if (_WIN32_IE >= 0x0300)
+    LPARAM lParam;
+#endif
+} TTTOOLINFOW, NEAR *PTOOLINFOW, FAR* LPTTTOOLINFOW;
+
+#ifdef UNICODE
+#define TTTOOLINFO              TTTOOLINFOW
+#define PTOOLINFO               PTOOLINFOW
+#define LPTTTOOLINFO            LPTTTOOLINFOW
+#define TTTOOLINFO_V1_SIZE TTTOOLINFOW_V1_SIZE
+#else
+#define PTOOLINFO               PTOOLINFOA
+#define TTTOOLINFO              TTTOOLINFOA
+#define LPTTTOOLINFO            LPTTTOOLINFOA
+#define TTTOOLINFO_V1_SIZE TTTOOLINFOA_V1_SIZE
+#endif
+
+// begin_r_commctrl
+
+#define TTS_ALWAYSTIP           0x01
+#define TTS_NOPREFIX            0x02
+
+// end_r_commctrl
+
+#define TTF_IDISHWND            0x0001
+
+// Use this to center around trackpoint in trackmode
+// -OR- to center around tool in normal mode.
+// Use TTF_ABSOLUTE to place the tip exactly at the track coords when
+// in tracking mode.  TTF_ABSOLUTE can be used in conjunction with TTF_CENTERTIP
+// to center the tip absolutely about the track point.
+
+#define TTF_CENTERTIP           0x0002
+#define TTF_RTLREADING          0x0004
+#define TTF_SUBCLASS            0x0010
+#if (_WIN32_IE >= 0x0300)
+#define TTF_TRACK               0x0020
+#define TTF_ABSOLUTE            0x0080
+#define TTF_TRANSPARENT         0x0100
+#define TTF_DI_SETITEM          0x8000       // valid only on the TTN_NEEDTEXT callback
+#endif      // _WIN32_IE >= 0x0300
+
+#define TTDT_AUTOMATIC          0
+#define TTDT_RESHOW             1
+#define TTDT_AUTOPOP            2
+#define TTDT_INITIAL            3
+
+#define TTM_ACTIVATE            (WM_USER + 1)
+#define TTM_SETDELAYTIME        (WM_USER + 3)
+#define TTM_ADDTOOLA            (WM_USER + 4)
+#define TTM_ADDTOOLW            (WM_USER + 50)
+#define TTM_DELTOOLA            (WM_USER + 5)
+#define TTM_DELTOOLW            (WM_USER + 51)
+#define TTM_NEWTOOLRECTA        (WM_USER + 6)
+#define TTM_NEWTOOLRECTW        (WM_USER + 52)
+#define TTM_RELAYEVENT          (WM_USER + 7)
+
+#define TTM_GETTOOLINFOA        (WM_USER + 8)
+#define TTM_GETTOOLINFOW        (WM_USER + 53)
+
+#define TTM_SETTOOLINFOA        (WM_USER + 9)
+#define TTM_SETTOOLINFOW        (WM_USER + 54)
+
+#define TTM_HITTESTA            (WM_USER +10)
+#define TTM_HITTESTW            (WM_USER +55)
+#define TTM_GETTEXTA            (WM_USER +11)
+#define TTM_GETTEXTW            (WM_USER +56)
+#define TTM_UPDATETIPTEXTA      (WM_USER +12)
+#define TTM_UPDATETIPTEXTW      (WM_USER +57)
+#define TTM_GETTOOLCOUNT        (WM_USER +13)
+#define TTM_ENUMTOOLSA          (WM_USER +14)
+#define TTM_ENUMTOOLSW          (WM_USER +58)
+#define TTM_GETCURRENTTOOLA     (WM_USER + 15)
+#define TTM_GETCURRENTTOOLW     (WM_USER + 59)
+#define TTM_WINDOWFROMPOINT     (WM_USER + 16)
+#if (_WIN32_IE >= 0x0300)
+#define TTM_TRACKACTIVATE       (WM_USER + 17)  // wParam = TRUE/FALSE start end  lparam = LPTOOLINFO
+#define TTM_TRACKPOSITION       (WM_USER + 18)  // lParam = dwPos
+#define TTM_SETTIPBKCOLOR       (WM_USER + 19)
+#define TTM_SETTIPTEXTCOLOR     (WM_USER + 20)
+#define TTM_GETDELAYTIME        (WM_USER + 21)
+#define TTM_GETTIPBKCOLOR       (WM_USER + 22)
+#define TTM_GETTIPTEXTCOLOR     (WM_USER + 23)
+#define TTM_SETMAXTIPWIDTH      (WM_USER + 24)
+#define TTM_GETMAXTIPWIDTH      (WM_USER + 25)
+#define TTM_SETMARGIN           (WM_USER + 26)  // lParam = lprc
+#define TTM_GETMARGIN           (WM_USER + 27)  // lParam = lprc
+#define TTM_POP                 (WM_USER + 28)
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TTM_UPDATE              (WM_USER + 29)
+#endif
+
+
+#ifdef UNICODE
+#define TTM_ADDTOOL             TTM_ADDTOOLW
+#define TTM_DELTOOL             TTM_DELTOOLW
+#define TTM_NEWTOOLRECT         TTM_NEWTOOLRECTW
+#define TTM_GETTOOLINFO         TTM_GETTOOLINFOW
+#define TTM_SETTOOLINFO         TTM_SETTOOLINFOW
+#define TTM_HITTEST             TTM_HITTESTW
+#define TTM_GETTEXT             TTM_GETTEXTW
+#define TTM_UPDATETIPTEXT       TTM_UPDATETIPTEXTW
+#define TTM_ENUMTOOLS           TTM_ENUMTOOLSW
+#define TTM_GETCURRENTTOOL      TTM_GETCURRENTTOOLW
+#else
+#define TTM_ADDTOOL             TTM_ADDTOOLA
+#define TTM_DELTOOL             TTM_DELTOOLA
+#define TTM_NEWTOOLRECT         TTM_NEWTOOLRECTA
+#define TTM_GETTOOLINFO         TTM_GETTOOLINFOA
+#define TTM_SETTOOLINFO         TTM_SETTOOLINFOA
+#define TTM_HITTEST             TTM_HITTESTA
+#define TTM_GETTEXT             TTM_GETTEXTA
+#define TTM_UPDATETIPTEXT       TTM_UPDATETIPTEXTA
+#define TTM_ENUMTOOLS           TTM_ENUMTOOLSA
+#define TTM_GETCURRENTTOOL      TTM_GETCURRENTTOOLA
+#endif
+
+
+#if (_WIN32_IE >= 0x0300)
+#define LPHITTESTINFOW    LPTTHITTESTINFOW
+#define LPHITTESTINFOA    LPTTHITTESTINFOA
+#else
+#define LPTTHITTESTINFOA  LPHITTESTINFOA
+#define LPTTHITTESTINFOW  LPHITTESTINFOW
+#endif
+
+#define LPHITTESTINFO     LPTTHITTESTINFO
+
+typedef struct _TT_HITTESTINFOA {
+    HWND hwnd;
+    POINT pt;
+    TTTOOLINFOA ti;
+} TTHITTESTINFOA, FAR * LPTTHITTESTINFOA;
+
+typedef struct _TT_HITTESTINFOW {
+    HWND hwnd;
+    POINT pt;
+    TTTOOLINFOW ti;
+} TTHITTESTINFOW, FAR * LPTTHITTESTINFOW;
+
+#ifdef UNICODE
+#define TTHITTESTINFO           TTHITTESTINFOW
+#define LPTTHITTESTINFO         LPTTHITTESTINFOW
+#else
+#define TTHITTESTINFO           TTHITTESTINFOA
+#define LPTTHITTESTINFO         LPTTHITTESTINFOA
+#endif
+
+#define TTN_GETDISPINFOA        (TTN_FIRST - 0)
+#define TTN_GETDISPINFOW        (TTN_FIRST - 10)
+#define TTN_SHOW                (TTN_FIRST - 1)
+#define TTN_POP                 (TTN_FIRST - 2)
+
+#ifdef UNICODE
+#define TTN_GETDISPINFO         TTN_GETDISPINFOW
+#else
+#define TTN_GETDISPINFO         TTN_GETDISPINFOA
+#endif
+
+#define TTN_NEEDTEXT            TTN_GETDISPINFO
+#define TTN_NEEDTEXTA           TTN_GETDISPINFOA
+#define TTN_NEEDTEXTW           TTN_GETDISPINFOW
+
+#if (_WIN32_IE >= 0x0300)
+#define TOOLTIPTEXTW NMTTDISPINFOW
+#define TOOLTIPTEXTA NMTTDISPINFOA
+#define LPTOOLTIPTEXTA LPNMTTDISPINFOA
+#define LPTOOLTIPTEXTW LPNMTTDISPINFOW
+#else
+#define tagNMTTDISPINFOA  tagTOOLTIPTEXTA
+#define NMTTDISPINFOA     TOOLTIPTEXTA
+#define LPNMTTDISPINFOA   LPTOOLTIPTEXTA
+#define tagNMTTDISPINFOW  tagTOOLTIPTEXTW
+#define NMTTDISPINFOW     TOOLTIPTEXTW
+#define LPNMTTDISPINFOW   LPTOOLTIPTEXTW
+#endif
+
+#define TOOLTIPTEXT    NMTTDISPINFO
+#define LPTOOLTIPTEXT  LPNMTTDISPINFO
+
+#define NMTTDISPINFOA_V1_SIZE CCSIZEOF_STRUCT(NMTTDISPINFOA, uFlags)
+#define NMTTDISPINFOW_V1_SIZE CCSIZEOF_STRUCT(NMTTDISPINFOW, uFlags)
+
+typedef struct tagNMTTDISPIFNOA {
+    NMHDR hdr;
+    LPSTR lpszText;
+    char szText[80];
+    HINSTANCE hinst;
+    UINT uFlags;
+#if (_WIN32_IE >= 0x0300)
+    LPARAM lParam;
+#endif
+} NMTTDISPINFOA, FAR *LPNMTTDISPINFOA;
+
+typedef struct tagNMTTDISPINFOW {
+    NMHDR hdr;
+    LPWSTR lpszText;
+    WCHAR szText[80];
+    HINSTANCE hinst;
+    UINT uFlags;
+#if (_WIN32_IE >= 0x0300)
+    LPARAM lParam;
+#endif
+} NMTTDISPINFOW, FAR *LPNMTTDISPINFOW;
+
+#ifdef UNICODE
+#define NMTTDISPINFO            NMTTDISPINFOW
+#define LPNMTTDISPINFO          LPNMTTDISPINFOW
+#define NMTTDISPINFO_V1_SIZE NMTTDISPINFOW_V1_SIZE
+#else
+#define NMTTDISPINFO            NMTTDISPINFOA
+#define LPNMTTDISPINFO          LPNMTTDISPINFOA
+#define NMTTDISPINFO_V1_SIZE NMTTDISPINFOA_V1_SIZE
+#endif
+
+#endif      // NOTOOLTIPS
+
+
+//====== STATUS BAR CONTROL ===================================================
+
+#ifndef NOSTATUSBAR
+
+// begin_r_commctrl
+
+#define SBARS_SIZEGRIP          0x0100
+
+// end_r_commctrl
+
+WINCOMMCTRLAPI void WINAPI DrawStatusTextA(HDC hDC, LPRECT lprc, LPCSTR pszText, UINT uFlags);
+WINCOMMCTRLAPI void WINAPI DrawStatusTextW(HDC hDC, LPRECT lprc, LPCWSTR pszText, UINT uFlags);
+
+WINCOMMCTRLAPI HWND WINAPI CreateStatusWindowA(LONG style, LPCSTR lpszText, HWND hwndParent, UINT wID);
+WINCOMMCTRLAPI HWND WINAPI CreateStatusWindowW(LONG style, LPCWSTR lpszText, HWND hwndParent, UINT wID);
+
+#ifdef UNICODE
+#define CreateStatusWindow      CreateStatusWindowW
+#define DrawStatusText          DrawStatusTextW
+#else
+#define CreateStatusWindow      CreateStatusWindowA
+#define DrawStatusText          DrawStatusTextA
+#endif
+
+#ifdef _WIN32
+#define STATUSCLASSNAMEW        L"msctls_statusbar32"
+#define STATUSCLASSNAMEA        "msctls_statusbar32"
+
+#ifdef UNICODE
+#define STATUSCLASSNAME         STATUSCLASSNAMEW
+#else
+#define STATUSCLASSNAME         STATUSCLASSNAMEA
+#endif
+
+#else
+#define STATUSCLASSNAME         "msctls_statusbar"
+#endif
+
+#define SB_SETTEXTA             (WM_USER+1)
+#define SB_SETTEXTW             (WM_USER+11)
+#define SB_GETTEXTA             (WM_USER+2)
+#define SB_GETTEXTW             (WM_USER+13)
+#define SB_GETTEXTLENGTHA       (WM_USER+3)
+#define SB_GETTEXTLENGTHW       (WM_USER+12)
+
+#ifdef UNICODE
+#define SB_GETTEXT              SB_GETTEXTW
+#define SB_SETTEXT              SB_SETTEXTW
+#define SB_GETTEXTLENGTH        SB_GETTEXTLENGTHW
+#if (_WIN32_IE >= 0x0400)
+#define SB_SETTIPTEXT           SB_SETTIPTEXTW
+#define SB_GETTIPTEXT           SB_GETTIPTEXTW
+#endif
+#else
+#define SB_GETTEXT              SB_GETTEXTA
+#define SB_SETTEXT              SB_SETTEXTA
+#define SB_GETTEXTLENGTH        SB_GETTEXTLENGTHA
+#if (_WIN32_IE >= 0x0400)
+#define SB_SETTIPTEXT           SB_SETTIPTEXTA
+#define SB_GETTIPTEXT           SB_GETTIPTEXTA
+#endif
+#endif
+
+
+#define SB_SETPARTS             (WM_USER+4)
+#define SB_GETPARTS             (WM_USER+6)
+#define SB_GETBORDERS           (WM_USER+7)
+#define SB_SETMINHEIGHT         (WM_USER+8)
+#define SB_SIMPLE               (WM_USER+9)
+#define SB_GETRECT              (WM_USER+10)
+#if (_WIN32_IE >= 0x0300)
+#define SB_ISSIMPLE             (WM_USER+14)
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define SB_SETICON              (WM_USER+15)
+#define SB_SETTIPTEXTA          (WM_USER+16)
+#define SB_SETTIPTEXTW          (WM_USER+17)
+#define SB_GETTIPTEXTA          (WM_USER+18)
+#define SB_GETTIPTEXTW          (WM_USER+19)
+#define SB_GETICON              (WM_USER+20)
+#define SB_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define SB_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+#endif
+
+#define SBT_OWNERDRAW            0x1000
+#define SBT_NOBORDERS            0x0100
+#define SBT_POPOUT               0x0200
+#define SBT_RTLREADING           0x0400
+#if (_WIN32_IE >= 0x0400)
+#define SBT_TOOLTIPS             0x0800
+#endif
+
+#define SB_SETBKCOLOR           CCM_SETBKCOLOR      // lParam = bkColor
+
+/// status bar notifications
+#if (_WIN32_IE >= 0x0400)
+#define SBN_SIMPLEMODECHANGE    (SBN_FIRST - 0)
+#endif
+
+#endif      // NOSTATUSBAR
+
+//====== MENU HELP ============================================================
+
+#ifndef NOMENUHELP
+
+WINCOMMCTRLAPI void WINAPI MenuHelp(UINT uMsg, WPARAM wParam, LPARAM lParam, HMENU hMainMenu, HINSTANCE hInst, HWND hwndStatus, UINT FAR *lpwIDs);
+WINCOMMCTRLAPI BOOL WINAPI ShowHideMenuCtl(HWND hWnd, UINT uFlags, LPINT lpInfo);
+WINCOMMCTRLAPI void WINAPI GetEffectiveClientRect(HWND hWnd, LPRECT lprc, LPINT lpInfo);
+
+#define MINSYSCOMMAND   SC_SIZE
+
+#endif
+
+
+//====== TRACKBAR CONTROL =====================================================
+
+#ifndef NOTRACKBAR
+
+#ifdef _WIN32
+
+#define TRACKBAR_CLASSA         "msctls_trackbar32"
+#define TRACKBAR_CLASSW         L"msctls_trackbar32"
+
+#ifdef UNICODE
+#define  TRACKBAR_CLASS         TRACKBAR_CLASSW
+#else
+#define  TRACKBAR_CLASS         TRACKBAR_CLASSA
+#endif
+
+#else
+#define TRACKBAR_CLASS          "msctls_trackbar"
+#endif
+
+
+// begin_r_commctrl
+
+#define TBS_AUTOTICKS           0x0001
+#define TBS_VERT                0x0002
+#define TBS_HORZ                0x0000
+#define TBS_TOP                 0x0004
+#define TBS_BOTTOM              0x0000
+#define TBS_LEFT                0x0004
+#define TBS_RIGHT               0x0000
+#define TBS_BOTH                0x0008
+#define TBS_NOTICKS             0x0010
+#define TBS_ENABLESELRANGE      0x0020
+#define TBS_FIXEDLENGTH         0x0040
+#define TBS_NOTHUMB             0x0080
+#if (_WIN32_IE >= 0x0300)
+#define TBS_TOOLTIPS            0x0100
+#endif
+
+// end_r_commctrl
+
+#define TBM_GETPOS              (WM_USER)
+#define TBM_GETRANGEMIN         (WM_USER+1)
+#define TBM_GETRANGEMAX         (WM_USER+2)
+#define TBM_GETTIC              (WM_USER+3)
+#define TBM_SETTIC              (WM_USER+4)
+#define TBM_SETPOS              (WM_USER+5)
+#define TBM_SETRANGE            (WM_USER+6)
+#define TBM_SETRANGEMIN         (WM_USER+7)
+#define TBM_SETRANGEMAX         (WM_USER+8)
+#define TBM_CLEARTICS           (WM_USER+9)
+#define TBM_SETSEL              (WM_USER+10)
+#define TBM_SETSELSTART         (WM_USER+11)
+#define TBM_SETSELEND           (WM_USER+12)
+#define TBM_GETPTICS            (WM_USER+14)
+#define TBM_GETTICPOS           (WM_USER+15)
+#define TBM_GETNUMTICS          (WM_USER+16)
+#define TBM_GETSELSTART         (WM_USER+17)
+#define TBM_GETSELEND           (WM_USER+18)
+#define TBM_CLEARSEL            (WM_USER+19)
+#define TBM_SETTICFREQ          (WM_USER+20)
+#define TBM_SETPAGESIZE         (WM_USER+21)
+#define TBM_GETPAGESIZE         (WM_USER+22)
+#define TBM_SETLINESIZE         (WM_USER+23)
+#define TBM_GETLINESIZE         (WM_USER+24)
+#define TBM_GETTHUMBRECT        (WM_USER+25)
+#define TBM_GETCHANNELRECT      (WM_USER+26)
+#define TBM_SETTHUMBLENGTH      (WM_USER+27)
+#define TBM_GETTHUMBLENGTH      (WM_USER+28)
+#if (_WIN32_IE >= 0x0300)
+#define TBM_SETTOOLTIPS         (WM_USER+29)
+#define TBM_GETTOOLTIPS         (WM_USER+30)
+#define TBM_SETTIPSIDE          (WM_USER+31)
+// TrackBar Tip Side flags
+#define TBTS_TOP                0
+#define TBTS_LEFT               1
+#define TBTS_BOTTOM             2
+#define TBTS_RIGHT              3
+
+#define TBM_SETBUDDY            (WM_USER+32) // wparam = BOOL fLeft; (or right)
+#define TBM_GETBUDDY            (WM_USER+33) // wparam = BOOL fLeft; (or right)
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TBM_SETUNICODEFORMAT    CCM_SETUNICODEFORMAT
+#define TBM_GETUNICODEFORMAT    CCM_GETUNICODEFORMAT
+#endif
+
+
+#define TB_LINEUP               0
+#define TB_LINEDOWN             1
+#define TB_PAGEUP               2
+#define TB_PAGEDOWN             3
+#define TB_THUMBPOSITION        4
+#define TB_THUMBTRACK           5
+#define TB_TOP                  6
+#define TB_BOTTOM               7
+#define TB_ENDTRACK             8
+
+
+#if (_WIN32_IE >= 0x0300)
+// custom draw item specs
+#define TBCD_TICS    0x0001
+#define TBCD_THUMB   0x0002
+#define TBCD_CHANNEL 0x0003
+#endif
+
+#endif // trackbar
+
+//====== DRAG LIST CONTROL ====================================================
+
+#ifndef NODRAGLIST
+
+typedef struct tagDRAGLISTINFO {
+    UINT uNotification;
+    HWND hWnd;
+    POINT ptCursor;
+} DRAGLISTINFO, FAR *LPDRAGLISTINFO;
+
+#define DL_BEGINDRAG            (WM_USER+133)
+#define DL_DRAGGING             (WM_USER+134)
+#define DL_DROPPED              (WM_USER+135)
+#define DL_CANCELDRAG           (WM_USER+136)
+
+#define DL_CURSORSET            0
+#define DL_STOPCURSOR           1
+#define DL_COPYCURSOR           2
+#define DL_MOVECURSOR           3
+
+#define DRAGLISTMSGSTRING       TEXT("commctrl_DragListMsg")
+
+WINCOMMCTRLAPI BOOL WINAPI MakeDragList(HWND hLB);
+WINCOMMCTRLAPI void WINAPI DrawInsert(HWND handParent, HWND hLB, int nItem);
+WINCOMMCTRLAPI int WINAPI LBItemFromPt(HWND hLB, POINT pt, BOOL bAutoScroll);
+
+#endif
+
+
+//====== UPDOWN CONTROL =======================================================
+
+#ifndef NOUPDOWN
+
+#ifdef _WIN32
+
+#define UPDOWN_CLASSA           "msctls_updown32"
+#define UPDOWN_CLASSW           L"msctls_updown32"
+
+#ifdef UNICODE
+#define  UPDOWN_CLASS           UPDOWN_CLASSW
+#else
+#define  UPDOWN_CLASS           UPDOWN_CLASSA
+#endif
+
+#else
+#define UPDOWN_CLASS            "msctls_updown"
+#endif
+
+
+typedef struct _UDACCEL {
+    UINT nSec;
+    UINT nInc;
+} UDACCEL, FAR *LPUDACCEL;
+
+#define UD_MAXVAL               0x7fff
+#define UD_MINVAL               (-UD_MAXVAL)
+
+// begin_r_commctrl
+
+#define UDS_WRAP                0x0001
+#define UDS_SETBUDDYINT         0x0002
+#define UDS_ALIGNRIGHT          0x0004
+#define UDS_ALIGNLEFT           0x0008
+#define UDS_AUTOBUDDY           0x0010
+#define UDS_ARROWKEYS           0x0020
+#define UDS_HORZ                0x0040
+#define UDS_NOTHOUSANDS         0x0080
+#if (_WIN32_IE >= 0x0300)
+#define UDS_HOTTRACK            0x0100
+#endif
+
+// end_r_commctrl
+
+#define UDM_SETRANGE            (WM_USER+101)
+#define UDM_GETRANGE            (WM_USER+102)
+#define UDM_SETPOS              (WM_USER+103)
+#define UDM_GETPOS              (WM_USER+104)
+#define UDM_SETBUDDY            (WM_USER+105)
+#define UDM_GETBUDDY            (WM_USER+106)
+#define UDM_SETACCEL            (WM_USER+107)
+#define UDM_GETACCEL            (WM_USER+108)
+#define UDM_SETBASE             (WM_USER+109)
+#define UDM_GETBASE             (WM_USER+110)
+#if (_WIN32_IE >= 0x0400)
+#define UDM_SETRANGE32          (WM_USER+111)
+#define UDM_GETRANGE32          (WM_USER+112) // wParam & lParam are LPINT
+#define UDM_SETUNICODEFORMAT    CCM_SETUNICODEFORMAT
+#define UDM_GETUNICODEFORMAT    CCM_GETUNICODEFORMAT
+#endif
+
+WINCOMMCTRLAPI HWND WINAPI CreateUpDownControl(DWORD dwStyle, int x, int y, int cx, int cy,
+                                HWND hParent, int nID, HINSTANCE hInst,
+                                HWND hBuddy,
+                                int nUpper, int nLower, int nPos);
+
+#if (_WIN32_IE >= 0x0300)
+#define NM_UPDOWN      NMUPDOWN
+#define LPNM_UPDOWN  LPNMUPDOWN
+#else
+#define NMUPDOWN      NM_UPDOWN
+#define LPNMUPDOWN  LPNM_UPDOWN
+#endif
+
+typedef struct _NM_UPDOWN
+{
+    NMHDR hdr;
+    int iPos;
+    int iDelta;
+} NMUPDOWN, FAR *LPNMUPDOWN;
+
+#define UDN_DELTAPOS            (UDN_FIRST - 1)
+
+#endif  // NOUPDOWN
+
+
+//====== PROGRESS CONTROL =====================================================
+
+#ifndef NOPROGRESS
+
+#ifdef _WIN32
+
+#define PROGRESS_CLASSA         "msctls_progress32"
+#define PROGRESS_CLASSW         L"msctls_progress32"
+
+#ifdef UNICODE
+#define  PROGRESS_CLASS         PROGRESS_CLASSW
+#else
+#define  PROGRESS_CLASS         PROGRESS_CLASSA
+#endif
+
+#else
+#define PROGRESS_CLASS          "msctls_progress"
+#endif
+
+
+#if (_WIN32_IE >= 0x0300)
+#define PBS_SMOOTH              0x01
+#define PBS_VERTICAL            0x04
+#endif
+
+#define PBM_SETRANGE            (WM_USER+1)
+#define PBM_SETPOS              (WM_USER+2)
+#define PBM_DELTAPOS            (WM_USER+3)
+#define PBM_SETSTEP             (WM_USER+4)
+#define PBM_STEPIT              (WM_USER+5)
+#if (_WIN32_IE >= 0x0300)
+#define PBM_SETRANGE32          (WM_USER+6)  // lParam = high, wParam = low
+typedef struct
+{
+   int iLow;
+   int iHigh;
+} PBRANGE, *PPBRANGE;
+#define PBM_GETRANGE            (WM_USER+7)  // wParam = return (TRUE ? low : high). lParam = PPBRANGE or NULL
+#define PBM_GETPOS              (WM_USER+8)
+#if (_WIN32_IE >= 0x0400)
+#define PBM_SETBARCOLOR         (WM_USER+9)		// lParam = bar color
+#endif      // _WIN32_IE >= 0x0400
+#define PBM_SETBKCOLOR          CCM_SETBKCOLOR  // lParam = bkColor
+#endif      // _WIN32_IE >= 0x0300
+
+#endif  // NOPROGRESS
+
+
+//====== HOTKEY CONTROL =======================================================
+
+#ifndef NOHOTKEY
+
+#define HOTKEYF_SHIFT           0x01
+#define HOTKEYF_CONTROL         0x02
+#define HOTKEYF_ALT             0x04
+#ifdef _MAC
+#define HOTKEYF_EXT             0x80
+#else
+#define HOTKEYF_EXT             0x08
+#endif
+
+#define HKCOMB_NONE             0x0001
+#define HKCOMB_S                0x0002
+#define HKCOMB_C                0x0004
+#define HKCOMB_A                0x0008
+#define HKCOMB_SC               0x0010
+#define HKCOMB_SA               0x0020
+#define HKCOMB_CA               0x0040
+#define HKCOMB_SCA              0x0080
+
+
+#define HKM_SETHOTKEY           (WM_USER+1)
+#define HKM_GETHOTKEY           (WM_USER+2)
+#define HKM_SETRULES            (WM_USER+3)
+
+#ifdef _WIN32
+
+#define HOTKEY_CLASSA           "msctls_hotkey32"
+#define HOTKEY_CLASSW           L"msctls_hotkey32"
+
+#ifdef UNICODE
+#define HOTKEY_CLASS            HOTKEY_CLASSW
+#else
+#define HOTKEY_CLASS            HOTKEY_CLASSA
+#endif
+
+#else
+#define HOTKEY_CLASS            "msctls_hotkey"
+#endif
+
+#endif  // NOHOTKEY
+
+// begin_r_commctrl
+
+//====== COMMON CONTROL STYLES ================================================
+
+#define CCS_TOP                 0x00000001L
+#define CCS_NOMOVEY             0x00000002L
+#define CCS_BOTTOM              0x00000003L
+#define CCS_NORESIZE            0x00000004L
+#define CCS_NOPARENTALIGN       0x00000008L
+#define CCS_ADJUSTABLE          0x00000020L
+#define CCS_NODIVIDER           0x00000040L
+#if (_WIN32_IE >= 0x0300)
+#define CCS_VERT                0x00000080L
+#define CCS_LEFT                (CCS_VERT | CCS_TOP)
+#define CCS_RIGHT               (CCS_VERT | CCS_BOTTOM)
+#define CCS_NOMOVEX             (CCS_VERT | CCS_NOMOVEY)
+#endif
+
+// end_r_commctrl
+
+//====== LISTVIEW CONTROL =====================================================
+
+#ifndef NOLISTVIEW
+
+#ifdef _WIN32
+
+#define WC_LISTVIEWA            "SysListView32"
+#define WC_LISTVIEWW            L"SysListView32"
+
+#ifdef UNICODE
+#define WC_LISTVIEW             WC_LISTVIEWW
+#else
+#define WC_LISTVIEW             WC_LISTVIEWA
+#endif
+
+#else
+#define WC_LISTVIEW             "SysListView"
+#endif
+
+// begin_r_commctrl
+
+#define LVS_ICON                0x0000
+#define LVS_REPORT              0x0001
+#define LVS_SMALLICON           0x0002
+#define LVS_LIST                0x0003
+#define LVS_TYPEMASK            0x0003
+#define LVS_SINGLESEL           0x0004
+#define LVS_SHOWSELALWAYS       0x0008
+#define LVS_SORTASCENDING       0x0010
+#define LVS_SORTDESCENDING      0x0020
+#define LVS_SHAREIMAGELISTS     0x0040
+#define LVS_NOLABELWRAP         0x0080
+#define LVS_AUTOARRANGE         0x0100
+#define LVS_EDITLABELS          0x0200
+#if (_WIN32_IE >= 0x0300)
+#define LVS_OWNERDATA           0x1000
+#endif
+#define LVS_NOSCROLL            0x2000
+
+#define LVS_TYPESTYLEMASK       0xfc00
+
+#define LVS_ALIGNTOP            0x0000
+#define LVS_ALIGNLEFT           0x0800
+#define LVS_ALIGNMASK           0x0c00
+
+#define LVS_OWNERDRAWFIXED      0x0400
+#define LVS_NOCOLUMNHEADER      0x4000
+#define LVS_NOSORTHEADER        0x8000
+
+// end_r_commctrl
+
+#if (_WIN32_IE >= 0x0400)
+#define LVM_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define ListView_SetUnicodeFormat(hwnd, fUnicode)  \
+    (BOOL)SNDMSG((hwnd), LVM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0)
+
+#define LVM_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+#define ListView_GetUnicodeFormat(hwnd)  \
+    (BOOL)SNDMSG((hwnd), LVM_GETUNICODEFORMAT, 0, 0)
+#endif
+
+#define LVM_GETBKCOLOR          (LVM_FIRST + 0)
+#define ListView_GetBkColor(hwnd)  \
+    (COLORREF)SNDMSG((hwnd), LVM_GETBKCOLOR, 0, 0L)
+
+#define LVM_SETBKCOLOR          (LVM_FIRST + 1)
+#define ListView_SetBkColor(hwnd, clrBk) \
+    (BOOL)SNDMSG((hwnd), LVM_SETBKCOLOR, 0, (LPARAM)(COLORREF)(clrBk))
+
+#define LVM_GETIMAGELIST        (LVM_FIRST + 2)
+#define ListView_GetImageList(hwnd, iImageList) \
+    (HIMAGELIST)SNDMSG((hwnd), LVM_GETIMAGELIST, (WPARAM)(INT)(iImageList), 0L)
+
+#define LVSIL_NORMAL            0
+#define LVSIL_SMALL             1
+#define LVSIL_STATE             2
+
+#define LVM_SETIMAGELIST        (LVM_FIRST + 3)
+#define ListView_SetImageList(hwnd, himl, iImageList) \
+    (HIMAGELIST)(UINT)SNDMSG((hwnd), LVM_SETIMAGELIST, (WPARAM)(iImageList), (LPARAM)(UINT)(HIMAGELIST)(himl))
+
+#define LVM_GETITEMCOUNT        (LVM_FIRST + 4)
+#define ListView_GetItemCount(hwnd) \
+    (int)SNDMSG((hwnd), LVM_GETITEMCOUNT, 0, 0L)
+
+
+#define LVIF_TEXT               0x0001
+#define LVIF_IMAGE              0x0002
+#define LVIF_PARAM              0x0004
+#define LVIF_STATE              0x0008
+#if (_WIN32_IE >= 0x0300)
+#define LVIF_INDENT             0x0010
+#define LVIF_NORECOMPUTE        0x0800
+#endif
+
+#define LVIS_FOCUSED            0x0001
+#define LVIS_SELECTED           0x0002
+#define LVIS_CUT                0x0004
+#define LVIS_DROPHILITED        0x0008
+#define LVIS_ACTIVATING         0x0020
+
+#define LVIS_OVERLAYMASK        0x0F00
+#define LVIS_STATEIMAGEMASK     0xF000
+
+#define INDEXTOSTATEIMAGEMASK(i) ((i) << 12)
+
+#if (_WIN32_IE >= 0x0300)
+#define I_INDENTCALLBACK        (-1)
+#define LV_ITEMA LVITEMA
+#define LV_ITEMW LVITEMW
+#else
+#define tagLVITEMA    _LV_ITEMA
+#define LVITEMA       LV_ITEMA
+#define tagLVITEMW    _LV_ITEMW
+#define LVITEMW       LV_ITEMW
+#endif
+
+#define LV_ITEM LVITEM
+
+#define LVITEMA_V1_SIZE CCSIZEOF_STRUCT(LVITEMA, lParam)
+#define LVITEMW_V1_SIZE CCSIZEOF_STRUCT(LVITEMW, lParam)
+
+typedef struct tagLVITEMA
+{
+    UINT mask;
+    int iItem;
+    int iSubItem;
+    UINT state;
+    UINT stateMask;
+    LPSTR pszText;
+    int cchTextMax;
+    int iImage;
+    LPARAM lParam;
+#if (_WIN32_IE >= 0x0300)
+    int iIndent;
+#endif
+} LVITEMA, FAR* LPLVITEMA;
+
+typedef struct tagLVITEMW
+{
+    UINT mask;
+    int iItem;
+    int iSubItem;
+    UINT state;
+    UINT stateMask;
+    LPWSTR pszText;
+    int cchTextMax;
+    int iImage;
+    LPARAM lParam;
+#if (_WIN32_IE >= 0x0300)
+    int iIndent;
+#endif
+} LVITEMW, FAR* LPLVITEMW;
+
+
+#ifdef UNICODE
+#define LVITEM    LVITEMW
+#define LPLVITEM  LPLVITEMW
+#define LVITEM_V1_SIZE LVITEMW_V1_SIZE
+#else
+#define LVITEM    LVITEMA
+#define LPLVITEM  LPLVITEMA
+#define LVITEM_V1_SIZE LVITEMA_V1_SIZE
+#endif
+
+
+#define LPSTR_TEXTCALLBACKW     ((LPWSTR)-1L)
+#define LPSTR_TEXTCALLBACKA     ((LPSTR)-1L)
+#ifdef UNICODE
+#define LPSTR_TEXTCALLBACK      LPSTR_TEXTCALLBACKW
+#else
+#define LPSTR_TEXTCALLBACK      LPSTR_TEXTCALLBACKA
+#endif
+
+#define I_IMAGECALLBACK         (-1)
+
+#define LVM_GETITEMA            (LVM_FIRST + 5)
+#define LVM_GETITEMW            (LVM_FIRST + 75)
+#ifdef UNICODE
+#define LVM_GETITEM             LVM_GETITEMW
+#else
+#define LVM_GETITEM             LVM_GETITEMA
+#endif
+
+#define ListView_GetItem(hwnd, pitem) \
+    (BOOL)SNDMSG((hwnd), LVM_GETITEM, 0, (LPARAM)(LV_ITEM FAR*)(pitem))
+
+
+#define LVM_SETITEMA            (LVM_FIRST + 6)
+#define LVM_SETITEMW            (LVM_FIRST + 76)
+#ifdef UNICODE
+#define LVM_SETITEM             LVM_SETITEMW
+#else
+#define LVM_SETITEM             LVM_SETITEMA
+#endif
+
+#define ListView_SetItem(hwnd, pitem) \
+    (BOOL)SNDMSG((hwnd), LVM_SETITEM, 0, (LPARAM)(const LV_ITEM FAR*)(pitem))
+
+
+#define LVM_INSERTITEMA         (LVM_FIRST + 7)
+#define LVM_INSERTITEMW         (LVM_FIRST + 77)
+#ifdef UNICODE
+#define LVM_INSERTITEM          LVM_INSERTITEMW
+#else
+#define LVM_INSERTITEM          LVM_INSERTITEMA
+#endif
+#define ListView_InsertItem(hwnd, pitem)   \
+    (int)SNDMSG((hwnd), LVM_INSERTITEM, 0, (LPARAM)(const LV_ITEM FAR*)(pitem))
+
+
+#define LVM_DELETEITEM          (LVM_FIRST + 8)
+#define ListView_DeleteItem(hwnd, i) \
+    (BOOL)SNDMSG((hwnd), LVM_DELETEITEM, (WPARAM)(int)(i), 0L)
+
+
+#define LVM_DELETEALLITEMS      (LVM_FIRST + 9)
+#define ListView_DeleteAllItems(hwnd) \
+    (BOOL)SNDMSG((hwnd), LVM_DELETEALLITEMS, 0, 0L)
+
+
+#define LVM_GETCALLBACKMASK     (LVM_FIRST + 10)
+#define ListView_GetCallbackMask(hwnd) \
+    (BOOL)SNDMSG((hwnd), LVM_GETCALLBACKMASK, 0, 0)
+
+
+#define LVM_SETCALLBACKMASK     (LVM_FIRST + 11)
+#define ListView_SetCallbackMask(hwnd, mask) \
+    (BOOL)SNDMSG((hwnd), LVM_SETCALLBACKMASK, (WPARAM)(UINT)(mask), 0)
+
+
+#define LVNI_ALL                0x0000
+#define LVNI_FOCUSED            0x0001
+#define LVNI_SELECTED           0x0002
+#define LVNI_CUT                0x0004
+#define LVNI_DROPHILITED        0x0008
+
+#define LVNI_ABOVE              0x0100
+#define LVNI_BELOW              0x0200
+#define LVNI_TOLEFT             0x0400
+#define LVNI_TORIGHT            0x0800
+
+
+#define LVM_GETNEXTITEM         (LVM_FIRST + 12)
+#define ListView_GetNextItem(hwnd, i, flags) \
+    (int)SNDMSG((hwnd), LVM_GETNEXTITEM, (WPARAM)(int)(i), MAKELPARAM((flags), 0))
+
+
+#define LVFI_PARAM              0x0001
+#define LVFI_STRING             0x0002
+#define LVFI_PARTIAL            0x0008
+#define LVFI_WRAP               0x0020
+#define LVFI_NEARESTXY          0x0040
+
+#if (_WIN32_IE >= 0x0300)
+#define LV_FINDINFOA    LVFINDINFOA
+#define LV_FINDINFOW    LVFINDINFOW
+#else
+#define tagLVFINDINFOA  _LV_FINDINFOA
+#define    LVFINDINFOA   LV_FINDINFOA
+#define tagLVFINDINFOW  _LV_FINDINFOW
+#define    LVFINDINFOW   LV_FINDINFOW
+#endif
+
+#define LV_FINDINFO  LVFINDINFO
+
+typedef struct tagLVFINDINFOA
+{
+    UINT flags;
+    LPCSTR psz;
+    LPARAM lParam;
+    POINT pt;
+    UINT vkDirection;
+} LVFINDINFOA, FAR* LPFINDINFOA;
+
+typedef struct tagLVFINDINFOW
+{
+    UINT flags;
+    LPCWSTR psz;
+    LPARAM lParam;
+    POINT pt;
+    UINT vkDirection;
+} LVFINDINFOW, FAR* LPFINDINFOW;
+
+#ifdef UNICODE
+#define  LVFINDINFO            LVFINDINFOW
+#else
+#define  LVFINDINFO            LVFINDINFOA
+#endif
+
+#define LVM_FINDITEMA           (LVM_FIRST + 13)
+#define LVM_FINDITEMW           (LVM_FIRST + 83)
+#ifdef UNICODE
+#define  LVM_FINDITEM           LVM_FINDITEMW
+#else
+#define  LVM_FINDITEM           LVM_FINDITEMA
+#endif
+
+#define ListView_FindItem(hwnd, iStart, plvfi) \
+    (int)SNDMSG((hwnd), LVM_FINDITEM, (WPARAM)(int)(iStart), (LPARAM)(const LV_FINDINFO FAR*)(plvfi))
+
+#define LVIR_BOUNDS             0
+#define LVIR_ICON               1
+#define LVIR_LABEL              2
+#define LVIR_SELECTBOUNDS       3
+
+
+#define LVM_GETITEMRECT         (LVM_FIRST + 14)
+#define ListView_GetItemRect(hwnd, i, prc, code) \
+     (BOOL)SNDMSG((hwnd), LVM_GETITEMRECT, (WPARAM)(int)(i), \
+           ((prc) ? (((RECT FAR *)(prc))->left = (code),(LPARAM)(RECT FAR*)(prc)) : (LPARAM)(RECT FAR*)NULL))
+
+
+#define LVM_SETITEMPOSITION     (LVM_FIRST + 15)
+#define ListView_SetItemPosition(hwndLV, i, x, y) \
+    (BOOL)SNDMSG((hwndLV), LVM_SETITEMPOSITION, (WPARAM)(int)(i), MAKELPARAM((x), (y)))
+
+
+#define LVM_GETITEMPOSITION     (LVM_FIRST + 16)
+#define ListView_GetItemPosition(hwndLV, i, ppt) \
+    (BOOL)SNDMSG((hwndLV), LVM_GETITEMPOSITION, (WPARAM)(int)(i), (LPARAM)(POINT FAR*)(ppt))
+
+
+#define LVM_GETSTRINGWIDTHA     (LVM_FIRST + 17)
+#define LVM_GETSTRINGWIDTHW     (LVM_FIRST + 87)
+#ifdef UNICODE
+#define  LVM_GETSTRINGWIDTH     LVM_GETSTRINGWIDTHW
+#else
+#define  LVM_GETSTRINGWIDTH     LVM_GETSTRINGWIDTHA
+#endif
+
+#define ListView_GetStringWidth(hwndLV, psz) \
+    (int)SNDMSG((hwndLV), LVM_GETSTRINGWIDTH, 0, (LPARAM)(LPCTSTR)(psz))
+
+
+#define LVHT_NOWHERE            0x0001
+#define LVHT_ONITEMICON         0x0002
+#define LVHT_ONITEMLABEL        0x0004
+#define LVHT_ONITEMSTATEICON    0x0008
+#define LVHT_ONITEM             (LVHT_ONITEMICON | LVHT_ONITEMLABEL | LVHT_ONITEMSTATEICON)
+
+#define LVHT_ABOVE              0x0008
+#define LVHT_BELOW              0x0010
+#define LVHT_TORIGHT            0x0020
+#define LVHT_TOLEFT             0x0040
+
+#if (_WIN32_IE >= 0x0300)
+#define LV_HITTESTINFO LVHITTESTINFO
+#else
+#define tagLVHITTESTINFO  _LV_HITTESTINFO
+#define    LVHITTESTINFO   LV_HITTESTINFO
+#endif
+
+#define LVHITTESTINFO_V1_SIZE CCSIZEOF_STRUCT(LVHITTESTINFO, iItem)
+
+typedef struct tagLVHITTESTINFO
+{
+    POINT pt;
+    UINT flags;
+    int iItem;
+#if (_WIN32_IE >= 0x0300)
+    int iSubItem;    // this is was NOT in win95.  valid only for LVM_SUBITEMHITTEST
+#endif
+} LVHITTESTINFO, FAR* LPLVHITTESTINFO;
+
+#define LVM_HITTEST             (LVM_FIRST + 18)
+#define ListView_HitTest(hwndLV, pinfo) \
+    (int)SNDMSG((hwndLV), LVM_HITTEST, 0, (LPARAM)(LV_HITTESTINFO FAR*)(pinfo))
+
+
+#define LVM_ENSUREVISIBLE       (LVM_FIRST + 19)
+#define ListView_EnsureVisible(hwndLV, i, fPartialOK) \
+    (BOOL)SNDMSG((hwndLV), LVM_ENSUREVISIBLE, (WPARAM)(int)(i), MAKELPARAM((fPartialOK), 0))
+
+
+#define LVM_SCROLL              (LVM_FIRST + 20)
+#define ListView_Scroll(hwndLV, dx, dy) \
+    (BOOL)SNDMSG((hwndLV), LVM_SCROLL, (WPARAM)(int)dx, (LPARAM)(int)dy)
+
+
+#define LVM_REDRAWITEMS         (LVM_FIRST + 21)
+#define ListView_RedrawItems(hwndLV, iFirst, iLast) \
+    (BOOL)SNDMSG((hwndLV), LVM_REDRAWITEMS, (WPARAM)(int)iFirst, (LPARAM)(int)iLast)
+
+
+#define LVA_DEFAULT             0x0000
+#define LVA_ALIGNLEFT           0x0001
+#define LVA_ALIGNTOP            0x0002
+#define LVA_SNAPTOGRID          0x0005
+
+#define LVM_ARRANGE             (LVM_FIRST + 22)
+#define ListView_Arrange(hwndLV, code) \
+    (BOOL)SNDMSG((hwndLV), LVM_ARRANGE, (WPARAM)(UINT)(code), 0L)
+
+
+#define LVM_EDITLABELA          (LVM_FIRST + 23)
+#define LVM_EDITLABELW          (LVM_FIRST + 118)
+#ifdef UNICODE
+#define LVM_EDITLABEL           LVM_EDITLABELW
+#else
+#define LVM_EDITLABEL           LVM_EDITLABELA
+#endif
+
+#define ListView_EditLabel(hwndLV, i) \
+    (HWND)SNDMSG((hwndLV), LVM_EDITLABEL, (WPARAM)(int)(i), 0L)
+
+
+#define LVM_GETEDITCONTROL      (LVM_FIRST + 24)
+#define ListView_GetEditControl(hwndLV) \
+    (HWND)SNDMSG((hwndLV), LVM_GETEDITCONTROL, 0, 0L)
+
+
+#if (_WIN32_IE >= 0x0300)
+#define LV_COLUMNA      LVCOLUMNA
+#define LV_COLUMNW      LVCOLUMNW
+#else
+#define tagLVCOLUMNA    _LV_COLUMNA
+#define    LVCOLUMNA     LV_COLUMNA
+#define tagLVCOLUMNW    _LV_COLUMNW
+#define    LVCOLUMNW     LV_COLUMNW
+#endif
+
+#define LV_COLUMN       LVCOLUMN
+
+#define LVCOLUMNA_V1_SIZE CCSIZEOF_STRUCT(LVCOLUMNA, iSubItem)
+#define LVCOLUMNW_V1_SIZE CCSIZEOF_STRUCT(LVCOLUMNW, iSubItem)
+
+typedef struct tagLVCOLUMNA
+{
+    UINT mask;
+    int fmt;
+    int cx;
+    LPSTR pszText;
+    int cchTextMax;
+    int iSubItem;
+#if (_WIN32_IE >= 0x0300)
+    int iImage;
+    int iOrder;
+#endif
+} LVCOLUMNA, FAR* LPLVCOLUMNA;
+
+typedef struct tagLVCOLUMNW
+{
+    UINT mask;
+    int fmt;
+    int cx;
+    LPWSTR pszText;
+    int cchTextMax;
+    int iSubItem;
+#if (_WIN32_IE >= 0x0300)
+    int iImage;
+    int iOrder;
+#endif
+} LVCOLUMNW, FAR* LPLVCOLUMNW;
+
+#ifdef UNICODE
+#define  LVCOLUMN               LVCOLUMNW
+#define  LPLVCOLUMN             LPLVCOLUMNW
+#define LVCOLUMN_V1_SIZE LVCOLUMNW_V1_SIZE
+#else
+#define  LVCOLUMN               LVCOLUMNA
+#define  LPLVCOLUMN             LPLVCOLUMNA
+#define LVCOLUMN_V1_SIZE LVCOLUMNA_V1_SIZE
+#endif
+
+
+#define LVCF_FMT                0x0001
+#define LVCF_WIDTH              0x0002
+#define LVCF_TEXT               0x0004
+#define LVCF_SUBITEM            0x0008
+#if (_WIN32_IE >= 0x0300)
+#define LVCF_IMAGE              0x0010
+#define LVCF_ORDER              0x0020
+#endif
+
+#define LVCFMT_LEFT             0x0000
+#define LVCFMT_RIGHT            0x0001
+#define LVCFMT_CENTER           0x0002
+#define LVCFMT_JUSTIFYMASK      0x0003
+#if (_WIN32_IE >= 0x0300)
+#define LVCFMT_IMAGE            0x0800
+#define LVCFMT_BITMAP_ON_RIGHT  0x1000
+#define LVCFMT_COL_HAS_IMAGES   0x8000
+#endif
+
+#define LVM_GETCOLUMNA          (LVM_FIRST + 25)
+#define LVM_GETCOLUMNW          (LVM_FIRST + 95)
+#ifdef UNICODE
+#define  LVM_GETCOLUMN          LVM_GETCOLUMNW
+#else
+#define  LVM_GETCOLUMN          LVM_GETCOLUMNA
+#endif
+
+#define ListView_GetColumn(hwnd, iCol, pcol) \
+    (BOOL)SNDMSG((hwnd), LVM_GETCOLUMN, (WPARAM)(int)(iCol), (LPARAM)(LV_COLUMN FAR*)(pcol))
+
+
+#define LVM_SETCOLUMNA          (LVM_FIRST + 26)
+#define LVM_SETCOLUMNW          (LVM_FIRST + 96)
+#ifdef UNICODE
+#define  LVM_SETCOLUMN          LVM_SETCOLUMNW
+#else
+#define  LVM_SETCOLUMN          LVM_SETCOLUMNA
+#endif
+
+#define ListView_SetColumn(hwnd, iCol, pcol) \
+    (BOOL)SNDMSG((hwnd), LVM_SETCOLUMN, (WPARAM)(int)(iCol), (LPARAM)(const LV_COLUMN FAR*)(pcol))
+
+
+#define LVM_INSERTCOLUMNA       (LVM_FIRST + 27)
+#define LVM_INSERTCOLUMNW       (LVM_FIRST + 97)
+#ifdef UNICODE
+#   define  LVM_INSERTCOLUMN    LVM_INSERTCOLUMNW
+#else
+#   define  LVM_INSERTCOLUMN    LVM_INSERTCOLUMNA
+#endif
+
+#define ListView_InsertColumn(hwnd, iCol, pcol) \
+    (int)SNDMSG((hwnd), LVM_INSERTCOLUMN, (WPARAM)(int)(iCol), (LPARAM)(const LV_COLUMN FAR*)(pcol))
+
+
+#define LVM_DELETECOLUMN        (LVM_FIRST + 28)
+#define ListView_DeleteColumn(hwnd, iCol) \
+    (BOOL)SNDMSG((hwnd), LVM_DELETECOLUMN, (WPARAM)(int)(iCol), 0)
+
+
+#define LVM_GETCOLUMNWIDTH      (LVM_FIRST + 29)
+#define ListView_GetColumnWidth(hwnd, iCol) \
+    (int)SNDMSG((hwnd), LVM_GETCOLUMNWIDTH, (WPARAM)(int)(iCol), 0)
+
+
+#define LVSCW_AUTOSIZE              -1
+#define LVSCW_AUTOSIZE_USEHEADER    -2
+#define LVM_SETCOLUMNWIDTH          (LVM_FIRST + 30)
+
+#define ListView_SetColumnWidth(hwnd, iCol, cx) \
+    (BOOL)SNDMSG((hwnd), LVM_SETCOLUMNWIDTH, (WPARAM)(int)(iCol), MAKELPARAM((cx), 0))
+
+#if (_WIN32_IE >= 0x0300)
+#define LVM_GETHEADER               (LVM_FIRST + 31)
+#define ListView_GetHeader(hwnd)\
+    (HWND)SNDMSG((hwnd), LVM_GETHEADER, 0, 0L)
+#endif
+
+#define LVM_CREATEDRAGIMAGE     (LVM_FIRST + 33)
+#define ListView_CreateDragImage(hwnd, i, lpptUpLeft) \
+    (HIMAGELIST)SNDMSG((hwnd), LVM_CREATEDRAGIMAGE, (WPARAM)(int)(i), (LPARAM)(LPPOINT)(lpptUpLeft))
+
+
+#define LVM_GETVIEWRECT         (LVM_FIRST + 34)
+#define ListView_GetViewRect(hwnd, prc) \
+    (BOOL)SNDMSG((hwnd), LVM_GETVIEWRECT, 0, (LPARAM)(RECT FAR*)(prc))
+
+
+#define LVM_GETTEXTCOLOR        (LVM_FIRST + 35)
+#define ListView_GetTextColor(hwnd)  \
+    (COLORREF)SNDMSG((hwnd), LVM_GETTEXTCOLOR, 0, 0L)
+
+
+#define LVM_SETTEXTCOLOR        (LVM_FIRST + 36)
+#define ListView_SetTextColor(hwnd, clrText) \
+    (BOOL)SNDMSG((hwnd), LVM_SETTEXTCOLOR, 0, (LPARAM)(COLORREF)(clrText))
+
+
+#define LVM_GETTEXTBKCOLOR      (LVM_FIRST + 37)
+#define ListView_GetTextBkColor(hwnd)  \
+    (COLORREF)SNDMSG((hwnd), LVM_GETTEXTBKCOLOR, 0, 0L)
+
+
+#define LVM_SETTEXTBKCOLOR      (LVM_FIRST + 38)
+#define ListView_SetTextBkColor(hwnd, clrTextBk) \
+    (BOOL)SNDMSG((hwnd), LVM_SETTEXTBKCOLOR, 0, (LPARAM)(COLORREF)(clrTextBk))
+
+
+#define LVM_GETTOPINDEX         (LVM_FIRST + 39)
+#define ListView_GetTopIndex(hwndLV) \
+    (int)SNDMSG((hwndLV), LVM_GETTOPINDEX, 0, 0)
+
+
+#define LVM_GETCOUNTPERPAGE     (LVM_FIRST + 40)
+#define ListView_GetCountPerPage(hwndLV) \
+    (int)SNDMSG((hwndLV), LVM_GETCOUNTPERPAGE, 0, 0)
+
+
+#define LVM_GETORIGIN           (LVM_FIRST + 41)
+#define ListView_GetOrigin(hwndLV, ppt) \
+    (BOOL)SNDMSG((hwndLV), LVM_GETORIGIN, (WPARAM)0, (LPARAM)(POINT FAR*)(ppt))
+
+
+#define LVM_UPDATE              (LVM_FIRST + 42)
+#define ListView_Update(hwndLV, i) \
+    (BOOL)SNDMSG((hwndLV), LVM_UPDATE, (WPARAM)i, 0L)
+
+
+#define LVM_SETITEMSTATE        (LVM_FIRST + 43)
+#define ListView_SetItemState(hwndLV, i, data, mask) \
+{ LV_ITEM _ms_lvi;\
+  _ms_lvi.stateMask = mask;\
+  _ms_lvi.state = data;\
+  SNDMSG((hwndLV), LVM_SETITEMSTATE, (WPARAM)i, (LPARAM)(LV_ITEM FAR *)&_ms_lvi);\
+}
+
+
+#define LVM_GETITEMSTATE        (LVM_FIRST + 44)
+#define ListView_GetItemState(hwndLV, i, mask) \
+   (UINT)SNDMSG((hwndLV), LVM_GETITEMSTATE, (WPARAM)i, (LPARAM)mask)
+
+#if (_WIN32_IE >= 0x0300)
+#define ListView_GetCheckState(hwndLV, i) \
+   ((((UINT)(SNDMSG((hwndLV), LVM_GETITEMSTATE, (WPARAM)i, LVIS_STATEIMAGEMASK))) >> 12) -1)
+#endif
+
+#define LVM_GETITEMTEXTA        (LVM_FIRST + 45)
+#define LVM_GETITEMTEXTW        (LVM_FIRST + 115)
+
+#ifdef UNICODE
+#define  LVM_GETITEMTEXT        LVM_GETITEMTEXTW
+#else
+#define  LVM_GETITEMTEXT        LVM_GETITEMTEXTA
+#endif
+
+#define ListView_GetItemText(hwndLV, i, iSubItem_, pszText_, cchTextMax_) \
+{ LV_ITEM _ms_lvi;\
+  _ms_lvi.iSubItem = iSubItem_;\
+  _ms_lvi.cchTextMax = cchTextMax_;\
+  _ms_lvi.pszText = pszText_;\
+  SNDMSG((hwndLV), LVM_GETITEMTEXT, (WPARAM)i, (LPARAM)(LV_ITEM FAR *)&_ms_lvi);\
+}
+
+
+#define LVM_SETITEMTEXTA        (LVM_FIRST + 46)
+#define LVM_SETITEMTEXTW        (LVM_FIRST + 116)
+
+#ifdef UNICODE
+#define  LVM_SETITEMTEXT        LVM_SETITEMTEXTW
+#else
+#define  LVM_SETITEMTEXT        LVM_SETITEMTEXTA
+#endif
+
+#define ListView_SetItemText(hwndLV, i, iSubItem_, pszText_) \
+{ LV_ITEM _ms_lvi;\
+  _ms_lvi.iSubItem = iSubItem_;\
+  _ms_lvi.pszText = pszText_;\
+  SNDMSG((hwndLV), LVM_SETITEMTEXT, (WPARAM)i, (LPARAM)(LV_ITEM FAR *)&_ms_lvi);\
+}
+
+#if (_WIN32_IE >= 0x0300)
+// these flags only apply to LVS_OWNERDATA listviews in report or list mode
+#define LVSICF_NOINVALIDATEALL  0x00000001
+#define LVSICF_NOSCROLL         0x00000002
+#endif
+
+#define LVM_SETITEMCOUNT        (LVM_FIRST + 47)
+#define ListView_SetItemCount(hwndLV, cItems) \
+  SNDMSG((hwndLV), LVM_SETITEMCOUNT, (WPARAM)cItems, 0)
+
+#if (_WIN32_IE >= 0x0300)
+#define ListView_SetItemCountEx(hwndLV, cItems, dwFlags) \
+  SNDMSG((hwndLV), LVM_SETITEMCOUNT, (WPARAM)cItems, (LPARAM)dwFlags)
+#endif
+
+typedef int (CALLBACK *PFNLVCOMPARE)(LPARAM, LPARAM, LPARAM);
+
+
+#define LVM_SORTITEMS           (LVM_FIRST + 48)
+#define ListView_SortItems(hwndLV, _pfnCompare, _lPrm) \
+  (BOOL)SNDMSG((hwndLV), LVM_SORTITEMS, (WPARAM)(LPARAM)_lPrm, \
+  (LPARAM)(PFNLVCOMPARE)_pfnCompare)
+
+
+#define LVM_SETITEMPOSITION32   (LVM_FIRST + 49)
+#define ListView_SetItemPosition32(hwndLV, i, x, y) \
+{ POINT ptNewPos = {x,y}; \
+    SNDMSG((hwndLV), LVM_SETITEMPOSITION32, (WPARAM)(int)(i), (LPARAM)&ptNewPos); \
+}
+
+
+#define LVM_GETSELECTEDCOUNT    (LVM_FIRST + 50)
+#define ListView_GetSelectedCount(hwndLV) \
+    (UINT)SNDMSG((hwndLV), LVM_GETSELECTEDCOUNT, 0, 0L)
+
+
+#define LVM_GETITEMSPACING      (LVM_FIRST + 51)
+#define ListView_GetItemSpacing(hwndLV, fSmall) \
+        (DWORD)SNDMSG((hwndLV), LVM_GETITEMSPACING, fSmall, 0L)
+
+
+#define LVM_GETISEARCHSTRINGA   (LVM_FIRST + 52)
+#define LVM_GETISEARCHSTRINGW   (LVM_FIRST + 117)
+
+#ifdef UNICODE
+#define LVM_GETISEARCHSTRING    LVM_GETISEARCHSTRINGW
+#else
+#define LVM_GETISEARCHSTRING    LVM_GETISEARCHSTRINGA
+#endif
+
+#define ListView_GetISearchString(hwndLV, lpsz) \
+        (BOOL)SNDMSG((hwndLV), LVM_GETISEARCHSTRING, 0, (LPARAM)(LPTSTR)lpsz)
+
+#if (_WIN32_IE >= 0x0300)
+#define LVM_SETICONSPACING      (LVM_FIRST + 53)
+// -1 for cx and cy means we'll use the default (system settings)
+// 0 for cx or cy means use the current setting (allows you to change just one param)
+#define ListView_SetIconSpacing(hwndLV, cx, cy) \
+        (DWORD)SNDMSG((hwndLV), LVM_SETICONSPACING, 0, MAKELONG(cx,cy))
+
+
+#define LVM_SETEXTENDEDLISTVIEWSTYLE (LVM_FIRST + 54)   // optional wParam == mask
+#define ListView_SetExtendedListViewStyle(hwndLV, dw)\
+        (DWORD)SNDMSG((hwndLV), LVM_SETEXTENDEDLISTVIEWSTYLE, 0, dw)
+#if (_WIN32_IE >= 0x0400)
+#define ListView_SetExtendedListViewStyleEx(hwndLV, dwMask, dw)\
+        (DWORD)SNDMSG((hwndLV), LVM_SETEXTENDEDLISTVIEWSTYLE, dwMask, dw)
+#endif
+
+#define LVM_GETEXTENDEDLISTVIEWSTYLE (LVM_FIRST + 55)
+#define ListView_GetExtendedListViewStyle(hwndLV)\
+        (DWORD)SNDMSG((hwndLV), LVM_GETEXTENDEDLISTVIEWSTYLE, 0, 0)
+
+#define LVS_EX_GRIDLINES        0x00000001
+#define LVS_EX_SUBITEMIMAGES    0x00000002
+#define LVS_EX_CHECKBOXES       0x00000004
+#define LVS_EX_TRACKSELECT      0x00000008
+#define LVS_EX_HEADERDRAGDROP   0x00000010
+#define LVS_EX_FULLROWSELECT    0x00000020 // applies to report mode only
+#define LVS_EX_ONECLICKACTIVATE 0x00000040
+#define LVS_EX_TWOCLICKACTIVATE 0x00000080
+#if (_WIN32_IE >= 0x0400)
+#define LVS_EX_FLATSB           0x00000100
+#define LVS_EX_REGIONAL         0x00000200
+#define LVS_EX_INFOTIP          0x00000400 // listview does InfoTips for you
+#define LVS_EX_UNDERLINEHOT     0x00000800
+#define LVS_EX_UNDERLINECOLD    0x00001000
+#define LVS_EX_MULTIWORKAREAS   0x00002000
+#endif
+
+#define LVM_GETSUBITEMRECT      (LVM_FIRST + 56)
+#define ListView_GetSubItemRect(hwnd, iItem, iSubItem, code, prc) \
+        (BOOL)SNDMSG((hwnd), LVM_GETSUBITEMRECT, (WPARAM)(int)(iItem), \
+                ((prc) ? ((((LPRECT)(prc))->top = iSubItem), (((LPRECT)(prc))->left = code), (LPARAM)(prc)) : (LPARAM)(LPRECT)NULL))
+
+#define LVM_SUBITEMHITTEST      (LVM_FIRST + 57)
+#define ListView_SubItemHitTest(hwnd, plvhti) \
+        (int)SNDMSG((hwnd), LVM_SUBITEMHITTEST, 0, (LPARAM)(LPLVHITTESTINFO)(plvhti))
+
+#define LVM_SETCOLUMNORDERARRAY (LVM_FIRST + 58)
+#define ListView_SetColumnOrderArray(hwnd, iCount, pi) \
+        (BOOL)SNDMSG((hwnd), LVM_SETCOLUMNORDERARRAY, (WPARAM)iCount, (LPARAM)(LPINT)pi)
+
+#define LVM_GETCOLUMNORDERARRAY (LVM_FIRST + 59)
+#define ListView_GetColumnOrderArray(hwnd, iCount, pi) \
+        (BOOL)SNDMSG((hwnd), LVM_GETCOLUMNORDERARRAY, (WPARAM)iCount, (LPARAM)(LPINT)pi)
+
+#define LVM_SETHOTITEM  (LVM_FIRST + 60)
+#define ListView_SetHotItem(hwnd, i) \
+        (int)SNDMSG((hwnd), LVM_SETHOTITEM, (WPARAM)i, 0)
+
+#define LVM_GETHOTITEM  (LVM_FIRST + 61)
+#define ListView_GetHotItem(hwnd) \
+        (int)SNDMSG((hwnd), LVM_GETHOTITEM, 0, 0)
+
+#define LVM_SETHOTCURSOR  (LVM_FIRST + 62)
+#define ListView_SetHotCursor(hwnd, hcur) \
+        (HCURSOR)SNDMSG((hwnd), LVM_SETHOTCURSOR, 0, (LPARAM)hcur)
+
+#define LVM_GETHOTCURSOR  (LVM_FIRST + 63)
+#define ListView_GetHotCursor(hwnd) \
+        (HCURSOR)SNDMSG((hwnd), LVM_GETHOTCURSOR, 0, 0)
+
+#define LVM_APPROXIMATEVIEWRECT (LVM_FIRST + 64)
+#define ListView_ApproximateViewRect(hwnd, iWidth, iHeight, iCount) \
+        (DWORD)SNDMSG((hwnd), LVM_APPROXIMATEVIEWRECT, iCount, MAKELPARAM(iWidth, iHeight))
+#endif      // _WIN32_IE >= 0x0300
+
+#if (_WIN32_IE >= 0x0400)
+
+#define LV_MAX_WORKAREAS         16                          
+#define LVM_SETWORKAREAS         (LVM_FIRST + 65)
+#define ListView_SetWorkAreas(hwnd, nWorkAreas, prc) \
+    (BOOL)SNDMSG((hwnd), LVM_SETWORKAREAS, (WPARAM)(int)nWorkAreas, (LPARAM)(RECT FAR*)(prc))
+
+#define LVM_GETWORKAREAS        (LVM_FIRST + 70)
+#define ListView_GetWorkAreas(hwnd, nWorkAreas, prc) \
+    (BOOL)SNDMSG((hwnd), LVM_GETWORKAREAS, (WPARAM)(int)nWorkAreas, (LPARAM)(RECT FAR*)(prc))
+
+
+#define LVM_GETNUMBEROFWORKAREAS  (LVM_FIRST + 73)
+#define ListView_GetNumberOfWorkAreas(hwnd, pnWorkAreas) \
+    (BOOL)SNDMSG((hwnd), LVM_GETNUMBEROFWORKAREAS, 0, (LPARAM)(UINT *)(pnWorkAreas))
+
+
+#define LVM_GETSELECTIONMARK    (LVM_FIRST + 66)
+#define ListView_GetSelectionMark(hwnd) \
+    (int)SNDMSG((hwnd), LVM_GETSELECTIONMARK, 0, 0)
+
+#define LVM_SETSELECTIONMARK    (LVM_FIRST + 67)
+#define ListView_SetSelectionMark(hwnd, i) \
+    (int)SNDMSG((hwnd), LVM_SETSELECTIONMARK, 0, (LPARAM)i)
+
+#define LVM_SETHOVERTIME        (LVM_FIRST + 71)
+#define ListView_SetHoverTime(hwndLV, dwHoverTimeMs)\
+        (DWORD)SendMessage((hwndLV), LVM_SETHOVERTIME, 0, dwHoverTimeMs)
+
+#define LVM_GETHOVERTIME        (LVM_FIRST + 72)
+#define ListView_GetHoverTime(hwndLV)\
+        (DWORD)SendMessage((hwndLV), LVM_GETHOVERTIME, 0, 0)
+
+#define LVM_SETTOOLTIPS       (LVM_FIRST + 74)
+#define ListView_SetToolTips(hwndLV, hwndNewHwnd)\
+        (HWND)SendMessage((hwndLV), LVM_SETTOOLTIPS, hwndNewHwnd, 0)
+
+#define LVM_GETTOOLTIPS       (LVM_FIRST + 78)
+#define ListView_GetToolTips(hwndLV)\
+        (HWND)SendMessage((hwndLV), LVM_GETTOOLTIPS, 0, 0)
+
+
+typedef struct tagLVBKIMAGEA
+{
+    ULONG ulFlags;              // LVBKIF_*
+    HBITMAP hbm;
+    LPSTR pszImage;
+    UINT cchImageMax;
+    int xOffsetPercent;
+    int yOffsetPercent;
+} LVBKIMAGEA, FAR *LPLVBKIMAGEA;
+typedef struct tagLVBKIMAGEW
+{
+    ULONG ulFlags;              // LVBKIF_*
+    HBITMAP hbm;
+    LPWSTR pszImage;
+    UINT cchImageMax;
+    int xOffsetPercent;
+    int yOffsetPercent;
+} LVBKIMAGEW, FAR *LPLVBKIMAGEW;
+
+#define LVBKIF_SOURCE_NONE      0x00000000
+#define LVBKIF_SOURCE_HBITMAP   0x00000001
+#define LVBKIF_SOURCE_URL       0x00000002
+#define LVBKIF_SOURCE_MASK      0x00000003
+#define LVBKIF_STYLE_NORMAL     0x00000000
+#define LVBKIF_STYLE_TILE       0x00000010
+#define LVBKIF_STYLE_MASK       0x00000010
+
+#define LVM_SETBKIMAGEA         (LVM_FIRST + 68)
+#define LVM_SETBKIMAGEW         (LVM_FIRST + 138)
+#define LVM_GETBKIMAGEA         (LVM_FIRST + 69)
+#define LVM_GETBKIMAGEW         (LVM_FIRST + 139)
+
+#ifdef UNICODE
+#define LVBKIMAGE               LVBKIMAGEW
+#define LPLVBKIMAGE             LPLVBKIMAGEW
+#define LVM_SETBKIMAGE          LVM_SETBKIMAGEW
+#define LVM_GETBKIMAGE          LVM_GETBKIMAGEW
+#else
+#define LVBKIMAGE               LVBKIMAGEA
+#define LPLVBKIMAGE             LPLVBKIMAGEA
+#define LVM_SETBKIMAGE          LVM_SETBKIMAGEA
+#define LVM_GETBKIMAGE          LVM_GETBKIMAGEA
+#endif
+
+#define ListView_SetBkImage(hwnd, plvbki) \
+    (BOOL)SNDMSG((hwnd), LVM_SETBKIMAGE, 0, (LPARAM)plvbki)
+
+#define ListView_GetBkImage(hwnd, plvbki) \
+    (BOOL)SNDMSG((hwnd), LVM_GETBKIMAGE, 0, (LPARAM)plvbki)
+
+
+#endif      // _WIN32_IE >= 0x0400
+
+#if (_WIN32_IE >= 0x0300)
+#define LPNM_LISTVIEW   LPNMLISTVIEW
+#define NM_LISTVIEW     NMLISTVIEW
+#else
+#define tagNMLISTVIEW   _NM_LISTVIEW
+#define    NMLISTVIEW    NM_LISTVIEW
+#define  LPNMLISTVIEW  LPNM_LISTVIEW
+#endif
+
+typedef struct tagNMLISTVIEW
+{
+    NMHDR   hdr;
+    int     iItem;
+    int     iSubItem;
+    UINT    uNewState;
+    UINT    uOldState;
+    UINT    uChanged;
+    POINT   ptAction;
+    LPARAM  lParam;
+} NMLISTVIEW, FAR *LPNMLISTVIEW;
+
+
+#if (_WIN32_IE >= 0x400)
+// NMITEMACTIVATE is used instead of NMLISTVIEW in IE >= 0x400
+// therefore all the fields are the same except for extra uKeyFlags
+// they are used to store key flags at the time of the single click with
+// delayed activation - because by the time the timer goes off a user may
+// not hold the keys (shift, ctrl) any more
+typedef struct tagNMITEMACTIVATE
+{
+    NMHDR   hdr;
+    int     iItem;
+    int     iSubItem;
+    UINT    uNewState;
+    UINT    uOldState;
+    UINT    uChanged;
+    POINT   ptAction;
+    LPARAM  lParam;
+    UINT    uKeyFlags;
+} NMITEMACTIVATE, FAR *LPNMITEMACTIVATE;
+
+// key flags stored in uKeyFlags
+#define LVKF_ALT       0x0001
+#define LVKF_CONTROL   0x0002
+#define LVKF_SHIFT     0x0004
+#endif //(_WIN32_IE >= 0x0400)
+
+
+#if (_WIN32_IE >= 0x0300)
+#define NMLVCUSTOMDRAW_V3_SIZE CCSIZEOF_STRUCT(NMLVCUSTOMDRW, clrTextBk)
+
+typedef struct tagNMLVCUSTOMDRAW
+{
+    NMCUSTOMDRAW nmcd;
+    COLORREF clrText;
+    COLORREF clrTextBk;
+#if (_WIN32_IE >= 0x0400)
+    int iSubItem;
+#endif
+} NMLVCUSTOMDRAW, *LPNMLVCUSTOMDRAW;
+
+typedef struct tagNMLVCACHEHINT
+{
+    NMHDR   hdr;
+    int     iFrom;
+    int     iTo;
+} NMLVCACHEHINT, FAR *LPNMLVCACHEHINT;
+
+#define LPNM_CACHEHINT  LPNMLVCACHEHINT
+#define PNM_CACHEHINT   LPNMLVCACHEHINT
+#define NM_CACHEHINT    NMLVCACHEHINT
+
+typedef struct tagNMLVFINDITEM
+{
+    NMHDR   hdr;
+    int     iStart;
+    LVFINDINFO lvfi;
+} NMLVFINDITEM, FAR *LPNMLVFINDITEM;
+
+#define PNM_FINDITEM    LPNMLVFINDITEM
+#define LPNM_FINDITEM   LPNMLVFINDITEM
+#define NM_FINDITEM     NMLVFINDITEM
+
+typedef struct tagNMLVODSTATECHANGE
+{
+    NMHDR hdr;
+    int iFrom;
+    int iTo;
+    UINT uNewState;
+    UINT uOldState;
+} NMLVODSTATECHANGE, FAR *LPNMLVODSTATECHANGE;
+
+#define PNM_ODSTATECHANGE   LPNMLVODSTATECHANGE
+#define LPNM_ODSTATECHANGE  LPNMLVODSTATECHANGE
+#define NM_ODSTATECHANGE    NMLVODSTATECHANGE
+#endif      // _WIN32_IE >= 0x0300
+
+
+#define LVN_ITEMCHANGING        (LVN_FIRST-0)
+#define LVN_ITEMCHANGED         (LVN_FIRST-1)
+#define LVN_INSERTITEM          (LVN_FIRST-2)
+#define LVN_DELETEITEM          (LVN_FIRST-3)
+#define LVN_DELETEALLITEMS      (LVN_FIRST-4)
+#define LVN_BEGINLABELEDITA     (LVN_FIRST-5)
+#define LVN_BEGINLABELEDITW     (LVN_FIRST-75)
+#define LVN_ENDLABELEDITA       (LVN_FIRST-6)
+#define LVN_ENDLABELEDITW       (LVN_FIRST-76)
+#define LVN_COLUMNCLICK         (LVN_FIRST-8)
+#define LVN_BEGINDRAG           (LVN_FIRST-9)
+#define LVN_BEGINRDRAG          (LVN_FIRST-11)
+
+#if (_WIN32_IE >= 0x0300)
+#define LVN_ODCACHEHINT         (LVN_FIRST-13)
+#define LVN_ODFINDITEMA         (LVN_FIRST-52)
+#define LVN_ODFINDITEMW         (LVN_FIRST-79)
+
+#define LVN_ITEMACTIVATE        (LVN_FIRST-14)
+#define LVN_ODSTATECHANGED      (LVN_FIRST-15)
+
+#ifdef UNICODE
+#define LVN_ODFINDITEM          LVN_ODFINDITEMW
+#else
+#define LVN_ODFINDITEM          LVN_ODFINDITEMA
+#endif
+#endif      // _WIN32_IE >= 0x0300
+
+
+#if (_WIN32_IE >= 0x0400)
+#define LVN_HOTTRACK            (LVN_FIRST-21)
+#endif
+
+#define LVN_GETDISPINFOA        (LVN_FIRST-50)
+#define LVN_GETDISPINFOW        (LVN_FIRST-77)
+#define LVN_SETDISPINFOA        (LVN_FIRST-51)
+#define LVN_SETDISPINFOW        (LVN_FIRST-78)
+
+#ifdef UNICODE
+#define LVN_BEGINLABELEDIT      LVN_BEGINLABELEDITW
+#define LVN_ENDLABELEDIT        LVN_ENDLABELEDITW
+#define LVN_GETDISPINFO         LVN_GETDISPINFOW
+#define LVN_SETDISPINFO         LVN_SETDISPINFOW
+#else
+#define LVN_BEGINLABELEDIT      LVN_BEGINLABELEDITA
+#define LVN_ENDLABELEDIT        LVN_ENDLABELEDITA
+#define LVN_GETDISPINFO         LVN_GETDISPINFOA
+#define LVN_SETDISPINFO         LVN_SETDISPINFOA
+#endif
+
+
+#define LVIF_DI_SETITEM         0x1000
+
+#if (_WIN32_IE >= 0x0300)
+#define LV_DISPINFOA    NMLVDISPINFOA
+#define LV_DISPINFOW    NMLVDISPINFOW
+#else
+#define tagLVDISPINFO   _LV_DISPINFO
+#define NMLVDISPINFOA    LV_DISPINFOA
+#define tagLVDISPINFOW  _LV_DISPINFOW
+#define NMLVDISPINFOW    LV_DISPINFOW
+#endif
+
+#define LV_DISPINFO     NMLVDISPINFO
+
+typedef struct tagLVDISPINFO {
+    NMHDR hdr;
+    LVITEMA item;
+} NMLVDISPINFOA, FAR *LPNMLVDISPINFOA;
+
+typedef struct tagLVDISPINFOW {
+    NMHDR hdr;
+    LVITEMW item;
+} NMLVDISPINFOW, FAR * LPNMLVDISPINFOW;
+
+#ifdef UNICODE
+#define  NMLVDISPINFO           NMLVDISPINFOW
+#else
+#define  NMLVDISPINFO           NMLVDISPINFOA
+#endif
+
+#define LVN_KEYDOWN             (LVN_FIRST-55)
+
+#if (_WIN32_IE >= 0x0300)
+#define LV_KEYDOWN              NMLVKEYDOWN
+#else
+#define tagLVKEYDOWN            _LV_KEYDOWN
+#define NMLVKEYDOWN              LV_KEYDOWN
+#endif
+
+typedef struct tagLVKEYDOWN
+{
+    NMHDR hdr;
+    WORD wVKey;
+    UINT flags;
+} NMLVKEYDOWN, FAR *LPNMLVKEYDOWN;
+
+#if (_WIN32_IE >= 0x0300)
+#define LVN_MARQUEEBEGIN        (LVN_FIRST-56)
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+typedef struct tagNMLVGETINFOTIPA
+{
+    NMHDR hdr;
+    DWORD dwFlags;
+    LPSTR pszText;
+    int cchTextMax;
+    int iItem;
+    int iSubItem;
+    LPARAM lParam;
+} NMLVGETINFOTIPA, *LPNMLVGETINFOTIPA;
+
+typedef struct tagNMLVGETINFOTIPW
+{
+    NMHDR hdr;
+    DWORD dwFlags;
+    LPWSTR pszText;
+    int cchTextMax;
+    int iItem;
+    int iSubItem;
+    LPARAM lParam;
+} NMLVGETINFOTIPW, *LPNMLVGETINFOTIPW;
+
+// NMLVGETINFOTIPA.dwFlag values
+
+#define LVGIT_UNFOLDED  0x0001
+
+#define LVN_GETINFOTIPA          (LVN_FIRST-57)
+#define LVN_GETINFOTIPW          (LVN_FIRST-58)
+
+#ifdef UNICODE
+#define LVN_GETINFOTIP          LVN_GETINFOTIPW
+#define NMLVGETINFOTIP          NMLVGETINFOTIPW
+#define LPNMLVGETINFOTIP        LPNMLVGETINFOTIPW
+#else
+#define LVN_GETINFOTIP          LVN_GETINFOTIPA
+#define NMLVGETINFOTIP          NMLVGETINFOTIPA
+#define LPNMLVGETINFOTIP        LPNMLVGETINFOTIPA
+#endif
+
+
+#endif      // _WIN32_IE >= 0x0400
+
+#endif // NOLISTVIEW
+
+//====== TREEVIEW CONTROL =====================================================
+
+#ifndef NOTREEVIEW
+
+#ifdef _WIN32
+#define WC_TREEVIEWA            "SysTreeView32"
+#define WC_TREEVIEWW            L"SysTreeView32"
+
+#ifdef UNICODE
+#define  WC_TREEVIEW            WC_TREEVIEWW
+#else
+#define  WC_TREEVIEW            WC_TREEVIEWA
+#endif
+
+#else
+#define WC_TREEVIEW             "SysTreeView"
+#endif
+
+// begin_r_commctrl
+
+#define TVS_HASBUTTONS          0x0001
+#define TVS_HASLINES            0x0002
+#define TVS_LINESATROOT         0x0004
+#define TVS_EDITLABELS          0x0008
+#define TVS_DISABLEDRAGDROP     0x0010
+#define TVS_SHOWSELALWAYS       0x0020
+#if (_WIN32_IE >= 0x0300)
+#define TVS_RTLREADING          0x0040
+
+#define TVS_NOTOOLTIPS          0x0080
+#define TVS_CHECKBOXES          0x0100
+#define TVS_TRACKSELECT         0x0200
+#if (_WIN32_IE >= 0x0400)
+#define TVS_SINGLEEXPAND        0x0400
+#define TVS_INFOTIP             0x0800
+#define TVS_FULLROWSELECT       0x1000
+#define TVS_NOSCROLL            0x2000
+#define TVS_NONEVENHEIGHT       0x4000
+#endif
+
+#endif
+
+// end_r_commctrl
+
+typedef struct _TREEITEM FAR* HTREEITEM;
+
+#define TVIF_TEXT               0x0001
+#define TVIF_IMAGE              0x0002
+#define TVIF_PARAM              0x0004
+#define TVIF_STATE              0x0008
+#define TVIF_HANDLE             0x0010
+#define TVIF_SELECTEDIMAGE      0x0020
+#define TVIF_CHILDREN           0x0040
+#if (_WIN32_IE >= 0x0400)
+#define TVIF_INTEGRAL           0x0080
+#endif
+#define TVIS_SELECTED           0x0002
+#define TVIS_CUT                0x0004
+#define TVIS_DROPHILITED        0x0008
+#define TVIS_BOLD               0x0010
+#define TVIS_EXPANDED           0x0020
+#define TVIS_EXPANDEDONCE       0x0040
+#if (_WIN32_IE >= 0x0300)
+#define TVIS_EXPANDPARTIAL      0x0080
+#endif
+
+#define TVIS_OVERLAYMASK        0x0F00
+#define TVIS_STATEIMAGEMASK     0xF000
+#define TVIS_USERMASK           0xF000
+
+#define I_CHILDRENCALLBACK  (-1)
+
+#if (_WIN32_IE >= 0x0300)
+#define LPTV_ITEMW              LPTVITEMW
+#define LPTV_ITEMA              LPTVITEMA
+#define TV_ITEMW                TVITEMW
+#define TV_ITEMA                TVITEMA
+#else
+#define tagTVITEMA             _TV_ITEMA
+#define    TVITEMA              TV_ITEMA
+#define  LPTVITEMA            LPTV_ITEMA
+#define tagTVITEMW             _TV_ITEMW
+#define    TVITEMW              TV_ITEMW
+#define  LPTVITEMW            LPTV_ITEMW
+#endif
+
+#define LPTV_ITEM               LPTVITEM
+#define TV_ITEM                 TVITEM
+
+typedef struct tagTVITEMA {
+    UINT      mask;
+    HTREEITEM hItem;
+    UINT      state;
+    UINT      stateMask;
+    LPSTR     pszText;
+    int       cchTextMax;
+    int       iImage;
+    int       iSelectedImage;
+    int       cChildren;
+    LPARAM    lParam;
+} TVITEMA, FAR *LPTVITEMA;
+
+typedef struct tagTVITEMW {
+    UINT      mask;
+    HTREEITEM hItem;
+    UINT      state;
+    UINT      stateMask;
+    LPWSTR    pszText;
+    int       cchTextMax;
+    int       iImage;
+    int       iSelectedImage;
+    int       cChildren;
+    LPARAM    lParam;
+} TVITEMW, FAR *LPTVITEMW;
+
+#if (_WIN32_IE >= 0x0400)
+// only used for Get and Set messages.  no notifies
+typedef struct tagTVITEMEXA {
+    UINT      mask;
+    HTREEITEM hItem;
+    UINT      state;
+    UINT      stateMask;
+    LPSTR     pszText;
+    int       cchTextMax;
+    int       iImage;
+    int       iSelectedImage;
+    int       cChildren;
+    LPARAM    lParam;
+    int       iIntegral;
+} TVITEMEXA, FAR *LPTVITEMEXA;
+// only used for Get and Set messages.  no notifies
+typedef struct tagTVITEMEXW {
+    UINT      mask;
+    HTREEITEM hItem;
+    UINT      state;
+    UINT      stateMask;
+    LPWSTR    pszText;
+    int       cchTextMax;
+    int       iImage;
+    int       iSelectedImage;
+    int       cChildren;
+    LPARAM    lParam;
+    int       iIntegral;
+} TVITEMEXW, FAR *LPTVITEMEXW;
+#ifdef UNICODE
+typedef TVITEMEXW TVITEMEX;
+typedef LPTVITEMEXW LPTVITEMEX;
+#else
+typedef TVITEMEXA TVITEMEX;
+typedef LPTVITEMEXA LPTVITEMEX;
+#endif // UNICODE
+
+#endif
+
+#ifdef UNICODE
+#define  TVITEM                 TVITEMW
+#define  LPTVITEM               LPTVITEMW
+#else
+#define  TVITEM                 TVITEMA
+#define  LPTVITEM               LPTVITEMA
+#endif
+
+
+#define TVI_ROOT                ((HTREEITEM)0xFFFF0000)
+#define TVI_FIRST               ((HTREEITEM)0xFFFF0001)
+#define TVI_LAST                ((HTREEITEM)0xFFFF0002)
+#define TVI_SORT                ((HTREEITEM)0xFFFF0003)
+
+#if (_WIN32_IE >= 0x0300)
+#define LPTV_INSERTSTRUCTA      LPTVINSERTSTRUCTA
+#define LPTV_INSERTSTRUCTW      LPTVINSERTSTRUCTW
+#define TV_INSERTSTRUCTA        TVINSERTSTRUCTA
+#define TV_INSERTSTRUCTW        TVINSERTSTRUCTW
+#else
+#define tagTVINSERTSTRUCTA     _TV_INSERTSTRUCTA
+#define    TVINSERTSTRUCTA      TV_INSERTSTRUCTA
+#define  LPTVINSERTSTRUCTA    LPTV_INSERTSTRUCTA
+#define tagTVINSERTSTRUCTW     _TV_INSERTSTRUCTW
+#define    TVINSERTSTRUCTW      TV_INSERTSTRUCTW
+#define  LPTVINSERTSTRUCTW    LPTV_INSERTSTRUCTW
+#endif
+
+#define TV_INSERTSTRUCT         TVINSERTSTRUCT
+#define LPTV_INSERTSTRUCT       LPTVINSERTSTRUCT
+
+
+#define TVINSERTSTRUCTA_V1_SIZE CCSIZEOF_STRUCT(TVINSERTSTRUCTA, item)
+#define TVINSERTSTRUCTW_V1_SIZE CCSIZEOF_STRUCT(TVINSERTSTRUCTW, item)
+
+typedef struct tagTVINSERTSTRUCTA {
+    HTREEITEM hParent;
+    HTREEITEM hInsertAfter;
+#if (_WIN32_IE >= 0x0400)
+    union
+    {
+        TVITEMEXA itemex;
+        TV_ITEMA  item;
+    } DUMMYUNIONNAME;
+#else
+    TV_ITEMA item;
+#endif
+} TVINSERTSTRUCTA, FAR *LPTVINSERTSTRUCTA;
+
+typedef struct tagTVINSERTSTRUCTW {
+    HTREEITEM hParent;
+    HTREEITEM hInsertAfter;
+#if (_WIN32_IE >= 0x0400)
+    union
+    {
+        TVITEMEXW itemex;
+        TV_ITEMW  item;
+    } DUMMYUNIONNAME;
+#else
+    TV_ITEMW item;
+#endif
+} TVINSERTSTRUCTW, FAR *LPTVINSERTSTRUCTW;
+
+#ifdef UNICODE
+#define  TVINSERTSTRUCT         TVINSERTSTRUCTW
+#define  LPTVINSERTSTRUCT       LPTVINSERTSTRUCTW
+#define TVINSERTSTRUCT_V1_SIZE TVINSERTSTRUCTW_V1_SIZE
+#else
+#define  TVINSERTSTRUCT         TVINSERTSTRUCTA
+#define  LPTVINSERTSTRUCT       LPTVINSERTSTRUCTA
+#define TVINSERTSTRUCT_V1_SIZE TVINSERTSTRUCTA_V1_SIZE
+#endif
+
+#define TVM_INSERTITEMA         (TV_FIRST + 0)
+#define TVM_INSERTITEMW         (TV_FIRST + 50)
+#ifdef UNICODE
+#define  TVM_INSERTITEM         TVM_INSERTITEMW
+#else
+#define  TVM_INSERTITEM         TVM_INSERTITEMA
+#endif
+
+#define TreeView_InsertItem(hwnd, lpis) \
+    (HTREEITEM)SNDMSG((hwnd), TVM_INSERTITEM, 0, (LPARAM)(LPTV_INSERTSTRUCT)(lpis))
+
+
+#define TVM_DELETEITEM          (TV_FIRST + 1)
+#define TreeView_DeleteItem(hwnd, hitem) \
+    (BOOL)SNDMSG((hwnd), TVM_DELETEITEM, 0, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TreeView_DeleteAllItems(hwnd) \
+    (BOOL)SNDMSG((hwnd), TVM_DELETEITEM, 0, (LPARAM)TVI_ROOT)
+
+
+#define TVM_EXPAND              (TV_FIRST + 2)
+#define TreeView_Expand(hwnd, hitem, code) \
+    (BOOL)SNDMSG((hwnd), TVM_EXPAND, (WPARAM)code, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TVE_COLLAPSE            0x0001
+#define TVE_EXPAND              0x0002
+#define TVE_TOGGLE              0x0003
+#if (_WIN32_IE >= 0x0300)
+#define TVE_EXPANDPARTIAL       0x4000
+#endif
+#define TVE_COLLAPSERESET       0x8000
+
+
+#define TVM_GETITEMRECT         (TV_FIRST + 4)
+#define TreeView_GetItemRect(hwnd, hitem, prc, code) \
+    (*(HTREEITEM FAR *)prc = (hitem), (BOOL)SNDMSG((hwnd), TVM_GETITEMRECT, (WPARAM)(code), (LPARAM)(RECT FAR*)(prc)))
+
+
+#define TVM_GETCOUNT            (TV_FIRST + 5)
+#define TreeView_GetCount(hwnd) \
+    (UINT)SNDMSG((hwnd), TVM_GETCOUNT, 0, 0)
+
+
+#define TVM_GETINDENT           (TV_FIRST + 6)
+#define TreeView_GetIndent(hwnd) \
+    (UINT)SNDMSG((hwnd), TVM_GETINDENT, 0, 0)
+
+
+#define TVM_SETINDENT           (TV_FIRST + 7)
+#define TreeView_SetIndent(hwnd, indent) \
+    (BOOL)SNDMSG((hwnd), TVM_SETINDENT, (WPARAM)indent, 0)
+
+
+#define TVM_GETIMAGELIST        (TV_FIRST + 8)
+#define TreeView_GetImageList(hwnd, iImage) \
+    (HIMAGELIST)SNDMSG((hwnd), TVM_GETIMAGELIST, iImage, 0)
+
+
+#define TVSIL_NORMAL            0
+#define TVSIL_STATE             2
+
+
+#define TVM_SETIMAGELIST        (TV_FIRST + 9)
+#define TreeView_SetImageList(hwnd, himl, iImage) \
+    (HIMAGELIST)SNDMSG((hwnd), TVM_SETIMAGELIST, iImage, (LPARAM)(UINT)(HIMAGELIST)(himl))
+
+
+#define TVM_GETNEXTITEM         (TV_FIRST + 10)
+#define TreeView_GetNextItem(hwnd, hitem, code) \
+    (HTREEITEM)SNDMSG((hwnd), TVM_GETNEXTITEM, (WPARAM)code, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TVGN_ROOT               0x0000
+#define TVGN_NEXT               0x0001
+#define TVGN_PREVIOUS           0x0002
+#define TVGN_PARENT             0x0003
+#define TVGN_CHILD              0x0004
+#define TVGN_FIRSTVISIBLE       0x0005
+#define TVGN_NEXTVISIBLE        0x0006
+#define TVGN_PREVIOUSVISIBLE    0x0007
+#define TVGN_DROPHILITE         0x0008
+#define TVGN_CARET              0x0009
+#if (_WIN32_IE >= 0x0400)
+#define TVGN_LASTVISIBLE        0x000A
+#endif      // _WIN32_IE >= 0x0400
+
+#define TreeView_GetChild(hwnd, hitem)          TreeView_GetNextItem(hwnd, hitem, TVGN_CHILD)
+#define TreeView_GetNextSibling(hwnd, hitem)    TreeView_GetNextItem(hwnd, hitem, TVGN_NEXT)
+#define TreeView_GetPrevSibling(hwnd, hitem)    TreeView_GetNextItem(hwnd, hitem, TVGN_PREVIOUS)
+#define TreeView_GetParent(hwnd, hitem)         TreeView_GetNextItem(hwnd, hitem, TVGN_PARENT)
+#define TreeView_GetFirstVisible(hwnd)          TreeView_GetNextItem(hwnd, NULL,  TVGN_FIRSTVISIBLE)
+#define TreeView_GetNextVisible(hwnd, hitem)    TreeView_GetNextItem(hwnd, hitem, TVGN_NEXTVISIBLE)
+#define TreeView_GetPrevVisible(hwnd, hitem)    TreeView_GetNextItem(hwnd, hitem, TVGN_PREVIOUSVISIBLE)
+#define TreeView_GetSelection(hwnd)             TreeView_GetNextItem(hwnd, NULL,  TVGN_CARET)
+#define TreeView_GetDropHilight(hwnd)           TreeView_GetNextItem(hwnd, NULL,  TVGN_DROPHILITE)
+#define TreeView_GetRoot(hwnd)                  TreeView_GetNextItem(hwnd, NULL,  TVGN_ROOT)
+#if (_WIN32_IE >= 0x0400)
+#define TreeView_GetLastVisible(hwnd)          TreeView_GetNextItem(hwnd, NULL,  TVGN_LASTVISIBLE)
+#endif      // _WIN32_IE >= 0x0400
+
+
+#define TVM_SELECTITEM          (TV_FIRST + 11)
+#define TreeView_Select(hwnd, hitem, code) \
+    (BOOL)SNDMSG((hwnd), TVM_SELECTITEM, (WPARAM)code, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TreeView_SelectItem(hwnd, hitem)            TreeView_Select(hwnd, hitem, TVGN_CARET)
+#define TreeView_SelectDropTarget(hwnd, hitem)      TreeView_Select(hwnd, hitem, TVGN_DROPHILITE)
+#define TreeView_SelectSetFirstVisible(hwnd, hitem) TreeView_Select(hwnd, hitem, TVGN_FIRSTVISIBLE)
+
+#define TVM_GETITEMA            (TV_FIRST + 12)
+#define TVM_GETITEMW            (TV_FIRST + 62)
+
+#ifdef UNICODE
+#define  TVM_GETITEM            TVM_GETITEMW
+#else
+#define  TVM_GETITEM            TVM_GETITEMA
+#endif
+
+#define TreeView_GetItem(hwnd, pitem) \
+    (BOOL)SNDMSG((hwnd), TVM_GETITEM, 0, (LPARAM)(TV_ITEM FAR*)(pitem))
+
+
+#define TVM_SETITEMA            (TV_FIRST + 13)
+#define TVM_SETITEMW            (TV_FIRST + 63)
+
+#ifdef UNICODE
+#define  TVM_SETITEM            TVM_SETITEMW
+#else
+#define  TVM_SETITEM            TVM_SETITEMA
+#endif
+
+#define TreeView_SetItem(hwnd, pitem) \
+    (BOOL)SNDMSG((hwnd), TVM_SETITEM, 0, (LPARAM)(const TV_ITEM FAR*)(pitem))
+
+
+#define TVM_EDITLABELA          (TV_FIRST + 14)
+#define TVM_EDITLABELW          (TV_FIRST + 65)
+#ifdef UNICODE
+#define TVM_EDITLABEL           TVM_EDITLABELW
+#else
+#define TVM_EDITLABEL           TVM_EDITLABELA
+#endif
+
+#define TreeView_EditLabel(hwnd, hitem) \
+    (HWND)SNDMSG((hwnd), TVM_EDITLABEL, 0, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TVM_GETEDITCONTROL      (TV_FIRST + 15)
+#define TreeView_GetEditControl(hwnd) \
+    (HWND)SNDMSG((hwnd), TVM_GETEDITCONTROL, 0, 0)
+
+
+#define TVM_GETVISIBLECOUNT     (TV_FIRST + 16)
+#define TreeView_GetVisibleCount(hwnd) \
+    (UINT)SNDMSG((hwnd), TVM_GETVISIBLECOUNT, 0, 0)
+
+
+#define TVM_HITTEST             (TV_FIRST + 17)
+#define TreeView_HitTest(hwnd, lpht) \
+    (HTREEITEM)SNDMSG((hwnd), TVM_HITTEST, 0, (LPARAM)(LPTV_HITTESTINFO)(lpht))
+
+
+#if (_WIN32_IE >= 0x0300)
+#define LPTV_HITTESTINFO   LPTVHITTESTINFO
+#define   TV_HITTESTINFO     TVHITTESTINFO
+#else
+#define tagTVHITTESTINFO    _TV_HITTESTINFO
+#define    TVHITTESTINFO     TV_HITTESTINFO
+#define  LPTVHITTESTINFO   LPTV_HITTESTINFO
+#endif
+
+typedef struct tagTVHITTESTINFO {
+    POINT       pt;
+    UINT        flags;
+    HTREEITEM   hItem;
+} TVHITTESTINFO, FAR *LPTVHITTESTINFO;
+
+#define TVHT_NOWHERE            0x0001
+#define TVHT_ONITEMICON         0x0002
+#define TVHT_ONITEMLABEL        0x0004
+#define TVHT_ONITEM             (TVHT_ONITEMICON | TVHT_ONITEMLABEL | TVHT_ONITEMSTATEICON)
+#define TVHT_ONITEMINDENT       0x0008
+#define TVHT_ONITEMBUTTON       0x0010
+#define TVHT_ONITEMRIGHT        0x0020
+#define TVHT_ONITEMSTATEICON    0x0040
+
+#define TVHT_ABOVE              0x0100
+#define TVHT_BELOW              0x0200
+#define TVHT_TORIGHT            0x0400
+#define TVHT_TOLEFT             0x0800
+
+
+#define TVM_CREATEDRAGIMAGE     (TV_FIRST + 18)
+#define TreeView_CreateDragImage(hwnd, hitem) \
+    (HIMAGELIST)SNDMSG((hwnd), TVM_CREATEDRAGIMAGE, 0, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TVM_SORTCHILDREN        (TV_FIRST + 19)
+#define TreeView_SortChildren(hwnd, hitem, recurse) \
+    (BOOL)SNDMSG((hwnd), TVM_SORTCHILDREN, (WPARAM)recurse, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TVM_ENSUREVISIBLE       (TV_FIRST + 20)
+#define TreeView_EnsureVisible(hwnd, hitem) \
+    (BOOL)SNDMSG((hwnd), TVM_ENSUREVISIBLE, 0, (LPARAM)(HTREEITEM)(hitem))
+
+
+#define TVM_SORTCHILDRENCB      (TV_FIRST + 21)
+#define TreeView_SortChildrenCB(hwnd, psort, recurse) \
+    (BOOL)SNDMSG((hwnd), TVM_SORTCHILDRENCB, (WPARAM)recurse, \
+    (LPARAM)(LPTV_SORTCB)(psort))
+
+
+#define TVM_ENDEDITLABELNOW     (TV_FIRST + 22)
+#define TreeView_EndEditLabelNow(hwnd, fCancel) \
+    (BOOL)SNDMSG((hwnd), TVM_ENDEDITLABELNOW, (WPARAM)fCancel, 0)
+
+
+#define TVM_GETISEARCHSTRINGA   (TV_FIRST + 23)
+#define TVM_GETISEARCHSTRINGW   (TV_FIRST + 64)
+
+#ifdef UNICODE
+#define TVM_GETISEARCHSTRING     TVM_GETISEARCHSTRINGW
+#else
+#define TVM_GETISEARCHSTRING     TVM_GETISEARCHSTRINGA
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define TVM_SETTOOLTIPS         (TV_FIRST + 24)
+#define TreeView_SetToolTips(hwnd,  hwndTT) \
+    (HWND)SNDMSG((hwnd), TVM_SETTOOLTIPS, (WPARAM)hwndTT, 0)
+#define TVM_GETTOOLTIPS         (TV_FIRST + 25)
+#define TreeView_GetToolTips(hwnd) \
+    (HWND)SNDMSG((hwnd), TVM_GETTOOLTIPS, 0, 0)
+#endif
+
+#define TreeView_GetISearchString(hwndTV, lpsz) \
+        (BOOL)SNDMSG((hwndTV), TVM_GETISEARCHSTRING, 0, (LPARAM)(LPTSTR)lpsz)
+
+#if (_WIN32_IE >= 0x0400)
+#define TVM_SETINSERTMARK       (TV_FIRST + 26)
+#define TreeView_SetInsertMark(hwnd, hItem, fAfter) \
+        (BOOL)SNDMSG((hwnd), TVM_SETINSERTMARK, (WPARAM) (fAfter), (LPARAM) (hItem))
+
+#define TVM_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define TreeView_SetUnicodeFormat(hwnd, fUnicode)  \
+    (BOOL)SNDMSG((hwnd), TVM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0)
+
+#define TVM_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+#define TreeView_GetUnicodeFormat(hwnd)  \
+    (BOOL)SNDMSG((hwnd), TVM_GETUNICODEFORMAT, 0, 0)
+
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+#define TVM_SETITEMHEIGHT         (TV_FIRST + 27)
+#define TreeView_SetItemHeight(hwnd,  iHeight) \
+    (int)SNDMSG((hwnd), TVM_SETITEMHEIGHT, (WPARAM)iHeight, 0)
+#define TVM_GETITEMHEIGHT         (TV_FIRST + 28)
+#define TreeView_GetItemHeight(hwnd) \
+    (int)SNDMSG((hwnd), TVM_GETITEMHEIGHT, 0, 0)
+
+#define TVM_SETBKCOLOR              (TV_FIRST + 29)
+#define TreeView_SetBkColor(hwnd, clr) \
+    (COLORREF)SNDMSG((hwnd), TVM_SETBKCOLOR, 0, (LPARAM)clr)
+
+#define TVM_SETTEXTCOLOR              (TV_FIRST + 30)
+#define TreeView_SetTextColor(hwnd, clr) \
+    (COLORREF)SNDMSG((hwnd), TVM_SETTEXTCOLOR, 0, (LPARAM)clr)
+
+#define TVM_GETBKCOLOR              (TV_FIRST + 31)
+#define TreeView_GetBkColor(hwnd) \
+    (COLORREF)SNDMSG((hwnd), TVM_GETBKCOLOR, 0, 0)
+
+#define TVM_GETTEXTCOLOR              (TV_FIRST + 32)
+#define TreeView_GetTextColor(hwnd) \
+    (COLORREF)SNDMSG((hwnd), TVM_GETTEXTCOLOR, 0, 0)
+
+#define TVM_SETSCROLLTIME              (TV_FIRST + 33)
+#define TreeView_SetScrollTime(hwnd, uTime) \
+    (UINT)SNDMSG((hwnd), TVM_SETSCROLLTIME, uTime, 0)
+
+#define TVM_GETSCROLLTIME              (TV_FIRST + 34)
+#define TreeView_GetScrollTime(hwnd) \
+    (UINT)SNDMSG((hwnd), TVM_GETSCROLLTIME, 0, 0)
+
+
+#if (_WIN32_IE >= 0x0400)
+#define TVM_SETINSERTMARKCOLOR              (TV_FIRST + 37)
+#define TreeView_SetInsertMarkColor(hwnd, clr) \
+    (COLORREF)SNDMSG((hwnd), TVM_SETINSERTMARKCOLOR, 0, (LPARAM)clr)
+#define TVM_GETINSERTMARKCOLOR              (TV_FIRST + 38)
+#define TreeView_GetInsertMarkColor(hwnd) \
+    (COLORREF)SNDMSG((hwnd), TVM_GETINSERTMARKCOLOR, 0, 0)
+#endif  /* (_WIN32_IE >= 0x0400) */
+
+#endif
+
+typedef int (CALLBACK *PFNTVCOMPARE)(LPARAM lParam1, LPARAM lParam2, LPARAM lParamSort);
+
+#if (_WIN32_IE >= 0x0300)
+#define LPTV_SORTCB    LPTVSORTCB
+#define   TV_SORTCB      TVSORTCB
+#else
+#define tagTVSORTCB    _TV_SORTCB
+#define    TVSORTCB     TV_SORTCB
+#define  LPTVSORTCB   LPTV_SORTCB
+#endif
+
+typedef struct tagTVSORTCB
+{
+        HTREEITEM       hParent;
+        PFNTVCOMPARE    lpfnCompare;
+        LPARAM          lParam;
+} TVSORTCB, FAR *LPTVSORTCB;
+
+
+#if (_WIN32_IE >= 0x0300)
+#define LPNM_TREEVIEWA          LPNMTREEVIEWA
+#define LPNM_TREEVIEWW          LPNMTREEVIEWW
+#define NM_TREEVIEWW            NMTREEVIEWW
+#define NM_TREEVIEWA            NMTREEVIEWA
+#else
+#define tagNMTREEVIEWA          _NM_TREEVIEWA
+#define tagNMTREEVIEWW          _NM_TREEVIEWW
+#define NMTREEVIEWA             NM_TREEVIEWA
+#define NMTREEVIEWW             NM_TREEVIEWW
+#define LPNMTREEVIEWA           LPNM_TREEVIEWA
+#define LPNMTREEVIEWW           LPNM_TREEVIEWW
+#endif
+
+#define LPNM_TREEVIEW           LPNMTREEVIEW
+#define NM_TREEVIEW             NMTREEVIEW
+
+typedef struct tagNMTREEVIEWA {
+    NMHDR       hdr;
+    UINT        action;
+    TVITEMA    itemOld;
+    TVITEMA    itemNew;
+    POINT       ptDrag;
+} NMTREEVIEWA, FAR *LPNMTREEVIEWA;
+
+
+typedef struct tagNMTREEVIEWW {
+    NMHDR       hdr;
+    UINT        action;
+    TVITEMW    itemOld;
+    TVITEMW    itemNew;
+    POINT       ptDrag;
+} NMTREEVIEWW, FAR *LPNMTREEVIEWW;
+
+
+#ifdef UNICODE
+#define  NMTREEVIEW             NMTREEVIEWW
+#define  LPNMTREEVIEW           LPNMTREEVIEWW
+#else
+#define  NMTREEVIEW             NMTREEVIEWA
+#define  LPNMTREEVIEW           LPNMTREEVIEWA
+#endif
+
+
+#define TVN_SELCHANGINGA        (TVN_FIRST-1)
+#define TVN_SELCHANGINGW        (TVN_FIRST-50)
+#define TVN_SELCHANGEDA         (TVN_FIRST-2)
+#define TVN_SELCHANGEDW         (TVN_FIRST-51)
+
+#define TVC_UNKNOWN             0x0000
+#define TVC_BYMOUSE             0x0001
+#define TVC_BYKEYBOARD          0x0002
+
+#define TVN_GETDISPINFOA        (TVN_FIRST-3)
+#define TVN_GETDISPINFOW        (TVN_FIRST-52)
+#define TVN_SETDISPINFOA        (TVN_FIRST-4)
+#define TVN_SETDISPINFOW        (TVN_FIRST-53)
+
+#define TVIF_DI_SETITEM         0x1000
+
+#if (_WIN32_IE >= 0x0300)
+#define TV_DISPINFOA            NMTVDISPINFOA
+#define TV_DISPINFOW            NMTVDISPINFOW
+#else
+#define tagTVDISPINFOA  _TV_DISPINFOA
+#define NMTVDISPINFOA    TV_DISPINFOA
+#define tagTVDISPINFOW  _TV_DISPINFOW
+#define NMTVDISPINFOW    TV_DISPINFOW
+#endif
+
+#define TV_DISPINFO             NMTVDISPINFO
+
+typedef struct tagTVDISPINFOA {
+    NMHDR hdr;
+    TVITEMA item;
+} NMTVDISPINFOA, FAR *LPNMTVDISPINFOA;
+
+typedef struct tagTVDISPINFOW {
+    NMHDR hdr;
+    TVITEMW item;
+} NMTVDISPINFOW, FAR *LPNMTVDISPINFOW;
+
+
+#ifdef UNICODE
+#define NMTVDISPINFO            NMTVDISPINFOW
+#define LPNMTVDISPINFO          LPNMTVDISPINFOW
+#else
+#define NMTVDISPINFO            NMTVDISPINFOA
+#define LPNMTVDISPINFO          LPNMTVDISPINFOA
+#endif
+
+#define TVN_ITEMEXPANDINGA      (TVN_FIRST-5)
+#define TVN_ITEMEXPANDINGW      (TVN_FIRST-54)
+#define TVN_ITEMEXPANDEDA       (TVN_FIRST-6)
+#define TVN_ITEMEXPANDEDW       (TVN_FIRST-55)
+#define TVN_BEGINDRAGA          (TVN_FIRST-7)
+#define TVN_BEGINDRAGW          (TVN_FIRST-56)
+#define TVN_BEGINRDRAGA         (TVN_FIRST-8)
+#define TVN_BEGINRDRAGW         (TVN_FIRST-57)
+#define TVN_DELETEITEMA         (TVN_FIRST-9)
+#define TVN_DELETEITEMW         (TVN_FIRST-58)
+#define TVN_BEGINLABELEDITA     (TVN_FIRST-10)
+#define TVN_BEGINLABELEDITW     (TVN_FIRST-59)
+#define TVN_ENDLABELEDITA       (TVN_FIRST-11)
+#define TVN_ENDLABELEDITW       (TVN_FIRST-60)
+#define TVN_KEYDOWN             (TVN_FIRST-12)
+
+#if (_WIN32_IE >= 0x0400)
+#define TVN_GETINFOTIPA         (TVN_FIRST-13)
+#define TVN_GETINFOTIPW         (TVN_FIRST-14)
+#define TVN_SINGLEEXPAND        (TVN_FIRST-15)
+#endif // 0x400
+
+
+#if (_WIN32_IE >= 0x0300)
+#define TV_KEYDOWN      NMTVKEYDOWN
+#else
+#define tagTVKEYDOWN    _TV_KEYDOWN
+#define  NMTVKEYDOWN     TV_KEYDOWN
+#endif
+
+typedef struct tagTVKEYDOWN {
+    NMHDR hdr;
+    WORD wVKey;
+    UINT flags;
+} NMTVKEYDOWN, FAR *LPNMTVKEYDOWN;
+
+
+#ifdef UNICODE
+#define TVN_SELCHANGING         TVN_SELCHANGINGW
+#define TVN_SELCHANGED          TVN_SELCHANGEDW
+#define TVN_GETDISPINFO         TVN_GETDISPINFOW
+#define TVN_SETDISPINFO         TVN_SETDISPINFOW
+#define TVN_ITEMEXPANDING       TVN_ITEMEXPANDINGW
+#define TVN_ITEMEXPANDED        TVN_ITEMEXPANDEDW
+#define TVN_BEGINDRAG           TVN_BEGINDRAGW
+#define TVN_BEGINRDRAG          TVN_BEGINRDRAGW
+#define TVN_DELETEITEM          TVN_DELETEITEMW
+#define TVN_BEGINLABELEDIT      TVN_BEGINLABELEDITW
+#define TVN_ENDLABELEDIT        TVN_ENDLABELEDITW
+#else
+#define TVN_SELCHANGING         TVN_SELCHANGINGA
+#define TVN_SELCHANGED          TVN_SELCHANGEDA
+#define TVN_GETDISPINFO         TVN_GETDISPINFOA
+#define TVN_SETDISPINFO         TVN_SETDISPINFOA
+#define TVN_ITEMEXPANDING       TVN_ITEMEXPANDINGA
+#define TVN_ITEMEXPANDED        TVN_ITEMEXPANDEDA
+#define TVN_BEGINDRAG           TVN_BEGINDRAGA
+#define TVN_BEGINRDRAG          TVN_BEGINRDRAGA
+#define TVN_DELETEITEM          TVN_DELETEITEMA
+#define TVN_BEGINLABELEDIT      TVN_BEGINLABELEDITA
+#define TVN_ENDLABELEDIT        TVN_ENDLABELEDITA
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define NMTVCUSTOMDRAW_V3_SIZE CCSIZEOF_STRUCT(NMTVCUSTOMDRAW, clrTextBk)
+
+typedef struct tagNMTVCUSTOMDRAW
+{
+    NMCUSTOMDRAW nmcd;
+    COLORREF     clrText;
+    COLORREF     clrTextBk;
+#if (_WIN32_IE >= 0x0400)
+    int iLevel;
+#endif
+} NMTVCUSTOMDRAW, *LPNMTVCUSTOMDRAW;
+#endif
+
+
+#if (_WIN32_IE >= 0x0400)
+
+// for tooltips
+
+typedef struct tagNMTVGETINFOTIPA
+{
+    NMHDR hdr;
+    LPSTR pszText;
+    int cchTextMax;
+    HTREEITEM hItem;
+    LPARAM lParam;
+} NMTVGETINFOTIPA, *LPNMTVGETINFOTIPA;
+
+typedef struct tagNMTVGETINFOTIPW
+{
+    NMHDR hdr;
+    LPWSTR pszText;
+    int cchTextMax;
+    HTREEITEM hItem;
+    LPARAM lParam;
+} NMTVGETINFOTIPW, *LPNMTVGETINFOTIPW;
+
+
+#ifdef UNICODE
+#define TVN_GETINFOTIP          TVN_GETINFOTIPW
+#define NMTVGETINFOTIP          NMTVGETINFOTIPW
+#define LPNMTVGETINFOTIP        LPNMTVGETINFOTIPW
+#else
+#define TVN_GETINFOTIP          TVN_GETINFOTIPA
+#define NMTVGETINFOTIP          NMTVGETINFOTIPA
+#define LPNMTVGETINFOTIP        LPNMTVGETINFOTIPA
+#endif
+
+// treeview's customdraw return meaning don't draw images.  valid on CDRF_NOTIFYITEMPREPAINT
+#define TVCDRF_NOIMAGES         0x00010000
+
+
+
+
+
+
+#endif      // _WIN32_IE >= 0x0400
+
+#endif      // NOTREEVIEW
+
+#if (_WIN32_IE >= 0x0300)
+
+#ifndef NOUSEREXCONTROLS
+
+////////////////////  ComboBoxEx ////////////////////////////////
+
+
+#define WC_COMBOBOXEXW         L"ComboBoxEx32"
+#define WC_COMBOBOXEXA         "ComboBoxEx32"
+
+#ifdef UNICODE
+#define WC_COMBOBOXEX          WC_COMBOBOXEXW
+#else
+#define WC_COMBOBOXEX          WC_COMBOBOXEXA
+#endif
+
+
+#define CBEIF_TEXT              0x00000001
+#define CBEIF_IMAGE             0x00000002
+#define CBEIF_SELECTEDIMAGE     0x00000004
+#define CBEIF_OVERLAY           0x00000008
+#define CBEIF_INDENT            0x00000010
+#define CBEIF_LPARAM            0x00000020
+
+#define CBEIF_DI_SETITEM        0x10000000
+
+typedef struct tagCOMBOBOXEXITEMA
+{
+    UINT mask;
+    int iItem;
+    LPSTR pszText;
+    int cchTextMax;
+    int iImage;
+    int iSelectedImage;
+    int iOverlay;
+    int iIndent;
+    LPARAM lParam;
+} COMBOBOXEXITEMA, *PCOMBOBOXEXITEMA;
+typedef COMBOBOXEXITEMA CONST *PCCOMBOEXITEMA;
+
+
+typedef struct tagCOMBOBOXEXITEMW
+{
+    UINT mask;
+    int iItem;
+    LPWSTR pszText;
+    int cchTextMax;
+    int iImage;
+    int iSelectedImage;
+    int iOverlay;
+    int iIndent;
+    LPARAM lParam;
+} COMBOBOXEXITEMW, *PCOMBOBOXEXITEMW;
+typedef COMBOBOXEXITEMW CONST *PCCOMBOEXITEMW;
+
+#ifdef UNICODE
+#define COMBOBOXEXITEM            COMBOBOXEXITEMW
+#define PCOMBOBOXEXITEM           PCOMBOBOXEXITEMW
+#define PCCOMBOBOXEXITEM          PCCOMBOBOXEXITEMW
+#else
+#define COMBOBOXEXITEM            COMBOBOXEXITEMA
+#define PCOMBOBOXEXITEM           PCOMBOBOXEXITEMA
+#define PCCOMBOBOXEXITEM          PCCOMBOBOXEXITEMA
+#endif
+
+#define CBEM_INSERTITEMA        (WM_USER + 1)
+#define CBEM_SETIMAGELIST       (WM_USER + 2)
+#define CBEM_GETIMAGELIST       (WM_USER + 3)
+#define CBEM_GETITEMA           (WM_USER + 4)
+#define CBEM_SETITEMA           (WM_USER + 5)
+#define CBEM_DELETEITEM         CB_DELETESTRING
+#define CBEM_GETCOMBOCONTROL    (WM_USER + 6)
+#define CBEM_GETEDITCONTROL     (WM_USER + 7)
+#if (_WIN32_IE >= 0x0400)
+#define CBEM_SETEXSTYLE         (WM_USER + 8)  // use  SETEXTENDEDSTYLE instead
+#define CBEM_SETEXTENDEDSTYLE   (WM_USER + 14)   // lparam == new style, wParam (optional) == mask
+#define CBEM_GETEXSTYLE         (WM_USER + 9) // use GETEXTENDEDSTYLE instead
+#define CBEM_GETEXTENDEDSTYLE   (WM_USER + 9)
+#define CBEM_SETUNICODEFORMAT   CCM_SETUNICODEFORMAT
+#define CBEM_GETUNICODEFORMAT   CCM_GETUNICODEFORMAT
+#else
+#define CBEM_SETEXSTYLE         (WM_USER + 8)
+#define CBEM_GETEXSTYLE         (WM_USER + 9)
+#endif
+#define CBEM_HASEDITCHANGED     (WM_USER + 10)
+#define CBEM_INSERTITEMW        (WM_USER + 11)
+#define CBEM_SETITEMW           (WM_USER + 12)
+#define CBEM_GETITEMW           (WM_USER + 13)
+
+#ifdef UNICODE
+#define CBEM_INSERTITEM         CBEM_INSERTITEMW
+#define CBEM_SETITEM            CBEM_SETITEMW
+#define CBEM_GETITEM            CBEM_GETITEMW
+#else
+#define CBEM_INSERTITEM         CBEM_INSERTITEMA
+#define CBEM_SETITEM            CBEM_SETITEMA
+#define CBEM_GETITEM            CBEM_GETITEMA
+#endif
+
+#define CBES_EX_NOEDITIMAGE          0x00000001
+#define CBES_EX_NOEDITIMAGEINDENT    0x00000002
+#define CBES_EX_PATHWORDBREAKPROC    0x00000004
+#if (_WIN32_IE >= 0x0400)
+#define CBES_EX_NOSIZELIMIT          0x00000008
+#define CBES_EX_CASESENSITIVE        0x00000010
+
+typedef struct {
+    NMHDR hdr;
+    COMBOBOXEXITEMA ceItem;
+} NMCOMBOBOXEXA, *PNMCOMBOBOXEXA;
+
+typedef struct {
+    NMHDR hdr;
+    COMBOBOXEXITEMW ceItem;
+} NMCOMBOBOXEXW, *PNMCOMBOBOXEXW;
+
+#ifdef UNICODE
+#define NMCOMBOBOXEX            NMCOMBOBOXEXW
+#define PNMCOMBOBOXEX           PNMCOMBOBOXEXW
+#define CBEN_GETDISPINFO        CBEN_GETDISPINFOW
+#else
+#define NMCOMBOBOXEX            NMCOMBOBOXEXA
+#define PNMCOMBOBOXEX           PNMCOMBOBOXEXA
+#define CBEN_GETDISPINFO        CBEN_GETDISPINFOA
+#endif
+
+#else
+typedef struct {
+    NMHDR hdr;
+    COMBOBOXEXITEM ceItem;
+} NMCOMBOBOXEX, *PNMCOMBOBOXEX;
+
+#define CBEN_GETDISPINFO         (CBEN_FIRST - 0)
+
+#endif      // _WIN32_IE >= 0x0400
+
+#if (_WIN32_IE >= 0x0400)
+#define CBEN_GETDISPINFOA        (CBEN_FIRST - 0)
+#endif
+#define CBEN_INSERTITEM          (CBEN_FIRST - 1)
+#define CBEN_DELETEITEM          (CBEN_FIRST - 2)
+#define CBEN_BEGINEDIT           (CBEN_FIRST - 4)
+#define CBEN_ENDEDITA            (CBEN_FIRST - 5)
+#define CBEN_ENDEDITW            (CBEN_FIRST - 6)
+
+#if (_WIN32_IE >= 0x0400)
+#define CBEN_GETDISPINFOW        (CBEN_FIRST - 7)
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+#define CBEN_DRAGBEGINA			 (CBEN_FIRST - 8)
+#define CBEN_DRAGBEGINW			 (CBEN_FIRST - 9)
+
+#ifdef UNICODE
+#define CBEN_DRAGBEGIN CBEN_DRAGBEGINW
+#else
+#define CBEN_DRAGBEGIN CBEN_DRAGBEGINA
+#endif
+
+#endif	//(_WIN32_IE >= 0x0400)
+
+// lParam specifies why the endedit is happening
+#ifdef UNICODE
+#define CBEN_ENDEDIT CBEN_ENDEDITW
+#else
+#define CBEN_ENDEDIT CBEN_ENDEDITA
+#endif
+
+#define CBENF_KILLFOCUS         1
+#define CBENF_RETURN            2
+#define CBENF_ESCAPE            3
+#define CBENF_DROPDOWN          4
+
+#define CBEMAXSTRLEN 260
+
+#if (_WIN32_IE >= 0x0400)
+// CBEN_DRAGBEGIN sends this information ...
+
+typedef struct {
+    NMHDR hdr;
+    int   iItemid;
+    WCHAR szText[CBEMAXSTRLEN];
+}NMCBEDRAGBEGINW, *LPNMCBEDRAGBEGINW, *PNMCBEDRAGBEGINW;
+
+
+typedef struct {
+    NMHDR hdr;
+    int   iItemid;
+    char szText[CBEMAXSTRLEN];
+}NMCBEDRAGBEGINA, *LPNMCBEDRAGBEGINA, *PNMCBEDRAGBEGINA;
+
+#ifdef UNICODE
+#define  NMCBEDRAGBEGIN NMCBEDRAGBEGINW
+#define  LPNMCBEDRAGBEGIN LPNMCBEDRAGBEGINW
+#define  PNMCBEDRAGBEGIN PNMCBEDRAGBEGINW
+#else
+#define  NMCBEDRAGBEGIN NMCBEDRAGBEGINA
+#define  LPNMCBEDRAGBEGIN LPNMCBEDRAGBEGINA
+#define  PNMCBEDRAGBEGIN PNMCBEDRAGBEGINA
+#endif
+#endif      // _WIN32_IE >= 0x0400
+
+// CBEN_ENDEDIT sends this information...
+// fChanged if the user actually did anything
+// iNewSelection gives what would be the new selection unless the notify is failed
+//                      iNewSelection may be CB_ERR if there's no match
+typedef struct {
+        NMHDR hdr;
+        BOOL fChanged;
+        int iNewSelection;
+        WCHAR szText[CBEMAXSTRLEN];
+        int iWhy;
+} NMCBEENDEDITW, *LPNMCBEENDEDITW, *PNMCBEENDEDITW;
+
+typedef struct {
+        NMHDR hdr;
+        BOOL fChanged;
+        int iNewSelection;
+        char szText[CBEMAXSTRLEN];
+        int iWhy;
+} NMCBEENDEDITA, *LPNMCBEENDEDITA,*PNMCBEENDEDITA;
+
+#ifdef UNICODE
+#define  NMCBEENDEDIT NMCBEENDEDITW
+#define  LPNMCBEENDEDIT LPNMCBEENDEDITW
+#define  PNMCBEENDEDIT PNMCBEENDEDITW
+#else
+#define  NMCBEENDEDIT NMCBEENDEDITA
+#define  LPNMCBEENDEDIT LPNMCBEENDEDITA
+#define  PNMCBEENDEDIT PNMCBEENDEDITA
+#endif
+
+#endif
+
+#endif      // _WIN32_IE >= 0x0300
+
+
+//====== TAB CONTROL ==========================================================
+
+#ifndef NOTABCONTROL
+
+#ifdef _WIN32
+
+#define WC_TABCONTROLA          "SysTabControl32"
+#define WC_TABCONTROLW          L"SysTabControl32"
+
+#ifdef UNICODE
+#define  WC_TABCONTROL          WC_TABCONTROLW
+#else
+#define  WC_TABCONTROL          WC_TABCONTROLA
+#endif
+
+#else
+#define WC_TABCONTROL           "SysTabControl"
+#endif
+
+// begin_r_commctrl
+
+#if (_WIN32_IE >= 0x0300)
+#define TCS_SCROLLOPPOSITE      0x0001   // assumes multiline tab
+#define TCS_BOTTOM              0x0002
+#define TCS_RIGHT               0x0002
+#define TCS_MULTISELECT         0x0004  // allow multi-select in button mode
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TCS_FLATBUTTONS         0x0008
+#endif
+#define TCS_FORCEICONLEFT       0x0010
+#define TCS_FORCELABELLEFT      0x0020
+#if (_WIN32_IE >= 0x0300)
+#define TCS_HOTTRACK            0x0040
+#define TCS_VERTICAL            0x0080
+#endif
+#define TCS_TABS                0x0000
+#define TCS_BUTTONS             0x0100
+#define TCS_SINGLELINE          0x0000
+#define TCS_MULTILINE           0x0200
+#define TCS_RIGHTJUSTIFY        0x0000
+#define TCS_FIXEDWIDTH          0x0400
+#define TCS_RAGGEDRIGHT         0x0800
+#define TCS_FOCUSONBUTTONDOWN   0x1000
+#define TCS_OWNERDRAWFIXED      0x2000
+#define TCS_TOOLTIPS            0x4000
+#define TCS_FOCUSNEVER          0x8000
+
+#if (_WIN32_IE >= 0x0400)
+// EX styles for use with TCM_SETEXTENDEDSTYLE
+#define TCS_EX_FLATSEPARATORS   0x00000001
+#define TCS_EX_REGISTERDROP     0x00000002
+#endif
+
+// end_r_commctrl
+
+
+#define TCM_GETIMAGELIST        (TCM_FIRST + 2)
+#define TabCtrl_GetImageList(hwnd) \
+    (HIMAGELIST)SNDMSG((hwnd), TCM_GETIMAGELIST, 0, 0L)
+
+
+#define TCM_SETIMAGELIST        (TCM_FIRST + 3)
+#define TabCtrl_SetImageList(hwnd, himl) \
+    (HIMAGELIST)SNDMSG((hwnd), TCM_SETIMAGELIST, 0, (LPARAM)(UINT)(HIMAGELIST)(himl))
+
+
+#define TCM_GETITEMCOUNT        (TCM_FIRST + 4)
+#define TabCtrl_GetItemCount(hwnd) \
+    (int)SNDMSG((hwnd), TCM_GETITEMCOUNT, 0, 0L)
+
+
+#define TCIF_TEXT               0x0001
+#define TCIF_IMAGE              0x0002
+#define TCIF_RTLREADING         0x0004
+#define TCIF_PARAM              0x0008
+#if (_WIN32_IE >= 0x0300)
+#define TCIF_STATE              0x0010
+
+
+#define TCIS_BUTTONPRESSED      0x0001
+#endif
+#if (_WIN32_IE >= 0x0400)
+#define TCIS_HIGHLIGHTED        0x0002
+#endif
+
+#if (_WIN32_IE >= 0x0300)
+#define TC_ITEMHEADERA         TCITEMHEADERA
+#define TC_ITEMHEADERW         TCITEMHEADERW
+#else
+#define tagTCITEMHEADERA       _TC_ITEMHEADERA
+#define    TCITEMHEADERA        TC_ITEMHEADERA
+#define tagTCITEMHEADERW       _TC_ITEMHEADERW
+#define    TCITEMHEADERW        TC_ITEMHEADERW
+#endif
+#define TC_ITEMHEADER          TCITEMHEADER
+
+typedef struct tagTCITEMHEADERA
+{
+    UINT mask;
+    UINT lpReserved1;
+    UINT lpReserved2;
+    LPSTR pszText;
+    int cchTextMax;
+    int iImage;
+} TCITEMHEADERA, FAR *LPTCITEMHEADERA;
+
+typedef struct tagTCITEMHEADERW
+{
+    UINT mask;
+    UINT lpReserved1;
+    UINT lpReserved2;
+    LPWSTR pszText;
+    int cchTextMax;
+    int iImage;
+} TCITEMHEADERW, FAR *LPTCITEMHEADERW;
+
+#ifdef UNICODE
+#define  TCITEMHEADER          TCITEMHEADERW
+#define  LPTCITEMHEADER        LPTCITEMHEADERW
+#else
+#define  TCITEMHEADER          TCITEMHEADERA
+#define  LPTCITEMHEADER        LPTCITEMHEADERA
+#endif
+
+
+#if (_WIN32_IE >= 0x0300)
+#define TC_ITEMA                TCITEMA
+#define TC_ITEMW                TCITEMW
+#else
+#define tagTCITEMA              _TC_ITEMA
+#define    TCITEMA               TC_ITEMA
+#define tagTCITEMW              _TC_ITEMW
+#define    TCITEMW               TC_ITEMW
+#endif
+#define TC_ITEM                 TCITEM
+
+typedef struct tagTCITEMA
+{
+    UINT mask;
+#if (_WIN32_IE >= 0x0300)
+    DWORD dwState;
+    DWORD dwStateMask;
+#else
+    UINT lpReserved1;
+    UINT lpReserved2;
+#endif
+    LPSTR pszText;
+    int cchTextMax;
+    int iImage;
+
+    LPARAM lParam;
+} TCITEMA, FAR *LPTCITEMA;
+
+typedef struct tagTCITEMW
+{
+    UINT mask;
+#if (_WIN32_IE >= 0x0300)
+    DWORD dwState;
+    DWORD dwStateMask;
+#else
+    UINT lpReserved1;
+    UINT lpReserved2;
+#endif
+    LPWSTR pszText;
+    int cchTextMax;
+    int iImage;
+
+    LPARAM lParam;
+} TCITEMW, FAR *LPTCITEMW;
+
+#ifdef UNICODE
+#define  TCITEM                 TCITEMW
+#define  LPTCITEM               LPTCITEMW
+#else
+#define  TCITEM                 TCITEMA
+#define  LPTCITEM               LPTCITEMA
+#endif
+
+
+#define TCM_GETITEMA            (TCM_FIRST + 5)
+#define TCM_GETITEMW            (TCM_FIRST + 60)
+
+#ifdef UNICODE
+#define TCM_GETITEM             TCM_GETITEMW
+#else
+#define TCM_GETITEM             TCM_GETITEMA
+#endif
+
+#define TabCtrl_GetItem(hwnd, iItem, pitem) \
+    (BOOL)SNDMSG((hwnd), TCM_GETITEM, (WPARAM)(int)iItem, (LPARAM)(TC_ITEM FAR*)(pitem))
+
+
+#define TCM_SETITEMA            (TCM_FIRST + 6)
+#define TCM_SETITEMW            (TCM_FIRST + 61)
+
+#ifdef UNICODE
+#define TCM_SETITEM             TCM_SETITEMW
+#else
+#define TCM_SETITEM             TCM_SETITEMA
+#endif
+
+#define TabCtrl_SetItem(hwnd, iItem, pitem) \
+    (BOOL)SNDMSG((hwnd), TCM_SETITEM, (WPARAM)(int)iItem, (LPARAM)(TC_ITEM FAR*)(pitem))
+
+
+#define TCM_INSERTITEMA         (TCM_FIRST + 7)
+#define TCM_INSERTITEMW         (TCM_FIRST + 62)
+
+#ifdef UNICODE
+#define TCM_INSERTITEM          TCM_INSERTITEMW
+#else
+#define TCM_INSERTITEM          TCM_INSERTITEMA
+#endif
+
+#define TabCtrl_InsertItem(hwnd, iItem, pitem)   \
+    (int)SNDMSG((hwnd), TCM_INSERTITEM, (WPARAM)(int)iItem, (LPARAM)(const TC_ITEM FAR*)(pitem))
+
+
+#define TCM_DELETEITEM          (TCM_FIRST + 8)
+#define TabCtrl_DeleteItem(hwnd, i) \
+    (BOOL)SNDMSG((hwnd), TCM_DELETEITEM, (WPARAM)(int)(i), 0L)
+
+
+#define TCM_DELETEALLITEMS      (TCM_FIRST + 9)
+#define TabCtrl_DeleteAllItems(hwnd) \
+    (BOOL)SNDMSG((hwnd), TCM_DELETEALLITEMS, 0, 0L)
+
+
+#define TCM_GETITEMRECT         (TCM_FIRST + 10)
+#define TabCtrl_GetItemRect(hwnd, i, prc) \
+    (BOOL)SNDMSG((hwnd), TCM_GETITEMRECT, (WPARAM)(int)(i), (LPARAM)(RECT FAR*)(prc))
+
+
+#define TCM_GETCURSEL           (TCM_FIRST + 11)
+#define TabCtrl_GetCurSel(hwnd) \
+    (int)SNDMSG((hwnd), TCM_GETCURSEL, 0, 0)
+
+
+#define TCM_SETCURSEL           (TCM_FIRST + 12)
+#define TabCtrl_SetCurSel(hwnd, i) \
+    (int)SNDMSG((hwnd), TCM_SETCURSEL, (WPARAM)i, 0)
+
+
+#define TCHT_NOWHERE            0x0001
+#define TCHT_ONITEMICON         0x0002
+#define TCHT_ONITEMLABEL        0x0004
+#define TCHT_ONITEM             (TCHT_ONITEMICON | TCHT_ONITEMLABEL)
+
+#if (_WIN32_IE >= 0x0300)
+#define LPTC_HITTESTINFO        LPTCHITTESTINFO
+#define TC_HITTESTINFO          TCHITTESTINFO
+#else
+#define tagTCHITTESTINFO        _TC_HITTESTINFO
+#define    TCHITTESTINFO         TC_HITTESTINFO
+#define  LPTCHITTESTINFO       LPTC_HITTESTINFO
+#endif
+
+typedef struct tagTCHITTESTINFO
+{
+    POINT pt;
+    UINT flags;
+} TCHITTESTINFO, FAR * LPTCHITTESTINFO;
+
+#define TCM_HITTEST             (TCM_FIRST + 13)
+#define TabCtrl_HitTest(hwndTC, pinfo) \
+    (int)SNDMSG((hwndTC), TCM_HITTEST, 0, (LPARAM)(TC_HITTESTINFO FAR*)(pinfo))
+
+
+#define TCM_SETITEMEXTRA        (TCM_FIRST + 14)
+#define TabCtrl_SetItemExtra(hwndTC, cb) \
+    (BOOL)SNDMSG((hwndTC), TCM_SETITEMEXTRA, (WPARAM)(cb), 0L)
+
+
+#define TCM_ADJUSTRECT          (TCM_FIRST + 40)
+#define TabCtrl_AdjustRect(hwnd, bLarger, prc) \
+    (int)SNDMSG(hwnd, TCM_ADJUSTRECT, (WPARAM)(BOOL)bLarger, (LPARAM)(RECT FAR *)prc)
+
+
+#define TCM_SETITEMSIZE         (TCM_FIRST + 41)
+#define TabCtrl_SetItemSize(hwnd, x, y) \
+    (DWORD)SNDMSG((hwnd), TCM_SETITEMSIZE, 0, MAKELPARAM(x,y))
+
+
+#define TCM_REMOVEIMAGE         (TCM_FIRST + 42)
+#define TabCtrl_RemoveImage(hwnd, i) \
+        (void)SNDMSG((hwnd), TCM_REMOVEIMAGE, i, 0L)
+
+
+#define TCM_SETPADDING          (TCM_FIRST + 43)
+#define TabCtrl_SetPadding(hwnd,  cx, cy) \
+        (void)SNDMSG((hwnd), TCM_SETPADDING, 0, MAKELPARAM(cx, cy))
+
+
+#define TCM_GETROWCOUNT         (TCM_FIRST + 44)
+#define TabCtrl_GetRowCount(hwnd) \
+        (int)SNDMSG((hwnd), TCM_GETROWCOUNT, 0, 0L)
+
+
+#define TCM_GETTOOLTIPS         (TCM_FIRST + 45)
+#define TabCtrl_GetToolTips(hwnd) \
+        (HWND)SNDMSG((hwnd), TCM_GETTOOLTIPS, 0, 0L)
+
+
+#define TCM_SETTOOLTIPS         (TCM_FIRST + 46)
+#define TabCtrl_SetToolTips(hwnd, hwndTT) \
+        (void)SNDMSG((hwnd), TCM_SETTOOLTIPS, (WPARAM)hwndTT, 0L)
+
+
+#define TCM_GETCURFOCUS         (TCM_FIRST + 47)
+#define TabCtrl_GetCurFocus(hwnd) \
+    (int)SNDMSG((hwnd), TCM_GETCURFOCUS, 0, 0)
+
+#define TCM_SETCURFOCUS         (TCM_FIRST + 48)
+#define TabCtrl_SetCurFocus(hwnd, i) \
+    SNDMSG((hwnd),TCM_SETCURFOCUS, i, 0)
+
+#if (_WIN32_IE >= 0x0300)
+#define TCM_SETMINTABWIDTH      (TCM_FIRST + 49)
+#define TabCtrl_SetMinTabWidth(hwnd, x) \
+        (int)SNDMSG((hwnd), TCM_SETMINTABWIDTH, 0, x)
+
+
+#define TCM_DESELECTALL         (TCM_FIRST + 50)
+#define TabCtrl_DeselectAll(hwnd, fExcludeFocus)\
+        (void)SNDMSG((hwnd), TCM_DESELECTALL, fExcludeFocus, 0)
+#endif
+
+#if (_WIN32_IE >= 0x0400)
+
+#define TCM_HIGHLIGHTITEM       (TCM_FIRST + 51)
+#define TabCtrl_HighlightItem(hwnd, i, fHighlight) \
+    (BOOL)SNDMSG((hwnd), TCM_HIGHLIGHTITEM, (WPARAM)i, (LPARAM)MAKELONG (fHighlight, 0))
+
+#define TCM_SETEXTENDEDSTYLE    (TCM_FIRST + 52)  // optional wParam == mask
+#define TabCtrl_SetExtendedStyle(hwnd, dw)\
+        (DWORD)SNDMSG((hwnd), TCM_SETEXTENDEDSTYLE, 0, dw)
+
+#define TCM_GETEXTENDEDSTYLE    (TCM_FIRST + 53)
+#define TabCtrl_GetExtendedStyle(hwnd)\
+        (DWORD)SNDMSG((hwnd), TCM_GETEXTENDEDSTYLE, 0, 0)
+
+#define TCM_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define TabCtrl_SetUnicodeFormat(hwnd, fUnicode)  \
+    (BOOL)SNDMSG((hwnd), TCM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0)
+
+#define TCM_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+#define TabCtrl_GetUnicodeFormat(hwnd)  \
+    (BOOL)SNDMSG((hwnd), TCM_GETUNICODEFORMAT, 0, 0)
+
+#endif      // _WIN32_IE >= 0x0400
+
+#define TCN_KEYDOWN             (TCN_FIRST - 0)
+
+#if (_WIN32_IE >= 0x0300)
+#define TC_KEYDOWN              NMTCKEYDOWN
+#else
+#define tagTCKEYDOWN            _TC_KEYDOWN
+#define  NMTCKEYDOWN             TC_KEYDOWN
+#endif
+
+typedef struct tagTCKEYDOWN
+{
+    NMHDR hdr;
+    WORD wVKey;
+    UINT flags;
+} NMTCKEYDOWN;
+
+#define TCN_SELCHANGE           (TCN_FIRST - 1)
+#define TCN_SELCHANGING         (TCN_FIRST - 2)
+#if (_WIN32_IE >= 0x0400)
+#define TCN_GETOBJECT           (TCN_FIRST - 3)
+#endif      // _WIN32_IE >= 0x0400
+
+#endif      // NOTABCONTROL
+
+
+
+
+//====== ANIMATE CONTROL ======================================================
+
+#ifndef NOANIMATE
+
+#ifdef _WIN32
+
+#define ANIMATE_CLASSW          L"SysAnimate32"
+#define ANIMATE_CLASSA          "SysAnimate32"
+
+#ifdef UNICODE
+#define ANIMATE_CLASS           ANIMATE_CLASSW
+#else
+#define ANIMATE_CLASS           ANIMATE_CLASSA
+#endif
+
+// begin_r_commctrl
+
+#define ACS_CENTER              0x0001
+#define ACS_TRANSPARENT         0x0002
+#define ACS_AUTOPLAY            0x0004
+#if (_WIN32_IE >= 0x0300)
+#define ACS_TIMER               0x0008  // don't use threads... use timers
+#endif
+
+// end_r_commctrl
+
+#define ACM_OPENA               (WM_USER+100)
+#define ACM_OPENW               (WM_USER+103)
+
+#ifdef UNICODE
+#define ACM_OPEN                ACM_OPENW
+#else
+#define ACM_OPEN                ACM_OPENA
+#endif
+
+#define ACM_PLAY                (WM_USER+101)
+#define ACM_STOP                (WM_USER+102)
+
+
+#define ACN_START               1
+#define ACN_STOP                2
+
+
+#define Animate_Create(hwndP, id, dwStyle, hInstance)   \
+            CreateWindow(ANIMATE_CLASS, NULL,           \
+                dwStyle, 0, 0, 0, 0, hwndP, (HMENU)(id), hInstance, NULL)
+
+#define Animate_Open(hwnd, szName)          (BOOL)SNDMSG(hwnd, ACM_OPEN, 0, (LPARAM)(LPTSTR)(szName))
+#define Animate_OpenEx(hwnd, hInst, szName) (BOOL)SNDMSG(hwnd, ACM_OPEN, (WPARAM)hInst, (LPARAM)(LPTSTR)(szName))
+#define Animate_Play(hwnd, from, to, rep)   (BOOL)SNDMSG(hwnd, ACM_PLAY, (WPARAM)(UINT)(rep), (LPARAM)MAKELONG(from, to))
+#define Animate_Stop(hwnd)                  (BOOL)SNDMSG(hwnd, ACM_STOP, 0, 0)
+#define Animate_Close(hwnd)                 Animate_Open(hwnd, NULL)
+#define Animate_Seek(hwnd, frame)           Animate_Play(hwnd, frame, frame, 1)
+#endif
+
+#endif      // NOANIMATE
+
+#if (_WIN32_IE >= 0x0300)
+//====== MONTHCAL CONTROL ======================================================
+
+#ifndef NOMONTHCAL
+#ifdef _WIN32
+
+#define MONTHCAL_CLASSW          L"SysMonthCal32"
+#define MONTHCAL_CLASSA          "SysMonthCal32"
+
+#ifdef UNICODE
+#define MONTHCAL_CLASS           MONTHCAL_CLASSW
+#else
+#define MONTHCAL_CLASS           MONTHCAL_CLASSA
+#endif
+
+// bit-packed array of "bold" info for a month
+// if a bit is on, that day is drawn bold
+typedef DWORD MONTHDAYSTATE, FAR * LPMONTHDAYSTATE;
+
+
+#define MCM_FIRST           0x1000
+
+// BOOL MonthCal_GetCurSel(HWND hmc, LPSYSTEMTIME pst)
+//   returns FALSE if MCS_MULTISELECT
+//   returns TRUE and sets *pst to the currently selected date otherwise
+#define MCM_GETCURSEL       (MCM_FIRST + 1)
+#define MonthCal_GetCurSel(hmc, pst)    (BOOL)SNDMSG(hmc, MCM_GETCURSEL, 0, (LPARAM)(pst))
+
+// BOOL MonthCal_SetCurSel(HWND hmc, LPSYSTEMTIME pst)
+//   returns FALSE if MCS_MULTISELECT
+//   returns TURE and sets the currently selected date to *pst otherwise
+#define MCM_SETCURSEL       (MCM_FIRST + 2)
+#define MonthCal_SetCurSel(hmc, pst)    (BOOL)SNDMSG(hmc, MCM_SETCURSEL, 0, (LPARAM)(pst))
+
+// DWORD MonthCal_GetMaxSelCount(HWND hmc)
+//   returns the maximum number of selectable days allowed
+#define MCM_GETMAXSELCOUNT  (MCM_FIRST + 3)
+#define MonthCal_GetMaxSelCount(hmc)    (DWORD)SNDMSG(hmc, MCM_GETMAXSELCOUNT, 0, 0L)
+
+// BOOL MonthCal_SetMaxSelCount(HWND hmc, UINT n)
+//   sets the max number days that can be selected iff MCS_MULTISELECT
+#define MCM_SETMAXSELCOUNT  (MCM_FIRST + 4)
+#define MonthCal_SetMaxSelCount(hmc, n) (BOOL)SNDMSG(hmc, MCM_SETMAXSELCOUNT, (WPARAM)(n), 0L)
+
+// BOOL MonthCal_GetSelRange(HWND hmc, LPSYSTEMTIME rgst)
+//   sets rgst[0] to the first day of the selection range
+//   sets rgst[1] to the last day of the selection range
+#define MCM_GETSELRANGE     (MCM_FIRST + 5)
+#define MonthCal_GetSelRange(hmc, rgst) SNDMSG(hmc, MCM_GETSELRANGE, 0, (LPARAM)(rgst))
+
+// BOOL MonthCal_SetSelRange(HWND hmc, LPSYSTEMTIME rgst)
+//   selects the range of days from rgst[0] to rgst[1]
+#define MCM_SETSELRANGE     (MCM_FIRST + 6)
+#define MonthCal_SetSelRange(hmc, rgst) SNDMSG(hmc, MCM_SETSELRANGE, 0, (LPARAM)(rgst))
+
+// DWORD MonthCal_GetMonthRange(HWND hmc, DWORD gmr, LPSYSTEMTIME rgst)
+//   if rgst specified, sets rgst[0] to the starting date and
+//      and rgst[1] to the ending date of the the selectable (non-grayed)
+//      days if GMR_VISIBLE or all the displayed days (including grayed)
+//      if GMR_DAYSTATE.
+//   returns the number of months spanned by the above range.
+#define MCM_GETMONTHRANGE   (MCM_FIRST + 7)
+#define MonthCal_GetMonthRange(hmc, gmr, rgst)  (DWORD)SNDMSG(hmc, MCM_GETMONTHRANGE, (WPARAM)(gmr), (LPARAM)(rgst))
+
+// BOOL MonthCal_SetDayState(HWND hmc, int cbds, DAYSTATE *rgds)
+//   cbds is the count of DAYSTATE items in rgds and it must be equal
+//   to the value returned from MonthCal_GetMonthRange(hmc, GMR_DAYSTATE, NULL)
+//   This sets the DAYSTATE bits for each month (grayed and non-grayed
+//   days) displayed in the calendar. The first bit in a month's DAYSTATE
+//   corresponts to bolding day 1, the second bit affects day 2, etc.
+#define MCM_SETDAYSTATE     (MCM_FIRST + 8)
+#define MonthCal_SetDayState(hmc, cbds, rgds)   SNDMSG(hmc, MCM_SETDAYSTATE, (WPARAM)(cbds), (LPARAM)(rgds))
+
+// BOOL MonthCal_GetMinReqRect(HWND hmc, LPRECT prc)
+//   sets *prc the minimal size needed to display one month
+//   To display two months, undo the AdjustWindowRect calculation already done to
+//   this rect, double the width, and redo the AdjustWindowRect calculation --
+//   the monthcal control will display two calendars in this window (if you also
+//   double the vertical size, you will get 4 calendars)
+//   NOTE: if you want to gurantee that the "Today" string is not clipped,
+//   get the MCM_GETMAXTODAYWIDTH and use the max of that width and this width
+#define MCM_GETMINREQRECT   (MCM_FIRST + 9)
+#define MonthCal_GetMinReqRect(hmc, prc)        SNDMSG(hmc, MCM_GETMINREQRECT, 0, (LPARAM)(prc))
+
+// set colors to draw control with -- see MCSC_ bits below
+#define MCM_SETCOLOR            (MCM_FIRST + 10)
+#define MonthCal_SetColor(hmc, iColor, clr) SNDMSG(hmc, MCM_SETCOLOR, iColor, clr)
+
+#define MCM_GETCOLOR            (MCM_FIRST + 11)
+#define MonthCal_GetColor(hmc, iColor) SNDMSG(hmc, MCM_SETCOLOR, iColor, 0)
+
+#define MCSC_BACKGROUND   0   // the background color (between months)
+#define MCSC_TEXT         1   // the dates
+#define MCSC_TITLEBK      2   // background of the title
+#define MCSC_TITLETEXT    3
+#define MCSC_MONTHBK      4   // background within the month cal
+#define MCSC_TRAILINGTEXT 5   // the text color of header & trailing days
+
+// set what day is "today"   send NULL to revert back to real date
+#define MCM_SETTODAY    (MCM_FIRST + 12)
+#define MonthCal_SetToday(hmc, pst)             SNDMSG(hmc, MCM_SETTODAY, 0, (LPARAM)pst)
+
+// get what day is "today"
+// returns BOOL for success/failure
+#define MCM_GETTODAY    (MCM_FIRST + 13)
+#define MonthCal_GetToday(hmc, pst)             (BOOL)SNDMSG(hmc, MCM_GETTODAY, 0, (LPARAM)pst)
+
+// determine what pinfo->pt is over
+#define MCM_HITTEST          (MCM_FIRST + 14)
+#define MonthCal_HitTest(hmc, pinfo) \
+        SNDMSG(hmc, MCM_HITTEST, 0, (LPARAM)(PMCHITTESTINFO)pinfo)
+
+typedef struct {
+        UINT cbSize;
+        POINT pt;
+
+        UINT uHit;   // out param
+        SYSTEMTIME st;
+} MCHITTESTINFO, *PMCHITTESTINFO;
+
+#define MCHT_TITLE                      0x00010000
+#define MCHT_CALENDAR                   0x00020000
+#define MCHT_TODAYLINK                  0x00030000
+
+#define MCHT_NEXT                       0x01000000   // these indicate that hitting
+#define MCHT_PREV                       0x02000000  // here will go to the next/prev month
+
+#define MCHT_NOWHERE                    0x00000000
+
+#define MCHT_TITLEBK                    (MCHT_TITLE)
+#define MCHT_TITLEMONTH                 (MCHT_TITLE | 0x0001)
+#define MCHT_TITLEYEAR                  (MCHT_TITLE | 0x0002)
+#define MCHT_TITLEBTNNEXT               (MCHT_TITLE | MCHT_NEXT | 0x0003)
+#define MCHT_TITLEBTNPREV               (MCHT_TITLE | MCHT_PREV | 0x0003)
+
+#define MCHT_CALENDARBK                 (MCHT_CALENDAR)
+#define MCHT_CALENDARDATE               (MCHT_CALENDAR | 0x0001)
+#define MCHT_CALENDARDATENEXT           (MCHT_CALENDARDATE | MCHT_NEXT)
+#define MCHT_CALENDARDATEPREV           (MCHT_CALENDARDATE | MCHT_PREV)
+#define MCHT_CALENDARDAY                (MCHT_CALENDAR | 0x0002)
+#define MCHT_CALENDARWEEKNUM            (MCHT_CALENDAR | 0x0003)
+
+// set first day of week to iDay:
+// 0 for Monday, 1 for Tuesday, ..., 6 for Sunday
+// -1 for means use locale info
+#define MCM_SETFIRSTDAYOFWEEK (MCM_FIRST + 15)
+#define MonthCal_SetFirstDayOfWeek(hmc, iDay) \
+        SNDMSG(hmc, MCM_SETFIRSTDAYOFWEEK, 0, iDay)
+
+// DWORD result...  low word has the day.  high word is bool if this is app set
+// or not (FALSE == using locale info)
+#define MCM_GETFIRSTDAYOFWEEK (MCM_FIRST + 16)
+#define MonthCal_GetFirstDayOfWeek(hmc) \
+        (DWORD)SNDMSG(hmc, MCM_GETFIRSTDAYOFWEEK, 0, 0)
+
+// DWORD MonthCal_GetRange(HWND hmc, LPSYSTEMTIME rgst)
+//   modifies rgst[0] to be the minimum ALLOWABLE systemtime (or 0 if no minimum)
+//   modifies rgst[1] to be the maximum ALLOWABLE systemtime (or 0 if no maximum)
+//   returns GDTR_MIN|GDTR_MAX if there is a minimum|maximum limit
+#define MCM_GETRANGE (MCM_FIRST + 17)
+#define MonthCal_GetRange(hmc, rgst) \
+        (DWORD)SNDMSG(hmc, MCM_GETRANGE, 0, (LPARAM)(rgst))
+
+// BOOL MonthCal_SetRange(HWND hmc, DWORD gdtr, LPSYSTEMTIME rgst)
+//   if GDTR_MIN, sets the minimum ALLOWABLE systemtime to rgst[0], otherwise removes minimum
+//   if GDTR_MAX, sets the maximum ALLOWABLE systemtime to rgst[1], otherwise removes maximum
+//   returns TRUE on success, FALSE on error (such as invalid parameters)
+#define MCM_SETRANGE (MCM_FIRST + 18)
+#define MonthCal_SetRange(hmc, gd, rgst) \
+        (BOOL)SNDMSG(hmc, MCM_SETRANGE, (WPARAM)(gd), (LPARAM)(rgst))
+
+// int MonthCal_GetMonthDelta(HWND hmc)
+//   returns the number of months one click on a next/prev button moves by
+#define MCM_GETMONTHDELTA (MCM_FIRST + 19)
+#define MonthCal_GetMonthDelta(hmc) \
+        (int)SNDMSG(hmc, MCM_GETMONTHDELTA, 0, 0)
+
+// int MonthCal_SetMonthDelta(HWND hmc, int n)
+//   sets the month delta to n. n==0 reverts to moving by a page of months
+//   returns the previous value of n.
+#define MCM_SETMONTHDELTA (MCM_FIRST + 20)
+#define MonthCal_SetMonthDelta(hmc, n) \
+        (int)SNDMSG(hmc, MCM_SETMONTHDELTA, n, 0)
+
+// DWORD MonthCal_GetMaxTodayWidth(HWND hmc, LPSIZE psz)
+//   sets *psz to the maximum width/height of the "Today" string displayed
+//   at the bottom of the calendar (as long as MCS_NOTODAY is not specified)
+#define MCM_GETMAXTODAYWIDTH (MCM_FIRST + 21)
+#define MonthCal_GetMaxTodayWidth(hmc) \
+        (DWORD)SNDMSG(hmc, MCM_GETMAXTODAYWIDTH, 0, 0)
+
+#if (_WIN32_IE >= 0x0400)
+#define MCM_SETUNICODEFORMAT     CCM_SETUNICODEFORMAT
+#define MonthCal_SetUnicodeFormat(hwnd, fUnicode)  \
+    (BOOL)SNDMSG((hwnd), MCM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0)
+
+#define MCM_GETUNICODEFORMAT     CCM_GETUNICODEFORMAT
+#define MonthCal_GetUnicodeFormat(hwnd)  \
+    (BOOL)SNDMSG((hwnd), MCM_GETUNICODEFORMAT, 0, 0)
+#endif
+
+// MCN_SELCHANGE is sent whenever the currently displayed date changes
+// via month change, year change, keyboard navigation, prev/next button
+//
+typedef struct tagNMSELCHANGE
+{
+    NMHDR           nmhdr;  // this must be first, so we don't break WM_NOTIFY
+
+    SYSTEMTIME      stSelStart;
+    SYSTEMTIME      stSelEnd;
+} NMSELCHANGE, FAR * LPNMSELCHANGE;
+
+#define MCN_SELCHANGE       (MCN_FIRST + 1)
+
+// MCN_GETDAYSTATE is sent for MCS_DAYSTATE controls whenever new daystate
+// information is needed (month or year scroll) to draw bolding information.
+// The app must fill in cDayState months worth of information starting from
+// stStart date. The app may fill in the array at prgDayState or change
+// prgDayState to point to a different array out of which the information
+// will be copied. (similar to tooltips)
+//
+typedef struct tagNMDAYSTATE
+{
+    NMHDR           nmhdr;  // this must be first, so we don't break WM_NOTIFY
+
+    SYSTEMTIME      stStart;
+    int             cDayState;
+
+    LPMONTHDAYSTATE prgDayState; // points to cDayState MONTHDAYSTATEs
+} NMDAYSTATE, FAR * LPNMDAYSTATE;
+
+#define MCN_GETDAYSTATE     (MCN_FIRST + 3)
+
+// MCN_SELECT is sent whenever a selection has occured (via mouse or keyboard)
+//
+typedef NMSELCHANGE NMSELECT, FAR * LPNMSELECT;
+
+
+#define MCN_SELECT          (MCN_FIRST + 4)
+
+
+#define MCS_DAYSTATE        0x0001
+#define MCS_MULTISELECT     0x0002
+#define MCS_WEEKNUMBERS     0x0004
+#if (_WIN32_IE >= 0x0400)
+#define MCS_NOTODAYCIRCLE   0x0008
+#define MCS_NOTODAY         0x0010
+#else
+#define MCS_NOTODAY         0x0008
+#endif
+
+#define GMR_VISIBLE     0       // visible portion of display
+#define GMR_DAYSTATE    1       // above plus the grayed out parts of
+                                // partially displayed months
+
+
+#endif // _WIN32
+#endif // NOMONTHCAL
+
+
+//====== DATETIMEPICK CONTROL ==================================================
+
+#ifndef NODATETIMEPICK
+#ifdef _WIN32
+
+#define DATETIMEPICK_CLASSW          L"SysDateTimePick32"
+#define DATETIMEPICK_CLASSA          "SysDateTimePick32"
+
+#ifdef UNICODE
+#define DATETIMEPICK_CLASS           DATETIMEPICK_CLASSW
+#else
+#define DATETIMEPICK_CLASS           DATETIMEPICK_CLASSA
+#endif
+
+#define DTM_FIRST        0x1000
+
+// DWORD DateTimePick_GetSystemtime(HWND hdp, LPSYSTEMTIME pst)
+//   returns GDT_NONE if "none" is selected (DTS_SHOWNONE only)
+//   returns GDT_VALID and modifies *pst to be the currently selected value
+#define DTM_GETSYSTEMTIME   (DTM_FIRST + 1)
+#define DateTime_GetSystemtime(hdp, pst)    (DWORD)SNDMSG(hdp, DTM_GETSYSTEMTIME, 0, (LPARAM)(pst))
+
+// BOOL DateTime_SetSystemtime(HWND hdp, DWORD gd, LPSYSTEMTIME pst)
+//   if gd==GDT_NONE, sets datetimepick to None (DTS_SHOWNONE only)
+//   if gd==GDT_VALID, sets datetimepick to *pst
+//   returns TRUE on success, FALSE on error (such as bad params)
+#define DTM_SETSYSTEMTIME   (DTM_FIRST + 2)
+#define DateTime_SetSystemtime(hdp, gd, pst)    (BOOL)SNDMSG(hdp, DTM_SETSYSTEMTIME, (LPARAM)(gd), (LPARAM)(pst))
+
+// DWORD DateTime_GetRange(HWND hdp, LPSYSTEMTIME rgst)
+//   modifies rgst[0] to be the minimum ALLOWABLE systemtime (or 0 if no minimum)
+//   modifies rgst[1] to be the maximum ALLOWABLE systemtime (or 0 if no maximum)
+//   returns GDTR_MIN|GDTR_MAX if there is a minimum|maximum limit
+#define DTM_GETRANGE (DTM_FIRST + 3)
+#define DateTime_GetRange(hdp, rgst)  (DWORD)SNDMSG(hdp, DTM_GETRANGE, 0, (LPARAM)(rgst))
+
+// BOOL DateTime_SetRange(HWND hdp, DWORD gdtr, LPSYSTEMTIME rgst)
+//   if GDTR_MIN, sets the minimum ALLOWABLE systemtime to rgst[0], otherwise removes minimum
+//   if GDTR_MAX, sets the maximum ALLOWABLE systemtime to rgst[1], otherwise removes maximum
+//   returns TRUE on success, FALSE on error (such as invalid parameters)
+#define DTM_SETRANGE (DTM_FIRST + 4)
+#define DateTime_SetRange(hdp, gd, rgst)  (BOOL)SNDMSG(hdp, DTM_SETRANGE, (WPARAM)(gd), (LPARAM)(rgst))
+
+// BOOL DateTime_SetFormat(HWND hdp, LPCTSTR sz)
+//   sets the display formatting string to sz (see GetDateFormat and GetTimeFormat for valid formatting chars)
+//   NOTE: 'X' is a valid formatting character which indicates that the application
+//   will determine how to display information. Such apps must support DTN_WMKEYDOWN,
+//   DTN_FORMAT, and DTN_FORMATQUERY.
+#define DTM_SETFORMATA (DTM_FIRST + 5)
+#define DTM_SETFORMATW (DTM_FIRST + 50)
+
+#ifdef UNICODE
+#define DTM_SETFORMAT       DTM_SETFORMATW
+#else
+#define DTM_SETFORMAT       DTM_SETFORMATA
+#endif
+
+#define DateTime_SetFormat(hdp, sz)  (BOOL)SNDMSG(hdp, DTM_SETFORMAT, 0, (LPARAM)(sz))
+
+
+#define DTM_SETMCCOLOR    (DTM_FIRST + 6)
+#define DateTime_SetMonthCalColor(hdp, iColor, clr) SNDMSG(hdp, DTM_SETMCCOLOR, iColor, clr)
+
+#define DTM_GETMCCOLOR    (DTM_FIRST + 7)
+#define DateTime_GetMonthCalColor(hdp, iColor) SNDMSG(hdp, DTM_GETMCCOLOR, iColor, 0)
+
+// HWND DateTime_GetMonthCal(HWND hdp)
+//   returns the HWND of the MonthCal popup window. Only valid
+// between DTN_DROPDOWN and DTN_CLOSEUP notifications.
+#define DTM_GETMONTHCAL   (DTM_FIRST + 8)
+#define DateTime_GetMonthCal(hdp) (HWND)SNDMSG(hdp, DTM_GETMONTHCAL, 0, 0)
+
+#if (_WIN32_IE >= 0x0400)
+
+#define DTM_SETMCFONT     (DTM_FIRST + 9)
+#define DateTime_SetMonthCalFont(hdp, hfont, fRedraw) SNDMSG(hdp, DTM_SETMCFONT, (WPARAM)hfont, (LPARAM)fRedraw)
+
+#define DTM_GETMCFONT     (DTM_FIRST + 10)
+#define DateTime_GetMonthCalFont(hdp) SNDMSG(hdp, DTM_GETMCFONT, 0, 0)
+
+#endif      // _WIN32_IE >= 0x0400
+
+#define DTS_UPDOWN          0x0001 // use UPDOWN instead of MONTHCAL
+#define DTS_SHOWNONE        0x0002 // allow a NONE selection
+#define DTS_SHORTDATEFORMAT 0x0000 // use the short date format (app must forward WM_WININICHANGE messages)
+#define DTS_LONGDATEFORMAT  0x0004 // use the long date format (app must forward WM_WININICHANGE messages)
+#define DTS_TIMEFORMAT      0x0009 // use the time format (app must forward WM_WININICHANGE messages)
+#define DTS_APPCANPARSE     0x0010 // allow user entered strings (app MUST respond to DTN_USERSTRING)
+#define DTS_RIGHTALIGN      0x0020 // right-align popup instead of left-align it
+
+#define DTN_DATETIMECHANGE  (DTN_FIRST + 1) // the systemtime has changed
+typedef struct tagNMDATETIMECHANGE
+{
+    NMHDR       nmhdr;
+    DWORD       dwFlags;    // GDT_VALID or GDT_NONE
+    SYSTEMTIME  st;         // valid iff dwFlags==GDT_VALID
+} NMDATETIMECHANGE, FAR * LPNMDATETIMECHANGE;
+
+#define DTN_USERSTRINGA  (DTN_FIRST + 2) // the user has entered a string
+#define DTN_USERSTRINGW  (DTN_FIRST + 15)
+typedef struct tagNMDATETIMESTRINGA
+{
+    NMHDR      nmhdr;
+    LPCSTR     pszUserString;  // string user entered
+    SYSTEMTIME st;             // app fills this in
+    DWORD      dwFlags;        // GDT_VALID or GDT_NONE
+} NMDATETIMESTRINGA, FAR * LPNMDATETIMESTRINGA;
+
+typedef struct tagNMDATETIMESTRINGW
+{
+    NMHDR      nmhdr;
+    LPCWSTR    pszUserString;  // string user entered
+    SYSTEMTIME st;             // app fills this in
+    DWORD      dwFlags;        // GDT_VALID or GDT_NONE
+} NMDATETIMESTRINGW, FAR * LPNMDATETIMESTRINGW;
+
+#ifdef UNICODE
+#define DTN_USERSTRING          DTN_USERSTRINGW
+#define NMDATETIMESTRING        NMDATETIMESTRINGW
+#define LPNMDATETIMESTRING      LPNMDATETIMESTRINGW
+#else
+#define DTN_USERSTRING          DTN_USERSTRINGA
+#define NMDATETIMESTRING        NMDATETIMESTRINGA
+#define LPNMDATETIMESTRING      LPNMDATETIMESTRINGA
+#endif
+
+
+#define DTN_WMKEYDOWNA  (DTN_FIRST + 3) // modify keydown on app format field (X)
+#define DTN_WMKEYDOWNW  (DTN_FIRST + 16)
+typedef struct tagNMDATETIMEWMKEYDOWNA
+{
+    NMHDR      nmhdr;
+    int        nVirtKey;  // virtual key code of WM_KEYDOWN which MODIFIES an X field
+    LPCSTR     pszFormat; // format substring
+    SYSTEMTIME st;        // current systemtime, app should modify based on key
+} NMDATETIMEWMKEYDOWNA, FAR * LPNMDATETIMEWMKEYDOWNA;
+
+typedef struct tagNMDATETIMEWMKEYDOWNW
+{
+    NMHDR      nmhdr;
+    int        nVirtKey;  // virtual key code of WM_KEYDOWN which MODIFIES an X field
+    LPCWSTR    pszFormat; // format substring
+    SYSTEMTIME st;        // current systemtime, app should modify based on key
+} NMDATETIMEWMKEYDOWNW, FAR * LPNMDATETIMEWMKEYDOWNW;
+
+#ifdef UNICODE
+#define DTN_WMKEYDOWN           DTN_WMKEYDOWNW
+#define NMDATETIMEWMKEYDOWN     NMDATETIMEWMKEYDOWNW
+#define LPNMDATETIMEWMKEYDOWN   LPNMDATETIMEWMKEYDOWNW
+#else
+#define DTN_WMKEYDOWN           DTN_WMKEYDOWNA
+#define NMDATETIMEWMKEYDOWN     NMDATETIMEWMKEYDOWNA
+#define LPNMDATETIMEWMKEYDOWN   LPNMDATETIMEWMKEYDOWNA
+#endif
+
+
+#define DTN_FORMATA  (DTN_FIRST + 4) // query display for app format field (X)
+#define DTN_FORMATW  (DTN_FIRST + 17)
+typedef struct tagNMDATETIMEFORMATA
+{
+    NMHDR nmhdr;
+    LPCSTR  pszFormat;   // format substring
+    SYSTEMTIME st;       // current systemtime
+    LPCSTR pszDisplay;   // string to display
+    CHAR szDisplay[64];  // buffer pszDisplay originally points at
+} NMDATETIMEFORMATA, FAR * LPNMDATETIMEFORMATA;
+
+typedef struct tagNMDATETIMEFORMATW
+{
+    NMHDR nmhdr;
+    LPCWSTR pszFormat;   // format substring
+    SYSTEMTIME st;       // current systemtime
+    LPCWSTR pszDisplay;  // string to display
+    WCHAR szDisplay[64]; // buffer pszDisplay originally points at
+} NMDATETIMEFORMATW, FAR * LPNMDATETIMEFORMATW;
+
+#ifdef UNICODE
+#define DTN_FORMAT             DTN_FORMATW
+#define NMDATETIMEFORMAT        NMDATETIMEFORMATW
+#define LPNMDATETIMEFORMAT      LPNMDATETIMEFORMATW
+#else
+#define DTN_FORMAT             DTN_FORMATA
+#define NMDATETIMEFORMAT        NMDATETIMEFORMATA
+#define LPNMDATETIMEFORMAT      LPNMDATETIMEFORMATA
+#endif
+
+
+#define DTN_FORMATQUERYA  (DTN_FIRST + 5) // query formatting info for app format field (X)
+#define DTN_FORMATQUERYW (DTN_FIRST + 18)
+typedef struct tagNMDATETIMEFORMATQUERYA
+{
+    NMHDR nmhdr;
+    LPCSTR pszFormat;  // format substring
+    SIZE szMax;        // max bounding rectangle app will use for this format string
+} NMDATETIMEFORMATQUERYA, FAR * LPNMDATETIMEFORMATQUERYA;
+
+typedef struct tagNMDATETIMEFORMATQUERYW
+{
+    NMHDR nmhdr;
+    LPCWSTR pszFormat; // format substring
+    SIZE szMax;        // max bounding rectangle app will use for this format string
+} NMDATETIMEFORMATQUERYW, FAR * LPNMDATETIMEFORMATQUERYW;
+
+#ifdef UNICODE
+#define DTN_FORMATQUERY         DTN_FORMATQUERYW
+#define NMDATETIMEFORMATQUERY   NMDATETIMEFORMATQUERYW
+#define LPNMDATETIMEFORMATQUERY LPNMDATETIMEFORMATQUERYW
+#else
+#define DTN_FORMATQUERY         DTN_FORMATQUERYA
+#define NMDATETIMEFORMATQUERY   NMDATETIMEFORMATQUERYA
+#define LPNMDATETIMEFORMATQUERY LPNMDATETIMEFORMATQUERYA
+#endif
+
+
+#define DTN_DROPDOWN    (DTN_FIRST + 6) // MonthCal has dropped down
+#define DTN_CLOSEUP     (DTN_FIRST + 7) // MonthCal is popping up
+
+
+#define GDTR_MIN     0x0001
+#define GDTR_MAX     0x0002
+
+#define GDT_ERROR    -1
+#define GDT_VALID    0
+#define GDT_NONE     1
+
+
+#endif // _WIN32
+#endif // NODATETIMEPICK
+
+
+#if (_WIN32_IE >= 0x0400)
+
+#ifndef NOIPADDRESS
+
+///////////////////////////////////////////////
+///    IP Address edit control
+
+// Messages sent to IPAddress controls
+
+#define IPM_CLEARADDRESS (WM_USER+100) // no parameters
+#define IPM_SETADDRESS   (WM_USER+101) // lparam = TCP/IP address
+#define IPM_GETADDRESS   (WM_USER+102) // lresult = # of non black fields.  lparam = LPDWORD for TCP/IP address
+#define IPM_SETRANGE (WM_USER+103) // wparam = field, lparam = range
+#define IPM_SETFOCUS (WM_USER+104) // wparam = field
+#define IPM_ISBLANK  (WM_USER+105) // no parameters
+
+#define WC_IPADDRESSW           L"SysIPAddress32"
+#define WC_IPADDRESSA           "SysIPAddress32"
+
+#ifdef UNICODE
+#define WC_IPADDRESS          WC_IPADDRESSW
+#else
+#define WC_IPADDRESS          WC_IPADDRESSA
+#endif
+
+#define IPN_FIELDCHANGED                (IPN_FIRST - 0)
+typedef struct tagNMIPADDRESS
+{
+        NMHDR hdr;
+        int iField;
+        int iValue;
+} NMIPADDRESS, *LPNMIPADDRESS;
+
+// The following is a useful macro for passing the range values in the
+// IPM_SETRANGE message.
+
+#define MAKEIPRANGE(low, high)    ((LPARAM)(WORD)(((BYTE)(high) << 8) + (BYTE)(low)))
+
+// And this is a useful macro for making the IP Address to be passed
+// as a LPARAM.
+
+#define MAKEIPADDRESS(b1,b2,b3,b4)  ((LPARAM)(((DWORD)(b1)<<24)+((DWORD)(b2)<<16)+((DWORD)(b3)<<8)+((DWORD)(b4))))
+
+// Get individual number
+#define FIRST_IPADDRESS(x)  ((x>>24) & 0xff)
+#define SECOND_IPADDRESS(x) ((x>>16) & 0xff)
+#define THIRD_IPADDRESS(x)  ((x>>8) & 0xff)
+#define FOURTH_IPADDRESS(x) (x & 0xff)
+
+
+#endif // NOIPADDRESS
+
+
+//---------------------------------------------------------------------------------------
+//---------------------------------------------------------------------------------------
+///  ====================== Pager Control =============================
+//---------------------------------------------------------------------------------------
+//---------------------------------------------------------------------------------------
+
+#ifndef NOPAGESCROLLER
+
+//Pager Class Name
+#define WC_PAGESCROLLERW           L"SysPager"
+#define WC_PAGESCROLLERA           "SysPager"
+
+#ifdef UNICODE
+#define WC_PAGESCROLLER          WC_PAGESCROLLERW
+#else
+#define WC_PAGESCROLLER          WC_PAGESCROLLERA
+#endif
+
+
+//---------------------------------------------------------------------------------------
+// Pager Control Styles
+//---------------------------------------------------------------------------------------
+#define PGS_VERT                0x00000000
+#define PGS_HORZ                0x00000001
+#define PGS_AUTOSCROLL          0x00000002
+#define PGS_DRAGNDROP           0x00000004
+
+
+//---------------------------------------------------------------------------------------
+// Pager Button State
+//---------------------------------------------------------------------------------------
+//The scroll can be in one of the following control State 
+#define  PGF_INVISIBLE   0      // Scroll button is not visible
+#define  PGF_NORMAL      1      // Scroll button is in normal state
+#define  PGF_GRAYED      2      // Scroll button is in grayed state
+#define  PGF_DEPRESSED   4      // Scroll button is in depressed state
+#define  PGF_HOT         8      // Scroll button is in hot state
+
+
+// The following identifiers specifies the button control 
+#define PGB_TOPORLEFT       0
+#define PGB_BOTTOMORRIGHT   1
+
+//---------------------------------------------------------------------------------------
+// Pager Control  Messages
+//---------------------------------------------------------------------------------------
+#define PGM_SETCHILD            (PGM_FIRST + 1)  // lParam == hwnd
+#define Pager_SetChild(hwnd, hwndChild) \
+        (void)SNDMSG((hwnd), PGM_SETCHILD, 0, (LPARAM)(hwndChild))
+
+#define PGM_RECALCSIZE          (PGM_FIRST + 2)
+#define Pager_RecalcSize(hwnd) \
+        (void)SNDMSG((hwnd), PGM_RECALCSIZE, 0, 0)
+
+#define PGM_FORWARDMOUSE        (PGM_FIRST + 3)
+#define Pager_ForwardMouse(hwnd, bForward) \
+        (void)SNDMSG((hwnd), PGM_FORWARDMOUSE, (WPARAM)(bForward), 0)
+
+#define PGM_SETBKCOLOR          (PGM_FIRST + 4)
+#define Pager_SetBkColor(hwnd, clr) \
+        (COLORREF)SNDMSG((hwnd), PGM_SETBKCOLOR, 0, (LPARAM)clr)
+
+#define PGM_GETBKCOLOR          (PGM_FIRST + 5)
+#define Pager_GetBkColor(hwnd) \
+        (COLORREF)SNDMSG((hwnd), PGM_GETBKCOLOR, 0, 0)
+
+#define PGM_SETBORDER          (PGM_FIRST + 6)
+#define Pager_SetBorder(hwnd, iBorder) \
+        (int)SNDMSG((hwnd), PGM_SETBORDER, 0, (LPARAM)iBorder)
+
+#define PGM_GETBORDER          (PGM_FIRST + 7)
+#define Pager_GetBorder(hwnd) \
+        (int)SNDMSG((hwnd), PGM_GETBORDER, 0, 0)
+
+#define PGM_SETPOS              (PGM_FIRST + 8)
+#define Pager_SetPos(hwnd, iPos) \
+        (int)SNDMSG((hwnd), PGM_SETPOS, 0, (LPARAM)iPos)
+
+#define PGM_GETPOS              (PGM_FIRST + 9)
+#define Pager_GetPos(hwnd) \
+        (int)SNDMSG((hwnd), PGM_GETPOS, 0, 0)
+
+#define PGM_SETBUTTONSIZE       (PGM_FIRST + 10)
+#define Pager_SetButtonSize(hwnd, iSize) \
+        (int)SNDMSG((hwnd), PGM_SETBUTTONSIZE, 0, (LPARAM)iSize)
+
+#define PGM_GETBUTTONSIZE       (PGM_FIRST + 11)
+#define Pager_GetButtonSize(hwnd) \
+        (int)SNDMSG((hwnd), PGM_GETBUTTONSIZE, 0,0)
+
+#define PGM_GETBUTTONSTATE      (PGM_FIRST + 12)
+#define Pager_GetButtonState(hwnd, iButton) \
+        (DWORD)SNDMSG((hwnd), PGM_GETBUTTONSTATE, 0, (LPARAM)iButton)
+
+#define PGM_GETDROPTARGET       CCM_GETDROPTARGET
+#define Pager_GetDropTarget(hwnd, ppdt) \
+        (void)SNDMSG((hwnd), PGM_GETDROPTARGET, 0, (LPARAM)ppdt)
+
+//---------------------------------------------------------------------------------------
+//Pager Control Notification Messages
+//---------------------------------------------------------------------------------------
+
+
+// PGN_SCROLL Notification Message
+
+#define PGN_SCROLL          (PGN_FIRST-1)
+
+#define PGF_SCROLLUP        1
+#define PGF_SCROLLDOWN      2
+#define PGF_SCROLLLEFT      4
+#define PGF_SCROLLRIGHT     8
+
+
+//Keys down
+#define PGK_SHIFT           1
+#define PGK_CONTROL         2
+#define PGK_MENU            4
+
+
+// This structure is sent along with PGN_SCROLL notifications
+typedef struct {
+    NMHDR hdr;
+    WORD fwKeys;            // Specifies which keys are down when this notification is send
+    RECT rcParent;          // Contains Parent Window Rect
+    int  iDir;              // Scrolling Direction
+    int  iXpos;             // Horizontal scroll position
+    int  iYpos;             // Vertical scroll position
+    int  iScroll;           // [in/out] Amount to scroll
+}NMPGSCROLL, *LPNMPGSCROLL;
+
+
+// PGN_CALCSIZE Notification Message
+
+#define PGN_CALCSIZE        (PGN_FIRST-2)
+
+#define PGF_CALCWIDTH       1
+#define PGF_CALCHEIGHT      2
+
+typedef struct {
+    NMHDR   hdr;
+    DWORD   dwFlag;
+    int     iWidth;
+    int     iHeight;
+}NMPGCALCSIZE, *LPNMPGCALCSIZE;
+
+#endif // NOPAGESCROLLER
+
+////======================  End Pager Control ==========================================
+
+//
+// === Native Font Control ===
+//
+#ifndef NONATIVEFONTCTL
+//NativeFont Class Name
+#define WC_NATIVEFONTCTLW           L"NativeFontCtl"
+#define WC_NATIVEFONTCTLA           "NativeFontCtl"
+
+#ifdef UNICODE
+#define WC_NATIVEFONTCTL          WC_NATIVEFONTCTLW
+#else
+#define WC_NATIVEFONTCTL          WC_NATIVEFONTCTLA
+#endif
+
+// style definition
+#define NFS_EDIT                0x0001
+#define NFS_STATIC              0x0002
+#define NFS_LISTCOMBO           0x0004
+#define NFS_BUTTON              0x0008
+#define NFS_ALL                 0x0010
+
+#endif // NONATIVEFONTCTL
+// === End Native Font Control ===
+
+#endif      // _WIN32_IE >= 0x0400
+
+#ifdef _WIN32
+//====== TrackMouseEvent  =====================================================
+
+#ifndef NOTRACKMOUSEEVENT
+
+//
+// If the messages for TrackMouseEvent have not been defined then define them
+// now.
+//
+#ifndef WM_MOUSEHOVER
+#define WM_MOUSEHOVER                   0x02A1
+#define WM_MOUSELEAVE                   0x02A3
+#endif
+
+//
+// If the TRACKMOUSEEVENT structure and associated flags havent been declared
+// then declare them now.
+//
+#ifndef TME_HOVER
+
+#define TME_HOVER       0x00000001
+#define TME_LEAVE       0x00000002
+#define TME_QUERY       0x40000000
+#define TME_CANCEL      0x80000000
+
+
+#define HOVER_DEFAULT   0xFFFFFFFF
+
+typedef struct tagTRACKMOUSEEVENT {
+    DWORD cbSize;
+    DWORD dwFlags;
+    HWND  hwndTrack;
+    DWORD dwHoverTime;
+} TRACKMOUSEEVENT, *LPTRACKMOUSEEVENT;
+
+#endif // !TME_HOVER
+
+//
+// Declare _TrackMouseEvent.  This API tries to use the window manager's
+// implementation of TrackMouseEvent if it is present, otherwise it emulates.
+//
+WINCOMMCTRLAPI
+BOOL
+WINAPI
+_TrackMouseEvent(
+    LPTRACKMOUSEEVENT lpEventTrack);
+
+#endif // !NOTRACKMOUSEEVENT
+
+#if (_WIN32_IE >= 0x0400)
+
+//====== Flat Scrollbar APIs=========================================
+#ifndef NOFLATSBAPIS
+
+#define WSB_PROP_CYVSCROLL  0x00000001L
+#define WSB_PROP_CXHSCROLL  0x00000002L
+#define WSB_PROP_CYHSCROLL  0x00000004L
+#define WSB_PROP_CXVSCROLL  0x00000008L
+#define WSB_PROP_CXHTHUMB   0x00000010L
+#define WSB_PROP_CYVTHUMB   0x00000020L
+#define WSB_PROP_VBKGCOLOR  0x00000040L
+#define WSB_PROP_HBKGCOLOR  0x00000080L
+#define WSB_PROP_VSTYLE     0x00000100L
+#define WSB_PROP_HSTYLE     0x00000200L
+#define WSB_PROP_WINSTYLE   0x00000400L
+#define WSB_PROP_PALETTE    0x00000800L
+#define WSB_PROP_MASK       0x00000FFFL
+
+#define FSB_FLAT_MODE           2
+#define FSB_ENCARTA_MODE        1
+#define FSB_REGULAR_MODE        0
+
+WINCOMMCTRLAPI BOOL WINAPI FlatSB_EnableScrollBar(HWND, int, UINT);
+WINCOMMCTRLAPI BOOL WINAPI FlatSB_ShowScrollBar(HWND, int code, BOOL);
+
+WINCOMMCTRLAPI BOOL WINAPI FlatSB_GetScrollRange(HWND, int code, LPINT, LPINT);
+WINCOMMCTRLAPI BOOL WINAPI FlatSB_GetScrollInfo(HWND, int code, LPSCROLLINFO);
+WINCOMMCTRLAPI int WINAPI FlatSB_GetScrollPos(HWND, int code);
+WINCOMMCTRLAPI BOOL WINAPI FlatSB_GetScrollProp(HWND, int propIndex, LPINT);
+
+WINCOMMCTRLAPI int WINAPI FlatSB_SetScrollPos(HWND, int code, int pos, BOOL fRedraw);
+WINCOMMCTRLAPI int WINAPI FlatSB_SetScrollInfo(HWND, int code, LPSCROLLINFO, BOOL fRedraw);
+WINCOMMCTRLAPI int WINAPI FlatSB_SetScrollRange(HWND, int code, int min, int max, BOOL fRedraw);
+WINCOMMCTRLAPI BOOL WINAPI FlatSB_SetScrollProp(HWND, UINT index, int newValue, BOOL);
+
+WINCOMMCTRLAPI BOOL WINAPI InitializeFlatSB(HWND);
+WINCOMMCTRLAPI HRESULT WINAPI UninitializeFlatSB(HWND);
+
+#endif  //  NOFLATSBAPIS
+
+#endif      // _WIN32_IE >= 0x0400
+
+#endif /* _WIN32 */
+
+#endif      // _WIN32_IE >= 0x0300
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#ifdef _WIN32
+#include <poppack.h>
+#endif
+
+#endif
+
+
+#endif  // _INC_COMMCTRL
diff --git a/source_code/version2.2_windows/POPPACK.H b/source_code/version2.2_windows/POPPACK.H
new file mode 100644
index 0000000000000000000000000000000000000000..09c2de4c7a8c1dda7d9adf80fd1616b68da2abdf
--- /dev/null
+++ b/source_code/version2.2_windows/POPPACK.H
@@ -0,0 +1,36 @@
+/*++
+
+Copyright 1990 - 1998 Microsoft Corporation
+
+Module Name:
+
+    poppack.h
+
+Abstract:
+
+    This file turns packing of structures off.  (That is, it enables
+    automatic alignment of structure fields.)  An include file is needed
+    because various compilers do this in different ways.
+
+    poppack.h is the complement to pshpack?.h.  An inclusion of poppack.h
+    MUST ALWAYS be preceded by an inclusion of one of pshpack?.h, in one-to-one
+    correspondence.
+
+    For Microsoft compatible compilers, this file uses the pop option
+    to the pack pragma so that it can restore the previous saved by the
+    pshpack?.h include file.
+
+--*/
+
+#if ! (defined(lint) || defined(_lint) || defined(RC_INVOKED))
+#if ( _MSC_VER >= 800 ) || defined(_PUSHPOP_SUPPORTED)
+#pragma warning(disable:4103)
+#if !(defined( MIDL_PASS )) || defined( __midl )
+#pragma pack(pop)
+#else
+#pragma pack()
+#endif
+#else
+#pragma pack()
+#endif
+#endif // ! (defined(lint) || defined(_lint) || defined(RC_INVOKED))
diff --git a/source_code/version2.2_windows/PRSHT.H b/source_code/version2.2_windows/PRSHT.H
new file mode 100644
index 0000000000000000000000000000000000000000..c3e165497df087eba0e379a300a7e3ee503497b3
--- /dev/null
+++ b/source_code/version2.2_windows/PRSHT.H
@@ -0,0 +1,519 @@
+
+/*****************************************************************************\
+*                                                                             *
+* prsht.h - - Interface for the Windows Property Sheet Pages                  *
+*                                                                             *
+* Version 1.0                                                                 *
+*                                                                             *
+* Copyright 1991-1998, Microsoft Corp.      All rights reserved.          *
+*                                                                             *
+\*****************************************************************************/
+
+#ifndef _PRSHT_H_
+#define _PRSHT_H_
+
+#ifndef _WIN32_IE
+#define _WIN32_IE 0x0400
+#else
+#if (_WIN32_IE < 0x0400) && defined(_WIN32_WINNT) && (_WIN32_WINNT >= 0x0500)
+#error _WIN32_IE setting conflicts with _WIN32_WINNT setting
+#endif
+#endif
+
+//
+// Define API decoration for direct importing of DLL references.
+//
+#ifndef WINCOMMCTRLAPI
+#if !defined(_COMCTL32_) && defined(_WIN32)
+#define WINCOMMCTRLAPI DECLSPEC_IMPORT
+#else
+#define WINCOMMCTRLAPI
+#endif
+#endif // WINCOMMCTRLAPI
+
+#ifndef CCSIZEOF_STRUCT
+#define CCSIZEOF_STRUCT(structname, member)  (((int)((LPBYTE)(&((structname*)0)->member) - ((LPBYTE)((structname*)0)))) + sizeof(((structname*)0)->member))
+#endif
+
+//
+// For compilers that don't support nameless unions
+//
+#ifndef DUMMYUNIONNAME
+#ifdef NONAMELESSUNION
+#define DUMMYUNIONNAME   u
+#define DUMMYUNIONNAME2  u2
+#define DUMMYUNIONNAME3  u3
+#define DUMMYUNIONNAME4  u4
+#define DUMMYUNIONNAME5  u5
+#else
+#define DUMMYUNIONNAME
+#define DUMMYUNIONNAME2
+#define DUMMYUNIONNAME3
+#define DUMMYUNIONNAME4
+#define DUMMYUNIONNAME5
+#endif
+#endif // DUMMYUNIONNAME
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+#ifndef SNDMSG
+#ifdef __cplusplus
+#ifndef _MAC
+#define SNDMSG ::SendMessage
+#else
+#define SNDMSG ::AfxSendMessage
+#endif
+#else
+#ifndef _MAC
+#define SNDMSG SendMessage
+#else
+#define SNDMSG AfxSendMessage
+#endif
+#endif
+#endif // ifndef SNDMSG
+
+#define MAXPROPPAGES            100
+
+struct _PSP;
+typedef struct _PSP FAR* HPROPSHEETPAGE;
+
+#ifndef MIDL_PASS
+struct _PROPSHEETPAGEA;
+struct _PROPSHEETPAGEW;
+#endif
+
+typedef UINT (CALLBACK FAR * LPFNPSPCALLBACKA)(HWND hwnd, UINT uMsg, struct _PROPSHEETPAGEA FAR *ppsp);
+typedef UINT (CALLBACK FAR * LPFNPSPCALLBACKW)(HWND hwnd, UINT uMsg, struct _PROPSHEETPAGEW FAR *ppsp);
+
+#ifdef UNICODE
+#define LPFNPSPCALLBACK         LPFNPSPCALLBACKW
+#else
+#define LPFNPSPCALLBACK         LPFNPSPCALLBACKA
+#endif
+
+#define PSP_DEFAULT                0x00000000
+#define PSP_DLGINDIRECT            0x00000001
+#define PSP_USEHICON               0x00000002
+#define PSP_USEICONID              0x00000004
+#define PSP_USETITLE               0x00000008
+#define PSP_RTLREADING             0x00000010
+
+#define PSP_HASHELP                0x00000020
+#define PSP_USEREFPARENT           0x00000040
+#define PSP_USECALLBACK            0x00000080
+#define PSP_PREMATURE              0x00000400
+
+#if (_WIN32_IE >= 0x0400)
+//----- New flags for wizard97 --------------
+#define PSP_HIDEHEADER             0x00000800
+#define PSP_USEHEADERTITLE         0x00001000
+#define PSP_USEHEADERSUBTITLE      0x00002000
+//-------------------------------------------
+#endif
+
+
+#define PSPCB_RELEASE           1
+#define PSPCB_CREATE            2
+
+#define PROPSHEETPAGEA_V1_SIZE CCSIZEOF_STRUCT(PROPSHEETPAGEA, pcRefParent)
+#define PROPSHEETPAGEW_V1_SIZE CCSIZEOF_STRUCT(PROPSHEETPAGEW, pcRefParent)
+
+typedef struct _PROPSHEETPAGEA {
+        DWORD           dwSize;
+        DWORD           dwFlags;
+        HINSTANCE       hInstance;
+        union {
+            LPCSTR          pszTemplate;
+#ifdef _WIN32
+            LPCDLGTEMPLATE  pResource;
+#else
+            const VOID FAR *pResource;
+#endif
+        } DUMMYUNIONNAME;
+        union {
+            HICON       hIcon;
+            LPCSTR      pszIcon;
+        } DUMMYUNIONNAME2;
+        LPCSTR          pszTitle;
+        DLGPROC         pfnDlgProc;
+        LPARAM          lParam;
+        LPFNPSPCALLBACKA pfnCallback;
+        UINT FAR * pcRefParent;
+
+#if (_WIN32_IE >= 0x0400)
+        LPCSTR pszHeaderTitle;    // this is displayed in the header
+        LPCSTR pszHeaderSubTitle; //
+#endif
+} PROPSHEETPAGEA, FAR *LPPROPSHEETPAGEA;
+typedef const PROPSHEETPAGEA FAR *LPCPROPSHEETPAGEA;
+
+typedef struct _PROPSHEETPAGEW {
+        DWORD           dwSize;
+        DWORD           dwFlags;
+        HINSTANCE       hInstance;
+        union {
+            LPCWSTR          pszTemplate;
+#ifdef _WIN32
+            LPCDLGTEMPLATE  pResource;
+#else
+            const VOID FAR *pResource;
+#endif
+        }DUMMYUNIONNAME;
+        union {
+            HICON       hIcon;
+            LPCWSTR      pszIcon;
+        }DUMMYUNIONNAME2;
+        LPCWSTR          pszTitle;
+        DLGPROC         pfnDlgProc;
+        LPARAM          lParam;
+        LPFNPSPCALLBACKW pfnCallback;
+        UINT FAR * pcRefParent;
+        
+#if (_WIN32_IE >= 0x0400)
+        LPCWSTR pszHeaderTitle;    // this is displayed in the header
+        LPCWSTR pszHeaderSubTitle; ///
+#endif
+} PROPSHEETPAGEW, FAR *LPPROPSHEETPAGEW;
+typedef const PROPSHEETPAGEW FAR *LPCPROPSHEETPAGEW;
+
+#ifdef UNICODE
+#define PROPSHEETPAGE           PROPSHEETPAGEW
+#define LPPROPSHEETPAGE         LPPROPSHEETPAGEW
+#define LPCPROPSHEETPAGE        LPCPROPSHEETPAGEW
+#define PROPSHEETPAGE_V1_SIZE PROPSHEETPAGEW_V1_SIZE
+#else
+#define PROPSHEETPAGE           PROPSHEETPAGEA
+#define LPPROPSHEETPAGE         LPPROPSHEETPAGEA
+#define LPCPROPSHEETPAGE        LPCPROPSHEETPAGEA
+#define PROPSHEETPAGE_V1_SIZE PROPSHEETPAGEA_V1_SIZE
+#endif
+
+
+#define PSH_DEFAULT             0x00000000
+#define PSH_PROPTITLE           0x00000001
+#define PSH_USEHICON            0x00000002
+#define PSH_USEICONID           0x00000004
+#define PSH_PROPSHEETPAGE       0x00000008
+#define PSH_WIZARDHASFINISH     0x00000010
+#define PSH_WIZARD              0x00000020
+#define PSH_USEPSTARTPAGE       0x00000040
+#define PSH_NOAPPLYNOW          0x00000080
+#define PSH_USECALLBACK         0x00000100
+#define PSH_HASHELP             0x00000200
+#define PSH_MODELESS            0x00000400
+#define PSH_RTLREADING          0x00000800
+#define PSH_WIZARDCONTEXTHELP   0x00001000
+
+#if (_WIN32_IE >= 0x0400)
+//----- New flags for wizard97 -----------
+#define PSH_WIZARD97            0x00002000  
+// 0x00004000 was not used by any previous release
+#define PSH_WATERMARK           0x00008000
+#define PSH_USEHBMWATERMARK     0x00010000  // user pass in a hbmWatermark instead of pszbmWatermark
+#define PSH_USEHPLWATERMARK     0x00020000  //
+#define PSH_STRETCHWATERMARK    0x00040000  // stretchwatermark also applies for the header
+#define PSH_HEADER              0x00080000
+#define PSH_USEHBMHEADER        0x00100000
+#define PSH_USEPAGELANG         0x00200000  // use frame dialog template matched to page
+//----------------------------------------
+#endif
+
+
+typedef int (CALLBACK *PFNPROPSHEETCALLBACK)(HWND, UINT, LPARAM);
+
+#define PROPSHEETHEADERA_V1_SIZE CCSIZEOF_STRUCT(PROPSHEETHEADERA, pfnCallback)
+#define PROPSHEETHEADERW_V1_SIZE CCSIZEOF_STRUCT(PROPSHEETHEADERW, pfnCallback)
+
+typedef struct _PROPSHEETHEADERA {
+        DWORD           dwSize;
+        DWORD           dwFlags;
+        HWND            hwndParent;
+        HINSTANCE       hInstance;
+        union {
+            HICON       hIcon;
+            LPCSTR      pszIcon;
+        }DUMMYUNIONNAME;
+        LPCSTR          pszCaption;
+
+        UINT            nPages;
+        union {
+            UINT        nStartPage;
+            LPCSTR      pStartPage;
+        }DUMMYUNIONNAME2;
+        union {
+            LPCPROPSHEETPAGEA ppsp;
+            HPROPSHEETPAGE FAR *phpage;
+        }DUMMYUNIONNAME3;
+        PFNPROPSHEETCALLBACK pfnCallback;
+
+#if (_WIN32_IE >= 0x0400)
+        union {
+            HBITMAP hbmWatermark;
+            LPCSTR pszbmWatermark;
+        } DUMMYUNIONNAME4;
+        HPALETTE hplWatermark;
+        union {
+            HBITMAP hbmHeader;     // Header  bitmap shares the palette with watermark
+            LPCSTR pszbmHeader;
+        } DUMMYUNIONNAME5;
+#endif
+} PROPSHEETHEADERA, FAR *LPPROPSHEETHEADERA;
+
+typedef const PROPSHEETHEADERA FAR *LPCPROPSHEETHEADERA;
+
+typedef struct _PROPSHEETHEADERW {
+        DWORD           dwSize;
+        DWORD           dwFlags;
+        HWND            hwndParent;
+        HINSTANCE       hInstance;
+        union {
+            HICON       hIcon;
+            LPCWSTR     pszIcon;
+        }DUMMYUNIONNAME;
+        LPCWSTR         pszCaption;
+
+
+        UINT            nPages;
+        union {
+            UINT        nStartPage;
+            LPCWSTR     pStartPage;
+        }DUMMYUNIONNAME2;
+        union {
+            LPCPROPSHEETPAGEW ppsp;
+            HPROPSHEETPAGE FAR *phpage;
+        }DUMMYUNIONNAME3;
+        PFNPROPSHEETCALLBACK pfnCallback;
+
+#if (_WIN32_IE >= 0x0400)
+        union {
+            HBITMAP hbmWatermark;
+            LPCWSTR pszbmWatermark;
+        } DUMMYUNIONNAME4;
+        HPALETTE hplWatermark;
+        union {
+            HBITMAP hbmHeader;
+            LPCWSTR pszbmHeader;
+        } DUMMYUNIONNAME5;
+#endif
+} PROPSHEETHEADERW, FAR *LPPROPSHEETHEADERW;
+typedef const PROPSHEETHEADERW FAR *LPCPROPSHEETHEADERW;
+
+#ifdef UNICODE
+#define PROPSHEETHEADER         PROPSHEETHEADERW
+#define LPPROPSHEETHEADER       LPPROPSHEETHEADERW
+#define LPCPROPSHEETHEADER      LPCPROPSHEETHEADERW
+#define PROPSHEETHEADER_V1_SIZE PROPSHEETHEADERW_V1_SIZE
+#else
+#define PROPSHEETHEADER         PROPSHEETHEADERA
+#define LPPROPSHEETHEADER       LPPROPSHEETHEADERA
+#define LPCPROPSHEETHEADER      LPCPROPSHEETHEADERA
+#define PROPSHEETHEADER_V1_SIZE PROPSHEETHEADERA_V1_SIZE
+#endif
+
+
+#define PSCB_INITIALIZED  1
+#define PSCB_PRECREATE    2
+
+WINCOMMCTRLAPI HPROPSHEETPAGE WINAPI CreatePropertySheetPageA(LPCPROPSHEETPAGEA);
+WINCOMMCTRLAPI HPROPSHEETPAGE WINAPI CreatePropertySheetPageW(LPCPROPSHEETPAGEW);
+WINCOMMCTRLAPI BOOL           WINAPI DestroyPropertySheetPage(HPROPSHEETPAGE);
+WINCOMMCTRLAPI int            WINAPI PropertySheetA(LPCPROPSHEETHEADERA);
+WINCOMMCTRLAPI int            WINAPI PropertySheetW(LPCPROPSHEETHEADERW);
+
+#ifdef UNICODE
+#define CreatePropertySheetPage  CreatePropertySheetPageW
+#define PropertySheet            PropertySheetW
+#else
+#define CreatePropertySheetPage  CreatePropertySheetPageA
+#define PropertySheet            PropertySheetA
+#endif
+
+
+
+typedef BOOL (CALLBACK FAR * LPFNADDPROPSHEETPAGE)(HPROPSHEETPAGE, LPARAM);
+typedef BOOL (CALLBACK FAR * LPFNADDPROPSHEETPAGES)(LPVOID, LPFNADDPROPSHEETPAGE, LPARAM);
+
+
+typedef struct _PSHNOTIFY
+{
+    NMHDR hdr;
+    LPARAM lParam;
+} PSHNOTIFY, FAR *LPPSHNOTIFY;
+
+#define PSN_FIRST               (0U-200U)
+#define PSN_LAST                (0U-299U)
+
+
+#define PSN_SETACTIVE           (PSN_FIRST-0)
+#define PSN_KILLACTIVE          (PSN_FIRST-1)
+// #define PSN_VALIDATE            (PSN_FIRST-1)
+#define PSN_APPLY               (PSN_FIRST-2)
+#define PSN_RESET               (PSN_FIRST-3)
+// #define PSN_CANCEL              (PSN_FIRST-3)
+#define PSN_HELP                (PSN_FIRST-5)
+#define PSN_WIZBACK             (PSN_FIRST-6)
+#define PSN_WIZNEXT             (PSN_FIRST-7)
+#define PSN_WIZFINISH           (PSN_FIRST-8)
+#define PSN_QUERYCANCEL         (PSN_FIRST-9)
+#if (_WIN32_IE >= 0x0400)
+#define PSN_GETOBJECT           (PSN_FIRST-10)
+#endif // 0x0400
+
+#define PSNRET_NOERROR              0
+#define PSNRET_INVALID              1
+#define PSNRET_INVALID_NOCHANGEPAGE 2
+
+
+#define PSM_SETCURSEL           (WM_USER + 101)
+#define PropSheet_SetCurSel(hDlg, hpage, index) \
+        SNDMSG(hDlg, PSM_SETCURSEL, (WPARAM)index, (LPARAM)hpage)
+
+
+#define PSM_REMOVEPAGE          (WM_USER + 102)
+#define PropSheet_RemovePage(hDlg, index, hpage) \
+        SNDMSG(hDlg, PSM_REMOVEPAGE, index, (LPARAM)hpage)
+
+
+#define PSM_ADDPAGE             (WM_USER + 103)
+#define PropSheet_AddPage(hDlg, hpage) \
+        SNDMSG(hDlg, PSM_ADDPAGE, 0, (LPARAM)hpage)
+
+
+#define PSM_CHANGED             (WM_USER + 104)
+#define PropSheet_Changed(hDlg, hwnd) \
+        SNDMSG(hDlg, PSM_CHANGED, (WPARAM)hwnd, 0L)
+
+
+#define PSM_RESTARTWINDOWS      (WM_USER + 105)
+#define PropSheet_RestartWindows(hDlg) \
+        SNDMSG(hDlg, PSM_RESTARTWINDOWS, 0, 0L)
+
+
+#define PSM_REBOOTSYSTEM        (WM_USER + 106)
+#define PropSheet_RebootSystem(hDlg) \
+        SNDMSG(hDlg, PSM_REBOOTSYSTEM, 0, 0L)
+
+
+#define PSM_CANCELTOCLOSE       (WM_USER + 107)
+#define PropSheet_CancelToClose(hDlg) \
+        PostMessage(hDlg, PSM_CANCELTOCLOSE, 0, 0L)
+
+
+#define PSM_QUERYSIBLINGS       (WM_USER + 108)
+#define PropSheet_QuerySiblings(hDlg, wParam, lParam) \
+        SNDMSG(hDlg, PSM_QUERYSIBLINGS, wParam, lParam)
+
+
+#define PSM_UNCHANGED           (WM_USER + 109)
+#define PropSheet_UnChanged(hDlg, hwnd) \
+        SNDMSG(hDlg, PSM_UNCHANGED, (WPARAM)hwnd, 0L)
+
+
+#define PSM_APPLY               (WM_USER + 110)
+#define PropSheet_Apply(hDlg) \
+        SNDMSG(hDlg, PSM_APPLY, 0, 0L)
+
+
+#define PSM_SETTITLEA           (WM_USER + 111)
+#define PSM_SETTITLEW           (WM_USER + 120)
+
+#ifdef UNICODE
+#define PSM_SETTITLE            PSM_SETTITLEW
+#else
+#define PSM_SETTITLE            PSM_SETTITLEA
+#endif
+
+#define PropSheet_SetTitle(hDlg, wStyle, lpszText)\
+        SNDMSG(hDlg, PSM_SETTITLE, wStyle, (LPARAM)(LPCTSTR)lpszText)
+
+
+#define PSM_SETWIZBUTTONS       (WM_USER + 112)
+#define PropSheet_SetWizButtons(hDlg, dwFlags) \
+        PostMessage(hDlg, PSM_SETWIZBUTTONS, 0, (LPARAM)dwFlags)
+
+
+#define PSWIZB_BACK             0x00000001
+#define PSWIZB_NEXT             0x00000002
+#define PSWIZB_FINISH           0x00000004
+#define PSWIZB_DISABLEDFINISH   0x00000008
+
+
+#define PSM_PRESSBUTTON         (WM_USER + 113)
+#define PropSheet_PressButton(hDlg, iButton) \
+        PostMessage(hDlg, PSM_PRESSBUTTON, (WPARAM)iButton, 0)
+
+
+#define PSBTN_BACK              0
+#define PSBTN_NEXT              1
+#define PSBTN_FINISH            2
+#define PSBTN_OK                3
+#define PSBTN_APPLYNOW          4
+#define PSBTN_CANCEL            5
+#define PSBTN_HELP              6
+#define PSBTN_MAX               6
+
+
+
+#define PSM_SETCURSELID         (WM_USER + 114)
+#define PropSheet_SetCurSelByID(hDlg, id) \
+        SNDMSG(hDlg, PSM_SETCURSELID, 0, (LPARAM)id)
+
+
+#define PSM_SETFINISHTEXTA      (WM_USER + 115)
+#define PSM_SETFINISHTEXTW      (WM_USER + 121)
+
+#ifdef UNICODE
+#define PSM_SETFINISHTEXT       PSM_SETFINISHTEXTW
+#else
+#define PSM_SETFINISHTEXT       PSM_SETFINISHTEXTA
+#endif
+
+#define PropSheet_SetFinishText(hDlg, lpszText) \
+        SNDMSG(hDlg, PSM_SETFINISHTEXT, 0, (LPARAM)lpszText)
+
+
+#define PSM_GETTABCONTROL       (WM_USER + 116)
+#define PropSheet_GetTabControl(hDlg) \
+        (HWND)SNDMSG(hDlg, PSM_GETTABCONTROL, 0, 0)
+
+#define PSM_ISDIALOGMESSAGE     (WM_USER + 117)
+#define PropSheet_IsDialogMessage(hDlg, pMsg) \
+        (BOOL)SNDMSG(hDlg, PSM_ISDIALOGMESSAGE, 0, (LPARAM)pMsg)
+
+#define PSM_GETCURRENTPAGEHWND  (WM_USER + 118)
+#define PropSheet_GetCurrentPageHwnd(hDlg) \
+        (HWND)SNDMSG(hDlg, PSM_GETCURRENTPAGEHWND, 0, 0L)
+
+#define ID_PSRESTARTWINDOWS     0x2
+#define ID_PSREBOOTSYSTEM       (ID_PSRESTARTWINDOWS | 0x1)
+
+
+#define WIZ_CXDLG               276
+#define WIZ_CYDLG               140
+
+#define WIZ_CXBMP               80
+
+#define WIZ_BODYX               92
+#define WIZ_BODYCX              184
+
+#define PROP_SM_CXDLG           212
+#define PROP_SM_CYDLG           188
+
+#define PROP_MED_CXDLG          227
+#define PROP_MED_CYDLG          215
+
+#define PROP_LG_CXDLG           252
+#define PROP_LG_CYDLG           218
+
+
+
+#ifdef __cplusplus
+}
+#endif
+
+
+#endif  // _PRSHT_H_
+
diff --git a/source_code/version2.2_windows/PSHPACK1.H b/source_code/version2.2_windows/PSHPACK1.H
new file mode 100644
index 0000000000000000000000000000000000000000..24497f00094d12a2096200278a93cf6c5ad88c12
--- /dev/null
+++ b/source_code/version2.2_windows/PSHPACK1.H
@@ -0,0 +1,32 @@
+/*++
+
+Copyright 1995 - 1998 Microsoft Corporation
+
+Module Name:
+
+    pshpack1.h
+
+Abstract:
+
+    This file turns 1 byte packing of structures on.  (That is, it disables
+    automatic alignment of structure fields.)  An include file is needed
+    because various compilers do this in different ways.  For Microsoft
+    compatible compilers, this files uses the push option to the pack pragma
+    so that the poppack.h include file can restore the previous packing
+    reliably.
+
+    The file poppack.h is the complement to this file.
+
+--*/
+
+#if ! (defined(lint) || defined(_lint) || defined(RC_INVOKED))
+#if ( _MSC_VER >= 800 ) || defined(_PUSHPOP_SUPPORTED)
+#pragma warning(disable:4103)
+#if !(defined( MIDL_PASS )) || defined( __midl )
+#pragma pack(push)
+#endif
+#pragma pack(1)
+#else
+#pragma pack(1)
+#endif
+#endif // ! (defined(lint) || defined(_lint) || defined(RC_INVOKED))
diff --git a/source_code/version2.2_windows/PSHPACK4.H b/source_code/version2.2_windows/PSHPACK4.H
new file mode 100644
index 0000000000000000000000000000000000000000..5d65da9d14b41d504c4385bb60bb76f63e1a05d3
--- /dev/null
+++ b/source_code/version2.2_windows/PSHPACK4.H
@@ -0,0 +1,32 @@
+/*++
+
+Copyright 1995 - 1998 Microsoft Corporation
+
+Module Name:
+
+    pshpack4.h
+
+Abstract:
+
+    This file turns 4 byte packing of structures on.  (That is, it disables
+    automatic alignment of structure fields.)  An include file is needed
+    because various compilers do this in different ways.  For Microsoft
+    compatible compilers, this files uses the push option to the pack pragma
+    so that the poppack.h include file can restore the previous packing
+    reliably.
+
+    The file poppack.h is the complement to this file.
+
+--*/
+
+#if ! (defined(lint) || defined(_lint) || defined(RC_INVOKED))
+#if ( _MSC_VER >= 800 ) || defined(_PUSHPOP_SUPPORTED)
+#pragma warning(disable:4103)
+#if !(defined( MIDL_PASS )) || defined( __midl )
+#pragma pack(push)
+#endif
+#pragma pack(4)
+#else
+#pragma pack(4)
+#endif
+#endif // ! (defined(lint) || defined(_lint) || defined(RC_INVOKED))
diff --git a/source_code/version2.2_windows/RICHEDIT.H b/source_code/version2.2_windows/RICHEDIT.H
new file mode 100644
index 0000000000000000000000000000000000000000..66970250e5811887d2a9e86c0c8d059fbb368836
--- /dev/null
+++ b/source_code/version2.2_windows/RICHEDIT.H
@@ -0,0 +1,1077 @@
+/*
+ *	RICHEDIT.H
+ *	
+ *	Purpose:
+ *		RICHEDIT v2.0 public definitions.  Note that there is additional
+ *		functionality available for v2.0 that is not in the original
+ *		Windows 95 release.
+ *	
+ *	Copyright (c) 1985-1996, Microsoft Corporation
+ */
+
+#ifndef _RICHEDIT_
+#define	_RICHEDIT_
+
+#ifdef _WIN32
+#include <pshpack4.h>
+#elif !defined(RC_INVOKED)
+#pragma pack(4)
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/* To mimic older RichEdit behavior, simply set _RICHEDIT_VER to the appropriate value */
+/*		Version 1.0		0x0100	*/
+/*		Version 2.0		0x0200	*/
+#ifndef _RICHEDIT_VER
+#define _RICHEDIT_VER	0x0210
+#endif
+
+/*
+ *	To make some structures which can be passed between 16 and 32 bit windows
+ *	almost compatible, padding is introduced to the 16 bit versions of the
+ *	structure.
+ */
+#ifdef _WIN32
+#	define	_WPAD	/##/
+#else
+#	define	_WPAD	WORD
+#endif
+
+#define cchTextLimitDefault 32767
+
+/* Richedit2.0 Window Class. */
+
+#define RICHEDIT_CLASSA		"RichEdit20A"
+#define RICHEDIT_CLASS10A	"RICHEDIT"			// Richedit 1.0
+
+#ifndef MACPORT
+#define RICHEDIT_CLASSW		L"RichEdit20W"
+#else	/*----------------------MACPORT */
+#define RICHEDIT_CLASSW		TEXT("RichEdit20W")	/* MACPORT change */
+#endif /* MACPORT  */
+
+#if (_RICHEDIT_VER >= 0x0200 )
+#ifdef UNICODE
+#define RICHEDIT_CLASS		RICHEDIT_CLASSW
+#else
+#define RICHEDIT_CLASS		RICHEDIT_CLASSA
+#endif /* UNICODE */
+#else
+#define RICHEDIT_CLASS		RICHEDIT_CLASS10A
+#endif /* _RICHEDIT_VER >= 0x0200 */
+
+/* RichEdit messages */
+
+#ifndef WM_CONTEXTMENU
+#define WM_CONTEXTMENU			0x007B
+#endif
+
+#ifndef WM_PRINTCLIENT
+#define WM_PRINTCLIENT			0x0318
+#endif
+
+#ifndef EM_GETLIMITTEXT
+#define EM_GETLIMITTEXT			(WM_USER + 37)
+#endif
+
+#ifndef EM_POSFROMCHAR	
+#define EM_POSFROMCHAR			(WM_USER + 38)
+#define EM_CHARFROMPOS			(WM_USER + 39)
+#endif
+
+#ifndef EM_SCROLLCARET
+#define EM_SCROLLCARET			(WM_USER + 49)
+#endif
+#define EM_CANPASTE				(WM_USER + 50)
+#define EM_DISPLAYBAND			(WM_USER + 51)
+#define EM_EXGETSEL				(WM_USER + 52)
+#define EM_EXLIMITTEXT			(WM_USER + 53)
+#define EM_EXLINEFROMCHAR		(WM_USER + 54)
+#define EM_EXSETSEL				(WM_USER + 55)
+#define EM_FINDTEXT				(WM_USER + 56)
+#define EM_FORMATRANGE			(WM_USER + 57)
+#define EM_GETCHARFORMAT		(WM_USER + 58)
+#define EM_GETEVENTMASK			(WM_USER + 59)
+#define EM_GETOLEINTERFACE		(WM_USER + 60)
+#define EM_GETPARAFORMAT		(WM_USER + 61)
+#define EM_GETSELTEXT			(WM_USER + 62)
+#define EM_HIDESELECTION		(WM_USER + 63)
+#define EM_PASTESPECIAL			(WM_USER + 64)
+#define EM_REQUESTRESIZE		(WM_USER + 65)
+#define EM_SELECTIONTYPE		(WM_USER + 66)
+#define EM_SETBKGNDCOLOR		(WM_USER + 67)
+#define EM_SETCHARFORMAT		(WM_USER + 68)
+#define EM_SETEVENTMASK			(WM_USER + 69)
+#define EM_SETOLECALLBACK		(WM_USER + 70)
+#define EM_SETPARAFORMAT		(WM_USER + 71)
+#define EM_SETTARGETDEVICE		(WM_USER + 72)
+#define EM_STREAMIN				(WM_USER + 73)
+#define EM_STREAMOUT			(WM_USER + 74)
+#define EM_GETTEXTRANGE			(WM_USER + 75)
+#define EM_FINDWORDBREAK		(WM_USER + 76)
+#define EM_SETOPTIONS			(WM_USER + 77)
+#define EM_GETOPTIONS			(WM_USER + 78)
+#define EM_FINDTEXTEX			(WM_USER + 79)
+#ifdef _WIN32
+#define EM_GETWORDBREAKPROCEX	(WM_USER + 80)
+#define EM_SETWORDBREAKPROCEX	(WM_USER + 81)
+#endif
+
+/* Richedit v2.0 messages */
+#define	EM_SETUNDOLIMIT			(WM_USER + 82)
+#define EM_REDO					(WM_USER + 84)
+#define EM_CANREDO				(WM_USER + 85)
+#define EM_GETUNDONAME			(WM_USER + 86)
+#define EM_GETREDONAME			(WM_USER + 87)
+#define EM_STOPGROUPTYPING		(WM_USER + 88)
+
+#define EM_SETTEXTMODE			(WM_USER + 89)
+#define EM_GETTEXTMODE			(WM_USER + 90)
+
+/* enum for use with EM_GET/SETTEXTMODE */
+typedef enum tagTextMode
+{
+	TM_PLAINTEXT			= 1,
+	TM_RICHTEXT				= 2,	/* default behavior */
+	TM_SINGLELEVELUNDO		= 4,
+	TM_MULTILEVELUNDO		= 8,	/* default behavior */
+	TM_SINGLECODEPAGE		= 16,
+	TM_MULTICODEPAGE		= 32	/* default behavior */
+} TEXTMODE;
+
+#define EM_AUTOURLDETECT		(WM_USER + 91)
+#define EM_GETAUTOURLDETECT		(WM_USER + 92)
+#define EM_SETPALETTE			(WM_USER + 93)
+#define EM_GETTEXTEX			(WM_USER + 94)
+#define EM_GETTEXTLENGTHEX		(WM_USER + 95)
+
+/* Far East specific messages */
+#define EM_SETPUNCTUATION		(WM_USER + 100)
+#define EM_GETPUNCTUATION		(WM_USER + 101)
+#define EM_SETWORDWRAPMODE		(WM_USER + 102)
+#define EM_GETWORDWRAPMODE		(WM_USER + 103)
+#define EM_SETIMECOLOR			(WM_USER + 104)
+#define EM_GETIMECOLOR			(WM_USER + 105)
+#define EM_SETIMEOPTIONS		(WM_USER + 106)
+#define EM_GETIMEOPTIONS		(WM_USER + 107)
+#define EM_CONVPOSITION 		(WM_USER + 108)
+
+#define EM_SETLANGOPTIONS		(WM_USER + 120)
+#define EM_GETLANGOPTIONS		(WM_USER + 121)
+#define EM_GETIMECOMPMODE		(WM_USER + 122)
+
+#define EM_FINDTEXTW			(WM_USER + 123)
+#define EM_FINDTEXTEXW			(WM_USER + 124)
+
+/* BiDi specific messages */
+#define EM_SETBIDIOPTIONS		(WM_USER + 200)
+#define EM_GETBIDIOPTIONS		(WM_USER + 201)
+
+/* Options for EM_SETLANGOPTIONS and EM_GETLANGOPTIONS */
+#define IMF_AUTOKEYBOARD		0x0001
+#define IMF_AUTOFONT			0x0002
+#define IMF_IMECANCELCOMPLETE	0x0004	// high completes the comp string when aborting, low cancels.
+#define IMF_IMEALWAYSSENDNOTIFY 0x0008
+
+/* Values for EM_GETIMECOMPMODE */
+#define ICM_NOTOPEN				0x0000
+#define ICM_LEVEL3				0x0001
+#define ICM_LEVEL2				0x0002
+#define ICM_LEVEL2_5			0x0003
+#define ICM_LEVEL2_SUI			0x0004
+
+/* New notifications */
+
+#define EN_MSGFILTER			0x0700
+#define EN_REQUESTRESIZE		0x0701
+#define EN_SELCHANGE			0x0702
+#define EN_DROPFILES			0x0703
+#define EN_PROTECTED			0x0704
+#define EN_CORRECTTEXT			0x0705			/* PenWin specific */
+#define EN_STOPNOUNDO			0x0706
+#define EN_IMECHANGE			0x0707			/* Far East specific */
+#define EN_SAVECLIPBOARD		0x0708
+#define EN_OLEOPFAILED			0x0709
+#define EN_OBJECTPOSITIONS		0x070a
+#define EN_LINK					0x070b
+#define EN_DRAGDROPDONE			0x070c
+
+/* BiDi specific notifications */
+
+#define EN_ALIGN_LTR			0x0710
+#define EN_ALIGN_RTL			0x0711
+
+/* Event notification masks */
+
+#define ENM_NONE				0x00000000
+#define ENM_CHANGE				0x00000001
+#define ENM_UPDATE				0x00000002
+#define ENM_SCROLL				0x00000004
+#define ENM_KEYEVENTS			0x00010000
+#define ENM_MOUSEEVENTS			0x00020000
+#define ENM_REQUESTRESIZE		0x00040000
+#define ENM_SELCHANGE			0x00080000
+#define ENM_DROPFILES			0x00100000
+#define ENM_PROTECTED			0x00200000
+#define ENM_CORRECTTEXT			0x00400000		/* PenWin specific */
+#define ENM_SCROLLEVENTS		0x00000008
+#define ENM_DRAGDROPDONE		0x00000010
+
+/* Far East specific notification mask */
+#define ENM_IMECHANGE			0x00800000		/* unused by RE2.0 */
+#define ENM_LANGCHANGE			0x01000000
+#define ENM_OBJECTPOSITIONS		0x02000000
+#define ENM_LINK				0x04000000
+
+/* New edit control styles */
+
+#define ES_SAVESEL				0x00008000
+#define ES_SUNKEN				0x00004000
+#define ES_DISABLENOSCROLL		0x00002000
+/* same as WS_MAXIMIZE, but that doesn't make sense so we re-use the value */
+#define ES_SELECTIONBAR			0x01000000
+/* same as ES_UPPERCASE, but re-used to completely disable OLE drag'n'drop */
+#define ES_NOOLEDRAGDROP		0x00000008
+
+/* New edit control extended style */
+#ifdef	_WIN32
+#define ES_EX_NOCALLOLEINIT		0x01000000
+#endif	
+
+/* These flags are used in FE Windows */
+#define ES_VERTICAL				0x00400000
+#define	ES_NOIME				0x00080000
+#define ES_SELFIME				0x00040000
+
+/* Edit control options */
+#define ECO_AUTOWORDSELECTION	0x00000001
+#define ECO_AUTOVSCROLL			0x00000040
+#define ECO_AUTOHSCROLL			0x00000080
+#define ECO_NOHIDESEL			0x00000100
+#define ECO_READONLY			0x00000800
+#define ECO_WANTRETURN			0x00001000
+#define ECO_SAVESEL				0x00008000
+#define ECO_SELECTIONBAR		0x01000000
+#define ECO_VERTICAL			0x00400000		/* FE specific */
+
+
+/* ECO operations */
+#define ECOOP_SET				0x0001
+#define ECOOP_OR				0x0002
+#define ECOOP_AND				0x0003
+#define ECOOP_XOR				0x0004
+
+/* new word break function actions */
+#define WB_CLASSIFY			3
+#define WB_MOVEWORDLEFT		4
+#define WB_MOVEWORDRIGHT	5
+#define WB_LEFTBREAK		6
+#define WB_RIGHTBREAK		7
+
+/* Far East specific flags */
+#define WB_MOVEWORDPREV		4
+#define WB_MOVEWORDNEXT		5
+#define WB_PREVBREAK		6
+#define WB_NEXTBREAK		7
+
+#define PC_FOLLOWING		1
+#define	PC_LEADING			2
+#define	PC_OVERFLOW			3
+#define	PC_DELIMITER		4
+#define WBF_WORDWRAP		0x010
+#define WBF_WORDBREAK		0x020
+#define	WBF_OVERFLOW		0x040	
+#define WBF_LEVEL1			0x080
+#define	WBF_LEVEL2			0x100
+#define	WBF_CUSTOM			0x200
+
+/* Far East specific flags */
+#define IMF_FORCENONE           0x0001
+#define IMF_FORCEENABLE         0x0002
+#define IMF_FORCEDISABLE        0x0004
+#define IMF_CLOSESTATUSWINDOW   0x0008
+#define IMF_VERTICAL            0x0020
+#define IMF_FORCEACTIVE         0x0040
+#define IMF_FORCEINACTIVE       0x0080
+#define IMF_FORCEREMEMBER       0x0100
+#define IMF_MULTIPLEEDIT        0x0400
+
+/* Word break flags (used with WB_CLASSIFY) */
+#define WBF_CLASS			((BYTE) 0x0F)
+#define WBF_ISWHITE			((BYTE) 0x10)
+#define WBF_BREAKLINE		((BYTE) 0x20)
+#define WBF_BREAKAFTER		((BYTE) 0x40)
+
+
+/* new data types */
+
+#ifdef _WIN32
+/* extended edit word break proc (character set aware) */
+typedef LONG (*EDITWORDBREAKPROCEX)(char *pchText, LONG cchText, BYTE bCharSet, INT action);
+#endif
+
+/* all character format measurements are in twips */
+typedef struct _charformat
+{
+	UINT		cbSize;
+	_WPAD		_wPad1;
+	DWORD		dwMask;
+	DWORD		dwEffects;
+	LONG		yHeight;
+	LONG		yOffset;
+	COLORREF	crTextColor;
+	BYTE		bCharSet;
+	BYTE		bPitchAndFamily;
+	char		szFaceName[LF_FACESIZE];
+	_WPAD		_wPad2;
+} CHARFORMATA;
+
+typedef struct _charformatw
+{
+	UINT		cbSize;
+	_WPAD		_wPad1;
+	DWORD		dwMask;
+	DWORD		dwEffects;
+	LONG		yHeight;
+	LONG		yOffset;
+	COLORREF	crTextColor;
+	BYTE		bCharSet;
+	BYTE		bPitchAndFamily;
+	WCHAR		szFaceName[LF_FACESIZE];
+	_WPAD		_wPad2;
+} CHARFORMATW;
+
+#if (_RICHEDIT_VER >= 0x0200)
+#ifdef UNICODE
+#define CHARFORMAT CHARFORMATW
+#else
+#define CHARFORMAT CHARFORMATA
+#endif /* UNICODE */
+#else
+#define CHARFORMAT CHARFORMATA
+#endif /* _RICHEDIT_VER >= 0x0200 */
+
+/* CHARFORMAT masks */
+#define CFM_BOLD		0x00000001
+#define CFM_ITALIC		0x00000002
+#define CFM_UNDERLINE	0x00000004
+#define CFM_STRIKEOUT	0x00000008
+#define CFM_PROTECTED	0x00000010
+#define CFM_LINK		0x00000020		/* Exchange hyperlink extension */
+#define CFM_SIZE		0x80000000
+#define CFM_COLOR		0x40000000
+#define CFM_FACE		0x20000000
+#define CFM_OFFSET		0x10000000
+#define CFM_CHARSET		0x08000000
+
+/* CHARFORMAT effects */
+#define CFE_BOLD		0x0001
+#define CFE_ITALIC		0x0002
+#define CFE_UNDERLINE	0x0004
+#define CFE_STRIKEOUT	0x0008
+#define CFE_PROTECTED	0x0010
+#define CFE_LINK		0x0020
+#define CFE_AUTOCOLOR	0x40000000		/* NOTE: this corresponds to */
+										/* CFM_COLOR, which controls it */
+#define yHeightCharPtsMost 1638
+
+/* EM_SETCHARFORMAT wParam masks */
+#define SCF_SELECTION	0x0001
+#define SCF_WORD		0x0002
+#define SCF_DEFAULT		0x0000		// set the default charformat or paraformat
+#define SCF_ALL			0x0004		// not valid with SCF_SELECTION or SCF_WORD
+#define SCF_USEUIRULES	0x0008		// modifier for SCF_SELECTION; says that
+									// the format came from a toolbar, etc. and
+									// therefore UI formatting rules should be
+									// used instead of strictly formatting the
+									// selection.
+
+
+typedef struct _charrange
+{
+	LONG	cpMin;
+	LONG	cpMax;
+} CHARRANGE;
+
+typedef struct _textrange
+{
+	CHARRANGE chrg;
+	LPSTR lpstrText;	/* allocated by caller, zero terminated by RichEdit */
+} TEXTRANGEA;
+
+typedef struct _textrangew
+{
+	CHARRANGE chrg;
+	LPWSTR lpstrText;	/* allocated by caller, zero terminated by RichEdit */
+} TEXTRANGEW;
+
+#if (_RICHEDIT_VER >= 0x0200)
+#ifdef UNICODE
+#define TEXTRANGE 	TEXTRANGEW
+#else
+#define TEXTRANGE	TEXTRANGEA
+#endif /* UNICODE */
+#else
+#define TEXTRANGE	TEXTRANGEA
+#endif /* _RICHEDIT_VER >= 0x0200 */
+
+
+typedef DWORD (CALLBACK *EDITSTREAMCALLBACK)(DWORD dwCookie, LPBYTE pbBuff, LONG cb, LONG *pcb);
+
+typedef struct _editstream
+{
+	DWORD dwCookie;		/* user value passed to callback as first parameter */
+	DWORD dwError;		/* last error */
+	EDITSTREAMCALLBACK pfnCallback;
+} EDITSTREAM;
+
+/* stream formats */
+
+#define SF_TEXT			0x0001
+#define SF_RTF			0x0002
+#define SF_RTFNOOBJS	0x0003		/* outbound only */
+#define SF_TEXTIZED		0x0004		/* outbound only */
+#define SF_UNICODE		0x0010		/* Unicode file of some kind */
+
+/* Flag telling stream operations to operate on the selection only */
+/* EM_STREAMIN will replace the current selection */
+/* EM_STREAMOUT will stream out the current selection */
+#define SFF_SELECTION	0x8000
+
+/* Flag telling stream operations to operate on the common RTF keyword only */
+/* EM_STREAMIN will accept the only common RTF keyword */
+/* EM_STREAMOUT will stream out the only common RTF keyword */
+#define SFF_PLAINRTF	0x4000
+
+typedef struct _findtext
+{
+	CHARRANGE chrg;
+	LPSTR lpstrText;
+} FINDTEXTA;
+
+typedef struct _findtextw
+{
+	CHARRANGE chrg;
+	LPWSTR lpstrText;
+} FINDTEXTW;
+
+#if (_RICHEDIT_VER >= 0x0200)
+#ifdef UNICODE
+#define FINDTEXT	FINDTEXTW
+#else
+#define FINDTEXT	FINDTEXTA
+#endif /* UNICODE */
+#else
+#define FINDTEXT	FINDTEXTA
+#endif /* _RICHEDIT_VER >= 0x0200 */
+
+typedef struct _findtextexa
+{
+	CHARRANGE chrg;
+	LPSTR lpstrText;
+	CHARRANGE chrgText;
+} FINDTEXTEXA;
+
+typedef struct _findtextexw
+{
+	CHARRANGE chrg;
+	LPWSTR lpstrText;
+	CHARRANGE chrgText;
+} FINDTEXTEXW;
+
+#if (_RICHEDIT_VER >= 0x0200)
+#ifdef UNICODE
+#define FINDTEXTEX	FINDTEXTEXW
+#else
+#define FINDTEXTEX	FINDTEXTEXA
+#endif /* UNICODE */
+#else
+#define FINDTEXTEX	FINDTEXTEXA
+#endif /* _RICHEDIT_VER >= 0x0200 */
+
+
+typedef struct _formatrange
+{
+	HDC hdc;
+	HDC hdcTarget;
+	RECT rc;
+	RECT rcPage;
+	CHARRANGE chrg;
+} FORMATRANGE;
+
+/* all paragraph measurements are in twips */
+
+#define MAX_TAB_STOPS 32
+#define lDefaultTab 720
+
+typedef struct _paraformat
+{
+	UINT	cbSize;
+	_WPAD	_wPad1;
+	DWORD	dwMask;
+	WORD	wNumbering;
+#if (_RICHEDIT_VER >= 0x0210)
+	WORD	wEffects;
+#else
+	WORD	wReserved;
+#endif /* _RICHEDIT_VER >= 0x0210 */
+	LONG	dxStartIndent;
+	LONG	dxRightIndent;
+	LONG	dxOffset;
+	WORD	wAlignment;
+	SHORT	cTabCount;
+	LONG	rgxTabs[MAX_TAB_STOPS];
+} PARAFORMAT;
+
+/* PARAFORMAT mask values */
+#define PFM_STARTINDENT			0x00000001
+#define PFM_RIGHTINDENT			0x00000002
+#define PFM_OFFSET				0x00000004
+#define PFM_ALIGNMENT			0x00000008
+#define PFM_TABSTOPS			0x00000010
+#define PFM_NUMBERING			0x00000020
+#define PFM_OFFSETINDENT		0x80000000
+
+/* PARAFORMAT numbering options */
+#define PFN_BULLET		0x0001
+
+/* PARAFORMAT alignment options */
+#define PFA_LEFT	0x0001
+#define PFA_RIGHT	0x0002
+#define PFA_CENTER	0x0003
+
+/* CHARFORMAT2 and PARAFORMAT2 structures */
+
+#ifdef __cplusplus
+
+struct CHARFORMAT2W : _charformatw
+{
+	WORD		wWeight;			/* Font weight (LOGFONT value)		*/
+	SHORT		sSpacing;			/* Amount to space between letters	*/
+	COLORREF	crBackColor;		/* Background color					*/
+	LCID		lcid;				/* Locale ID						*/
+	DWORD		dwReserved;			/* Reserved. Must be 0				*/
+	SHORT		sStyle;				/* Style handle						*/
+	WORD		wKerning;			/* Twip size above which to kern char pair*/
+	BYTE		bUnderlineType;		/* Underline type					*/
+	BYTE		bAnimation;			/* Animated text like marching ants */
+	BYTE		bRevAuthor;			/* Revision author index			*/
+};
+
+struct CHARFORMAT2A : _charformat
+{
+	WORD		wWeight;			/* Font weight (LOGFONT value)		*/
+	SHORT		sSpacing;			/* Amount to space between letters	*/
+	COLORREF	crBackColor;		/* Background color					*/
+	LCID		lcid;				/* Locale ID						*/
+	DWORD		dwReserved;			/* Reserved. Must be 0				*/
+	SHORT		sStyle;				/* Style handle						*/
+	WORD		wKerning;			/* Twip size above which to kern char pair*/
+	BYTE		bUnderlineType;		/* Underline type					*/
+	BYTE		bAnimation;			/* Animated text like marching ants	*/
+	BYTE		bRevAuthor;			/* Revision author index			*/
+};
+
+#else	/* regular C-style  */
+
+typedef struct _charformat2w
+{
+	UINT		cbSize;
+	_WPAD		_wPad1;
+	DWORD		dwMask;
+	DWORD		dwEffects;
+	LONG		yHeight;
+	LONG		yOffset;			/* > 0 for superscript, < 0 for subscript */
+	COLORREF	crTextColor;
+	BYTE		bCharSet;
+	BYTE		bPitchAndFamily;
+	WCHAR		szFaceName[LF_FACESIZE];
+	_WPAD		_wPad2;
+	WORD		wWeight;			/* Font weight (LOGFONT value)		*/
+	SHORT		sSpacing;			/* Amount to space between letters	*/
+	COLORREF	crBackColor;		/* Background color					*/
+	LCID		lcid;				/* Locale ID						*/
+	DWORD		dwReserved;			/* Reserved. Must be 0				*/
+	SHORT		sStyle;				/* Style handle						*/
+	WORD		wKerning;			/* Twip size above which to kern char pair*/
+	BYTE		bUnderlineType;		/* Underline type					*/
+	BYTE		bAnimation;			/* Animated text like marching ants	*/
+	BYTE		bRevAuthor;			/* Revision author index			*/
+	BYTE		bReserved1;
+} CHARFORMAT2W;
+
+typedef struct _charformat2a
+{
+	UINT		cbSize;
+	_WPAD		_wPad1;
+	DWORD		dwMask;
+	DWORD		dwEffects;
+	LONG		yHeight;
+	LONG		yOffset;			/* > 0 for superscript, < 0 for subscript */
+	COLORREF	crTextColor;
+	BYTE		bCharSet;
+	BYTE		bPitchAndFamily;
+	char		szFaceName[LF_FACESIZE];
+	_WPAD		_wPad2;
+	WORD		wWeight;			/* Font weight (LOGFONT value)		*/
+	SHORT		sSpacing;			/* Amount to space between letters	*/
+	COLORREF	crBackColor;		/* Background color					*/
+	LCID		lcid;				/* Locale ID						*/
+	DWORD		dwReserved;			/* Reserved. Must be 0				*/
+	SHORT		sStyle;				/* Style handle						*/
+	WORD		wKerning;			/* Twip size above which to kern char pair*/
+	BYTE		bUnderlineType;		/* Underline type					*/
+	BYTE		bAnimation;			/* Animated text like marching ants	*/
+	BYTE		bRevAuthor;			/* Revision author index			*/
+} CHARFORMAT2A;
+
+#endif /* C++ */
+
+#ifdef UNICODE
+#define CHARFORMAT2	CHARFORMAT2W
+#else
+#define CHARFORMAT2 CHARFORMAT2A
+#endif
+
+#define CHARFORMATDELTA		(sizeof(CHARFORMAT2) - sizeof(CHARFORMAT))
+
+
+/* CHARFORMAT and PARAFORMAT "ALL" masks
+   CFM_COLOR mirrors CFE_AUTOCOLOR, a little hack to easily deal with autocolor*/
+
+#define CFM_EFFECTS (CFM_BOLD | CFM_ITALIC | CFM_UNDERLINE | CFM_COLOR | \
+					 CFM_STRIKEOUT | CFE_PROTECTED | CFM_LINK)
+#define CFM_ALL (CFM_EFFECTS | CFM_SIZE | CFM_FACE | CFM_OFFSET | CFM_CHARSET)
+
+#define	PFM_ALL (PFM_STARTINDENT | PFM_RIGHTINDENT | PFM_OFFSET	| \
+				 PFM_ALIGNMENT   | PFM_TABSTOPS    | PFM_NUMBERING | \
+				 PFM_OFFSETINDENT| PFM_DIR)
+
+/* New masks and effects -- a parenthesized asterisk indicates that
+   the data is stored by RichEdit2.0, but not displayed */
+
+#define CFM_SMALLCAPS		0x0040			/* (*)	*/
+#define	CFM_ALLCAPS			0x0080			/* (*)	*/
+#define	CFM_HIDDEN			0x0100			/* (*)	*/
+#define	CFM_OUTLINE			0x0200			/* (*)	*/
+#define	CFM_SHADOW			0x0400			/* (*)	*/
+#define	CFM_EMBOSS			0x0800			/* (*)	*/
+#define	CFM_IMPRINT			0x1000			/* (*)	*/
+#define CFM_DISABLED		0x2000
+#define	CFM_REVISED			0x4000
+
+#define CFM_BACKCOLOR		0x04000000
+#define CFM_LCID			0x02000000
+#define	CFM_UNDERLINETYPE	0x00800000		/* (*)	*/
+#define	CFM_WEIGHT			0x00400000
+#define CFM_SPACING			0x00200000		/* (*)	*/
+#define CFM_KERNING			0x00100000		/* (*)	*/
+#define CFM_STYLE			0x00080000		/* (*)	*/
+#define CFM_ANIMATION		0x00040000		/* (*)	*/
+#define CFM_REVAUTHOR		0x00008000
+
+#define CFE_SUBSCRIPT		0x00010000		/* Superscript and subscript are */
+#define CFE_SUPERSCRIPT		0x00020000		/*  mutually exclusive			 */
+
+#define CFM_SUBSCRIPT		CFE_SUBSCRIPT | CFE_SUPERSCRIPT
+#define CFM_SUPERSCRIPT		CFM_SUBSCRIPT
+
+#define	CFM_EFFECTS2 (CFM_EFFECTS | CFM_DISABLED | CFM_SMALLCAPS | CFM_ALLCAPS \
+					| CFM_HIDDEN  | CFM_OUTLINE | CFM_SHADOW | CFM_EMBOSS \
+					| CFM_IMPRINT | CFM_DISABLED | CFM_REVISED \
+					| CFM_SUBSCRIPT | CFM_SUPERSCRIPT | CFM_BACKCOLOR)
+
+#define CFM_ALL2	 (CFM_ALL | CFM_EFFECTS2 | CFM_BACKCOLOR | CFM_LCID \
+					| CFM_UNDERLINETYPE | CFM_WEIGHT | CFM_REVAUTHOR \
+					| CFM_SPACING | CFM_KERNING | CFM_STYLE | CFM_ANIMATION)
+
+#define	CFE_SMALLCAPS		CFM_SMALLCAPS
+#define	CFE_ALLCAPS			CFM_ALLCAPS
+#define	CFE_HIDDEN			CFM_HIDDEN
+#define	CFE_OUTLINE			CFM_OUTLINE
+#define	CFE_SHADOW			CFM_SHADOW
+#define	CFE_EMBOSS			CFM_EMBOSS
+#define	CFE_IMPRINT			CFM_IMPRINT
+#define	CFE_DISABLED		CFM_DISABLED
+#define	CFE_REVISED			CFM_REVISED
+
+/* NOTE: CFE_AUTOCOLOR and CFE_AUTOBACKCOLOR correspond to CFM_COLOR and
+   CFM_BACKCOLOR, respectively, which control them */
+#define CFE_AUTOBACKCOLOR	CFM_BACKCOLOR
+
+/* Underline types */
+#define CFU_CF1UNDERLINE	0xFF	/* map charformat's bit underline to CF2.*/
+#define CFU_INVERT			0xFE	/* For IME composition fake a selection.*/	
+#define	CFU_UNDERLINEDOTTED	0x4		/* (*) displayed as ordinary underline	*/
+#define	CFU_UNDERLINEDOUBLE	0x3		/* (*) displayed as ordinary underline	*/
+#define CFU_UNDERLINEWORD	0x2		/* (*) displayed as ordinary underline	*/
+#define CFU_UNDERLINE		0x1
+#define CFU_UNDERLINENONE	0
+
+#ifdef __cplusplus
+struct PARAFORMAT2 : _paraformat
+{
+	LONG	dySpaceBefore;			/* Vertical spacing before para			*/
+	LONG	dySpaceAfter;			/* Vertical spacing after para			*/	
+	LONG	dyLineSpacing;			/* Line spacing depending on Rule		*/
+	SHORT	sStyle;					/* Style handle							*/
+	BYTE	bLineSpacingRule;		/* Rule for line spacing (see tom.doc)	*/
+	BYTE	bCRC;					/* Reserved for CRC for rapid searching	*/
+	WORD	wShadingWeight;			/* Shading in hundredths of a per cent	*/
+	WORD	wShadingStyle;			/* Nibble 0: style, 1: cfpat, 2: cbpat	*/
+	WORD	wNumberingStart;		/* Starting value for numbering			*/
+	WORD	wNumberingStyle;		/* Alignment, roman/arabic, (), ), ., etc.*/
+	WORD	wNumberingTab;			/* Space bet FirstIndent and 1st-line text*/
+	WORD	wBorderSpace;			/* Space between border and text (twips)*/
+	WORD	wBorderWidth;			/* Border pen width (twips)				*/
+	WORD	wBorders;				/* Byte 0: bits specify which borders	*/
+									/* Nibble 2: border style, 3: color index*/
+};
+
+#else	/* regular C-style	*/
+
+typedef struct _paraformat2
+{
+	UINT	cbSize;
+	_WPAD	_wPad1;
+	DWORD	dwMask;
+	WORD	wNumbering;
+#if (_RICHEDIT_VER >= 0x0210)
+	WORD	wEffects;
+#else
+	WORD	wReserved;
+#endif /* _RICHEDIT_VER >= 0x0210 */
+	LONG	dxStartIndent;
+	LONG	dxRightIndent;
+	LONG	dxOffset;
+	WORD	wAlignment;
+	SHORT	cTabCount;
+	LONG	rgxTabs[MAX_TAB_STOPS];
+ 	LONG	dySpaceBefore;			/* Vertical spacing before para			*/
+	LONG	dySpaceAfter;			/* Vertical spacing after para			*/
+	LONG	dyLineSpacing;			/* Line spacing depending on Rule		*/
+	SHORT	sStyle;					/* Style handle							*/
+	BYTE	bLineSpacingRule;		/* Rule for line spacing (see tom.doc)	*/
+	BYTE	bCRC;					/* Reserved for CRC for rapid searching	*/
+	WORD	wShadingWeight;			/* Shading in hundredths of a per cent	*/
+	WORD	wShadingStyle;			/* Nibble 0: style, 1: cfpat, 2: cbpat	*/
+	WORD	wNumberingStart;		/* Starting value for numbering			*/	
+	WORD	wNumberingStyle;		/* Alignment, roman/arabic, (), ), ., etc.*/
+	WORD	wNumberingTab;			/* Space bet 1st indent and 1st-line text*/
+	WORD	wBorderSpace;			/* Space between border and text (twips)*/
+	WORD	wBorderWidth;			/* Border pen width (twips)				*/
+	WORD	wBorders;				/* Byte 0: bits specify which borders	*/
+									/* Nibble 2: border style, 3: color index*/
+} PARAFORMAT2;
+
+#endif /* C++	*/
+
+/* PARAFORMAT 2.0 masks and effects */
+
+#define PFM_SPACEBEFORE			0x00000040
+#define PFM_SPACEAFTER			0x00000080
+#define PFM_LINESPACING			0x00000100
+#define	PFM_STYLE				0x00000400
+#define PFM_BORDER				0x00000800	/* (*)	*/
+#define PFM_SHADING				0x00001000	/* (*)	*/
+#define PFM_NUMBERINGSTYLE		0x00002000	/* (*)	*/
+#define PFM_NUMBERINGTAB		0x00004000	/* (*)	*/
+#define PFM_NUMBERINGSTART		0x00008000	/* (*)	*/
+
+#define PFM_DIR					0x00010000
+#define PFM_RTLPARA				0x00010000	/* (Version 1.0 flag) */
+#define PFM_KEEP				0x00020000	/* (*)	*/
+#define PFM_KEEPNEXT			0x00040000	/* (*)	*/
+#define PFM_PAGEBREAKBEFORE		0x00080000	/* (*)	*/
+#define PFM_NOLINENUMBER		0x00100000	/* (*)	*/
+#define PFM_NOWIDOWCONTROL		0x00200000	/* (*)	*/
+#define PFM_DONOTHYPHEN			0x00400000	/* (*)	*/
+#define PFM_SIDEBYSIDE			0x00800000	/* (*)	*/
+
+#define PFM_TABLE				0xc0000000	/* (*)	*/
+
+/* Note: PARAFORMAT has no effects */
+#define PFM_EFFECTS  (PFM_DIR | PFM_KEEP | PFM_KEEPNEXT | PFM_TABLE \
+					| PFM_PAGEBREAKBEFORE | PFM_NOLINENUMBER  \
+					| PFM_NOWIDOWCONTROL | PFM_DONOTHYPHEN | PFM_SIDEBYSIDE \
+					| PFM_TABLE)
+
+#define PFM_ALL2	(PFM_ALL | PFM_EFFECTS | PFM_SPACEBEFORE | PFM_SPACEAFTER \
+					| PFM_LINESPACING | PFM_STYLE | PFM_SHADING | PFM_BORDER \
+					| PFM_NUMBERINGTAB | PFM_NUMBERINGSTART | PFM_NUMBERINGSTYLE)
+
+#define PFE_RTLPARA				(PFM_DIR			 >> 16)
+#define PFE_RTLPAR				(PFM_RTLPARA		 >> 16)	/* (Version 1.0 flag) */
+#define PFE_KEEP				(PFM_KEEP			 >> 16)	/* (*)	*/
+#define PFE_KEEPNEXT			(PFM_KEEPNEXT		 >> 16)	/* (*)	*/
+#define PFE_PAGEBREAKBEFORE		(PFM_PAGEBREAKBEFORE >> 16)	/* (*)	*/
+#define PFE_NOLINENUMBER		(PFM_NOLINENUMBER	 >> 16)	/* (*)	*/
+#define PFE_NOWIDOWCONTROL		(PFM_NOWIDOWCONTROL	 >> 16)	/* (*)	*/
+#define PFE_DONOTHYPHEN			(PFM_DONOTHYPHEN 	 >> 16)	/* (*)	*/
+#define PFE_SIDEBYSIDE			(PFM_SIDEBYSIDE		 >> 16)	/* (*)	*/
+
+#define PFE_TABLEROW			0xc000		/* These 3 options are mutually	*/
+#define PFE_TABLECELLEND		0x8000		/*  exclusive and each imply	*/
+#define PFE_TABLECELL			0x4000		/*  that para is part of a table*/
+
+/*
+ *	PARAFORMAT numbering options (values for wNumbering):
+ *
+ *		Numbering Type		Value	Meaning
+ *		tomNoNumbering		  0		Turn off paragraph numbering
+ *		tomNumberAsLCLetter	  1		a, b, c, ...
+ *		tomNumberAsUCLetter	  2		A, B, C, ...
+ *		tomNumberAsLCRoman	  3		i, ii, iii, ...
+ *		tomNumberAsUCRoman	  4		I, II, III, ...
+ *		tomNumberAsSymbols	  5		default is bullet
+ *		tomNumberAsNumber	  6		0, 1, 2, ...
+ *		tomNumberAsSequence	  7		tomNumberingStart is first Unicode to use
+ *
+ *	Other valid Unicode chars are Unicodes for bullets.
+ */
+
+
+#define	PFA_JUSTIFY			4	/* New paragraph-alignment option 2.0 (*)
+
+
+/* notification structures */
+
+#ifndef WM_NOTIFY
+#define WM_NOTIFY				0x004E
+
+typedef struct _nmhdr
+{
+	HWND	hwndFrom;
+	_WPAD	_wPad1;
+	UINT	idFrom;
+	_WPAD	_wPad2;
+	UINT	code;
+	_WPAD	_wPad3;
+} NMHDR;
+#endif  /* !WM_NOTIFY */
+
+typedef struct _msgfilter
+{
+	NMHDR	nmhdr;
+	UINT	msg;
+	_WPAD	_wPad1;
+	WPARAM	wParam;
+	_WPAD	_wPad2;
+	LPARAM	lParam;
+} MSGFILTER;
+
+typedef struct _reqresize
+{
+	NMHDR nmhdr;
+	RECT rc;
+} REQRESIZE;
+
+typedef struct _selchange
+{
+	NMHDR nmhdr;
+	CHARRANGE chrg;
+	WORD seltyp;
+} SELCHANGE;
+
+#define SEL_EMPTY		0x0000
+#define SEL_TEXT		0x0001
+#define SEL_OBJECT		0x0002
+#define SEL_MULTICHAR	0x0004
+#define SEL_MULTIOBJECT	0x0008
+
+/* used with IRichEditOleCallback::GetContextMenu, this flag will be
+   passed as a "selection type".  It indicates that a context menu for
+   a right-mouse drag drop should be generated.  The IOleObject parameter
+   will really be the IDataObject for the drop
+ */
+#define GCM_RIGHTMOUSEDROP  0x8000
+
+typedef struct _endropfiles
+{
+	NMHDR nmhdr;
+	HANDLE hDrop;
+	LONG cp;
+	BOOL fProtected;
+} ENDROPFILES;
+
+typedef struct _enprotected
+{
+	NMHDR nmhdr;
+	UINT msg;
+	_WPAD	_wPad1;
+	WPARAM wParam;
+	_WPAD	_wPad2;
+	LPARAM lParam;
+	CHARRANGE chrg;
+} ENPROTECTED;
+
+typedef struct _ensaveclipboard
+{
+	NMHDR nmhdr;
+	LONG cObjectCount;
+    LONG cch;
+} ENSAVECLIPBOARD;
+
+#ifndef MACPORT
+typedef struct _enoleopfailed
+{
+	NMHDR nmhdr;
+	LONG iob;
+	LONG lOper;
+	HRESULT hr;
+} ENOLEOPFAILED;
+#endif
+
+#define	OLEOP_DOVERB	1
+
+typedef struct _objectpositions
+{
+    NMHDR nmhdr;
+    LONG cObjectCount;
+    LONG *pcpPositions;
+} OBJECTPOSITIONS;
+
+typedef struct _enlink
+{
+    NMHDR nmhdr;
+    UINT msg;
+    _WPAD   _wPad1;
+    WPARAM wParam;
+    _WPAD   _wPad2;
+    LPARAM lParam;
+    CHARRANGE chrg;
+} ENLINK;
+
+/* PenWin specific */
+typedef struct _encorrecttext
+{
+	NMHDR nmhdr;
+	CHARRANGE chrg;
+	WORD seltyp;
+} ENCORRECTTEXT;
+
+/* Far East specific */
+typedef struct _punctuation
+{
+	UINT	iSize;
+	LPSTR	szPunctuation;
+} PUNCTUATION;
+
+/* Far East specific */
+typedef struct _compcolor
+{
+	COLORREF crText;
+	COLORREF crBackground;
+	DWORD dwEffects;
+}COMPCOLOR;
+
+
+/* clipboard formats - use as parameter to RegisterClipboardFormat() */
+#define CF_RTF 			TEXT("Rich Text Format")
+#define CF_RTFNOOBJS 	TEXT("Rich Text Format Without Objects")
+#define CF_RETEXTOBJ 	TEXT("RichEdit Text and Objects")
+
+/* Paste Special */
+typedef struct _repastespecial
+{
+	DWORD	dwAspect;
+	DWORD	dwParam;
+} REPASTESPECIAL;
+
+/*	UndoName info */
+typedef enum _undonameid
+{
+    UID_UNKNOWN     = 0,
+	UID_TYPING		= 1,
+	UID_DELETE 		= 2,
+	UID_DRAGDROP	= 3,
+	UID_CUT			= 4,
+	UID_PASTE		= 5
+} UNDONAMEID;
+
+/* flags for the GETEXTEX data structure */
+#define GT_DEFAULT		0
+#define GT_USECRLF		1
+
+/* EM_GETTEXTEX info; this struct is passed in the wparam of the message */
+typedef struct _gettextex
+{
+	DWORD	cb;				/* count of bytes in the string				*/
+	DWORD	flags;			/* flags (see the GT_XXX defines			*/
+	UINT	codepage;		/* code page for translation (CP_ACP for default,
+						       1200 for Unicode							*/
+	LPCSTR	lpDefaultChar;	/* replacement for unmappable chars			*/
+	LPBOOL	lpUsedDefChar;	/* pointer to flag set when def char used	*/
+} GETTEXTEX;
+
+/* flags for the GETTEXTLENGTHEX data structure							*/
+#define GTL_DEFAULT		0	/* do the default (return # of chars)		*/
+#define GTL_USECRLF		1	/* compute answer using CRLFs for paragraphs*/
+#define GTL_PRECISE		2	/* compute a precise answer					*/
+#define GTL_CLOSE		4	/* fast computation of a "close" answer		*/
+#define GTL_NUMCHARS	8	/* return the number of characters			*/
+#define GTL_NUMBYTES	16	/* return the number of _bytes_				*/
+
+/* EM_GETTEXTLENGTHEX info; this struct is passed in the wparam of the msg */
+typedef struct _gettextlengthex
+{
+	DWORD	flags;			/* flags (see GTL_XXX defines)				*/
+	UINT	codepage;		/* code page for translation (CP_ACP for default,
+							   1200 for Unicode							*/
+} GETTEXTLENGTHEX;
+	
+/* BiDi specific features */
+typedef struct _bidioptions
+{
+	UINT	cbSize;
+	_WPAD	_wPad1;
+	WORD	wMask;
+	WORD	wEffects; 
+} BIDIOPTIONS;
+
+/* BIDIOPTIONS masks */
+#if (_RICHEDIT_VER == 0x0100)
+#define BOM_DEFPARADIR			0x0001	/* Default paragraph direction (implies alignment) (obsolete) */
+#define BOM_PLAINTEXT			0x0002	/* Use plain text layout (obsolete) */
+#define BOM_NEUTRALOVERRIDE		0x0004	/* Override neutral layout (obsolete) */
+#endif /* _RICHEDIT_VER == 0x0100 */
+#define BOM_CONTEXTREADING		0x0008	/* Context reading order */
+#define BOM_CONTEXTALIGNMENT	0x0010	/* Context alignment */
+
+/* BIDIOPTIONS effects */
+#if (_RICHEDIT_VER == 0x0100)
+#define BOE_RTLDIR				0x0001	/* Default paragraph direction (implies alignment) (obsolete) */
+#define BOE_PLAINTEXT			0x0002	/* Use plain text layout (obsolete) */
+#define BOE_NEUTRALOVERRIDE		0x0004	/* Override neutral layout (obsolete) */
+#endif /* _RICHEDIT_VER == 0x0100 */
+#define BOE_CONTEXTREADING		0x0008	/* Context reading order */
+#define BOE_CONTEXTALIGNMENT	0x0010	/* Context alignment */
+
+/* Additional EM_FINDTEXT[EX] flags */
+#define FR_MATCHDIAC                    0x20000000
+#define FR_MATCHKASHIDA                 0x40000000
+#define FR_MATCHALEFHAMZA               0x80000000
+
+/* UNICODE embedding character */
+#ifndef WCH_EMBEDDING
+#define WCH_EMBEDDING (WCHAR)0xFFFC
+#endif /* WCH_EMBEDDING */
+		
+
+#undef _WPAD
+
+#ifdef _WIN32
+#include <poppack.h>
+#elif !defined(RC_INVOKED)
+#pragma pack()
+#endif
+
+#ifdef __cplusplus
+}
+#endif  /* __cplusplus */
+
+#endif /* !_RICHEDIT_ */
+
diff --git a/source_code/version2.2_windows/WINDOWS.H b/source_code/version2.2_windows/WINDOWS.H
new file mode 100644
index 0000000000000000000000000000000000000000..c60db455a057fa3b6d00b3bc87df66868942282b
--- /dev/null
+++ b/source_code/version2.2_windows/WINDOWS.H
@@ -0,0 +1,268 @@
+
+/*++ BUILD Version: 0001    Increment this if a change has global effects
+
+Copyright (c) 1985-1997, Microsoft Corporation
+
+Module Name:
+
+
+    windows.h
+
+Abstract:
+
+    Master include file for Windows applications.
+
+Modified with WC_STATIC by F. Suckow  04.08.2011
+
+--*/
+
+#ifndef _WINDOWS_
+#define _WINDOWS_
+
+#ifndef WINVER
+#define WINVER 0x0400
+#else	
+#if defined(_WIN32_WINNT) && (WINVER < 0x0400) && (_WIN32_WINNT > 0x0400)
+#error WINVER setting conflicts with _WIN32_WINNT setting
+#endif
+#endif
+
+#ifndef WC_STATIC
+#define WC_STATIC               "Static"
+#endif
+
+#if(WINVER >= 0x0500)
+#pragma message ("")
+#pragma message ("NOTE: WINVER has been defined as 0x0500 or greater which enables")
+#pragma message ("Windows NT 5.0 and Windows 98 features. When these headers were released,")
+#pragma message ("Windows NT 5.0 beta 1 and Windows 98 beta 2.1 were the current versions.")
+#pragma message ("")
+#pragma message ("For this release when WINVER is defined as 0x0500 or greater, you can only")
+#pragma message ("build beta or test applications.  To build a retail application,")
+#pragma message ("set WINVER to 0x0400 or visit http://www.microsoft.com/msdn/sdk")
+#pragma message ("to see if retail Windows NT 5.0 or Windows 98 headers are available.")
+#pragma message ("")
+#pragma message ("See the SDK release notes for more information.")
+#pragma message ("")
+#endif
+
+#ifndef _INC_WINDOWS
+#define _INC_WINDOWS
+
+#if defined (_MSC_VER) && (_MSC_VER >= 1020)
+#pragma once
+#endif
+
+/*  If defined, the following flags inhibit definition
+ *     of the indicated items.
+ *
+ *  NOGDICAPMASKS     - CC_*, LC_*, PC_*, CP_*, TC_*, RC_
+ *  NOVIRTUALKEYCODES - VK_*
+ *  NOWINMESSAGES     - WM_*, EM_*, LB_*, CB_*
+ *  NOWINSTYLES       - WS_*, CS_*, ES_*, LBS_*, SBS_*, CBS_*
+ *  NOSYSMETRICS      - SM_*
+ *  NOMENUS           - MF_*
+ *  NOICONS           - IDI_*
+ *  NOKEYSTATES       - MK_*
+ *  NOSYSCOMMANDS     - SC_*
+ *  NORASTEROPS       - Binary and Tertiary raster ops
+ *  NOSHOWWINDOW      - SW_*
+ *  OEMRESOURCE       - OEM Resource values
+ *  NOATOM            - Atom Manager routines
+ *  NOCLIPBOARD       - Clipboard routines
+ *  NOCOLOR           - Screen colors
+ *  NOCTLMGR          - Control and Dialog routines
+ *  NODRAWTEXT        - DrawText() and DT_*
+ *  NOGDI             - All GDI defines and routines
+ *  NOKERNEL          - All KERNEL defines and routines
+ *  NOUSER            - All USER defines and routines
+ *  NONLS             - All NLS defines and routines
+ *  NOMB              - MB_* and MessageBox()
+ *  NOMEMMGR          - GMEM_*, LMEM_*, GHND, LHND, associated routines
+ *  NOMETAFILE        - typedef METAFILEPICT
+ *  NOMINMAX          - Macros min(a,b) and max(a,b)
+ *  NOMSG             - typedef MSG and associated routines
+ *  NOOPENFILE        - OpenFile(), OemToAnsi, AnsiToOem, and OF_*
+ *  NOSCROLL          - SB_* and scrolling routines
+ *  NOSERVICE         - All Service Controller routines, SERVICE_ equates, etc.
+ *  NOSOUND           - Sound driver routines
+ *  NOTEXTMETRIC      - typedef TEXTMETRIC and associated routines
+ *  NOWH              - SetWindowsHook and WH_*
+ *  NOWINOFFSETS      - GWL_*, GCL_*, associated routines
+ *  NOCOMM            - COMM driver routines
+ *  NOKANJI           - Kanji support stuff.
+ *  NOHELP            - Help engine interface.
+ *  NOPROFILER        - Profiler interface.
+ *  NODEFERWINDOWPOS  - DeferWindowPos routines
+ *  NOMCX             - Modem Configuration Extensions
+ */
+
+#if defined(RC_INVOKED) && !defined(NOWINRES)
+
+#include <winresrc.h>
+
+#else
+
+#if defined(RC_INVOKED)
+/* Turn off a bunch of stuff to ensure that RC files compile OK. */
+#define NOATOM
+#define NOGDI
+#define NOGDICAPMASKS
+#define NOMETAFILE
+#define NOMINMAX
+#define NOMSG
+#define NOOPENFILE
+#define NORASTEROPS
+#define NOSCROLL
+#define NOSOUND
+#define NOSYSMETRICS
+#define NOTEXTMETRIC
+#define NOWH
+#define NOCOMM
+#define NOKANJI
+#define NOCRYPT
+#define NOMCX
+#endif
+
+#if !defined(_68K_) && !defined(_MPPC_) && !defined(_PPC_) && !defined(_ALPHA_) && !defined(_MIPS_) && !defined(_X86_) && defined(_M_IX86)
+#define _X86_
+#endif
+
+#if !defined(_68K_) && !defined(_MPPC_) && !defined(_PPC_) && !defined(_ALPHA_) && !defined(_X86_) && !defined(_MIPS_) && defined(_M_MRX000)
+#define _MIPS_
+#endif
+
+#if !defined(_68K_) && !defined(_MPPC_) && !defined(_PPC_) && !defined(_ALPHA_) && !defined(_X86_) && !defined(_MIPS_) && defined(_M_ALPHA)
+#define _ALPHA_
+#endif
+
+#if !defined(_68K_) && !defined(_MPPC_) && !defined(_PPC_) && !defined(_ALPHA_) && !defined(_X86_) && !defined(_MIPS_) && defined(_M_PPC)
+#define _PPC_
+#endif
+
+#if !defined(_68K_) && !defined(_MPPC_) && !defined(_PPC_) && !defined(_ALPHA_) && !defined(_X86_) && !defined(_MIPS_) && defined(_M_M68K)
+#define _68K_
+#endif
+
+#if !defined(_68K_) && !defined(_MPPC_) && !defined(_PPC_) && !defined(_ALPHA_) && !defined(_X86_) && !defined(_MIPS_) && defined(_M_MPPC)
+#define _MPPC_
+#endif
+
+#ifndef _MAC
+#if defined(_68K_) || defined(_MPPC_)
+#define _MAC
+#endif
+#endif
+
+#ifndef RC_INVOKED
+#if     ( _MSC_VER >= 800 )
+#pragma warning(disable:4001)
+#pragma warning(disable:4201)
+#pragma warning(disable:4214)
+#pragma warning(disable:4514)
+#endif
+#include <excpt.h>
+#include <stdarg.h>
+#endif /* RC_INVOKED */
+
+#include <windef.h>
+#include <winbase.h>
+#include <wingdi.h>
+#include <winuser.h>
+#ifdef _MAC
+DECLARE_HANDLE(HKEY);
+typedef HKEY *PHKEY;
+#endif
+#if !defined(_MAC) || defined(_WIN32NLS)
+#include <winnls.h>
+#endif
+#ifndef _MAC
+#include <wincon.h>
+#include <winver.h>
+#endif
+#if !defined(_MAC) || defined(_WIN32REG)
+#include <winreg.h>
+#endif
+#ifndef _MAC
+#include <winnetwk.h>
+#endif
+
+#ifndef WIN32_LEAN_AND_MEAN
+#include <cderr.h>
+#include <dde.h>
+#include <ddeml.h>
+#include <dlgs.h>
+#ifndef _MAC
+#include <lzexpand.h>
+#include <mmsystem.h>
+#include <nb30.h>
+#include <rpc.h>
+#endif
+#include <shellapi.h>
+#ifndef _MAC
+#include <winperf.h>
+
+#if(_WIN32_WINNT >= 0x0400)
+#include <winsock2.h>
+#include <mswsock.h>
+#else
+#include <winsock.h>
+#endif /* _WIN32_WINNT >=  0x0400 */
+
+#endif
+#ifndef NOCRYPT
+#include <wincrypt.h>
+#endif
+
+#ifndef NOGDI
+#include <commdlg.h>
+#ifndef _MAC
+#include <winspool.h>
+#ifdef INC_OLE1
+#include <ole.h>
+#else
+#include <ole2.h>
+#endif /* !INC_OLE1 */
+#endif /* !MAC */
+#endif /* !NOGDI */
+#endif /* WIN32_LEAN_AND_MEAN */
+
+#ifdef _MAC
+#include <winwlm.h>
+#endif
+
+
+#ifdef INC_OLE2
+#include <ole2.h>
+#endif /* INC_OLE2 */
+
+#ifndef _MAC
+#ifndef NOSERVICE
+#include <winsvc.h>
+#endif
+
+#if(WINVER >= 0x0400)
+#ifndef NOMCX          
+#include <mcx.h>      
+#endif /* NOMCX */      
+                   
+#ifndef NOIME           
+#include <imm.h>        
+#endif
+#endif /* WINVER >= 0x0400 */
+#endif
+
+#ifndef RC_INVOKED
+#if     ( _MSC_VER >= 800 )
+#pragma warning(default:4001)
+#pragma warning(default:4201)
+#pragma warning(default:4214)
+/* Leave 4514 disabled.  It's a stupid warning anyway. */
+#endif
+#endif /* RC_INVOKED */
+
+#endif /* RC_INVOKED */
+
+#endif /* _INC_WINDOWS */
+#endif /* _WINDOWS_ */
+
diff --git a/source_code/version2.2_windows/filesave.f90 b/source_code/version2.2_windows/filesave.f90
new file mode 100644
index 0000000000000000000000000000000000000000..12bc78df3e9b4f42f4bfc0ef3e7c04f30c639834
--- /dev/null
+++ b/source_code/version2.2_windows/filesave.f90
@@ -0,0 +1,88 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                   - windows shell -                           *!
+!*                                                               *!
+!*  contains:                                                    *!
+!*   FileSave                                                    *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+
+Subroutine FileSave (file_spec, filter_spec)
+
+! Following example of calling the Win32 API routine GetOpenFileName
+
+use comdlg32
+!use dflib  ! In case QuickWin is used
+implicit none
+
+! Declare structure used to pass and receive attributes
+!
+type(T_OPENFILENAME) ofn
+
+! Declare filter specification.  This is a concatenation of
+! pairs of null-terminated strings.  The first string in each pair
+! is the file type name, the second is a semicolon-separated list
+! of file types for the given name.  The list ends with a trailing
+! null-terminated empty string.
+!
+character*(*) :: filter_spec 
+! Declare string variable to return the file specification.
+! Initialize with an initial filespec, if any - null string
+! otherwise
+!
+!character*512 :: file_spec = ""C
+character*512 :: file_spec
+integer status,ilen
+ofn%lStructSize = SIZEOF(ofn)
+ofn%hwndOwner = NULL  ! For non-console applications,
+                      ! set this to the Hwnd of the
+                      ! Owner window.  For QuickWin
+                      ! and Standard Graphics projects,
+                      ! use GETHWNDQQ(QWIN$FRAMEWINDOW)
+                      !
+ofn%hInstance = NULL  ! For Win32 applications, you
+                      ! can set this to the appropriate
+                      ! hInstance
+                      !
+ofn%lpstrFilter = loc(filter_spec)
+ofn%lpstrCustomFilter = NULL
+ofn%nMaxCustFilter = 0
+ofn%nFilterIndex = 1 ! Specifies initial filter value
+ofn%lpstrFile = loc(file_spec)
+ofn%nMaxFile = sizeof(file_spec)
+ofn%nMaxFileTitle = 0
+ofn%lpstrInitialDir = NULL  ! Use Windows default directory
+ofn%lpstrTitle = loc(""C)
+ofn%Flags = OFN_PATHMUSTEXIST
+ofn%lpstrDefExt = loc("txt"C)
+ofn%lpfnHook = NULL
+ofn%lpTemplateName = NULL
+
+! Call GetOpenFileName and check status
+! 
+status = GetSaveFileName(ofn)
+if (status .eq. 0) then
+  type *,'No file name specified'
+else
+  ! Get length of file_spec by looking for trailing NUL
+  ilen = INDEX(file_spec,CHAR(0))
+
+end if
+
+end Subroutine FileSave
+
+
+
+
diff --git a/source_code/version2.2_windows/getopenfilename.f90 b/source_code/version2.2_windows/getopenfilename.f90
new file mode 100644
index 0000000000000000000000000000000000000000..0dbacf701bf0cf1c57d379fb30cf4eace828f2f0
--- /dev/null
+++ b/source_code/version2.2_windows/getopenfilename.f90
@@ -0,0 +1,92 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                   - windows shell -                           *!
+!*                                                               *!
+!*  contains:                                                    *!
+!*   FileOpen                                                    *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+
+Subroutine FileOpen (file_spec, filter_spec)
+
+! Following example of calling the Win32 API routine GetOpenFileName
+
+use comdlg32
+!use dflib  ! In case QuickWin is used
+implicit none
+
+! Declare structure used to pass and receive attributes
+!
+type(T_OPENFILENAME) ofn
+
+! Declare filter specification.  This is a concatenation of
+! pairs of null-terminated strings.  The first string in each pair
+! is the file type name, the second is a semicolon-separated list
+! of file types for the given name.  The list ends with a trailing
+! null-terminated empty string.
+!
+character*(*) :: filter_spec 
+
+! Declare string variable to return the file specification.
+! Initialize with an initial filespec, if any - null string
+! otherwise
+
+character*512 :: file_spec
+integer status,ilen
+ofn%lStructSize = SIZEOF(ofn)
+ofn%hwndOwner = NULL  ! For non-console applications,
+                      ! set this to the Hwnd of the
+                      ! Owner window.  For QuickWin
+                      ! and Standard Graphics projects,
+                      ! use GETHWNDQQ(QWIN$FRAMEWINDOW)
+                      !
+ofn%hInstance = NULL  ! For Win32 applications, you
+                      ! can set this to the appropriate
+                      ! hInstance
+                      !
+ofn%lpstrFilter = loc(filter_spec)
+ofn%lpstrCustomFilter = NULL
+ofn%nMaxCustFilter = 0
+ofn%nFilterIndex = 1 ! Specifies initial filter value
+ofn%lpstrFile = loc(file_spec)
+ofn%nMaxFile = sizeof(file_spec)
+ofn%nMaxFileTitle = 0
+ofn%lpstrInitialDir = NULL  ! Use Windows default directory
+ofn%lpstrTitle = loc(""C)
+ofn%Flags = OFN_PATHMUSTEXIST
+ofn%lpstrDefExt = loc("txt"C)
+ofn%lpfnHook = NULL
+ofn%lpTemplateName = NULL
+
+! Call GetOpenFileName and check status
+do
+    status = GetOpenFileName(ofn)
+    if (status .eq. 0) then
+      write(*,'(A)',advance='no') '  No file name specified' 
+      write(*,'(A)',advance='no') '  Program aborted' 
+      PAUSE
+      STOP
+
+    else
+      ! Get length of file_spec by looking for trailing NUL
+      ilen = INDEX(file_spec,CHAR(0))
+    
+       exit
+    end if
+enddo
+
+end Subroutine fileopen
+
diff --git a/source_code/version2.2_windows/main_4c_cons_win.f90 b/source_code/version2.2_windows/main_4c_cons_win.f90
new file mode 100644
index 0000000000000000000000000000000000000000..93a0324bcde67a35e0f88621af000173ae1fd688
--- /dev/null
+++ b/source_code/version2.2_windows/main_4c_cons_win.f90
@@ -0,0 +1,38 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                   - windows shell -                           *!
+!*                                                               *!
+!*  contains:                                                    *!
+!*     main program for 4C                                       *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+    
+    PROGRAM foresee
+
+    USE data_simul
+	
+	real time1, time2
+
+	call CPU_time (time1)
+    call Act_Dir(actDir)
+
+	CALL topmenu_win
+    call CPU_time (time2)
+    
+    print *, ' 4C total run time ', time2-time1, ' sec'
+
+	END PROGRAM foresee
+
diff --git a/source_code/version2.2_windows/pik400x.bmp b/source_code/version2.2_windows/pik400x.bmp
new file mode 100644
index 0000000000000000000000000000000000000000..6fbda0e5c2dba5a4b4af05d4305bc533b78e88c5
Binary files /dev/null and b/source_code/version2.2_windows/pik400x.bmp differ
diff --git a/source_code/version2.2_windows/script1.aps b/source_code/version2.2_windows/script1.aps
new file mode 100644
index 0000000000000000000000000000000000000000..54a0e549789bec1779a608def6716878dc144fb7
Binary files /dev/null and b/source_code/version2.2_windows/script1.aps differ
diff --git a/source_code/version2.2_windows/script1.rc b/source_code/version2.2_windows/script1.rc
new file mode 100644
index 0000000000000000000000000000000000000000..dc33e36ea1f3c40437c808a1379ec653d826108f
--- /dev/null
+++ b/source_code/version2.2_windows/script1.rc
@@ -0,0 +1,481 @@
+// Generated by ResEdit 1.5.9
+// Copyright (C) 2006-2011
+// http://www.resedit.net
+
+#include <windows.h>
+#include <commctrl.h>
+#include <richedit.h>
+#include "4C_dialogs.h"
+
+
+
+
+//
+// Bitmap resources
+//
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDB_BITMAP1        BITMAP         "4c_logo_klein.bmp"
+
+
+
+//
+// Dialog resources
+//
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_coh_daily DIALOG 100, 0, 540, 213
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_DAILYCOH_BUTTON_OK, 380, 190, 50, 14
+    PUSHBUTTON      "Cancel", ID_CANCEL_OUTF, 439, 190, 50, 14
+    GROUPBOX        "", IDC_STATIC_year, 10, 10, 510, 170
+    AUTOCHECKBOX    "", IDC_CHECK_y1, 26, 30, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y2, 26, 45, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y3, 26, 60, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y4, 26, 75, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y5, 25, 90, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y6, 26, 105, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y7, 26, 120, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y8, 26, 135, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y9, 26, 150, 271, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y10, 26, 165, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y11, 295, 30, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y12, 295, 45, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y13, 295, 60, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y14, 295, 75, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y15, 295, 90, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y16, 295, 105, 217, 8
+    LTEXT           "  Choose daily cohort output files  ", IDC_STATIC_yfile, 25, 10, 107, 8, SS_LEFT
+    AUTOCHECKBOX    "", IDC_CHECK_y17, 295, 120, 217, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y18, 295, 135, 217, 8
+    PUSHBUTTON      "Select all", ID_DAILYCOH_BUTTON_SELECT, 321, 190, 50, 14
+    PUSHBUTTON      "Deselect all", ID_DAILYCOH_BUTTON_DESELECT, 262, 190, 50, 14
+    AUTOCHECKBOX    "", IDC_CHECK_y19, 295, 150, 217, 8
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_coh_yearly DIALOG 0, 0, 718, 318
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_YEARLYCOH_BUTTON_OK, 559, 290, 50, 14
+    PUSHBUTTON      "Cancel", ID_CANCEL_OUTF, 625, 290, 50, 14
+    GROUPBOX        "", IDC_STATIC_year, 15, 10, 683, 275
+    AUTOCHECKBOX    "", IDC_CHECK_y1, 21, 30, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y2, 20, 45, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y3, 21, 60, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y4, 21, 75, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y5, 21, 90, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y6, 21, 105, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y7, 21, 120, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y8, 21, 135, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y9, 21, 150, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y10, 21, 165, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y11, 21, 180, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y12, 21, 195, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y13, 21, 210, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y14, 21, 225, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y15, 21, 240, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y16, 21, 255, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y17, 21, 270, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y18, 244, 30, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y19, 244, 45, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y20, 244, 60, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y21, 244, 75, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y22, 244, 90, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y23, 244, 105, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y24, 244, 120, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y25, 244, 135, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y26, 244, 150, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y27, 244, 165, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y28, 244, 180, 222, 8
+    LTEXT           "  Choose yearly cohort output files  ", IDC_STATIC_yfile, 30, 10, 111, 8, SS_LEFT
+    AUTOCHECKBOX    "", IDC_CHECK_y29, 244, 195, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y30, 244, 210, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y31, 244, 225, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y32, 244, 240, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y33, 244, 255, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y34, 244, 270, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y35, 465, 30, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y36, 465, 45, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y37, 465, 60, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y38, 465, 75, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y39, 465, 90, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y40, 465, 105, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y41, 465, 120, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y42, 465, 135, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y43, 465, 150, 222, 8
+    PUSHBUTTON      "Select all", ID_YEARLYCOH_BUTTON_SELECT, 493, 290, 50, 14
+    PUSHBUTTON      "Deselect all", ID_YEARLYCOH_BUTTON_DESELECT, 427, 290, 50, 14
+    AUTOCHECKBOX    "", IDC_CHECK_y44, 465, 165, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y45, 465, 178, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y46, 465, 193, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y47, 465, 210, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y48, 465, 225, 222, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y49, 465, 240, 222, 13
+    AUTOCHECKBOX    "", IDC_CHECK_y50, 465, 255, 222, 13
+    AUTOCHECKBOX    "", IDC_CHECK_y51, 465, 270, 222, 13
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_ctr DIALOG 100, 0, 280, 349
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_CTR_BUTTON_OK, 147, 319, 50, 14
+    PUSHBUTTON      "Cancel", IDCANCEL, 207, 319, 50, 14
+    LTEXT           "Edit simulation control file", IDC_STATIC_simul, 15, 14, 91, 11, SS_LEFT
+    GROUPBOX        "Run option control", IDC_STATIC_runo, 15, 30, 241, 173
+    LTEXT           "Run option", IDC_STATIC_runv, 23, 47, 36, 8, SS_LEFT
+    LTEXT           "Number of runs", IDC_STATIC_runnr, 23, 68, 49, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_runv, 69, 47, 175, 98, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    EDITTEXT        IDC_EDIT_runnr, 162, 67, 40, 12, ES_AUTOHSCROLL
+    LTEXT           "Number of simulation years", IDC_STATIC_yearn, 23, 89, 85, 8, SS_LEFT
+    LTEXT           "Start year", IDC_STATIC_start, 23, 111, 31, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_yearn, 162, 89, 40, 14, ES_AUTOHSCROLL
+    EDITTEXT        IDC_EDIT_start, 162, 111, 40, 14, ES_AUTOHSCROLL
+    LTEXT           "Patch size [m²]", IDC_STATIC_patch, 23, 134, 47, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_patch, 162, 134, 40, 14, ES_AUTOHSCROLL
+    LTEXT           "Thickness of foliage layers [cm]", IDC_STATIC_thickf, 23, 158, 100, 8, SS_LEFT
+    LTEXT           "Time step photosynthesis calculations [d]", IDC_STATIC_timeph, 23, 184, 130, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_thickf, 162, 157, 40, 14, ES_AUTOHSCROLL
+    EDITTEXT        IDC_EDIT_timeph, 162, 180, 40, 14, ES_AUTOHSCROLL
+    GROUPBOX        "Run flags control", IDC_STATIC_runo3, 15, 214, 240, 93
+    COMBOBOX        IDC_COMBO_runv3, 65, 235, 101, 98, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "Run number", IDC_STATIC_runv3, 23, 238, 40, 8, SS_LEFT
+    DEFPUSHBUTTON   "Set Flags", ID_CTR_BUTTON_FLAGS, 177, 281, 65, 14
+    DEFPUSHBUTTON   "Set Files", ID_CTR_BUTTON_FILES, 177, 258, 65, 14
+    DEFPUSHBUTTON   "Apply", ID_CTR_BUTTON_RUNNR, 213, 66, 30, 14
+    DEFPUSHBUTTON   "Change Output Id", ID_CTR_BUTTON_IDS, 178, 235, 64, 14
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_daily DIALOG 0, 0, 568, 221
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_DAILY_BUTTON_OK, 408, 195, 50, 14
+    PUSHBUTTON      "Cancel", ID_CANCEL_OUTF, 471, 195, 50, 14
+    GROUPBOX        "", IDC_STATIC_day, 11, 14, 534, 171
+    AUTOCHECKBOX    "", IDC_CHECK_y1, 37, 30, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y2, 37, 45, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y3, 37, 60, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y4, 37, 75, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y5, 37, 90, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y6, 37, 105, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y7, 37, 120, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y8, 37, 135, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y9, 37, 150, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y10, 37, 165, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y11, 284, 30, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y12, 284, 45, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y13, 284, 60, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y14, 284, 75, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y15, 284, 90, 240, 8
+    LTEXT           "  Choose daily output files  ", IDC_STATIC_yfile, 22, 15, 85, 8, SS_LEFT
+    AUTOCHECKBOX    "", IDC_CHECK_y16, 284, 105, 240, 8
+    PUSHBUTTON      "Select all", ID_DAILY_BUTTON_SELECT, 345, 195, 50, 14
+    PUSHBUTTON      "Deselect all", ID_DAILY_BUTTON_DESELECT, 282, 195, 50, 14
+    AUTOCHECKBOX    "", IDC_CHECK_y17, 284, 120, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y18, 284, 135, 240, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y19, 284, 150, 240, 8
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_default_dir DIALOG 10, 100, 320, 99
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_DEFAULT_DIR_BUTTON_OK, 138, 79, 50, 14
+    LTEXT           "Default input and output directories", IDC_STATIC_4C, 15, 4, 216, 9, SS_LEFT
+    LTEXT           "Input directory", IDC_STATIC_dirin, 16, 31, 51, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_DIR_IN, 81, 27, 210, 12, ES_AUTOHSCROLL | ES_MULTILINE
+    LTEXT           "Output directory", IDC_STATIC_dirout, 16, 56, 51, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_DIR_OUT, 81, 52, 210, 12, ES_AUTOHSCROLL | ES_MULTILINE
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_files DIALOG 100, 0, 310, 330
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_FILES_BUTTON_OK, 189, 307, 50, 14
+    PUSHBUTTON      "Cancel", ID_CANCEL_FILES, 251, 307, 50, 14
+    GROUPBOX        "Model input files", IDC_STATIC_files, 7, 10, 295, 209
+    LTEXT           "Species parameter file", IDC_STATIC_specpar, 16, 51, 70, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_specpar, 109, 53, 146, 12, ES_AUTOHSCROLL | ES_MULTILINE
+    PUSHBUTTON      "Browse", IDC_BUTTON_specpar, 259, 54, 35, 12, WS_GROUP
+    LTEXT           "Soil parameter file", IDC_STATIC_sop, 16, 69, 56, 8, SS_LEFT
+    LTEXT           "Soil initialisation file", IDC_STATIC_soi, 16, 87, 60, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_sop, 109, 70, 146, 12, ES_AUTOHSCROLL
+    EDITTEXT        IDC_EDIT_soi, 109, 87, 146, 12, ES_AUTOHSCROLL
+    LTEXT           "Stand initialisation file", IDC_STATIC_ini, 13, 238, 68, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_ini, 107, 235, 145, 14, ES_AUTOHSCROLL
+    GROUPBOX        "", IDC_STATIC_ini1, 7, 222, 295, 73
+    LTEXT           "Stand identifier", IDC_STATIC_standid, 15, 256, 48, 8, SS_LEFT
+    PUSHBUTTON      "Browse", IDC_BUTTON_ini, 259, 235, 35, 12, WS_GROUP
+    LTEXT           "Management file", IDC_STATIC_man, 16, 107, 53, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_man, 109, 104, 146, 12, ES_AUTOHSCROLL
+    LTEXT           "Deposition data file", IDC_STATIC_dep, 16, 123, 61, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_dep, 109, 121, 146, 12, ES_AUTOHSCROLL
+    LTEXT           " N-reduction ( RedN) file", IDC_STATIC_red, 16, 141, 77, 8, SS_LEFT
+    LTEXT           "Litter intilisation file", IDC_STATIC_lit, 16, 158, 59, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_red, 109, 139, 146, 12, ES_AUTOHSCROLL
+    EDITTEXT        IDC_EDIT_lit, 109, 155, 146, 12, ES_AUTOHSCROLL
+    PUSHBUTTON      "Browse", IDC_BUTTON_sop, 259, 71, 35, 12, WS_GROUP
+    PUSHBUTTON      "Browse", IDC_BUTTON_soi, 259, 88, 35, 12, WS_GROUP
+    PUSHBUTTON      "Browse", IDC_BUTTON_man, 259, 105, 35, 12, WS_GROUP
+    PUSHBUTTON      "Browse", IDC_BUTTON_dep, 259, 123, 35, 12, WS_GROUP
+    PUSHBUTTON      "Browse", IDC_BUTTON_red, 259, 139, 35, 12, WS_GROUP
+    PUSHBUTTON      "Browse", IDC_BUTTON_lit, 259, 156, 35, 12, WS_GROUP
+    LTEXT           "Climate data file", IDC_STATIC_cli, 17, 32, 70, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_cli, 110, 34, 146, 12, ES_AUTOHSCROLL | ES_MULTILINE
+    PUSHBUTTON      "Browse", IDC_BUTTON_cli, 260, 35, 35, 12, WS_GROUP
+    COMBOBOX        IDC_COMBO_standid, 106, 254, 85, 77, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "WPM spinup intilisation file", IDC_STATIC_spinup, 15, 177, 84, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_wpm, 109, 174, 146, 12, ES_AUTOHSCROLL
+    PUSHBUTTON      "Browse", IDC_BUTTON_wpm, 259, 175, 35, 12, WS_GROUP
+    EDITTEXT        IDC_EDIT_standid, 106, 273, 76, 14, ES_AUTOHSCROLL
+    LTEXT           "Measurement file", IDC_STATIC_mes, 16, 194, 54, 8, SS_LEFT
+    EDITTEXT        IDC_EDIT_mes, 110, 191, 146, 12, ES_AUTOHSCROLL
+    PUSHBUTTON      "Browse", IDC_BUTTON_mes, 260, 191, 35, 12, WS_GROUP
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_flags DIALOGEX 100, 0, 580, 297
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+EXSTYLE WS_EX_TOOLWINDOW
+CAPTION "4C"
+FONT 8, "MS Sans Serif", 0, 0, 1
+{
+    DEFPUSHBUTTON   "OK", ID_FLAGS_BUTTON_OK, 443, 263, 50, 14
+    PUSHBUTTON      "Cancel", ID_CANCEL_FLAGS, 509, 262, 50, 14
+    LTEXT           "Mortality flag (flag_mort) ", IDC_STATIC_mort, 18, 33, 77, 8, SS_LEFT
+    LTEXT           "Regeneration flag (flag_reg) ", IDC_STATIC_reg, 18, 50, 90, 8, SS_LEFT
+    LTEXT           "Use FORSKA factors (flag_forska)", IDC_STATIC_forska, 18, 67, 113, 13, WS_TABSTOP | NOT WS_GROUP | SS_LEFT
+    LTEXT           "Stand initialization flag (flag_stand)", IDC_STATIC_stand, 18, 84, 109, 8, WS_TABSTOP | NOT WS_GROUP | SS_LEFT
+    LTEXT           "Soil vegetation flag (flag_sveg)", IDC_STATIC_sveg, 18, 101, 98, 8, SS_LEFT
+    LTEXT           "Management flag (flag_mg)", IDC_STATIC_mg, 18, 118, 86, 8, SS_LEFT
+    LTEXT           "Disturbance flag (flag_dis)", IDC_STATIC_dis, 18, 135, 82, 8, SS_LEFT
+    LTEXT           "Ligth algorithm number (flag_light)", IDC_STATIC_light, 18, 152, 106, 8, SS_LEFT
+    LTEXT           "Foliage-height relationship (flag_folhei)", IDC_STATIC_folhei, 18, 169, 120, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_mort, 143, 33, 133, 42, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_reg, 143, 50, 133, 116, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL
+    COMBOBOX        IDC_COMBO_forska, 143, 67, 133, 25, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "Volume function (flag_volfunc)", IDC_STATIC_volfunc, 18, 186, 96, 8, SS_LEFT
+    LTEXT           "Respiration flag (flag_resp)", IDC_STATIC_resp, 18, 203, 84, 8, SS_LEFT
+    LTEXT           "Limitation flag (flag_limi)", IDC_STATIC_limi, 18, 220, 74, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_stand, 143, 84, 133, 54, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_sveg, 143, 101, 133, 48, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_mg, 143, 118, 133, 78, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_dis, 143, 135, 133, 32, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_light, 143, 152, 133, 55, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_folhei, 143, 169, 133, 53, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_volfunc, 143, 186, 133, 63, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "Decomposition model (flag_decomp) ", IDC_STATIC_decomp, 308, 33, 117, 8, SS_LEFT
+    LTEXT           "Root activity function flag (flag_sign)", IDC_STATIC_sign, 308, 50, 115, 8, SS_LEFT
+    LTEXT           "Soil water uptake flag (flag_wred)", IDC_STATIC_wred, 308, 67, 106, 8, SS_LEFT
+    LTEXT           "Root distribution flag (flag_wurz)", IDC_STATIC_wurz, 308, 84, 101, 8, SS_LEFT
+    LTEXT           "Heat conductance flag (flag_cond)", IDC_STATIC_cond, 308, 101, 111, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_resp, 143, 203, 133, 64, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_limi, 143, 220, 133, 65, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_decomp, 431, 33, 133, 54, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_sign, 431, 50, 133, 67, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_wred, 431, 67, 133, 61, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_wurz, 431, 84, 133, 64, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_cond, 431, 101, 133, 78, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_int, 431, 118, 133, 75, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_eva, 431, 135, 133, 78, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "Interception flag (flag_int)", IDC_STATIC_int, 308, 118, 80, 8, SS_LEFT
+    LTEXT           "Evapotranspiration flag (flag_eva)", IDC_STATIC_eva, 308, 135, 106, 8, SS_LEFT
+    LTEXT           "Assortment flag (flag_sort)", IDC_STATIC_sort, 308, 169, 82, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_CO2, 431, 152, 133, 51, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_sort, 431, 169, 133, 48, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    GROUPBOX        "Model specification", IDC_STATIC_model, 0, 15, 564, 239
+    LTEXT           "wpm flag (flag_wpm)", IDC_STATIC_wpm, 307, 186, 65, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_wpm, 431, 186, 133, 64, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "Statistical analysis flag (flag_stat)", IDC_STATIC_stat, 307, 203, 104, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_stat, 431, 203, 133, 48, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    LTEXT           "CO2 flag (flag_CO2)", IDC_STATIC_CO2, 308, 152, 64, 8, SS_LEFT
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_ids DIALOG 100, 0, 130, 78
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_IDS_BUTTON_OK, 10, 55, 50, 14
+    GROUPBOX        "Output File Identifiers", IDC_STATIC_model, 6, 14, 111, 35
+    EDITTEXT        IDC_EDIT_ID, 14, 29, 95, 14, ES_AUTOHSCROLL
+    PUSHBUTTON      "Cancel", ID_CANCEL_IDS, 67, 55, 50, 14
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_main DIALOGEX 300, 50, 245, 268
+STYLE DS_3DLOOK | DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_VISIBLE | WS_POPUP | WS_SYSMENU
+EXSTYLE WS_EX_CLIENTEDGE | WS_EX_STATICEDGE
+CAPTION "4C"
+FONT 8, "MS Sans Serif", 0, 0, 1
+{
+    GROUPBOX        "", IDC_STATIC_year, 5, 6, 233, 258, 0, WS_EX_STATICEDGE
+    CTEXT           "Forest Growth Model 4C   PIK   2016", IDC_STATIC_4C, 25, 53, 82, 23, SS_CENTER
+    DEFPUSHBUTTON   "Start 4C", ID_START_4C, 103, 233, 56, 14
+    PUSHBUTTON      "Exit 4C", IDSTOP, 174, 233, 50, 14
+    GROUPBOX        "Simulation Control", IDC_STATIC_Control, 20, 126, 207, 68
+    AUTORADIOBUTTON "Start simulation", IDC_RADIO_start, 35, 148, 121, 10
+    AUTORADIOBUTTON "Edit control file", IDC_RADIO_edit, 35, 166, 62, 10
+    CONTROL         "", IDC_REBAR1, REBARCLASSNAME, WS_TABSTOP | 0x00000401, 4294967294, 4294967295, 249, 4, WS_EX_DLGMODALFRAME | WS_EX_ACCEPTFILES | WS_EX_STATICEDGE
+    CONTROL         IDB_BITMAP1, IDC_STATIC_pic, WC_STATIC, SS_BITMAP, 123, 14, 100, 104
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_out DIALOG 100, 0, 293, 212
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "Start simulation", ID_START, 89, 182, 56, 14
+    PUSHBUTTON      "Exit 4C", IDCANCEL, 226, 182, 50, 14
+    LTEXT           "Choice of output files", IDC_STATIC, 15, 18, 67, 8, SS_LEFT
+    PUSHBUTTON      "Yearly output", IDC_BUTTON_yearly, 207, 37, 50, 14
+    PUSHBUTTON      "Daily output", IDC_BUTTON_daily, 207, 60, 50, 14
+    PUSHBUTTON      "Cohorts yearly", IDC_BUTTON_coh_yearly, 207, 84, 50, 14
+    PUSHBUTTON      "Cohorts daily", IDC_BUTTON_coh_daily, 207, 108, 50, 14
+    GROUPBOX        "", IDC_STATIC_choice_out, 8, 7, 268, 164
+    LTEXT           "Summation output", IDC_STATIC_SUM, 19, 145, 58, 8, SS_LEFT
+    COMBOBOX        IDC_COMBO_sum, 88, 142, 165, 74, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_SORT
+    DEFPUSHBUTTON   "Back", ID_OUT_BUTTON_BACK, 161, 182, 50, 14
+    DEFPUSHBUTTON   "Save changes", ID_SAVE, 17, 182, 56, 14
+    COMBOBOX        IDC_COMBO_yearly, 14, 37, 181, 77, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_daily, 13, 60, 181, 77, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_coh_yearly, 13, 85, 181, 77, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+    COMBOBOX        IDC_COMBO_coh_daily, 13, 109, 181, 77, WS_TABSTOP | WS_VSCROLL | CBS_DROPDOWN | CBS_AUTOHSCROLL | CBS_SORT
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_4C_yearly DIALOG 100, 0, 606, 352
+STYLE DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_POPUP | WS_SYSMENU
+CAPTION "4C"
+FONT 8, "MS Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", ID_YEARLY_BUTTON_OK, 455, 327, 50, 14
+    PUSHBUTTON      "Cancel", ID_CANCEL_OUTF, 519, 327, 50, 14
+    GROUPBOX        "", IDC_STATIC_year, 7, 15, 573, 302
+    AUTOCHECKBOX    "", IDC_CHECK_y1, 21, 30, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y2, 21, 45, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y3, 21, 60, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y4, 21, 75, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y5, 21, 90, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y6, 21, 105, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y7, 21, 120, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y8, 21, 135, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y9, 21, 150, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y10, 21, 165, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y11, 21, 180, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y12, 21, 195, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y13, 21, 210, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y14, 21, 225, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y15, 21, 240, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y16, 21, 255, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y17, 21, 270, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y18, 21, 285, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y19, 21, 300, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y20, 294, 30, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y21, 294, 45, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y22, 294, 60, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y23, 294, 75, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y24, 294, 90, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y25, 294, 105, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y26, 294, 120, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y27, 294, 135, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y28, 294, 150, 270, 8
+    LTEXT           "  Choose yearly output files  ", IDC_STATIC_yfile, 21, 14, 89, 8, SS_LEFT
+    AUTOCHECKBOX    "", IDC_CHECK_y29, 294, 165, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y30, 294, 180, 270, 8
+    PUSHBUTTON      "Select all", ID_YEARLY_BUTTON_SELECT, 391, 327, 50, 14
+    PUSHBUTTON      "Deselect all", ID_YEARLY_BUTTON_DESELECT, 327, 327, 50, 14
+    AUTOCHECKBOX    "", IDC_CHECK_y31, 294, 195, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y32, 294, 210, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y33, 294, 225, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y34, 294, 240, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y35, 294, 255, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y36, 294, 270, 270, 8
+    AUTOCHECKBOX    "", IDC_CHECK_y37, 294, 285, 270, 8
+}
+
+
+
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+IDD_DIALOG1 DIALOG 0, 0, 186, 95
+STYLE DS_3DLOOK | DS_CENTER | DS_MODALFRAME | DS_SETFONT | WS_CAPTION | WS_VISIBLE | WS_POPUP | WS_SYSMENU
+CAPTION "Dialog"
+FONT 8, "Microsoft Sans Serif"
+{
+    DEFPUSHBUTTON   "OK", IDOK, 129, 7, 50, 14
+    PUSHBUTTON      "Cancel", IDCANCEL, 129, 24, 50, 14
+}
+
+
+
+//
+// Version Information resources
+//
+LANGUAGE LANG_GERMAN, SUBLANG_GERMAN
+VS_VERSION_INFO VERSIONINFO
+    FILEVERSION     1,0,0,0
+    PRODUCTVERSION  0,0,0,0
+    FILEOS          VOS_NT_WINDOWS32
+    FILETYPE        VFT_APP
+    FILESUBTYPE     VFT2_UNKNOWN
+    FILEFLAGSMASK   0x0000003F
+    FILEFLAGS       0x00000000
+{
+    BLOCK "StringFileInfo"
+    {
+        BLOCK "080904B0"
+        {
+            VALUE "Comments", "\0"
+            VALUE "CompanyName", "Potsdam-Institut für Klimafolgenforschung\0"
+            VALUE "FileDescription", "FORESEE - Forest Ecosystems in a changing Environment\0"
+            VALUE "FileVersion", "0.99e\0"
+            VALUE "InternalName", "4C\0"
+            VALUE "LegalCopyright", "Copyright © 2004\0"
+            VALUE "LegalTrademarks", "\0"
+            VALUE "OriginalFilename", "4C.exe\0"
+            VALUE "PrivateBuild", "\0"
+            VALUE "ProductName", "4C - PIK\0"
+            VALUE "ProductVersion", "0.99e\0"
+            VALUE "SpecialBuild", "\0"
+        }
+    }
+    BLOCK "VarFileInfo"
+    {
+        VALUE "Translation", 0x0809, 0x04B0
+    }
+}
diff --git a/source_code/version2.2_windows/win_appl.f90 b/source_code/version2.2_windows/win_appl.f90
new file mode 100644
index 0000000000000000000000000000000000000000..8983052dc0a7206f20883435bf2e7f98ff3ae09e
--- /dev/null
+++ b/source_code/version2.2_windows/win_appl.f90
@@ -0,0 +1,153 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                                                               *!
+!*    - topmenu_win:   calls the dialog windows					 *!
+!*					   controls the application flow	         *!
+!*                                                               *!
+!*   - control functions: start  - ok button control			 *!
+!*						  cancel - exits the application, cancel *!
+!*								   button						 *!
+!*                        stepback - back button control		 *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!                 
+!*****************************************************************!
+
+SUBROUTINE topmenu_win 
+
+USE dflogm
+
+INCLUDE '4C_dialogs.fd'
+
+TYPE (DIALOG)  dlg_main
+integer(4) retint
+
+	call InitMain(dlg_main)
+
+end subroutine topmenu_win
+
+!***************************************************************
+!****** Control Functions **************************************
+!***************************************************************
+SUBROUTINE Start ( dlg, id, callbacktype )
+
+use dflogm
+use dflib
+
+use data_simul
+use data_stand
+use flag_field
+
+
+implicit none
+
+type (dialog) dlg, dlg_default_dir
+integer id
+integer callbacktype
+integer retint
+
+include '4C_dialogs.fd'
+
+logical retlog, push_state
+character :: text = 'Simulation control file: '
+character :: text_mes = 'Measurement file: '
+integer id_ctr
+!Settings for FileOpen
+character*(*),parameter :: filter_spec = &
+						  "Simulation control files (*.sim)"C//"*.sim"C// &
+						"All Files (*)"C//"*"C//""C
+character(512) filename
+
+logical retdir
+	
+	! get the radio button before the dlg was closed
+	retlog = DlgGet( dlg, IDC_RADIO_start, push_state ) 
+	if (push_state) id_ctr = IDC_RADIO_start
+	
+	retlog = DlgGet( dlg, IDC_RADIO_edit, push_state ) 
+	if (push_state) id_ctr = IDC_RADIO_edit
+
+		! get the control file
+		call GetFileF (filename, filter_spec, text)
+        retdir = changedirqq (actdir)
+		simfile = filename
+		call readsim
+		call winPath
+		call outtest
+		print *, '----------------------------------'
+		print *, '---- Start simulation... ---------'	
+	    ! simulation
+		call sim_control
+        call deallofile
+		
+	if ( allocated(flagsave)) deallocate(flagsave)
+
+    print *, '4C end'
+ 
+END SUBROUTINE Start
+
+!*******************************************
+
+SUBROUTINE Cancel ( dlg, id, callbacktype )
+
+use dflogm
+
+use data_simul
+use data_stand
+
+implicit none
+type (dialog) dlg
+integer id
+integer callbacktype
+integer retint
+
+
+include '4C_dialogs.fd'
+
+logical retlog, push_state
+
+    ! supress compiler warnings for unreferenced arguments
+	integer local_id, local_callbacktype
+	local_id = id
+	local_callbacktype = callbacktype
+
+	select case(id)
+
+	case (ID_CANCEL_FLAGS) 
+		call DlgSetReturn(dlg, ID_CANCEL_FLAGS)
+		call DlgExit(dlg)
+
+	case (ID_CANCEL_FILES)
+		call DlgSetReturn(dlg, ID_CANCEL_FILES)
+		call DlgExit(dlg)
+
+	case (ID_CANCEL_IDS)
+		call DlgSetReturn(dlg, ID_CANCEL_IDS)
+		call DlgExit(dlg)
+
+	case (ID_CANCEL_OUTF)	
+		call DLGSetReturn(dlg ,ID_CANCEL_OUTF)
+		call DlgExit(dlg)
+
+	case (IDCANCEL)	
+		call DLGSetReturn(dlg ,IDCANCEL)
+		call DlgExit(dlg)
+	
+	case (IDSTOP)
+		print *, ''
+		print *, '---------------------------------------------'
+		stop ' -------Program terminated by the user.------'
+
+	end select
+
+END SUBROUTINE Cancel
diff --git a/source_code/version2.2_windows/win_appl_dlg_init.f90 b/source_code/version2.2_windows/win_appl_dlg_init.f90
new file mode 100644
index 0000000000000000000000000000000000000000..cde86bc1ee305b160b4b5eee037c13156a6988fc
--- /dev/null
+++ b/source_code/version2.2_windows/win_appl_dlg_init.f90
@@ -0,0 +1,54 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                   - windows shell -                           *!
+!*                                                               *!
+!*  contains:                                                    *!
+!*   InitMain                                                    *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+
+SUBROUTINE InitMain(dlgParent)
+
+use dflogm
+use data_simul
+
+type (dialog) dlg
+type (dialog) dlgParent
+type (dialog) local_dlg
+
+external Start, Cancel
+
+include '4C_dialogs.fd'
+
+logical retlog
+character(150) dir
+integer nflag
+character(90), dimension(5) :: charflag
+character(20) text, helpsim
+
+	local_dlg = dlgParent
+
+	if ( .not. DlgInit( idd_4C_main, dlg ) ) then
+		write (*,*) "error: resource not found"
+	else
+
+	 	! set functionality of the OK and CANCEL button
+		retlog = DlgSetSub( dlg, IDSTOP, Cancel )
+		retlog = DlgSetSub( dlg, ID_START_4C, Start )
+	endif 	
+	
+	retint = DlgModal(dlg)
+
+END SUBROUTINE InitMain
diff --git a/source_code/version2.2_windows/win_appl_flags_field.f90 b/source_code/version2.2_windows/win_appl_flags_field.f90
new file mode 100644
index 0000000000000000000000000000000000000000..a93d03c395c8e524f21751f915c441db859fe7bf
--- /dev/null
+++ b/source_code/version2.2_windows/win_appl_flags_field.f90
@@ -0,0 +1,69 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                                                               *!
+!*    - data_general_dlg: module to store the general dlg info	 *!
+!*    - flag_field :      module to store the flags				 *!
+!*    - flags_comments:   module to store the flags commens		 *!
+!*                                                               *!                                 
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!      
+!*****************************************************************!
+
+module data_general_dlg
+	
+	! which way was chosen
+	integer :: id_ctr	
+
+end module
+
+!***********************************************************************
+
+! data module containig the flags changes for the win_appl
+module flag_field
+
+	integer,allocatable,save,dimension(:,:)	::	flagsave
+	character(50), dimension(22) :: flagnames	
+	integer act_run
+
+    end ! module flags_field
+
+!**********************
+    
+!contains all flag comments for the combo-boxes
+module flags_comments
+	character(60), dimension(30) :: flag_mort_com
+	character(60), dimension(30) :: flag_reg_com
+	character(60), dimension(30) :: flag_forska_com
+	character(60), dimension(30) :: flag_stand_com
+	character(60), dimension(30) :: flag_sveg_com
+	character(60), dimension(30) :: flag_mg_com
+	character(60), dimension(30) :: flag_dis_com
+	character(60), dimension(30) :: flag_light_com
+	character(60), dimension(30) :: flag_folhei_com
+	character(60), dimension(30) :: flag_volfunc_com
+	character(60), dimension(30) :: flag_resp_com
+	character(60), dimension(30) :: flag_limi_com
+	character(60), dimension(30) :: flag_decomp_com
+	character(60), dimension(30) :: flag_sign_com
+	character(60), dimension(30) :: flag_wred_com
+	character(60), dimension(30) :: flag_wurz_com
+	character(60), dimension(30) :: flag_cond_com
+	character(60), dimension(30) :: flag_int_com
+	character(60), dimension(30) :: flag_eva_com
+	character(100), dimension(30) :: flag_CO2_com
+	character(60), dimension(30) :: flag_sort_com
+	character(60), dimension(30) :: flag_wpm_com
+	character(60), dimension(30) :: flag_stat_com
+end
+
diff --git a/source_code/version2.2_windows/win_appl_help_functions.f90 b/source_code/version2.2_windows/win_appl_help_functions.f90
new file mode 100644
index 0000000000000000000000000000000000000000..cf748fa2f601e183524439786e3f7d225291ac61
--- /dev/null
+++ b/source_code/version2.2_windows/win_appl_help_functions.f90
@@ -0,0 +1,92 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                   - windows shell -                           *!
+!*                                                               *!
+!*  contains:                                                    *!
+!*   GetFile                                                     *!
+!*   GetFileF                                                    *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+
+SUBROUTINE GetFile ( filename, filter_spec, text )
+
+use dflogm
+
+implicit none
+integer id
+logical ex
+character(512):: filename 
+character(*)  :: text
+
+!Settings for FileOpen
+character*512 :: file_get 
+character*(*) :: filter_spec 
+
+include '4C_dialogs.fd'
+
+logical retlog
+
+         call FileOpen (filename, filter_spec)
+         inquire (File = filename, exist = ex)
+         if(ex .eqv. .true.) then
+            write(*,'(A,A)') ' Simulation control file: ', trim(filename)
+         else
+			filename = ' '
+         endif
+
+END SUBROUTINE GetFile
+
+!***************************************************************
+
+! needed for time_out in Open Existing File
+SUBROUTINE GetFileF ( filename, filter_spec, text )
+
+use dflogm
+
+implicit none
+
+integer id
+logical ex
+character(150) :: filename 
+character(*) :: text
+
+!Settings for FileOpen
+character*512 :: file_get 
+character*(*) :: filter_spec 
+
+include '4C_dialogs.fd'
+
+logical retlog
+!logical retdir
+
+        call FileOpen (file_get, filter_spec)
+        do       
+         filename = file_get
+        ex = .true.
+        if(ex .eqv. .true.) then
+            write(*,'(A,A)') ' Simulation control file: ', trim(filename)
+            exit
+         else
+            write(*,'(A)') ' Simulation control file: ', trim(filename), ' not exists'
+            write(*,'(A)',advance='no') ' Try again' 
+            PAUSE
+            call FileOpen (file_get, filter_spec)
+            cycle
+         endif
+        enddo 
+
+END SUBROUTINE GetFileF
+
+!***************************************************************
diff --git a/source_code/version2.2_windows/win_appl_path.f90 b/source_code/version2.2_windows/win_appl_path.f90
new file mode 100644
index 0000000000000000000000000000000000000000..0fa1319c02596479f577877264b4410708ac180c
--- /dev/null
+++ b/source_code/version2.2_windows/win_appl_path.f90
@@ -0,0 +1,150 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*                   - windows shell -                           *!
+!*                                                               *!
+!*  contains:                                                    *!
+!*   Act_Dir                                                     *!
+!*   winPath                                                     *!
+!*   dealofile                                                   *!
+!*   fullPath                                                    *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+    
+SUBROUTINE Act_Dir (dir)
+
+!  Program to demonstrate GETDRIVEDIRQQ
+use IFPORT
+!USE DFLIB ! In case QuickWin is used
+CHARACTER(150) dir
+INTEGER(4) length
+
+!  Get current directory
+dir = FILE$CURDRIVE
+
+length = GETDRIVEDIRQQ(dir)
+
+IF (length .GT. 0) THEN
+  WRITE (*,*) 'Current directory is: '
+  WRITE (*,*) dir
+ELSE
+  WRITE (*,*) 'Failed to get current directory'
+END IF
+
+END SUBROUTINE Act_Dir
+
+!**********************************************************
+
+subroutine winPath()
+
+use data_mess
+use data_simul
+
+implicit none
+
+integer ind, i
+
+	! set full path for the files	
+	ind = index(actDir, '\', .TRUE.)
+	! go to ..
+	if ( 'input' == trim(actDir(ind+1:ind+5)) ) then
+		dirout = trim(actDir(1:ind))//'output\'
+	! stay in the directory
+	else
+		dirout = trim(actdir)//'\output\' 
+	endif
+
+	do i = 1,site_nr 
+        call fullPath( sitefile(i) , actDir)
+        call fullPath( treefile(i) , actDir)
+	end do
+
+    if (.not.flag_mult910) then
+	    do i = 1,site_nr 
+		    call fullPath( specfile(i) , actDir)
+		    call fullPath( climfile(i) , actDir)
+            call fullPath( valfile(i)  , actDir)
+            call fullPath( manfile(i)  , actDir)
+            call fullPath( depofile(i) , actDir)
+            call fullPath( redfile(i)  , actDir)
+            call fullPath( litfile(i)  , actDir)
+		    
+		    ! till the wpm files is set
+		    wpmfile(i) = 'dummy.wpm'
+		    call fullPath( wpmfile(i)  , actDir)	
+	    end do
+    else
+		call fullPath( specfile(1) , actDir)
+        call fullPath( manfile(1)  , actDir)
+        call fullPath( depofile(1) , actDir)
+        call fullPath( redfile(1)  , actDir)
+        call fullPath( litfile(1)  , actDir)
+
+    endif
+
+    if (allocated(mesfile)) call fullPath( mesfile(1)  , actDir)	
+
+end subroutine winPath
+    
+!**************************************************************
+
+SUBROUTINE deallofile
+
+use data_simul
+
+implicit none
+
+    if ( allocated(site_name) ) deallocate(site_name)
+
+    if ( allocated(climfile) ) deallocate(climfile)
+
+    if ( allocated(sitefile) ) deallocate(sitefile)
+
+    if ( allocated(valfile) ) deallocate(valfile)
+
+    if ( allocated(treefile) ) deallocate(treefile)
+	if ( allocated(wpmfile) ) deallocate(wpmfile)
+    if ( allocated(standid) ) deallocate(standid)
+    if ( allocated(manfile) ) deallocate(manfile)
+    if ( allocated(depofile) ) deallocate(depofile)
+    if ( allocated(redfile) ) deallocate(redfile)
+    if ( allocated(litfile) ) deallocate(litfile)
+	if ( allocated(specfile) ) deallocate(specfile)
+	
+	site_nr = 1
+
+end subroutine deallofile
+
+!**************************************************************
+
+! changes "input\..." filename into absolute path filename
+subroutine fullPath(filename, dir)
+	
+character(150) dir, filename
+integer ind
+
+	if ('input' == filename(1:5)) then
+
+		! Problem: input/input
+		ind = index(dir, '\', .TRUE.)
+		if ( 'input' == trim(dir(ind+1:ind+5)) ) then
+			ind = index(filename, '/', .TRUE.)
+			filename = trim(dir)//trim(filename(ind:))
+		else
+			filename = trim(dir)//'\'//trim(filename)
+		end if
+	end if
+
+end subroutine fullPath
+
diff --git a/source_code/version2.2_windows/win_openfile.f90 b/source_code/version2.2_windows/win_openfile.f90
new file mode 100644
index 0000000000000000000000000000000000000000..8be9bfd3221a91c49665c06be64186057a3312e8
--- /dev/null
+++ b/source_code/version2.2_windows/win_openfile.f90
@@ -0,0 +1,175 @@
+! ********************************************************************
+! *                                                                  *
+! *  Copyright 2000 Compaq Computer Corporation                      *
+! *                                                                  *
+! *  COMPAQ Registered in U.S. Patent and Trademark Office.          *
+! *                                                                  *
+! *  Confidential computer software. Valid license from Compaq or    *
+! *  authorized sublicensor required for possession, use or copying. *
+! *  Consistent with FAR 12.211 and 12.212, Commercial Computer      *
+! *  Software, Computer Software Documentation, and Technical Data   *
+! *  for Commercial Items are licensed to the U.S. Government under  *
+! *  vendor's standard commercial license.                           *
+! *                                                                  *
+! ********************************************************************
+!
+!DEC$ IF .NOT. DEFINED (COMDLG32_ )
+!DEC$ DEFINE COMDLG32_  
+!
+!
+!
+!************This version of comdlg32 contains new items****************** 
+! Whether new interfaces for routines in COMDLG32.LIB extracted from
+! VC++6 header files are included is controlled by a statement with the
+! following format towards the end of this file.
+! 
+!IF .NOT. DEFINED(__DO_NOT_INCLUDE_VC6_ITEMS)
+!
+!Unless the inclusion is explicitly turned off by defining the
+!above symbol, the items will be included. 
+!
+module comdlg32
+use dfwinty
+!DEC$OBJCOMMENT LIB:"COMDLG32.LIB"
+!
+!                       *****COMMDLG******
+interface !lib=comdlg32.lib
+logical(4) function  GetOpenFileName (dummy ) 
+!DEC$ ATTRIBUTES DEFAULT :: GetOpenFileName
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_GetOpenFileNameA@4' :: GetOpenFileName
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'GetOpenFileNameA'   :: GetOpenFileName
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_OPENFILENAME)  dummy
+end function GetOpenFileName
+end interface
+interface !lib=comdlg32.lib
+logical(4) function  GetSaveFileName (dummy ) 
+!DEC$ ATTRIBUTES DEFAULT :: GetSaveFileName
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_GetSaveFileNameA@4' :: GetSaveFileName
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'GetSaveFileNameA'   :: GetSaveFileName
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_OPENFILENAME)    dummy
+end function GetSaveFileName
+end interface
+interface !lib=comdlg32.lib
+integer*2 function  GetFileTitle (dummya ,dummyb ,dummyc ) 
+!DEC$ ATTRIBUTES DEFAULT :: GetFileTitle
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_GetFileTitleA@12' :: GetFileTitle
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'GetFileTitleA'    :: GetFileTitle
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummya
+!DEC$ ATTRIBUTES REFERENCE :: dummyb
+character*(*)   dummya
+character*(*)   dummyb
+integer*2       dummyc
+end function GetFileTitle
+end interface
+interface !lib=comdlg32.lib
+logical(4) function  ChooseColor (dummy ) 
+!DEC$ ATTRIBUTES DEFAULT :: ChooseColor
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_ChooseColorA@4' :: ChooseColor
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'ChooseColorA'   :: ChooseColor
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_CHOOSECOLOR) dummy
+end function ChooseColor
+end interface
+interface !lib=comdlg32.lib
+integer*4 function  FindText (dummy ) 
+!DEC$ ATTRIBUTES DEFAULT :: FindText
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_FindTextA@4' :: FindText
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'FindTextA'   :: FindText
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_FINDREPLACE) dummy
+end function FindText
+end interface
+interface !lib=comdlg32.lib
+integer*4 function  ReplaceText (dummy ) 
+!DEC$ ATTRIBUTES DEFAULT :: ReplaceText
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_ReplaceTextA@4' :: ReplaceText
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'ReplaceTextA'   :: ReplaceText
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_FINDREPLACE) dummy
+end function ReplaceText
+end interface
+interface !lib=comdlg32.lib
+logical(4) function  ChooseFont (dummy ) 
+!DEC$ ATTRIBUTES DEFAULT :: ChooseFont
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_ChooseFontA@4' :: ChooseFont
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'ChooseFontA'   :: ChooseFont
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_CHOOSEFONT) dummy
+end function ChooseFont
+end interface
+interface !lib=comdlg32.lib
+logical(4) function  PrintDlg (dummy) 
+!DEC$ ATTRIBUTES DEFAULT :: PrintDlg
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_PrintDlgA@4' :: PrintDlg
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'PrintDlgA'   :: PrintDlg
+!DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: dummy
+use dfwinty
+type(T_PRINTDLG)    dummy
+end function PrintDlg
+end interface
+interface !lib=comdlg32.lib
+integer*4 function  CommDlgExtendedError () 
+!DEC$ ATTRIBUTES DEFAULT :: CommDlgExtendedError
+!DEC$ IF DEFINED(_X86_)
+!DEC$ ATTRIBUTES STDCALL, ALIAS:'_CommDlgExtendedError@0' :: CommDlgExtendedError
+!DEC$ ELSE
+!DEC$ ATTRIBUTES STDCALL, ALIAS: 'CommDlgExtendedError'   :: CommDlgExtendedError
+!DEC$ ENDIF
+end function CommDlgExtendedError
+end interface
+!
+!DEC$ IF .NOT. DEFINED(__DO_NOT_INCLUDE_VC6_ITEMS)
+!
+INTERFACE 
+FUNCTION PageSetupDlg( &
+        arg1)
+USE DFWINTY
+  integer(BOOL) :: PageSetupDlg ! BOOL
+    !DEC$ ATTRIBUTES DEFAULT :: PageSetupDlg
+    !DEC$IF DEFINED(_X86_)
+    !DEC$ ATTRIBUTES STDCALL, ALIAS:'_PageSetupDlgA@4' :: PageSetupDlg
+    !DEC$ ELSE
+    !DEC$ ATTRIBUTES STDCALL, ALIAS:'PageSetupDlgA' :: PageSetupDlg
+    !DEC$ ENDIF
+!DEC$ ATTRIBUTES REFERENCE :: arg1
+  TYPE (T_PAGESETUPDLGA) arg1 ! LPPAGESETUPDLGA arg1
+ END FUNCTION
+END INTERFACE
+!
+!DEC$ ENDIF ! /* __DO_NOT_INCLUDE_VC6_ITEMS */
+!
+end module comdlg32
+!
+!DEC$ ENDIF ! /* COMDLG32_ */
diff --git a/source_code/version2.2_windows/win_prepini.f b/source_code/version2.2_windows/win_prepini.f
new file mode 100644
index 0000000000000000000000000000000000000000..9df31593665bbba600b32a43a4d1248f693e53d3
--- /dev/null
+++ b/source_code/version2.2_windows/win_prepini.f
@@ -0,0 +1,107 @@
+SUBROUTINE win_prepini
+
+!*
+!*  Implementation and Revisions:
+!*  -----------------------------
+!*
+! 15.08.11 Su Zwischendruck bei treeini raus
+! 24.02.11 Su stand_id als Character
+! 01.02.05 ag win_prepini: help_ip set to actual run number
+! 28.01.05 Su  
+
+
+! check stand_id from multi-stand-intialisaton file (...tree.ini)
+! lmulti = 0  ==> single initialisation file
+
+  USE data_simul
+  USE data_site
+  USE data_stand
+  USE data_species
+  use flag_field
+
+  IMPLICIT NONE
+
+  CHARACTER      :: a
+  CHARACTER(30)  :: filename, text
+  CHARACTER(50)  :: test_stand_id
+  INTEGER        :: ios,treeunit
+  LOGICAL        :: exs, lstin
+  INTEGER        :: help_ip, test_vf, i
+  REAL           :: test_patchsize, xx
+
+  IF(site_nr==1) THEN
+      help_ip=site_nr
+  ELSE
+      help_ip=act_run
+  END IF
+
+! when initialization stand flag == 1
+IF(flag_stand>0) then
+    exs = .false.
+    stand_id = standid(help_ip)
+    ! reading stand information from treefile
+    inquire (File = treefile(help_ip), exist = exs)
+    IF(exs .eqv. .false.) write(*,*) '  Stand initialization file not exists!'
+
+    ! read values from treefile
+    IF (exs.eqv. .true.)  then
+       treeunit=getunit()
+       OPEN(treeunit,file=treefile(help_ip),action='read', pad='YES')
+       READ(treeunit,'(I1,F12.0)',iostat=ios) test_vf, test_patchsize
+
+       IF(test_patchsize .GT. 0.) THEN
+         lmulti = .FALSE.
+         IF(test_patchsize.NE.kpatchsize) THEN
+           CALL error_mess(time,"patch size in sim-file and the one used for initialisation do not match",kpatchsize)
+           CALL error_mess(time,"value in ini-file",test_patchsize)
+           CALL error_mess(time,"value in sim-file",kpatchsize)
+             kpatchsize = test_patchsize
+         ENDIF
+       ELSE
+           lmulti = .TRUE.
+      ! count number of stand_id
+           anz_standid = 0
+           do
+             READ(treeunit,'(A)',iostat=ios) a
+             IF (a .ne. '!') exit
+           end do
+           
+           do  
+               read(treeunit,*,iostat=ios) xx
+               IF (ios .lt. 0) exit
+               anz_standid = anz_standid + 1
+                  do while (xx .gt. -90.0)
+                     read (treeunit,*) xx
+!                     print *,xx
+                  enddo  ! xx
+           enddo
+           if (allocated(standid_list)) deallocate(standid_list)
+           allocate (standid_list(anz_standid))
+           rewind treeunit
+
+      ! read stand_id
+           read (treeunit,*) xx
+           do
+             READ(treeunit,'(A)',iostat=ios) a
+             IF (a .ne. '!') exit
+           end do
+           backspace treeunit
+
+           lstandid = .FALSE.
+           do  i = 1, anz_standid 
+               read(treeunit,*) test_stand_id, test_patchsize, text
+               standid_list(i) = test_stand_id
+               if (test_stand_id .eq. stand_id) lstandid = .TRUE.
+
+               read (treeunit,*) xx
+                  do while (xx .gt. -90.0)
+                     read (treeunit,*) xx
+                  enddo  ! xx
+           enddo
+
+       END IF   ! test_patchsize  --  lmulti
+       CLOSE(treeunit)
+    END IF   ! exs
+END IF
+
+END SUBROUTINE win_prepini
diff --git a/source_code/version2.2_windows/writesim.f90 b/source_code/version2.2_windows/writesim.f90
new file mode 100644
index 0000000000000000000000000000000000000000..00b118edf40f024b506b92f590f2ce28e58d1a4c
--- /dev/null
+++ b/source_code/version2.2_windows/writesim.f90
@@ -0,0 +1,372 @@
+!*****************************************************************!
+!*                                                               *!
+!*              4C (FORESEE) Simulation Model                    *!
+!*                                                               *!
+!*                                                               *!
+!*                    Subroutines for:                           *!
+!*    - WRITESIM:   Write simulation options into file           *!
+!*                                                               *!
+!*                  Copyright (C) 1996-2018                      *!
+!*     Potsdam Institute for Climate Impact Reserach (PIK)       *!
+!*          Authors and contributors see AUTHOR file             *!
+!*  This file is part of 4C and is licensed under BSD-2-Clause   *!
+!*                   See LICENSE file or under:                  *!
+!*     http://www.https://opensource.org/licenses/BSD-2-Clause   *!
+!*                           Contact:                            *!
+!*       https://gitlab.pik-potsdam.de/XXXXXXXXXXXXXXXXXXXXX     *!
+!*                                                               *!
+!*****************************************************************!
+
+SUBROUTINE writesim(simfile_new)
+
+! read simulation options from file
+
+use data_climate
+use data_mess
+use data_out
+use data_simul
+use data_stand
+use data_site
+use data_tsort
+
+implicit none
+
+logical ex
+integer i, ios, ios1, nowunit, nowunit1, k, anzclim, j
+real help
+character a
+character (150) tspec, tname, tval, tsite, tman, ttree, tdepo, tred, tlit,  &
+                    pathdir1, pathdir2,pathdir3, pathdir4, pathdir5, climszen, siteall, climall,site_name_all
+character(3), dimension(100) :: clim_nam
+character(150), dimension(:), allocatable:: site_name_ad
+character(150), dimension(:), allocatable:: climfile_ad
+character(150), dimension(:), allocatable:: manfile_ad
+character(150), dimension(:), allocatable:: treefile_ad
+character(150), dimension(:), allocatable:: depofile_ad
+character(150), dimension(:), allocatable:: wpmfile_ad
+character(10), dimension(1000)   :: climnum
+character(50)  istand
+character(150)  simfile_new
+
+    nowunit = getunit()
+    ios = 0
+    
+!!! set Filename 
+
+    write (*, *) ' Input name of simfile'
+    write (*, *) simfile_new 
+
+    open(nowunit,file=simfile_new,iostat=ios, status='replace')
+
+    write(nowunit,'(I6,A)',iostat=ios) flag_multi	, '  ! Run option'
+    write(nowunit,'(I6,A)',iostat=ios) site_nr		, '  ! number of runs'
+    write(nowunit,'(A)',iostat=ios) '! *** simulation specifications  **************************************'
+    write(nowunit,'(I6,A)',iostat=ios) year			, '  ! number of simulation years'
+    write(nowunit,'(I6,A)',iostat=ios) time_b		, '   ! start year for simulation'
+    write(nowunit,'(F7.0,A)',iostat=ios) kpatchsize	, '  ! patch size [m²]'
+    write(nowunit,'(F7.1,A)',iostat=ios) dz			, '  ! thickness of foliage layers [cm]'
+    write(nowunit,'(I6,A)',iostat=ios) ns_pro		, '  ! time step photosynthesis calculations [d]'
+    write(nowunit,'(A)',iostat=ios) '! *** choice of model options *****************************************'
+    write(nowunit,'(I6,A)',iostat=ios) flag_mort	, '  ! mortality flag (flag_mort)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_reg		, '  ! regeneration flag (flag_reg)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_forska	, '  ! use FORSKA environmental factors and regeneration (flag_forska)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_stand	, '  ! initialization flag (flag_stand)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_sveg	, '  ! soil vegetation flag (flag_sveg)    !!! new !!!'
+    write(nowunit,'(I6,A)',iostat=ios) flag_mg		, '  ! management flag (flag_mg)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_dis		, '  ! disturbance flag (flag_dis)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_light	, '  ! ligth algorithm number (flag_light)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_folhei	, '  ! foliage-height relationship (flag_folhei)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_volfunc	, '  ! volume function (flag_volfunc)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_resp	, '  ! respiration flag (flag_resp)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_limi	, '  ! limitation flag (flag_limi)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_decomp	, '  ! decomposition model (flag_decomp)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_sign	, '  ! root activity function flag (flag_sign)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_wred	, '  ! soil water uptake flag (flag_wred)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_wurz	, '  ! root distribution flag (flag_wurz)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_cond	, '  ! heat conductance flag (flag_cond)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_int		, '  ! interception flag (flag_int)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_eva		, '  ! evapotranspiration flag (flag_eva)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_co2		, '  ! CO2 flag (flag_CO2)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_sort	, '  ! sort flag (flag_sort)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_wpm		, '  ! wpm flag (flag_wpm)'
+    write(nowunit,'(I6,A)',iostat=ios) flag_stat	, '  ! comparison with measurements (flag_stat)'
+    write(nowunit,'(A)',iostat=ios) '! *** output specifications *******************************************'
+    write(nowunit,'(I6,A)',iostat=ios) time_out
+!     write name of yearly output variables
+    do i = 1, outy_n
+       if (outy(i)%out_flag .gt. 0) write(nowunit,'(A)',iostat=ios) outy(i)%kind_name
+    enddo
+    write(nowunit,'(A)',iostat=ios)  'end'
+
+    write(nowunit,'(I6,A)',iostat=ios) flag_dayout
+!     write name of daily output variables
+    do i = 1, outd_n
+       if (outd(i)%out_flag .gt. 0) write(nowunit,'(A)',iostat=ios) outd(i)%kind_name
+    enddo
+    write(nowunit,'(A)',iostat=ios)  'end'
+
+    if(flag_cohoutd .gt. 0 .or. flag_cohouty .gt. 0) then 
+       flag_cohout = 1
+    else
+       flag_cohout = 0
+    endif
+    write(nowunit,'(I6,A)',iostat=ios) flag_cohout
+!     define name of cohort output variables
+    ncvar = ncvar + ncdvar
+    do i = 1, outcy_n
+       if (outcy(i)%out_flag .gt. 0) write(nowunit,'(A)',iostat=ios) outcy(i)%kind_name
+    enddo
+    do i = 1, outcd_n
+       if (outcd(i)%out_flag .gt. 0) write(nowunit,'(A)',iostat=ios) outcd(i)%kind_name
+    enddo
+    write(nowunit,'(A)',iostat=ios)  'end'
+
+    write(nowunit,'(I6,A)',iostat=ios) flag_sum
+
+    write(nowunit,'(A)',iostat=ios) '! *** input files *****************************************************'
+
+ SELECT CASE(flag_multi)
+ CASE (0,1,2,3,6)
+      jpar = 1
+      DO i=1,site_nr
+        if(i .gt. 1) then
+        write(nowunit,'(A,I2,A)',iostat=ios) '! ******************* run ',i,' *******************************************'
+
+          do while (vpar(jpar) .gt. -99.0)
+             write(nowunit,'(F7.1, A)') vpar(jpar), '  '//simpar(jpar)
+             jpar = jpar + 1
+          enddo
+          help = -99.0
+          write(nowunit,'(F7.1, A)') help, '  end'
+        endif
+
+        write(nowunit,'(A)',iostat=ios) specfile(i)
+        write(nowunit,'(A)') site_name(i)
+        write(nowunit,'(A)') climfile(i)
+        write(nowunit,'(A)') sitefile(i)
+        write(nowunit,'(A)') valfile(i)
+        write(nowunit,'(A)') treefile(i)
+        write(nowunit,*) standid(i)
+        write(nowunit,'(A)') manfile(i)
+        write(nowunit,'(A)') depofile(i)
+        write(nowunit,'(A)') redfile(i)
+        write(nowunit,'(A)') litfile(i)
+        if(i .eq. 1 .and. flag_stat .gt. 0) write(nowunit,'(A)') mesfile(1)
+
+        print *, ' >>>foresee message: site_nr ',i,'; input of filenames completed'
+
+      end DO
+
+      if(flag_multi .ne. 2) call errorfile(simfile, ios, nowunit)
+
+ CASE (4,5)
+      write(nowunit,'(A)',iostat=ios) specfile(1)
+      write(nowunit,'(A)') site_name(1)
+      write(nowunit,'(A)') treefile(1)
+      write(nowunit,'(A)') manfile(1)
+      write(nowunit,'(A)') siteall
+      write(nowunit,'(A)') climall
+      write(nowunit,'(A)') pathdir1
+      write(nowunit,'(A)') pathdir2
+      write(nowunit,'(A)') climszen
+
+      print *, ' >>>foresee message: Input of filenames completed'
+
+!  define name of output variables
+      nvar = 1
+      write(nowunit,*) outvar(nvar)
+      do while (trim(outvar(nvar)) .ne. 'end')
+         nvar = nvar + 1
+         write(nowunit,*) outvar(nvar)
+      enddo
+
+      if (nvar .gt. 1) allocate(output_var(nvar-1,site_nr,year))
+
+      call errorfile(simfile, ios, nowunit)
+
+!  writeing file with desription of climate stations used
+      nowunit1 = getunit()
+      ios1 = 0
+      open(nowunit1,file=climall,iostat=ios,status='old',action='write')
+      k=1
+      do
+         write(nowunit1,'(A)',iostat=ios1) a
+         IF (a .ne. '!') exit
+
+      end do
+      backspace nowunit1
+
+      do
+
+          if(ios1 .lt. 0) exit
+          k = k+1
+      end do
+      anzclim = k-1
+      ios1 = 0
+
+      call errorfile(climall, ios1, nowunit1)
+
+! reading control file with site-id, climate-id, soil-id, gwtabe-id
+
+      nowunit1 = getunit()
+
+      open(nowunit1,file=siteall,iostat=ios1,status='old',action='read')
+      do
+         write(nowunit1,'(A)',iostat=ios1) a
+         IF (a .ne. '!') exit
+
+      end do
+      backspace nowunit1
+
+      do i=1,site_nr
+         write(nowunit1,*,iostat=ios1) sitenum(i), clim_id(i), soilid(i), gwtable(i)
+!          Fuellen der sitefile
+         standid(i) = sitenum(i)
+         site_name(i) = site_name(1)
+         specfile(i) = specfile(1)
+         treefile(i) = treefile(1)
+         manfile(i)  = manfile(1)
+         do j = 1,anzclim
+           if(clim_id(i).eq.climnum(j)) then
+                if(flag_climtyp.ne.0) then
+                   climfile(i) =trim(pathdir1)//trim(clim_nam(j))//trim(climszen)//'.dat'
+                else
+                   climfile(i) =trim(pathdir1)//trim(clim_nam(j))//trim(climszen)//'.cli'
+                end if
+                exit
+           end if
+         end do
+         sitefile(i) =trim(pathdir2)//'wbuek'//trim(soilid(i))//'.sop'
+         valfile(i)  =trim(pathdir2)//'wbuek'//trim(soilid(i))//'.soi'
+         depofile(i) ='dummy.dep'
+         redfile = 'dummy.red'
+         litfile = 'dummy.lit'
+      enddo
+
+       call errorfile(siteall, ios1, nowunit1)
+
+!  variation of flag_multi= 5, especially for SILVISTRAT
+
+ CASE (7)
+
+      allocate(site_name_ad(site_nr))
+      allocate(climfile_ad(site_nr))
+      allocate(manfile_ad(site_nr))
+      allocate(treefile_ad(site_nr))
+	  allocate(wpmfile_ad(site_nr))
+      allocate(depofile_ad(site_nr))
+
+      allocate(fl_co2(site_nr))
+
+      write(nowunit,'(A)',iostat=ios) specfile(1)
+      write(nowunit,'(A)') site_name_all
+      write(nowunit,'(A)') sitefile(1)
+      write(nowunit,'(A)') valfile(1)
+      write(nowunit,'(A)') siteall
+      write(nowunit,'(A)') pathdir1
+      write(nowunit,'(A)') pathdir2
+      write(nowunit,'(A)') pathdir3
+      write(nowunit,'(A)') depofile(1)
+      write(nowunit,'(A)') redfile(1)
+      write(nowunit,'(A)') litfile(1)
+
+      call errorfile(simfile, ios, nowunit)
+
+! reading control file with site-id,name, climate scenario, man-file, treeini-file, dep-file
+
+      nowunit1 = getunit()
+
+      open(nowunit1,file=siteall,iostat=ios1,status='old',action='read')
+      do
+         READ(nowunit1,'(A)',iostat=ios1) a
+         IF (a .ne. '!') exit
+
+      end do
+      backspace nowunit1
+
+      do i=1,site_nr
+         read(nowunit1,*,iostat=ios1) sitenum(i),site_name_ad(i), climfile_ad(i),manfile_ad(i), treefile_ad(i),depofile_ad(i),fl_co2(i)
+!          Fuellen der sitefile
+         standid(i) = sitenum(i)
+         climfile(i)= trim(pathdir1)//climfile_ad(i)
+         site_name(i) = trim(site_name_all)//trim(site_name_ad(i))
+         specfile(i) = specfile(1)
+         sitefile(i) = sitefile(1)
+         valfile(i) = valfile(1)
+         treefile(i) =trim(pathdir2)//trim(treefile_ad(i))
+         manfile(i)  =trim(pathdir3)//trim(manfile_ad(i))
+         depofile(i)  =depofile(1)
+         redfile(i)  = redfile(1)
+         litfile(i)  = litfile(1)
+
+      enddo
+       flag_co2=fl_co2(1)
+       call errorfile(siteall, ios1, nowunit1)
+
+       deallocate(site_name_ad)
+       deallocate(climfile_ad)
+       deallocate(manfile_ad)
+       deallocate(treefile_ad)
+       deallocate(depofile_ad)
+
+ END SELECT
+
+
+    jpar = 0  ! reset jpar for restore
+
+    if(flag_multi .eq. 2)then
+              read (nowunit,*) step_sum_T,n_T_downsteps,n_T_upsteps
+              read (nowunit,*) step_fac_P,n_P_downsteps,n_P_upsteps
+
+              site_nr = (1+n_T_downsteps+n_T_upsteps) * (1+n_P_downsteps+n_P_upsteps)
+		      repeat_number = site_nr
+
+              tspec = specfile(1)
+              tname = site_name(1)
+              tsite = sitefile(1)
+              tval  = valfile(1)
+              ttree = treefile(1)
+              tman  = manfile(1)
+              tdepo = depofile(1)
+              tred  = redfile(1)
+              tlit  = litfile(1)
+              istand = standid(1)
+
+              deallocate (specfile)
+              deallocate (site_name)
+              deallocate (sitefile)
+              deallocate (valfile)
+              deallocate (treefile)
+              deallocate (manfile)
+              deallocate (depofile)
+              deallocate (redfile)
+              deallocate (litfile)
+              deallocate (standid)
+              allocate (specfile(site_nr))
+              allocate (site_name(site_nr))
+              allocate (sitefile(site_nr))
+              allocate (valfile(site_nr))
+              allocate (treefile(site_nr))
+              allocate (manfile(site_nr))
+              allocate (depofile(site_nr))
+              allocate (standid(site_nr))
+              allocate (redfile(site_nr))
+              allocate (litfile(site_nr))
+
+              specfile  = tspec
+              site_name = tname
+              sitefile  = tsite
+              valfile   = tval
+              treefile  = ttree
+              manfile   = tman
+              depofile  = tdepo
+              redfile   = tred
+              litfile   = tlit
+              standid   = istand
+
+       call errorfile(simfile, ios, nowunit)
+
+    endif   ! flag_multi = 2
+
+END subroutine writesim
+
diff --git a/test data sets/4C testing/flag_limi/.gitkeep b/test_data_sets/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_limi/.gitkeep
rename to test_data_sets/.gitkeep
diff --git a/test data sets/4C testing/flag_multi_2/.gitkeep b/test_data_sets/4C testing/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_multi_2/.gitkeep
rename to test_data_sets/4C testing/.gitkeep
diff --git a/test data sets/4C testing/flag_multi_6/.gitkeep b/test_data_sets/4C testing/flag_limi/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_multi_6/.gitkeep
rename to test_data_sets/4C testing/flag_limi/.gitkeep
diff --git a/test data sets/4C testing/flag_limi/Standortsammlung2.sod b/test_data_sets/4C testing/flag_limi/Standortsammlung2.sod
similarity index 100%
rename from test data sets/4C testing/flag_limi/Standortsammlung2.sod
rename to test_data_sets/4C testing/flag_limi/Standortsammlung2.sod
diff --git a/test data sets/4C testing/flag_limi/site10.cli b/test_data_sets/4C testing/flag_limi/site10.cli
similarity index 100%
rename from test data sets/4C testing/flag_limi/site10.cli
rename to test_data_sets/4C testing/flag_limi/site10.cli
diff --git a/test data sets/4C testing/flag_limi/site10.dep b/test_data_sets/4C testing/flag_limi/site10.dep
similarity index 100%
rename from test data sets/4C testing/flag_limi/site10.dep
rename to test_data_sets/4C testing/flag_limi/site10.dep
diff --git a/test data sets/4C testing/flag_limi/site10.ini b/test_data_sets/4C testing/flag_limi/site10.ini
similarity index 100%
rename from test data sets/4C testing/flag_limi/site10.ini
rename to test_data_sets/4C testing/flag_limi/site10.ini
diff --git a/test data sets/4C testing/flag_limi/site10.man b/test_data_sets/4C testing/flag_limi/site10.man
similarity index 100%
rename from test data sets/4C testing/flag_limi/site10.man
rename to test_data_sets/4C testing/flag_limi/site10.man
diff --git a/test data sets/4C testing/flag_limi/test_flaglimi.sim b/test_data_sets/4C testing/flag_limi/test_flaglimi.sim
similarity index 100%
rename from test data sets/4C testing/flag_limi/test_flaglimi.sim
rename to test_data_sets/4C testing/flag_limi/test_flaglimi.sim
diff --git a/test data sets/4C testing/flag_multi_7/.gitkeep b/test_data_sets/4C testing/flag_multi_2/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/.gitkeep
rename to test_data_sets/4C testing/flag_multi_2/.gitkeep
diff --git a/test data sets/4C testing/flag_multi_2/Standortsammlung2.sod b/test_data_sets/4C testing/flag_multi_2/Standortsammlung2.sod
similarity index 100%
rename from test data sets/4C testing/flag_multi_2/Standortsammlung2.sod
rename to test_data_sets/4C testing/flag_multi_2/Standortsammlung2.sod
diff --git a/test data sets/4C testing/flag_multi_2/site10.cli b/test_data_sets/4C testing/flag_multi_2/site10.cli
similarity index 100%
rename from test data sets/4C testing/flag_multi_2/site10.cli
rename to test_data_sets/4C testing/flag_multi_2/site10.cli
diff --git a/test data sets/4C testing/flag_multi_2/site10.ini b/test_data_sets/4C testing/flag_multi_2/site10.ini
similarity index 100%
rename from test data sets/4C testing/flag_multi_2/site10.ini
rename to test_data_sets/4C testing/flag_multi_2/site10.ini
diff --git a/test data sets/4C testing/flag_multi_2/test_flagm2.sim b/test_data_sets/4C testing/flag_multi_2/test_flagm2.sim
similarity index 100%
rename from test data sets/4C testing/flag_multi_2/test_flagm2.sim
rename to test_data_sets/4C testing/flag_multi_2/test_flagm2.sim
diff --git a/test data sets/4C testing/flag_multi_8/.gitkeep b/test_data_sets/4C testing/flag_multi_6/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/.gitkeep
rename to test_data_sets/4C testing/flag_multi_6/.gitkeep
diff --git a/test data sets/4C testing/flag_multi_6/Standortsammlung2.sod b/test_data_sets/4C testing/flag_multi_6/Standortsammlung2.sod
similarity index 100%
rename from test data sets/4C testing/flag_multi_6/Standortsammlung2.sod
rename to test_data_sets/4C testing/flag_multi_6/Standortsammlung2.sod
diff --git a/test data sets/4C testing/flag_multi_6/site10.cli b/test_data_sets/4C testing/flag_multi_6/site10.cli
similarity index 100%
rename from test data sets/4C testing/flag_multi_6/site10.cli
rename to test_data_sets/4C testing/flag_multi_6/site10.cli
diff --git a/test data sets/4C testing/flag_multi_6/site10.ini b/test_data_sets/4C testing/flag_multi_6/site10.ini
similarity index 100%
rename from test data sets/4C testing/flag_multi_6/site10.ini
rename to test_data_sets/4C testing/flag_multi_6/site10.ini
diff --git a/test data sets/4C testing/flag_multi_6/test_flagm6.sim b/test_data_sets/4C testing/flag_multi_6/test_flagm6.sim
similarity index 100%
rename from test data sets/4C testing/flag_multi_6/test_flagm6.sim
rename to test_data_sets/4C testing/flag_multi_6/test_flagm6.sim
diff --git a/test data sets/4C testing/flag_statistics_annual/.gitkeep b/test_data_sets/4C testing/flag_multi_7/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/.gitkeep
rename to test_data_sets/4C testing/flag_multi_7/.gitkeep
diff --git a/test data sets/4C testing/flag_multi_7/site05.cli b/test_data_sets/4C testing/flag_multi_7/site05.cli
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/site05.cli
rename to test_data_sets/4C testing/flag_multi_7/site05.cli
diff --git a/test data sets/4C testing/flag_multi_7/site05.dep b/test_data_sets/4C testing/flag_multi_7/site05.dep
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/site05.dep
rename to test_data_sets/4C testing/flag_multi_7/site05.dep
diff --git a/test data sets/4C testing/flag_multi_7/site05.ini b/test_data_sets/4C testing/flag_multi_7/site05.ini
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/site05.ini
rename to test_data_sets/4C testing/flag_multi_7/site05.ini
diff --git a/test data sets/4C testing/flag_multi_7/site05.sod b/test_data_sets/4C testing/flag_multi_7/site05.sod
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/site05.sod
rename to test_data_sets/4C testing/flag_multi_7/site05.sod
diff --git a/test data sets/4C testing/flag_multi_7/test_flagm7.sim b/test_data_sets/4C testing/flag_multi_7/test_flagm7.sim
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/test_flagm7.sim
rename to test_data_sets/4C testing/flag_multi_7/test_flagm7.sim
diff --git a/test data sets/4C testing/flag_multi_7/test_multi7.con b/test_data_sets/4C testing/flag_multi_7/test_multi7.con
similarity index 100%
rename from test data sets/4C testing/flag_multi_7/test_multi7.con
rename to test_data_sets/4C testing/flag_multi_7/test_multi7.con
diff --git a/test data sets/4C testing/flag_statistics_daily/.gitkeep b/test_data_sets/4C testing/flag_multi_8/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/.gitkeep
rename to test_data_sets/4C testing/flag_multi_8/.gitkeep
diff --git a/test data sets/4C testing/flag_multi_8/100005basz.dat b/test_data_sets/4C testing/flag_multi_8/100005basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100005basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100005basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100009basz.dat b/test_data_sets/4C testing/flag_multi_8/100009basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100009basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100009basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100080basz.dat b/test_data_sets/4C testing/flag_multi_8/100080basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100080basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100080basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100096basz.dat b/test_data_sets/4C testing/flag_multi_8/100096basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100096basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100096basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100097basz.dat b/test_data_sets/4C testing/flag_multi_8/100097basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100097basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100097basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100098basz.dat b/test_data_sets/4C testing/flag_multi_8/100098basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100098basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100098basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100099basz.dat b/test_data_sets/4C testing/flag_multi_8/100099basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100099basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100099basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100100basz.dat b/test_data_sets/4C testing/flag_multi_8/100100basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100100basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100100basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100101basz.dat b/test_data_sets/4C testing/flag_multi_8/100101basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100101basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100101basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/100104basz.dat b/test_data_sets/4C testing/flag_multi_8/100104basz.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/100104basz.dat
rename to test_data_sets/4C testing/flag_multi_8/100104basz.dat
diff --git a/test data sets/4C testing/flag_multi_8/Standortsammlung2.sod b/test_data_sets/4C testing/flag_multi_8/Standortsammlung2.sod
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/Standortsammlung2.sod
rename to test_data_sets/4C testing/flag_multi_8/Standortsammlung2.sod
diff --git a/test data sets/4C testing/flag_multi_8/clim_motive_dim.dat b/test_data_sets/4C testing/flag_multi_8/clim_motive_dim.dat
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/clim_motive_dim.dat
rename to test_data_sets/4C testing/flag_multi_8/clim_motive_dim.dat
diff --git a/test data sets/4C testing/flag_multi_8/motive_d.ini b/test_data_sets/4C testing/flag_multi_8/motive_d.ini
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/motive_d.ini
rename to test_data_sets/4C testing/flag_multi_8/motive_d.ini
diff --git a/test data sets/4C testing/flag_multi_8/motive_dl2im.con b/test_data_sets/4C testing/flag_multi_8/motive_dl2im.con
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/motive_dl2im.con
rename to test_data_sets/4C testing/flag_multi_8/motive_dl2im.con
diff --git a/test data sets/4C testing/flag_multi_8/test_flagm8.sim b/test_data_sets/4C testing/flag_multi_8/test_flagm8.sim
similarity index 100%
rename from test data sets/4C testing/flag_multi_8/test_flagm8.sim
rename to test_data_sets/4C testing/flag_multi_8/test_flagm8.sim
diff --git a/test data sets/4C testing/flag_wpm_sea/.gitkeep b/test_data_sets/4C testing/flag_statistics_annual/.gitkeep
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/.gitkeep
rename to test_data_sets/4C testing/flag_statistics_annual/.gitkeep
diff --git a/test data sets/4C testing/flag_statistics_annual/site02.ini b/test_data_sets/4C testing/flag_statistics_annual/site02.ini
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/site02.ini
rename to test_data_sets/4C testing/flag_statistics_annual/site02.ini
diff --git a/test data sets/4C testing/flag_statistics_annual/site02.man b/test_data_sets/4C testing/flag_statistics_annual/site02.man
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/site02.man
rename to test_data_sets/4C testing/flag_statistics_annual/site02.man
diff --git a/test data sets/4C testing/flag_statistics_annual/site02.prn b/test_data_sets/4C testing/flag_statistics_annual/site02.prn
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/site02.prn
rename to test_data_sets/4C testing/flag_statistics_annual/site02.prn
diff --git a/test data sets/4C testing/flag_statistics_annual/site02.sod b/test_data_sets/4C testing/flag_statistics_annual/site02.sod
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/site02.sod
rename to test_data_sets/4C testing/flag_statistics_annual/site02.sod
diff --git a/test data sets/4C testing/flag_statistics_annual/szenario101.dat b/test_data_sets/4C testing/flag_statistics_annual/szenario101.dat
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/szenario101.dat
rename to test_data_sets/4C testing/flag_statistics_annual/szenario101.dat
diff --git a/test data sets/4C testing/flag_statistics_annual/test_stat_ann.sim b/test_data_sets/4C testing/flag_statistics_annual/test_stat_ann.sim
similarity index 100%
rename from test data sets/4C testing/flag_statistics_annual/test_stat_ann.sim
rename to test_data_sets/4C testing/flag_statistics_annual/test_stat_ann.sim
diff --git a/test data sets/4C testing/test initialisation/.gitkeep b/test_data_sets/4C testing/flag_statistics_daily/.gitkeep
similarity index 100%
rename from test data sets/4C testing/test initialisation/.gitkeep
rename to test_data_sets/4C testing/flag_statistics_daily/.gitkeep
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.cli b/test_data_sets/4C testing/flag_statistics_daily/site01.cli
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.cli
rename to test_data_sets/4C testing/flag_statistics_daily/site01.cli
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.dep b/test_data_sets/4C testing/flag_statistics_daily/site01.dep
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.dep
rename to test_data_sets/4C testing/flag_statistics_daily/site01.dep
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.ini b/test_data_sets/4C testing/flag_statistics_daily/site01.ini
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.ini
rename to test_data_sets/4C testing/flag_statistics_daily/site01.ini
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.man b/test_data_sets/4C testing/flag_statistics_daily/site01.man
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.man
rename to test_data_sets/4C testing/flag_statistics_daily/site01.man
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.mes b/test_data_sets/4C testing/flag_statistics_daily/site01.mes
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.mes
rename to test_data_sets/4C testing/flag_statistics_daily/site01.mes
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.red b/test_data_sets/4C testing/flag_statistics_daily/site01.red
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.red
rename to test_data_sets/4C testing/flag_statistics_daily/site01.red
diff --git a/test data sets/4C testing/flag_statistics_daily/site01.sod b/test_data_sets/4C testing/flag_statistics_daily/site01.sod
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/site01.sod
rename to test_data_sets/4C testing/flag_statistics_daily/site01.sod
diff --git a/test data sets/4C testing/flag_statistics_daily/test_stat_day.sim b/test_data_sets/4C testing/flag_statistics_daily/test_stat_day.sim
similarity index 100%
rename from test data sets/4C testing/flag_statistics_daily/test_stat_day.sim
rename to test_data_sets/4C testing/flag_statistics_daily/test_stat_day.sim
diff --git a/test data sets/4C testing/test short rotation coppice/.gitkeep b/test_data_sets/4C testing/flag_wpm_sea/.gitkeep
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/.gitkeep
rename to test_data_sets/4C testing/flag_wpm_sea/.gitkeep
diff --git a/test data sets/4C testing/flag_wpm_sea/Standortsammlung2.sod b/test_data_sets/4C testing/flag_wpm_sea/Standortsammlung2.sod
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/Standortsammlung2.sod
rename to test_data_sets/4C testing/flag_wpm_sea/Standortsammlung2.sod
diff --git a/test data sets/4C testing/flag_wpm_sea/sea_prices.wpm b/test_data_sets/4C testing/flag_wpm_sea/sea_prices.wpm
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/sea_prices.wpm
rename to test_data_sets/4C testing/flag_wpm_sea/sea_prices.wpm
diff --git a/test data sets/4C testing/flag_wpm_sea/site10.cli b/test_data_sets/4C testing/flag_wpm_sea/site10.cli
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/site10.cli
rename to test_data_sets/4C testing/flag_wpm_sea/site10.cli
diff --git a/test data sets/4C testing/flag_wpm_sea/site10.dep b/test_data_sets/4C testing/flag_wpm_sea/site10.dep
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/site10.dep
rename to test_data_sets/4C testing/flag_wpm_sea/site10.dep
diff --git a/test data sets/4C testing/flag_wpm_sea/site10.ini b/test_data_sets/4C testing/flag_wpm_sea/site10.ini
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/site10.ini
rename to test_data_sets/4C testing/flag_wpm_sea/site10.ini
diff --git a/test data sets/4C testing/flag_wpm_sea/site10.man b/test_data_sets/4C testing/flag_wpm_sea/site10.man
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/site10.man
rename to test_data_sets/4C testing/flag_wpm_sea/site10.man
diff --git a/test data sets/4C testing/flag_wpm_sea/test_wpm.sim b/test_data_sets/4C testing/flag_wpm_sea/test_wpm.sim
similarity index 100%
rename from test data sets/4C testing/flag_wpm_sea/test_wpm.sim
rename to test_data_sets/4C testing/flag_wpm_sea/test_wpm.sim
diff --git a/test data sets/4C testing/generreg.par b/test_data_sets/4C testing/generreg.par
similarity index 100%
rename from test data sets/4C testing/generreg.par
rename to test_data_sets/4C testing/generreg.par
diff --git a/test data sets/4C testing/species.par b/test_data_sets/4C testing/species.par
similarity index 100%
rename from test data sets/4C testing/species.par
rename to test_data_sets/4C testing/species.par
diff --git a/test data sets/4C testing/test initialisation/000101basz.dat b/test_data_sets/4C testing/test initialisation/.gitkeep
similarity index 100%
rename from test data sets/4C testing/test initialisation/000101basz.dat
rename to test_data_sets/4C testing/test initialisation/.gitkeep
diff --git a/test data sets/4C testing/test initialisation/pine_age62.prn b/test_data_sets/4C testing/test initialisation/000101basz.dat
similarity index 100%
rename from test data sets/4C testing/test initialisation/pine_age62.prn
rename to test_data_sets/4C testing/test initialisation/000101basz.dat
diff --git a/test data sets/4C testing/test initialisation/site02.sod b/test_data_sets/4C testing/test initialisation/pine_age62.prn
similarity index 100%
rename from test data sets/4C testing/test initialisation/site02.sod
rename to test_data_sets/4C testing/test initialisation/pine_age62.prn
diff --git a/test data sets/4C testing/test initialisation/test_ini.sim b/test_data_sets/4C testing/test initialisation/site02.sod
similarity index 100%
rename from test data sets/4C testing/test initialisation/test_ini.sim
rename to test_data_sets/4C testing/test initialisation/site02.sod
diff --git a/test data sets/4C testing/test short rotation coppice/11002basz.dat b/test_data_sets/4C testing/test initialisation/test_ini.sim
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/11002basz.dat
rename to test_data_sets/4C testing/test initialisation/test_ini.sim
diff --git a/test data sets/4C testing/test short rotation coppice/aspen5.man b/test_data_sets/4C testing/test short rotation coppice/.gitkeep
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/aspen5.man
rename to test_data_sets/4C testing/test short rotation coppice/.gitkeep
diff --git a/test data sets/4C testing/test short rotation coppice/clim_src.dat b/test_data_sets/4C testing/test short rotation coppice/11002basz.dat
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/clim_src.dat
rename to test_data_sets/4C testing/test short rotation coppice/11002basz.dat
diff --git a/test data sets/4C testing/test short rotation coppice/test_src.con b/test_data_sets/4C testing/test short rotation coppice/aspen5.man
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/test_src.con
rename to test_data_sets/4C testing/test short rotation coppice/aspen5.man
diff --git a/test data sets/4C testing/test short rotation coppice/test_src.sim b/test_data_sets/4C testing/test short rotation coppice/clim_src.dat
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/test_src.sim
rename to test_data_sets/4C testing/test short rotation coppice/clim_src.dat
diff --git a/test data sets/4C testing/test short rotation coppice/wald_buek_2011.sod b/test_data_sets/4C testing/test short rotation coppice/test_src.con
similarity index 100%
rename from test data sets/4C testing/test short rotation coppice/wald_buek_2011.sod
rename to test_data_sets/4C testing/test short rotation coppice/test_src.con
diff --git a/test data sets/4C testing/test_4C_manual.pdf b/test_data_sets/4C testing/test short rotation coppice/test_src.sim
similarity index 100%
rename from test data sets/4C testing/test_4C_manual.pdf
rename to test_data_sets/4C testing/test short rotation coppice/test_src.sim
diff --git a/test_data_sets/4C testing/test short rotation coppice/wald_buek_2011.sod b/test_data_sets/4C testing/test short rotation coppice/wald_buek_2011.sod
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/test_data_sets/4C testing/test_4C_manual.pdf b/test_data_sets/4C testing/test_4C_manual.pdf
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391