nsprpub/pr/src/md/os2/os2_errors.c

Thu, 22 Jan 2015 13:21:57 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 22 Jan 2015 13:21:57 +0100
branch
TOR_BUG_9701
changeset 15
b8a032363ba2
permissions
-rw-r--r--

Incorporate requested changes from Mozilla in review:
https://bugzilla.mozilla.org/show_bug.cgi?id=1123480#c6

michael@0 1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
michael@0 2 /* This Source Code Form is subject to the terms of the Mozilla Public
michael@0 3 * License, v. 2.0. If a copy of the MPL was not distributed with this
michael@0 4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
michael@0 5
michael@0 6 #include "prerror.h"
michael@0 7 #include "primpl.h"
michael@0 8
michael@0 9 void _MD_os2_map_default_error(PRInt32 err)
michael@0 10 {
michael@0 11 switch (err) {
michael@0 12 case EWOULDBLOCK:
michael@0 13 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 14 break;
michael@0 15 case EBADF:
michael@0 16 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 17 break;
michael@0 18 case ENOTSOCK:
michael@0 19 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 20 break;
michael@0 21 case EMSGSIZE:
michael@0 22 case EINVAL:
michael@0 23 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 24 break;
michael@0 25 case ENOBUFS:
michael@0 26 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 27 break;
michael@0 28 case ECONNREFUSED:
michael@0 29 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 30 break;
michael@0 31 case EISCONN:
michael@0 32 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 33 break;
michael@0 34 #ifdef SOCEFAULT
michael@0 35 case SOCEFAULT:
michael@0 36 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 37 break;
michael@0 38 #endif
michael@0 39 case ERROR_NETNAME_DELETED:
michael@0 40 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 41 break;
michael@0 42 default:
michael@0 43 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 44 break;
michael@0 45 }
michael@0 46 }
michael@0 47 void _MD_os2_map_opendir_error(PRInt32 err)
michael@0 48 {
michael@0 49 switch (err) {
michael@0 50 case ERROR_FILE_NOT_FOUND:
michael@0 51 case ERROR_PATH_NOT_FOUND:
michael@0 52 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 53 break;
michael@0 54 case ERROR_ACCESS_DENIED:
michael@0 55 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 56 break;
michael@0 57 case ERROR_INVALID_ADDRESS:
michael@0 58 case ERROR_INVALID_ACCESS:
michael@0 59 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 60 break;
michael@0 61 case ERROR_INVALID_NAME:
michael@0 62 case ERROR_INVALID_PARAMETER:
michael@0 63 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 64 break;
michael@0 65 case ERROR_TOO_MANY_OPEN_FILES:
michael@0 66 case ERROR_NOT_DOS_DISK:
michael@0 67 case ERROR_NOT_READY:
michael@0 68 case ERROR_OPEN_FAILED:
michael@0 69 case ERROR_PATH_BUSY:
michael@0 70 case ERROR_CANNOT_MAKE:
michael@0 71 PR_SetError(PR_IO_ERROR, err);
michael@0 72 break;
michael@0 73 case ERROR_DRIVE_LOCKED:
michael@0 74 case ERROR_DEVICE_IN_USE:
michael@0 75 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 76 break;
michael@0 77 case ERROR_FILENAME_EXCED_RANGE:
michael@0 78 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 79 break;
michael@0 80 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 81 case ERROR_SHARING_BUFFER_EXCEEDED:
michael@0 82 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 83 break;
michael@0 84 default:
michael@0 85 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 86 break;
michael@0 87 }
michael@0 88 }
michael@0 89
michael@0 90 void _MD_os2_map_closedir_error(PRInt32 err)
michael@0 91 {
michael@0 92 switch (err) {
michael@0 93 case ERROR_FILE_NOT_FOUND:
michael@0 94 case ERROR_ACCESS_DENIED:
michael@0 95 case ERROR_INVALID_HANDLE:
michael@0 96 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 97 break;
michael@0 98 default:
michael@0 99 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 100 break;
michael@0 101 }
michael@0 102 }
michael@0 103
michael@0 104 void _MD_os2_readdir_error(PRInt32 err)
michael@0 105 {
michael@0 106
michael@0 107 switch (err) {
michael@0 108 case ERROR_NO_MORE_FILES:
michael@0 109 PR_SetError(PR_NO_MORE_FILES_ERROR, err);
michael@0 110 break;
michael@0 111 case ERROR_FILE_NOT_FOUND:
michael@0 112 case ERROR_INVALID_HANDLE:
michael@0 113 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 114 break;
michael@0 115 case ERROR_INVALID_ADDRESS:
michael@0 116 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 117 break;
michael@0 118 case ERROR_NOT_DOS_DISK:
michael@0 119 case ERROR_LOCK_VIOLATION:
michael@0 120 case ERROR_BROKEN_PIPE:
michael@0 121 case ERROR_NOT_READY:
michael@0 122 PR_SetError(PR_IO_ERROR, err);
michael@0 123 break;
michael@0 124 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 125 case ERROR_MORE_DATA:
michael@0 126 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 127 break;
michael@0 128 default:
michael@0 129 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 130 break;
michael@0 131 }
michael@0 132 }
michael@0 133
michael@0 134 void _MD_os2_map_delete_error(PRInt32 err)
michael@0 135 {
michael@0 136 switch (err) {
michael@0 137 case ERROR_FILE_NOT_FOUND:
michael@0 138 case ERROR_PATH_NOT_FOUND:
michael@0 139 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 140 break;
michael@0 141 case ERROR_ACCESS_DENIED:
michael@0 142 case ERROR_WRITE_PROTECT:
michael@0 143 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 144 break;
michael@0 145 case ERROR_INVALID_ADDRESS:
michael@0 146 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 147 break;
michael@0 148 case ERROR_DRIVE_LOCKED:
michael@0 149 case ERROR_LOCKED:
michael@0 150 case ERROR_SHARING_VIOLATION:
michael@0 151 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 152 break;
michael@0 153 default:
michael@0 154 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 155 break;
michael@0 156 }
michael@0 157 }
michael@0 158
michael@0 159 /* The error code for stat() is in errno. */
michael@0 160 void _MD_os2_map_stat_error(PRInt32 err)
michael@0 161 {
michael@0 162 switch (err) {
michael@0 163 case ENOENT:
michael@0 164 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 165 break;
michael@0 166 case EACCES:
michael@0 167 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 168 break;
michael@0 169 default:
michael@0 170 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 171 }
michael@0 172 }
michael@0 173
michael@0 174 void _MD_os2_map_fstat_error(PRInt32 err)
michael@0 175 {
michael@0 176 switch (err) {
michael@0 177 case ERROR_ACCESS_DENIED:
michael@0 178 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 179 break;
michael@0 180 case ERROR_INVALID_HANDLE:
michael@0 181 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 182 break;
michael@0 183 case ERROR_INVALID_ADDRESS:
michael@0 184 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 185 break;
michael@0 186 case ERROR_NOT_READY:
michael@0 187 case ERROR_PATH_BUSY:
michael@0 188 PR_SetError(PR_IO_ERROR, err);
michael@0 189 break;
michael@0 190 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 191 case ERROR_MORE_DATA:
michael@0 192 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 193 break;
michael@0 194 case ERROR_DRIVE_LOCKED:
michael@0 195 case ERROR_LOCKED:
michael@0 196 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 197 break;
michael@0 198 default:
michael@0 199 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 200 break;
michael@0 201 }
michael@0 202 }
michael@0 203
michael@0 204 void _MD_os2_map_rename_error(PRInt32 err)
michael@0 205 {
michael@0 206 switch (err) {
michael@0 207 case ERROR_FILE_NOT_FOUND:
michael@0 208 case ERROR_PATH_NOT_FOUND:
michael@0 209 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 210 break;
michael@0 211 case ERROR_ACCESS_DENIED:
michael@0 212 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 213 break;
michael@0 214 case ERROR_INVALID_ADDRESS:
michael@0 215 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 216 break;
michael@0 217 case ERROR_INVALID_NAME:
michael@0 218 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 219 break;
michael@0 220 case ERROR_NOT_READY:
michael@0 221 case ERROR_PATH_BUSY:
michael@0 222 PR_SetError(PR_IO_ERROR, err);
michael@0 223 break;
michael@0 224 case ERROR_DRIVE_LOCKED:
michael@0 225 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 226 break;
michael@0 227 case ERROR_FILENAME_EXCED_RANGE:
michael@0 228 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 229 break;
michael@0 230 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 231 case ERROR_MORE_DATA:
michael@0 232 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 233 break;
michael@0 234 case ERROR_ALREADY_EXISTS:
michael@0 235 case ERROR_FILE_EXISTS:
michael@0 236 PR_SetError(PR_FILE_EXISTS_ERROR, err);
michael@0 237 break;
michael@0 238 default:
michael@0 239 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 240 break;
michael@0 241 }
michael@0 242 }
michael@0 243
michael@0 244 /* The error code for access() is in errno. */
michael@0 245 void _MD_os2_map_access_error(PRInt32 err)
michael@0 246 {
michael@0 247 switch (err) {
michael@0 248 case ENOENT:
michael@0 249 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 250 break;
michael@0 251 case EACCES:
michael@0 252 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 253 break;
michael@0 254 default:
michael@0 255 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 256 }
michael@0 257 }
michael@0 258
michael@0 259 void _MD_os2_map_mkdir_error(PRInt32 err)
michael@0 260 {
michael@0 261 switch (err) {
michael@0 262 case ERROR_ALREADY_EXISTS:
michael@0 263 case ERROR_FILE_EXISTS:
michael@0 264 PR_SetError(PR_FILE_EXISTS_ERROR, err);
michael@0 265 break;
michael@0 266 case ERROR_FILE_NOT_FOUND:
michael@0 267 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 268 break;
michael@0 269 case ERROR_ACCESS_DENIED:
michael@0 270 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 271 break;
michael@0 272 case ERROR_INVALID_ADDRESS:
michael@0 273 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 274 break;
michael@0 275 case ERROR_INVALID_NAME:
michael@0 276 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 277 break;
michael@0 278 case ERROR_NOT_READY:
michael@0 279 case ERROR_PATH_BUSY:
michael@0 280 PR_SetError(PR_IO_ERROR, err);
michael@0 281 break;
michael@0 282 case ERROR_DRIVE_LOCKED:
michael@0 283 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 284 break;
michael@0 285 case ERROR_FILENAME_EXCED_RANGE:
michael@0 286 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 287 break;
michael@0 288 case ERROR_TOO_MANY_OPEN_FILES:
michael@0 289 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 290 break;
michael@0 291 case ERROR_PATH_NOT_FOUND:
michael@0 292 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 293 break;
michael@0 294 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 295 case ERROR_MORE_DATA:
michael@0 296 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 297 break;
michael@0 298 case ERROR_DISK_FULL:
michael@0 299 case ERROR_HANDLE_DISK_FULL:
michael@0 300 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 301 break;
michael@0 302 case ERROR_WRITE_PROTECT:
michael@0 303 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 304 break;
michael@0 305 default:
michael@0 306 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 307 break;
michael@0 308 }
michael@0 309 }
michael@0 310
michael@0 311 void _MD_os2_map_rmdir_error(PRInt32 err)
michael@0 312 {
michael@0 313
michael@0 314 switch (err) {
michael@0 315 case ERROR_FILE_NOT_FOUND:
michael@0 316 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 317 break;
michael@0 318 case ERROR_ACCESS_DENIED:
michael@0 319 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 320 break;
michael@0 321 case ERROR_INVALID_ADDRESS:
michael@0 322 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 323 break;
michael@0 324 case ERROR_INVALID_NAME:
michael@0 325 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 326 break;
michael@0 327 case ERROR_NOT_READY:
michael@0 328 case ERROR_PATH_BUSY:
michael@0 329 PR_SetError(PR_IO_ERROR, err);
michael@0 330 break;
michael@0 331 case ERROR_DRIVE_LOCKED:
michael@0 332 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 333 break;
michael@0 334 case ERROR_FILENAME_EXCED_RANGE:
michael@0 335 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 336 break;
michael@0 337 case ERROR_TOO_MANY_OPEN_FILES:
michael@0 338 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 339 break;
michael@0 340 case ERROR_PATH_NOT_FOUND:
michael@0 341 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 342 break;
michael@0 343 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 344 case ERROR_MORE_DATA:
michael@0 345 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 346 break;
michael@0 347 case ERROR_WRITE_PROTECT:
michael@0 348 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 349 break;
michael@0 350 default:
michael@0 351 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 352 break;
michael@0 353 }
michael@0 354 }
michael@0 355
michael@0 356 void _MD_os2_map_read_error(PRInt32 err)
michael@0 357 {
michael@0 358 switch (err) {
michael@0 359 case ERROR_ACCESS_DENIED:
michael@0 360 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 361 break;
michael@0 362 case ERROR_INVALID_HANDLE:
michael@0 363 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 364 break;
michael@0 365 case ERROR_INVALID_ADDRESS:
michael@0 366 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 367 break;
michael@0 368 case ERROR_NOT_READY:
michael@0 369 case ERROR_PATH_BUSY:
michael@0 370 PR_SetError(PR_IO_ERROR, err);
michael@0 371 break;
michael@0 372 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 373 case ERROR_MORE_DATA:
michael@0 374 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 375 break;
michael@0 376 case ERROR_DRIVE_LOCKED:
michael@0 377 case ERROR_LOCKED:
michael@0 378 case ERROR_SHARING_VIOLATION:
michael@0 379 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 380 break;
michael@0 381 case ERROR_NETNAME_DELETED:
michael@0 382 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 383 break;
michael@0 384 case EBADF:
michael@0 385 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 386 break;
michael@0 387 case ENOTSOCK:
michael@0 388 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 389 break;
michael@0 390 #ifdef SOCEFAULT
michael@0 391 case SOCEFAULT:
michael@0 392 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 393 break;
michael@0 394 #endif
michael@0 395 default:
michael@0 396 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 397 break;
michael@0 398 }
michael@0 399 }
michael@0 400
michael@0 401 void _MD_os2_map_transmitfile_error(PRInt32 err)
michael@0 402 {
michael@0 403 switch (err) {
michael@0 404 case ERROR_ACCESS_DENIED:
michael@0 405 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 406 break;
michael@0 407 case ERROR_INVALID_HANDLE:
michael@0 408 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 409 break;
michael@0 410 case ERROR_INVALID_ADDRESS:
michael@0 411 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 412 break;
michael@0 413 case ERROR_NOT_READY:
michael@0 414 case ERROR_PATH_BUSY:
michael@0 415 PR_SetError(PR_IO_ERROR, err);
michael@0 416 break;
michael@0 417 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 418 case ERROR_MORE_DATA:
michael@0 419 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 420 break;
michael@0 421 case ERROR_DRIVE_LOCKED:
michael@0 422 case ERROR_LOCKED:
michael@0 423 case ERROR_SHARING_VIOLATION:
michael@0 424 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 425 break;
michael@0 426 case ERROR_FILENAME_EXCED_RANGE:
michael@0 427 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 428 break;
michael@0 429 case ERROR_TOO_MANY_OPEN_FILES:
michael@0 430 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 431 break;
michael@0 432 case ERROR_PATH_NOT_FOUND:
michael@0 433 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 434 break;
michael@0 435 case EBADF:
michael@0 436 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 437 break;
michael@0 438 case ENOTSOCK:
michael@0 439 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 440 break;
michael@0 441 #ifdef SOCEFAULT
michael@0 442 case SOCEFAULT:
michael@0 443 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 444 break;
michael@0 445 #endif
michael@0 446 default:
michael@0 447 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 448 break;
michael@0 449 }
michael@0 450 }
michael@0 451
michael@0 452 void _MD_os2_map_write_error(PRInt32 err)
michael@0 453 {
michael@0 454 switch (err) {
michael@0 455 case ERROR_ACCESS_DENIED:
michael@0 456 case ERROR_WRITE_PROTECT:
michael@0 457 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 458 break;
michael@0 459 case ERROR_INVALID_HANDLE:
michael@0 460 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 461 break;
michael@0 462 case ERROR_INVALID_ADDRESS:
michael@0 463 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 464 break;
michael@0 465 case ERROR_NOT_READY:
michael@0 466 case ERROR_PATH_BUSY:
michael@0 467 PR_SetError(PR_IO_ERROR, err);
michael@0 468 break;
michael@0 469 case ERROR_DRIVE_LOCKED:
michael@0 470 case ERROR_LOCKED:
michael@0 471 case ERROR_SHARING_VIOLATION:
michael@0 472 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 473 break;
michael@0 474 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 475 case ERROR_MORE_DATA:
michael@0 476 case ERROR_DISK_FULL:
michael@0 477 case ERROR_HANDLE_DISK_FULL:
michael@0 478 case ENOSPC:
michael@0 479 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 480 break;
michael@0 481 case ERROR_NETNAME_DELETED:
michael@0 482 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 483 break;
michael@0 484 case EBADF:
michael@0 485 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 486 break;
michael@0 487 case ENOTSOCK:
michael@0 488 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 489 break;
michael@0 490 case EMSGSIZE:
michael@0 491 case EINVAL:
michael@0 492 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 493 break;
michael@0 494 case ENOBUFS:
michael@0 495 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 496 break;
michael@0 497 case ECONNREFUSED:
michael@0 498 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 499 break;
michael@0 500 case EISCONN:
michael@0 501 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 502 break;
michael@0 503 #ifdef SOCEFAULT
michael@0 504 case SOCEFAULT:
michael@0 505 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 506 break;
michael@0 507 #endif
michael@0 508 default:
michael@0 509 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 510 break;
michael@0 511 }
michael@0 512 }
michael@0 513
michael@0 514 void _MD_os2_map_lseek_error(PRInt32 err)
michael@0 515 {
michael@0 516 switch (err) {
michael@0 517 case ERROR_INVALID_HANDLE:
michael@0 518 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 519 break;
michael@0 520 case ERROR_SEEK_ON_DEVICE:
michael@0 521 PR_SetError(PR_IO_ERROR, err);
michael@0 522 break;
michael@0 523 default:
michael@0 524 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 525 break;
michael@0 526 }
michael@0 527 }
michael@0 528
michael@0 529 void _MD_os2_map_fsync_error(PRInt32 err)
michael@0 530 {
michael@0 531 switch (err) {
michael@0 532 case ERROR_ACCESS_DENIED:
michael@0 533 case ERROR_WRITE_PROTECT:
michael@0 534 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 535 break;
michael@0 536 case ERROR_INVALID_HANDLE:
michael@0 537 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 538 break;
michael@0 539 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 540 case ERROR_MORE_DATA:
michael@0 541 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 542 break;
michael@0 543 case ERROR_DISK_FULL:
michael@0 544 case ERROR_HANDLE_DISK_FULL:
michael@0 545 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 546 break;
michael@0 547 default:
michael@0 548 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 549 break;
michael@0 550 }
michael@0 551 }
michael@0 552
michael@0 553 void _MD_os2_map_close_error(PRInt32 err)
michael@0 554 {
michael@0 555 switch (err) {
michael@0 556 case ERROR_INVALID_HANDLE:
michael@0 557 case EBADF:
michael@0 558 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 559 break;
michael@0 560 case ERROR_NOT_READY:
michael@0 561 case ERROR_PATH_BUSY:
michael@0 562 PR_SetError(PR_IO_ERROR, err);
michael@0 563 break;
michael@0 564 default:
michael@0 565 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 566 break;
michael@0 567 }
michael@0 568 }
michael@0 569
michael@0 570 void _MD_os2_map_socket_error(PRInt32 err)
michael@0 571 {
michael@0 572 switch (err) {
michael@0 573 case EPROTONOSUPPORT:
michael@0 574 PR_SetError(PR_PROTOCOL_NOT_SUPPORTED_ERROR, err);
michael@0 575 break;
michael@0 576 case EACCES:
michael@0 577 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 578 break;
michael@0 579 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 580 case ERROR_MORE_DATA:
michael@0 581 case ENOBUFS:
michael@0 582 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 583 break;
michael@0 584 default:
michael@0 585 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 586 break;
michael@0 587 }
michael@0 588 }
michael@0 589
michael@0 590 void _MD_os2_map_recv_error(PRInt32 err)
michael@0 591 {
michael@0 592 switch (err) {
michael@0 593 case EWOULDBLOCK:
michael@0 594 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 595 break;
michael@0 596 case EBADF:
michael@0 597 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 598 break;
michael@0 599 case ENOTSOCK:
michael@0 600 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 601 break;
michael@0 602 #ifdef SOCEFAULT
michael@0 603 case SOCEFAULT:
michael@0 604 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 605 break;
michael@0 606 #endif
michael@0 607 case ERROR_NETNAME_DELETED:
michael@0 608 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 609 break;
michael@0 610 default:
michael@0 611 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 612 break;
michael@0 613 }
michael@0 614 }
michael@0 615
michael@0 616 void _MD_os2_map_recvfrom_error(PRInt32 err)
michael@0 617 {
michael@0 618 switch (err) {
michael@0 619 case EWOULDBLOCK:
michael@0 620 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 621 break;
michael@0 622 case EBADF:
michael@0 623 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 624 break;
michael@0 625 case ENOTSOCK:
michael@0 626 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 627 break;
michael@0 628 #ifdef SOCEFAULT
michael@0 629 case SOCEFAULT:
michael@0 630 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 631 break;
michael@0 632 #endif
michael@0 633 case ERROR_NETNAME_DELETED:
michael@0 634 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 635 break;
michael@0 636 default:
michael@0 637 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 638 break;
michael@0 639 }
michael@0 640 }
michael@0 641
michael@0 642 void _MD_os2_map_send_error(PRInt32 err)
michael@0 643 {
michael@0 644 switch (err) {
michael@0 645 case EWOULDBLOCK:
michael@0 646 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 647 break;
michael@0 648 case EBADF:
michael@0 649 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 650 break;
michael@0 651 case ENOTSOCK:
michael@0 652 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 653 break;
michael@0 654 case EMSGSIZE:
michael@0 655 case EINVAL:
michael@0 656 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 657 break;
michael@0 658 case ENOBUFS:
michael@0 659 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 660 break;
michael@0 661 case ECONNREFUSED:
michael@0 662 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 663 break;
michael@0 664 case EISCONN:
michael@0 665 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 666 break;
michael@0 667 #ifdef SOCEFAULT
michael@0 668 case SOCEFAULT:
michael@0 669 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 670 break;
michael@0 671 #endif
michael@0 672 case ERROR_NETNAME_DELETED:
michael@0 673 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 674 break;
michael@0 675 default:
michael@0 676 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 677 break;
michael@0 678 }
michael@0 679 }
michael@0 680
michael@0 681 void _MD_os2_map_sendto_error(PRInt32 err)
michael@0 682 {
michael@0 683 _MD_os2_map_default_error(err);
michael@0 684 }
michael@0 685
michael@0 686 void _MD_os2_map_writev_error(int err)
michael@0 687 {
michael@0 688 _MD_os2_map_default_error(err);
michael@0 689 }
michael@0 690
michael@0 691 void _MD_os2_map_accept_error(PRInt32 err)
michael@0 692 {
michael@0 693 _MD_os2_map_default_error(err);
michael@0 694 }
michael@0 695
michael@0 696 void _MD_os2_map_acceptex_error(PRInt32 err)
michael@0 697 {
michael@0 698 switch (err) {
michael@0 699 case ERROR_INVALID_HANDLE:
michael@0 700 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 701 break;
michael@0 702 case ERROR_INVALID_ADDRESS:
michael@0 703 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 704 break;
michael@0 705 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 706 case ERROR_MORE_DATA:
michael@0 707 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 708 break;
michael@0 709 default:
michael@0 710 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 711 break;
michael@0 712 }
michael@0 713 }
michael@0 714
michael@0 715 /*
michael@0 716 * An error code of 0 means that the nonblocking connect succeeded.
michael@0 717 */
michael@0 718
michael@0 719 int _MD_os2_get_nonblocking_connect_error(int osfd)
michael@0 720 {
michael@0 721 int err;
michael@0 722 int len = sizeof(err);
michael@0 723 if (getsockopt(osfd, SOL_SOCKET, SO_ERROR, (char *) &err, &len) == -1) {
michael@0 724 return sock_errno();
michael@0 725 } else {
michael@0 726 return err;
michael@0 727 }
michael@0 728 }
michael@0 729
michael@0 730 void _MD_os2_map_connect_error(PRInt32 err)
michael@0 731 {
michael@0 732 switch (err) {
michael@0 733 case EWOULDBLOCK:
michael@0 734 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 735 break;
michael@0 736 case EINPROGRESS:
michael@0 737 PR_SetError(PR_IN_PROGRESS_ERROR, err);
michael@0 738 break;
michael@0 739 case EALREADY:
michael@0 740 case EINVAL:
michael@0 741 PR_SetError(PR_ALREADY_INITIATED_ERROR, err);
michael@0 742 break;
michael@0 743 case EBADF:
michael@0 744 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 745 break;
michael@0 746 case EADDRNOTAVAIL:
michael@0 747 PR_SetError(PR_ADDRESS_NOT_AVAILABLE_ERROR, err);
michael@0 748 break;
michael@0 749 case ENOTSOCK:
michael@0 750 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 751 break;
michael@0 752 case EAFNOSUPPORT:
michael@0 753 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 754 break;
michael@0 755 case ETIMEDOUT:
michael@0 756 PR_SetError(PR_IO_TIMEOUT_ERROR, err);
michael@0 757 break;
michael@0 758 case ECONNREFUSED:
michael@0 759 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 760 break;
michael@0 761 case ENETUNREACH:
michael@0 762 PR_SetError(PR_NETWORK_UNREACHABLE_ERROR, err);
michael@0 763 break;
michael@0 764 case EADDRINUSE:
michael@0 765 PR_SetError(PR_ADDRESS_IN_USE_ERROR, err);
michael@0 766 break;
michael@0 767 case EISCONN:
michael@0 768 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 769 break;
michael@0 770 #ifdef SOCEFAULT
michael@0 771 case SOCEFAULT:
michael@0 772 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 773 break;
michael@0 774 #endif
michael@0 775 default:
michael@0 776 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 777 break;
michael@0 778 }
michael@0 779 }
michael@0 780
michael@0 781 void _MD_os2_map_bind_error(PRInt32 err)
michael@0 782 {
michael@0 783 switch (err) {
michael@0 784 case EBADF:
michael@0 785 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 786 break;
michael@0 787 case ENOTSOCK:
michael@0 788 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 789 break;
michael@0 790 #ifdef SOCEFAULT
michael@0 791 case SOCEFAULT:
michael@0 792 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 793 break;
michael@0 794 #endif
michael@0 795 case EADDRNOTAVAIL:
michael@0 796 PR_SetError(PR_ADDRESS_NOT_AVAILABLE_ERROR, err);
michael@0 797 break;
michael@0 798 case EADDRINUSE:
michael@0 799 PR_SetError(PR_ADDRESS_IN_USE_ERROR, err);
michael@0 800 break;
michael@0 801 case EACCES:
michael@0 802 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 803 break;
michael@0 804 case EINVAL:
michael@0 805 PR_SetError(PR_SOCKET_ADDRESS_IS_BOUND_ERROR, err);
michael@0 806 break;
michael@0 807 default:
michael@0 808 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 809 break;
michael@0 810 }
michael@0 811 }
michael@0 812
michael@0 813 void _MD_os2_map_listen_error(PRInt32 err)
michael@0 814 {
michael@0 815 switch (err) {
michael@0 816 case EBADF:
michael@0 817 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 818 break;
michael@0 819 case ENOTSOCK:
michael@0 820 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 821 break;
michael@0 822 case EOPNOTSUPP:
michael@0 823 PR_SetError(PR_NOT_TCP_SOCKET_ERROR, err);
michael@0 824 break;
michael@0 825 default:
michael@0 826 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 827 break;
michael@0 828 }
michael@0 829 }
michael@0 830
michael@0 831 void _MD_os2_map_shutdown_error(PRInt32 err)
michael@0 832 {
michael@0 833 switch (err) {
michael@0 834 case EBADF:
michael@0 835 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 836 break;
michael@0 837 case ENOTSOCK:
michael@0 838 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 839 break;
michael@0 840 case ENOTCONN:
michael@0 841 PR_SetError(PR_NOT_CONNECTED_ERROR, err);
michael@0 842 break;
michael@0 843 default:
michael@0 844 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 845 break;
michael@0 846 }
michael@0 847 }
michael@0 848
michael@0 849 void _MD_os2_map_socketpair_error(PRInt32 err)
michael@0 850 {
michael@0 851 switch (err) {
michael@0 852 case ENOMEM:
michael@0 853 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 854 break;
michael@0 855 case EAFNOSUPPORT:
michael@0 856 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 857 break;
michael@0 858 case EPROTONOSUPPORT:
michael@0 859 PR_SetError(PR_PROTOCOL_NOT_SUPPORTED_ERROR, err);
michael@0 860 break;
michael@0 861 case EOPNOTSUPP:
michael@0 862 PR_SetError(PR_NOT_TCP_SOCKET_ERROR, err);
michael@0 863 break;
michael@0 864 case EPROTOTYPE:
michael@0 865 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 866 break;
michael@0 867 default:
michael@0 868 _MD_os2_map_default_error(err);
michael@0 869 return;
michael@0 870 }
michael@0 871 }
michael@0 872
michael@0 873 void _MD_os2_map_getsockname_error(PRInt32 err)
michael@0 874 {
michael@0 875 switch (err) {
michael@0 876 case EBADF:
michael@0 877 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 878 break;
michael@0 879 case ENOTSOCK:
michael@0 880 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 881 break;
michael@0 882 #ifdef SOCEFAULT
michael@0 883 case SOCEFAULT:
michael@0 884 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 885 break;
michael@0 886 #endif
michael@0 887 case ENOBUFS:
michael@0 888 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 889 break;
michael@0 890 default:
michael@0 891 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 892 break;
michael@0 893 }
michael@0 894 }
michael@0 895
michael@0 896 void _MD_os2_map_getpeername_error(PRInt32 err)
michael@0 897 {
michael@0 898
michael@0 899 switch (err) {
michael@0 900 case EBADF:
michael@0 901 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 902 break;
michael@0 903 case ENOTSOCK:
michael@0 904 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 905 break;
michael@0 906 case ENOTCONN:
michael@0 907 PR_SetError(PR_NOT_CONNECTED_ERROR, err);
michael@0 908 break;
michael@0 909 #ifdef SOCEFAULT
michael@0 910 case SOCEFAULT:
michael@0 911 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 912 break;
michael@0 913 #endif
michael@0 914 case ENOBUFS:
michael@0 915 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 916 break;
michael@0 917 default:
michael@0 918 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 919 break;
michael@0 920 }
michael@0 921 }
michael@0 922
michael@0 923 void _MD_os2_map_getsockopt_error(PRInt32 err)
michael@0 924 {
michael@0 925 switch (err) {
michael@0 926 case EBADF:
michael@0 927 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 928 break;
michael@0 929 case ENOTSOCK:
michael@0 930 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 931 break;
michael@0 932 case ENOPROTOOPT:
michael@0 933 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 934 break;
michael@0 935 #ifdef SOCEFAULT
michael@0 936 case SOCEFAULT:
michael@0 937 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 938 break;
michael@0 939 #endif
michael@0 940 case EINVAL:
michael@0 941 PR_SetError(PR_BUFFER_OVERFLOW_ERROR, err);
michael@0 942 break;
michael@0 943 default:
michael@0 944 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 945 break;
michael@0 946 }
michael@0 947 }
michael@0 948
michael@0 949 void _MD_os2_map_setsockopt_error(PRInt32 err)
michael@0 950 {
michael@0 951 switch (err) {
michael@0 952 case EBADF:
michael@0 953 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 954 break;
michael@0 955 case ENOTSOCK:
michael@0 956 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 957 break;
michael@0 958 case ENOPROTOOPT:
michael@0 959 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 960 break;
michael@0 961 #ifdef SOCEFAULT
michael@0 962 case SOCEFAULT:
michael@0 963 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 964 break;
michael@0 965 #endif
michael@0 966 case EINVAL:
michael@0 967 PR_SetError(PR_BUFFER_OVERFLOW_ERROR, err);
michael@0 968 break;
michael@0 969 default:
michael@0 970 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 971 break;
michael@0 972 }
michael@0 973 }
michael@0 974
michael@0 975 void _MD_os2_map_open_error(PRInt32 err)
michael@0 976 {
michael@0 977 switch (err) {
michael@0 978 case ERROR_ALREADY_EXISTS:
michael@0 979 case ERROR_FILE_EXISTS:
michael@0 980 PR_SetError(PR_FILE_EXISTS_ERROR, err);
michael@0 981 break;
michael@0 982 case ERROR_FILE_NOT_FOUND:
michael@0 983 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 984 break;
michael@0 985 case ERROR_ACCESS_DENIED:
michael@0 986 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 987 break;
michael@0 988 case ERROR_INVALID_ADDRESS:
michael@0 989 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 990 break;
michael@0 991 case ERROR_INVALID_NAME:
michael@0 992 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 993 break;
michael@0 994 case ERROR_NOT_READY:
michael@0 995 case ERROR_OPEN_FAILED:
michael@0 996 case ERROR_PATH_BUSY:
michael@0 997 PR_SetError(PR_IO_ERROR, err);
michael@0 998 break;
michael@0 999 case ERROR_DRIVE_LOCKED:
michael@0 1000 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 1001 break;
michael@0 1002 case ERROR_FILENAME_EXCED_RANGE:
michael@0 1003 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 1004 break;
michael@0 1005 case ERROR_TOO_MANY_OPEN_FILES:
michael@0 1006 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 1007 break;
michael@0 1008 case ERROR_PATH_NOT_FOUND:
michael@0 1009 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 1010 break;
michael@0 1011 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 1012 case ERROR_MORE_DATA:
michael@0 1013 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1014 break;
michael@0 1015 case ERROR_DISK_FULL:
michael@0 1016 case ERROR_HANDLE_DISK_FULL:
michael@0 1017 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 1018 break;
michael@0 1019 case ERROR_WRITE_PROTECT:
michael@0 1020 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 1021 break;
michael@0 1022 default:
michael@0 1023 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1024 break;
michael@0 1025 }
michael@0 1026 }
michael@0 1027
michael@0 1028 void _MD_os2_map_gethostname_error(PRInt32 err)
michael@0 1029 {
michael@0 1030 switch (err) {
michael@0 1031 #ifdef SOCEFAULT
michael@0 1032 case SOCEFAULT:
michael@0 1033 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1034 break;
michael@0 1035 #endif
michael@0 1036 case ENETDOWN:
michael@0 1037 case EINPROGRESS:
michael@0 1038 default:
michael@0 1039 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1040 break;
michael@0 1041 }
michael@0 1042 }
michael@0 1043
michael@0 1044 void _MD_os2_map_select_error(PRInt32 err)
michael@0 1045 {
michael@0 1046 PRErrorCode prerror;
michael@0 1047
michael@0 1048 switch (err) {
michael@0 1049 /*
michael@0 1050 * OS/2 select() only works on sockets. So in this
michael@0 1051 * context, ENOTSOCK is equivalent to EBADF on Unix.
michael@0 1052 */
michael@0 1053 case ENOTSOCK:
michael@0 1054 prerror = PR_BAD_DESCRIPTOR_ERROR;
michael@0 1055 break;
michael@0 1056 case EINVAL:
michael@0 1057 prerror = PR_INVALID_ARGUMENT_ERROR;
michael@0 1058 break;
michael@0 1059 #ifdef SOCEFAULT
michael@0 1060 case SOCEFAULT:
michael@0 1061 prerror = PR_ACCESS_FAULT_ERROR;
michael@0 1062 break;
michael@0 1063 #endif
michael@0 1064 default:
michael@0 1065 prerror = PR_UNKNOWN_ERROR;
michael@0 1066 }
michael@0 1067 PR_SetError(prerror, err);
michael@0 1068 }
michael@0 1069
michael@0 1070 void _MD_os2_map_lockf_error(PRInt32 err)
michael@0 1071 {
michael@0 1072 switch (err) {
michael@0 1073 case ERROR_ACCESS_DENIED:
michael@0 1074 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 1075 break;
michael@0 1076 case ERROR_INVALID_HANDLE:
michael@0 1077 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1078 break;
michael@0 1079 case ERROR_INVALID_ADDRESS:
michael@0 1080 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1081 break;
michael@0 1082 case ERROR_DRIVE_LOCKED:
michael@0 1083 case ERROR_LOCKED:
michael@0 1084 case ERROR_SHARING_VIOLATION:
michael@0 1085 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 1086 break;
michael@0 1087 case ERROR_NOT_ENOUGH_MEMORY:
michael@0 1088 case ERROR_MORE_DATA:
michael@0 1089 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1090 break;
michael@0 1091 default:
michael@0 1092 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1093 break;
michael@0 1094 }
michael@0 1095 }

mercurial