nsprpub/pr/src/md/beos/beos_errors.c

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

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 "prtypes.h"
michael@0 7 #include "md/_unix_errors.h"
michael@0 8 #include "prerror.h"
michael@0 9 #include <errno.h>
michael@0 10
michael@0 11 void _MD_unix_map_opendir_error(int err)
michael@0 12 {
michael@0 13 switch (err) {
michael@0 14 case ENOTDIR:
michael@0 15 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 16 break;
michael@0 17 case EACCES:
michael@0 18 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 19 break;
michael@0 20 case EMFILE:
michael@0 21 PR_SetError(PR_PROC_DESC_TABLE_FULL_ERROR, err);
michael@0 22 break;
michael@0 23 case ENFILE:
michael@0 24 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 25 break;
michael@0 26 case EFAULT:
michael@0 27 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 28 break;
michael@0 29 case ELOOP:
michael@0 30 PR_SetError(PR_LOOP_ERROR, err);
michael@0 31 break;
michael@0 32 case ENAMETOOLONG:
michael@0 33 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 34 break;
michael@0 35 case ENOENT:
michael@0 36 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 37 break;
michael@0 38 default:
michael@0 39 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 40 break;
michael@0 41 }
michael@0 42 }
michael@0 43
michael@0 44 void _MD_unix_map_closedir_error(int err)
michael@0 45 {
michael@0 46 switch (err) {
michael@0 47 case EINVAL:
michael@0 48 case EBADF:
michael@0 49 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 50 break;
michael@0 51 default:
michael@0 52 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 53 break;
michael@0 54 }
michael@0 55 }
michael@0 56
michael@0 57 void _MD_unix_readdir_error(int err)
michael@0 58 {
michael@0 59
michael@0 60 switch (err) {
michael@0 61 case 0:
michael@0 62 case ENOENT:
michael@0 63 PR_SetError(PR_NO_MORE_FILES_ERROR, err);
michael@0 64 break;
michael@0 65 case EBADF:
michael@0 66 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 67 break;
michael@0 68 #ifdef IRIX
michael@0 69 #ifdef IRIX5_3
michael@0 70 #else
michael@0 71 case EDIRCORRUPTED:
michael@0 72 PR_SetError(PR_DIRECTORY_CORRUPTED_ERROR, err);
michael@0 73 break;
michael@0 74 #endif
michael@0 75 #endif
michael@0 76 #ifdef EOVERFLOW
michael@0 77 case EOVERFLOW:
michael@0 78 PR_SetError(PR_IO_ERROR, err);
michael@0 79 break;
michael@0 80 #endif
michael@0 81 case EINVAL:
michael@0 82 PR_SetError(PR_IO_ERROR, err);
michael@0 83 break;
michael@0 84 #ifdef EBADMSG
michael@0 85 case EBADMSG:
michael@0 86 PR_SetError(PR_IO_ERROR, err);
michael@0 87 break;
michael@0 88 #endif
michael@0 89 case EDEADLK:
michael@0 90 PR_SetError(PR_DEADLOCK_ERROR, err);
michael@0 91 break;
michael@0 92 case EFAULT:
michael@0 93 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 94 break;
michael@0 95 case EINTR:
michael@0 96 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 97 break;
michael@0 98 case EIO:
michael@0 99 PR_SetError(PR_IO_ERROR, err);
michael@0 100 break;
michael@0 101 case ENOLCK:
michael@0 102 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 103 break;
michael@0 104 #ifdef ENOLINK
michael@0 105 case ENOLINK:
michael@0 106 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 107 break;
michael@0 108 #endif
michael@0 109 case ENXIO:
michael@0 110 PR_SetError(PR_IO_ERROR, err);
michael@0 111 break;
michael@0 112 default:
michael@0 113 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 114 break;
michael@0 115 }
michael@0 116 }
michael@0 117
michael@0 118 void _MD_unix_map_unlink_error(int err)
michael@0 119 {
michael@0 120 switch (err) {
michael@0 121 case EACCES:
michael@0 122 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 123 break;
michael@0 124 case EBUSY:
michael@0 125 PR_SetError(PR_FILESYSTEM_MOUNTED_ERROR, err);
michael@0 126 break;
michael@0 127 case EFAULT:
michael@0 128 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 129 break;
michael@0 130 case EINTR:
michael@0 131 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 132 break;
michael@0 133 case ELOOP:
michael@0 134 PR_SetError(PR_LOOP_ERROR, err);
michael@0 135 break;
michael@0 136 case ENAMETOOLONG:
michael@0 137 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 138 break;
michael@0 139 case ENOENT:
michael@0 140 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 141 break;
michael@0 142 case ENOTDIR:
michael@0 143 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 144 break;
michael@0 145 case EPERM:
michael@0 146 PR_SetError(PR_IS_DIRECTORY_ERROR, err);
michael@0 147 break;
michael@0 148 case EROFS:
michael@0 149 PR_SetError(PR_READ_ONLY_FILESYSTEM_ERROR, err);
michael@0 150 break;
michael@0 151 default:
michael@0 152 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 153 break;
michael@0 154 }
michael@0 155 }
michael@0 156
michael@0 157 void _MD_unix_map_stat_error(int err)
michael@0 158 {
michael@0 159 switch (err) {
michael@0 160 case EACCES:
michael@0 161 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 162 break;
michael@0 163 case EFAULT:
michael@0 164 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 165 break;
michael@0 166 case EINTR:
michael@0 167 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 168 break;
michael@0 169 case ETIMEDOUT:
michael@0 170 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 171 break;
michael@0 172 case ELOOP:
michael@0 173 PR_SetError(PR_LOOP_ERROR, err);
michael@0 174 break;
michael@0 175 case ENAMETOOLONG:
michael@0 176 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 177 break;
michael@0 178 case ENOENT:
michael@0 179 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 180 break;
michael@0 181 case ENOTDIR:
michael@0 182 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 183 break;
michael@0 184 #ifdef EOVERFLOW
michael@0 185 case EOVERFLOW:
michael@0 186 PR_SetError(PR_BUFFER_OVERFLOW_ERROR, err);
michael@0 187 break;
michael@0 188 #endif
michael@0 189 default:
michael@0 190 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 191 break;
michael@0 192 }
michael@0 193 }
michael@0 194
michael@0 195 void _MD_unix_map_fstat_error(int err)
michael@0 196 {
michael@0 197 switch (err) {
michael@0 198 case EBADF:
michael@0 199 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 200 break;
michael@0 201 case EFAULT:
michael@0 202 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 203 break;
michael@0 204 case EINTR:
michael@0 205 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 206 break;
michael@0 207 case ETIMEDOUT:
michael@0 208 #ifdef ENOLINK
michael@0 209 case ENOLINK:
michael@0 210 #endif
michael@0 211 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 212 break;
michael@0 213 #ifdef EOVERFLOW
michael@0 214 case EOVERFLOW:
michael@0 215 PR_SetError(PR_BUFFER_OVERFLOW_ERROR, err);
michael@0 216 break;
michael@0 217 #endif
michael@0 218 default:
michael@0 219 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 220 break;
michael@0 221 }
michael@0 222 }
michael@0 223
michael@0 224 void _MD_unix_map_rename_error(int err)
michael@0 225 {
michael@0 226 switch (err) {
michael@0 227 case EACCES:
michael@0 228 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 229 break;
michael@0 230 case EBUSY:
michael@0 231 PR_SetError(PR_FILESYSTEM_MOUNTED_ERROR, err);
michael@0 232 break;
michael@0 233 #ifdef EDQUOT
michael@0 234 case EDQUOT:
michael@0 235 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 236 break;
michael@0 237 #endif
michael@0 238 case EEXIST:
michael@0 239 PR_SetError(PR_DIRECTORY_NOT_EMPTY_ERROR, err);
michael@0 240 break;
michael@0 241 case EFAULT:
michael@0 242 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 243 break;
michael@0 244 case EINTR:
michael@0 245 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 246 break;
michael@0 247 case EINVAL:
michael@0 248 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 249 break;
michael@0 250 case EIO:
michael@0 251 PR_SetError(PR_IO_ERROR, err);
michael@0 252 break;
michael@0 253 case EISDIR:
michael@0 254 PR_SetError(PR_IS_DIRECTORY_ERROR, err);
michael@0 255 break;
michael@0 256 case ELOOP:
michael@0 257 PR_SetError(PR_LOOP_ERROR, err);
michael@0 258 break;
michael@0 259 case ENAMETOOLONG:
michael@0 260 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 261 break;
michael@0 262 case ENOENT:
michael@0 263 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 264 break;
michael@0 265 case ENOSPC:
michael@0 266 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 267 break;
michael@0 268 case ENOTDIR:
michael@0 269 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 270 break;
michael@0 271 case EROFS:
michael@0 272 PR_SetError(PR_READ_ONLY_FILESYSTEM_ERROR, err);
michael@0 273 break;
michael@0 274 case EXDEV:
michael@0 275 PR_SetError(PR_NOT_SAME_DEVICE_ERROR, err);
michael@0 276 break;
michael@0 277 case EMLINK:
michael@0 278 PR_SetError(PR_MAX_DIRECTORY_ENTRIES_ERROR, err);
michael@0 279 break;
michael@0 280 default:
michael@0 281 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 282 break;
michael@0 283 }
michael@0 284 }
michael@0 285
michael@0 286 void _MD_unix_map_access_error(int err)
michael@0 287 {
michael@0 288 switch (err) {
michael@0 289 case EACCES:
michael@0 290 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 291 break;
michael@0 292 case EFAULT:
michael@0 293 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 294 break;
michael@0 295 case EINTR:
michael@0 296 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 297 break;
michael@0 298 case EINVAL:
michael@0 299 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 300 break;
michael@0 301 case ELOOP:
michael@0 302 PR_SetError(PR_LOOP_ERROR, err);
michael@0 303 break;
michael@0 304 case ETIMEDOUT:
michael@0 305 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 306 break;
michael@0 307 case ENAMETOOLONG:
michael@0 308 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 309 break;
michael@0 310 case ENOENT:
michael@0 311 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 312 break;
michael@0 313 case ENOTDIR:
michael@0 314 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 315 break;
michael@0 316 case EROFS:
michael@0 317 PR_SetError(PR_READ_ONLY_FILESYSTEM_ERROR, err);
michael@0 318 break;
michael@0 319 default:
michael@0 320 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 321 break;
michael@0 322 }
michael@0 323 }
michael@0 324
michael@0 325 void _MD_unix_map_mkdir_error(int err)
michael@0 326 {
michael@0 327 switch (err) {
michael@0 328 case ENOTDIR:
michael@0 329 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 330 break;
michael@0 331 case ENOENT:
michael@0 332 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 333 break;
michael@0 334 case ENAMETOOLONG:
michael@0 335 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 336 break;
michael@0 337 case EACCES:
michael@0 338 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 339 break;
michael@0 340 case EEXIST:
michael@0 341 PR_SetError(PR_FILE_EXISTS_ERROR, err);
michael@0 342 break;
michael@0 343 case EROFS:
michael@0 344 PR_SetError(PR_READ_ONLY_FILESYSTEM_ERROR, err);
michael@0 345 break;
michael@0 346 case EFAULT:
michael@0 347 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 348 break;
michael@0 349 case ELOOP:
michael@0 350 PR_SetError(PR_LOOP_ERROR, err);
michael@0 351 break;
michael@0 352 case EMLINK:
michael@0 353 PR_SetError(PR_MAX_DIRECTORY_ENTRIES_ERROR, err);
michael@0 354 break;
michael@0 355 case ENOSPC:
michael@0 356 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 357 break;
michael@0 358 #ifdef EDQUOT
michael@0 359 case EDQUOT:
michael@0 360 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 361 break;
michael@0 362 #endif
michael@0 363 case EIO:
michael@0 364 PR_SetError(PR_IO_ERROR, err);
michael@0 365 break;
michael@0 366 default:
michael@0 367 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 368 break;
michael@0 369 }
michael@0 370 }
michael@0 371
michael@0 372 void _MD_unix_map_rmdir_error(int err)
michael@0 373 {
michael@0 374
michael@0 375 switch (err) {
michael@0 376 case EACCES:
michael@0 377 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 378 break;
michael@0 379 case EBUSY:
michael@0 380 PR_SetError(PR_FILESYSTEM_MOUNTED_ERROR, err);
michael@0 381 break;
michael@0 382 case EEXIST:
michael@0 383 PR_SetError(PR_DIRECTORY_NOT_EMPTY_ERROR, err);
michael@0 384 break;
michael@0 385 case EFAULT:
michael@0 386 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 387 break;
michael@0 388 case EINVAL:
michael@0 389 PR_SetError(PR_DIRECTORY_NOT_EMPTY_ERROR, err);
michael@0 390 break;
michael@0 391 case EIO:
michael@0 392 PR_SetError(PR_IO_ERROR, err);
michael@0 393 break;
michael@0 394 case ELOOP:
michael@0 395 PR_SetError(PR_LOOP_ERROR, err);
michael@0 396 break;
michael@0 397 case ETIMEDOUT:
michael@0 398 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 399 break;
michael@0 400 case ENAMETOOLONG:
michael@0 401 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 402 break;
michael@0 403 case ENOENT:
michael@0 404 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 405 break;
michael@0 406 case ENOTDIR:
michael@0 407 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 408 break;
michael@0 409 case EROFS:
michael@0 410 PR_SetError(PR_READ_ONLY_FILESYSTEM_ERROR, err);
michael@0 411 break;
michael@0 412 default:
michael@0 413 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 414 break;
michael@0 415 }
michael@0 416 }
michael@0 417
michael@0 418 void _MD_unix_map_read_error(int err)
michael@0 419 {
michael@0 420 switch (err) {
michael@0 421 case EACCES:
michael@0 422 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 423 break;
michael@0 424 case EAGAIN:
michael@0 425 #if EWOULDBLOCK != EAGAIN
michael@0 426 case EWOULDBLOCK:
michael@0 427 #endif
michael@0 428 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 429 break;
michael@0 430 case EBADF:
michael@0 431 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 432 break;
michael@0 433 #ifdef EBADMSG
michael@0 434 case EBADMSG:
michael@0 435 PR_SetError(PR_IO_ERROR, err);
michael@0 436 break;
michael@0 437 #endif
michael@0 438 case EDEADLK:
michael@0 439 PR_SetError(PR_DEADLOCK_ERROR, err);
michael@0 440 break;
michael@0 441 case EFAULT:
michael@0 442 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 443 break;
michael@0 444 case EINTR:
michael@0 445 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 446 break;
michael@0 447 case EINVAL:
michael@0 448 PR_SetError(PR_INVALID_METHOD_ERROR, err);
michael@0 449 break;
michael@0 450 case EIO:
michael@0 451 PR_SetError(PR_IO_ERROR, err);
michael@0 452 break;
michael@0 453 case ENOLCK:
michael@0 454 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 455 break;
michael@0 456 case ENXIO:
michael@0 457 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 458 break;
michael@0 459 case EISDIR:
michael@0 460 PR_SetError(PR_IS_DIRECTORY_ERROR, err);
michael@0 461 break;
michael@0 462 case ECONNRESET:
michael@0 463 case EPIPE:
michael@0 464 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 465 break;
michael@0 466 #ifdef ENOLINK
michael@0 467 case ENOLINK:
michael@0 468 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 469 break;
michael@0 470 #endif
michael@0 471 default:
michael@0 472 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 473 break;
michael@0 474 }
michael@0 475 }
michael@0 476
michael@0 477 void _MD_unix_map_write_error(int err)
michael@0 478 {
michael@0 479 switch (err) {
michael@0 480 case EAGAIN:
michael@0 481 #if EWOULDBLOCK != EAGAIN
michael@0 482 case EWOULDBLOCK:
michael@0 483 #endif
michael@0 484 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 485 break;
michael@0 486 case EBADF:
michael@0 487 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 488 break;
michael@0 489 case EDEADLK:
michael@0 490 PR_SetError(PR_DEADLOCK_ERROR, err);
michael@0 491 break;
michael@0 492 case EFAULT:
michael@0 493 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 494 break;
michael@0 495 case EFBIG:
michael@0 496 PR_SetError(PR_FILE_TOO_BIG_ERROR, err);
michael@0 497 break;
michael@0 498 case EINTR:
michael@0 499 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 500 break;
michael@0 501 case EINVAL:
michael@0 502 PR_SetError(PR_INVALID_METHOD_ERROR, err);
michael@0 503 break;
michael@0 504 case EIO:
michael@0 505 PR_SetError(PR_IO_ERROR, err);
michael@0 506 break;
michael@0 507 case ENOLCK:
michael@0 508 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 509 break;
michael@0 510 #ifdef ENOSR
michael@0 511 case ENOSR:
michael@0 512 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 513 break;
michael@0 514 #endif
michael@0 515 case ENOSPC:
michael@0 516 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 517 break;
michael@0 518 case ENXIO:
michael@0 519 PR_SetError(PR_INVALID_METHOD_ERROR, err);
michael@0 520 break;
michael@0 521 case ERANGE:
michael@0 522 PR_SetError(PR_INVALID_METHOD_ERROR, err);
michael@0 523 break;
michael@0 524 case ETIMEDOUT:
michael@0 525 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 526 break;
michael@0 527 case ECONNRESET:
michael@0 528 case EPIPE:
michael@0 529 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 530 break;
michael@0 531 #ifdef EDQUOT
michael@0 532 case EDQUOT:
michael@0 533 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 534 break;
michael@0 535 #endif
michael@0 536 #ifdef ENOLINK
michael@0 537 case ENOLINK:
michael@0 538 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 539 break;
michael@0 540 #endif
michael@0 541 default:
michael@0 542 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 543 break;
michael@0 544 }
michael@0 545 }
michael@0 546
michael@0 547 void _MD_unix_map_lseek_error(int err)
michael@0 548 {
michael@0 549 switch (err) {
michael@0 550 case EBADF:
michael@0 551 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 552 break;
michael@0 553 case ESPIPE:
michael@0 554 PR_SetError(PR_INVALID_METHOD_ERROR, err);
michael@0 555 break;
michael@0 556 case EINVAL:
michael@0 557 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 558 break;
michael@0 559 default:
michael@0 560 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 561 break;
michael@0 562 }
michael@0 563 }
michael@0 564
michael@0 565 void _MD_unix_map_fsync_error(int err)
michael@0 566 {
michael@0 567 switch (err) {
michael@0 568 case EBADF:
michael@0 569 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 570 break;
michael@0 571 #ifdef ENOLINK
michael@0 572 case ENOLINK:
michael@0 573 #endif
michael@0 574 case ETIMEDOUT:
michael@0 575 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 576 break;
michael@0 577 case EINTR:
michael@0 578 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 579 break;
michael@0 580 case EIO:
michael@0 581 PR_SetError(PR_IO_ERROR, err);
michael@0 582 break;
michael@0 583 case EINVAL:
michael@0 584 PR_SetError(PR_INVALID_METHOD_ERROR, err);
michael@0 585 break;
michael@0 586 default:
michael@0 587 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 588 break;
michael@0 589 }
michael@0 590 }
michael@0 591
michael@0 592 void _MD_unix_map_close_error(int err)
michael@0 593 {
michael@0 594 switch (err) {
michael@0 595 case EBADF:
michael@0 596 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 597 break;
michael@0 598 case EINTR:
michael@0 599 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 600 break;
michael@0 601 #ifdef ENOLINK
michael@0 602 case ENOLINK:
michael@0 603 #endif
michael@0 604 case ETIMEDOUT:
michael@0 605 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 606 break;
michael@0 607 case EIO:
michael@0 608 PR_SetError(PR_IO_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_unix_map_socket_error(int err)
michael@0 617 {
michael@0 618 switch (err) {
michael@0 619 case EPROTONOSUPPORT:
michael@0 620 PR_SetError(PR_PROTOCOL_NOT_SUPPORTED_ERROR, err);
michael@0 621 break;
michael@0 622 case EMFILE:
michael@0 623 PR_SetError(PR_PROC_DESC_TABLE_FULL_ERROR, err);
michael@0 624 break;
michael@0 625 case ENFILE:
michael@0 626 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 627 break;
michael@0 628 case EACCES:
michael@0 629 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 630 break;
michael@0 631 #if !defined(SCO)
michael@0 632 case ENOBUFS:
michael@0 633 #endif /* !defined(SCO) */
michael@0 634 case ENOMEM:
michael@0 635 #ifdef ENOSR
michael@0 636 case ENOSR:
michael@0 637 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 638 break;
michael@0 639 #endif
michael@0 640 default:
michael@0 641 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 642 break;
michael@0 643 }
michael@0 644 }
michael@0 645
michael@0 646 void _MD_unix_map_socketavailable_error(int err)
michael@0 647 {
michael@0 648 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 649 }
michael@0 650
michael@0 651 void _MD_unix_map_recv_error(int err)
michael@0 652 {
michael@0 653 switch (err) {
michael@0 654 case EAGAIN:
michael@0 655 #if EWOULDBLOCK != EAGAIN
michael@0 656 case EWOULDBLOCK:
michael@0 657 #endif
michael@0 658 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 659 break;
michael@0 660 case EBADF:
michael@0 661 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 662 break;
michael@0 663 #if !defined(BEOS)
michael@0 664 case ENOTSOCK:
michael@0 665 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 666 break;
michael@0 667 #endif
michael@0 668 case EINTR:
michael@0 669 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 670 break;
michael@0 671 case EFAULT:
michael@0 672 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 673 break;
michael@0 674 case ENOMEM:
michael@0 675 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 676 break;
michael@0 677 case ECONNRESET:
michael@0 678 case EPIPE:
michael@0 679 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 680 break;
michael@0 681 #ifdef ENOSR
michael@0 682 case ENOSR:
michael@0 683 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 684 break;
michael@0 685 #endif
michael@0 686 default:
michael@0 687 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 688 break;
michael@0 689 }
michael@0 690 }
michael@0 691
michael@0 692 void _MD_unix_map_recvfrom_error(int err)
michael@0 693 {
michael@0 694 switch (err) {
michael@0 695 case EAGAIN:
michael@0 696 #if EWOULDBLOCK != EAGAIN
michael@0 697 case EWOULDBLOCK:
michael@0 698 #endif
michael@0 699 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 700 break;
michael@0 701 case EBADF:
michael@0 702 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 703 break;
michael@0 704 #if !defined(BEOS)
michael@0 705 case ENOTSOCK:
michael@0 706 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 707 break;
michael@0 708 #endif
michael@0 709 case EINTR:
michael@0 710 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 711 break;
michael@0 712 case EFAULT:
michael@0 713 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 714 break;
michael@0 715 case ENOMEM:
michael@0 716 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 717 break;
michael@0 718 #ifdef ENOSR
michael@0 719 case ENOSR:
michael@0 720 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 721 break;
michael@0 722 #endif
michael@0 723 case ECONNRESET:
michael@0 724 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 725 break;
michael@0 726 default:
michael@0 727 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 728 break;
michael@0 729 }
michael@0 730 }
michael@0 731
michael@0 732 void _MD_unix_map_send_error(int err)
michael@0 733 {
michael@0 734 switch (err) {
michael@0 735 case EAGAIN:
michael@0 736 #if EWOULDBLOCK != EAGAIN
michael@0 737 case EWOULDBLOCK:
michael@0 738 #endif
michael@0 739 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 740 break;
michael@0 741 case EBADF:
michael@0 742 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 743 break;
michael@0 744 #if !defined(BEOS)
michael@0 745 case ENOTSOCK:
michael@0 746 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 747 break;
michael@0 748 #endif
michael@0 749 #if !defined(BEOS)
michael@0 750 case EMSGSIZE:
michael@0 751 #endif
michael@0 752 case EINVAL:
michael@0 753 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 754 break;
michael@0 755 #if !defined(SCO)
michael@0 756 case ENOBUFS:
michael@0 757 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 758 break;
michael@0 759 #endif /* !defined(SCO) */
michael@0 760 case ECONNREFUSED:
michael@0 761 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 762 break;
michael@0 763 case EISCONN:
michael@0 764 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 765 break;
michael@0 766 case EFAULT:
michael@0 767 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 768 break;
michael@0 769 case EINTR:
michael@0 770 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 771 break;
michael@0 772 case ENOMEM:
michael@0 773 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 774 break;
michael@0 775 #ifdef ENOSR
michael@0 776 case ENOSR:
michael@0 777 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 778 break;
michael@0 779 #endif
michael@0 780 case ECONNRESET:
michael@0 781 case EPIPE:
michael@0 782 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 783 break;
michael@0 784 default:
michael@0 785 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 786 break;
michael@0 787 }
michael@0 788 }
michael@0 789
michael@0 790 void _MD_unix_map_sendto_error(int err)
michael@0 791 {
michael@0 792 switch (err) {
michael@0 793 case EAGAIN:
michael@0 794 #if EWOULDBLOCK != EAGAIN
michael@0 795 case EWOULDBLOCK:
michael@0 796 #endif
michael@0 797 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 798 break;
michael@0 799 case EBADF:
michael@0 800 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 801 break;
michael@0 802 #if !defined(BEOS)
michael@0 803 case ENOTSOCK:
michael@0 804 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 805 break;
michael@0 806 #endif
michael@0 807 #if !defined(BEOS)
michael@0 808 case EMSGSIZE:
michael@0 809 #endif
michael@0 810 case EINVAL:
michael@0 811 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 812 break;
michael@0 813 #if !defined(SCO)
michael@0 814 case ENOBUFS:
michael@0 815 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 816 break;
michael@0 817 #endif /* !defined(SCO) */
michael@0 818 case ECONNREFUSED:
michael@0 819 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 820 break;
michael@0 821 case EISCONN:
michael@0 822 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 823 break;
michael@0 824 case EFAULT:
michael@0 825 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 826 break;
michael@0 827 case EINTR:
michael@0 828 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 829 break;
michael@0 830 case ENOMEM:
michael@0 831 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 832 break;
michael@0 833 #ifdef ENOSR
michael@0 834 case ENOSR:
michael@0 835 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 836 break;
michael@0 837 #endif
michael@0 838 case ECONNRESET:
michael@0 839 case EPIPE:
michael@0 840 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 841 break;
michael@0 842 default:
michael@0 843 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 844 break;
michael@0 845 }
michael@0 846 }
michael@0 847
michael@0 848 void _MD_unix_map_writev_error(int err)
michael@0 849 {
michael@0 850 switch (err) {
michael@0 851 case EAGAIN:
michael@0 852 #if EWOULDBLOCK != EAGAIN
michael@0 853 case EWOULDBLOCK:
michael@0 854 #endif
michael@0 855 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 856 break;
michael@0 857 case EBADF:
michael@0 858 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 859 break;
michael@0 860 case EFAULT:
michael@0 861 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 862 break;
michael@0 863 case EINTR:
michael@0 864 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 865 break;
michael@0 866 #ifdef ENOSR
michael@0 867 case ENOSR:
michael@0 868 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 869 break;
michael@0 870 #endif
michael@0 871 case EINVAL:
michael@0 872 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 873 break;
michael@0 874 case ECONNRESET:
michael@0 875 case EPIPE:
michael@0 876 PR_SetError(PR_CONNECT_RESET_ERROR, err);
michael@0 877 break;
michael@0 878 default:
michael@0 879 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 880 break;
michael@0 881 }
michael@0 882 }
michael@0 883
michael@0 884 void _MD_unix_map_accept_error(int err)
michael@0 885 {
michael@0 886 switch (err) {
michael@0 887 case EAGAIN:
michael@0 888 #if EWOULDBLOCK != EAGAIN
michael@0 889 case EWOULDBLOCK:
michael@0 890 #endif
michael@0 891 PR_SetError(PR_WOULD_BLOCK_ERROR, err);
michael@0 892 break;
michael@0 893 case EBADF:
michael@0 894 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 895 break;
michael@0 896 #if !defined(BEOS)
michael@0 897 case ENOTSOCK:
michael@0 898 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 899 break;
michael@0 900 #endif
michael@0 901 #if !defined(BEOS)
michael@0 902 case EOPNOTSUPP:
michael@0 903 #endif
michael@0 904 case ENODEV:
michael@0 905 PR_SetError(PR_NOT_TCP_SOCKET_ERROR, err);
michael@0 906 break;
michael@0 907 case EFAULT:
michael@0 908 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 909 break;
michael@0 910 case EMFILE:
michael@0 911 PR_SetError(PR_PROC_DESC_TABLE_FULL_ERROR, err);
michael@0 912 break;
michael@0 913 case ENFILE:
michael@0 914 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 915 break;
michael@0 916 case EINTR:
michael@0 917 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 918 break;
michael@0 919 case ENOMEM:
michael@0 920 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 921 break;
michael@0 922 #ifdef ENOSR
michael@0 923 case ENOSR:
michael@0 924 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 925 break;
michael@0 926 #endif
michael@0 927 #ifdef EPROTO
michael@0 928 case EPROTO:
michael@0 929 PR_SetError(PR_IO_ERROR, err);
michael@0 930 break;
michael@0 931 #endif
michael@0 932 default:
michael@0 933 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 934 break;
michael@0 935 }
michael@0 936 }
michael@0 937
michael@0 938 void _MD_unix_map_connect_error(int err)
michael@0 939 {
michael@0 940 switch (err) {
michael@0 941 case EBADF:
michael@0 942 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 943 break;
michael@0 944 case EADDRNOTAVAIL:
michael@0 945 PR_SetError(PR_ADDRESS_NOT_AVAILABLE_ERROR, err);
michael@0 946 break;
michael@0 947 case EINPROGRESS:
michael@0 948 PR_SetError(PR_IN_PROGRESS_ERROR, err);
michael@0 949 break;
michael@0 950 case EALREADY:
michael@0 951 PR_SetError(PR_ALREADY_INITIATED_ERROR, err);
michael@0 952 break;
michael@0 953 #if !defined(BEOS)
michael@0 954 case ENOTSOCK:
michael@0 955 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 956 break;
michael@0 957 #endif
michael@0 958 case EAFNOSUPPORT:
michael@0 959 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 960 break;
michael@0 961 case EISCONN:
michael@0 962 PR_SetError(PR_IS_CONNECTED_ERROR, err);
michael@0 963 break;
michael@0 964 case ETIMEDOUT:
michael@0 965 PR_SetError(PR_IO_TIMEOUT_ERROR, err);
michael@0 966 break;
michael@0 967 case ECONNREFUSED:
michael@0 968 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 969 break;
michael@0 970 case ENETUNREACH:
michael@0 971 PR_SetError(PR_NETWORK_UNREACHABLE_ERROR, err);
michael@0 972 break;
michael@0 973 case EADDRINUSE:
michael@0 974 PR_SetError(PR_ADDRESS_IN_USE_ERROR, err);
michael@0 975 break;
michael@0 976 case EFAULT:
michael@0 977 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 978 break;
michael@0 979 /*
michael@0 980 * UNIX domain sockets are not supported in NSPR
michael@0 981 */
michael@0 982 case EACCES:
michael@0 983 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 984 break;
michael@0 985 case EINTR:
michael@0 986 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 987 break;
michael@0 988 case EINVAL:
michael@0 989 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 990 break;
michael@0 991 case EIO:
michael@0 992 #if defined(UNIXWARE)
michael@0 993 /*
michael@0 994 * On some platforms, if we connect to a port on
michael@0 995 * the local host (the loopback address) that no
michael@0 996 * process is listening on, we get EIO instead
michael@0 997 * of ECONNREFUSED.
michael@0 998 */
michael@0 999 PR_SetError(PR_CONNECT_REFUSED_ERROR, err);
michael@0 1000 #else
michael@0 1001 PR_SetError(PR_IO_ERROR, err);
michael@0 1002 #endif
michael@0 1003 break;
michael@0 1004 case ELOOP:
michael@0 1005 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 1006 break;
michael@0 1007 case ENOENT:
michael@0 1008 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 1009 break;
michael@0 1010 #ifdef ENOSR
michael@0 1011 case ENOSR:
michael@0 1012 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1013 break;
michael@0 1014 #endif
michael@0 1015 case ENXIO:
michael@0 1016 PR_SetError(PR_IO_ERROR, err);
michael@0 1017 break;
michael@0 1018 case EPROTOTYPE:
michael@0 1019 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 1020 break;
michael@0 1021 default:
michael@0 1022 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1023 break;
michael@0 1024 }
michael@0 1025 }
michael@0 1026
michael@0 1027 void _MD_unix_map_bind_error(int err)
michael@0 1028 {
michael@0 1029 switch (err) {
michael@0 1030 case EBADF:
michael@0 1031 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1032 break;
michael@0 1033 #if !defined(BEOS)
michael@0 1034 case ENOTSOCK:
michael@0 1035 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1036 break;
michael@0 1037 #endif
michael@0 1038 case EFAULT:
michael@0 1039 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1040 break;
michael@0 1041 case EADDRNOTAVAIL:
michael@0 1042 PR_SetError(PR_ADDRESS_NOT_AVAILABLE_ERROR, err);
michael@0 1043 break;
michael@0 1044 case EADDRINUSE:
michael@0 1045 PR_SetError(PR_ADDRESS_IN_USE_ERROR, err);
michael@0 1046 break;
michael@0 1047 case EACCES:
michael@0 1048 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 1049 break;
michael@0 1050 case EINVAL:
michael@0 1051 PR_SetError(PR_SOCKET_ADDRESS_IS_BOUND_ERROR, err);
michael@0 1052 break;
michael@0 1053 #ifdef ENOSR
michael@0 1054 case ENOSR:
michael@0 1055 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1056 break;
michael@0 1057 #endif
michael@0 1058 /*
michael@0 1059 * UNIX domain sockets are not supported in NSPR
michael@0 1060 */
michael@0 1061 case EIO:
michael@0 1062 case EISDIR:
michael@0 1063 case ELOOP:
michael@0 1064 case ENOENT:
michael@0 1065 case ENOTDIR:
michael@0 1066 case EROFS:
michael@0 1067 PR_SetError(PR_ADDRESS_NOT_SUPPORTED_ERROR, err);
michael@0 1068 break;
michael@0 1069 default:
michael@0 1070 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1071 break;
michael@0 1072 }
michael@0 1073 }
michael@0 1074
michael@0 1075 void _MD_unix_map_listen_error(int err)
michael@0 1076 {
michael@0 1077 switch (err) {
michael@0 1078 case EBADF:
michael@0 1079 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1080 break;
michael@0 1081 #if !defined(BEOS)
michael@0 1082 case ENOTSOCK:
michael@0 1083 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1084 break;
michael@0 1085 #endif
michael@0 1086 #if !defined(BEOS)
michael@0 1087 case EOPNOTSUPP:
michael@0 1088 PR_SetError(PR_NOT_TCP_SOCKET_ERROR, err);
michael@0 1089 break;
michael@0 1090 #endif
michael@0 1091 default:
michael@0 1092 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1093 break;
michael@0 1094 }
michael@0 1095 }
michael@0 1096
michael@0 1097 void _MD_unix_map_shutdown_error(int err)
michael@0 1098 {
michael@0 1099 switch (err) {
michael@0 1100 case EBADF:
michael@0 1101 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1102 break;
michael@0 1103 #if !defined(BEOS)
michael@0 1104 case ENOTSOCK:
michael@0 1105 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1106 break;
michael@0 1107 #endif
michael@0 1108 case ENOTCONN:
michael@0 1109 PR_SetError(PR_NOT_CONNECTED_ERROR, err);
michael@0 1110 break;
michael@0 1111 case ENOMEM:
michael@0 1112 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 1113 break;
michael@0 1114 #ifdef ENOSR
michael@0 1115 case ENOSR:
michael@0 1116 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1117 break;
michael@0 1118 #endif
michael@0 1119 default:
michael@0 1120 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1121 break;
michael@0 1122 }
michael@0 1123 }
michael@0 1124
michael@0 1125 void _MD_unix_map_socketpair_error(int err)
michael@0 1126 {
michael@0 1127 switch (err) {
michael@0 1128 case EMFILE:
michael@0 1129 PR_SetError(PR_PROC_DESC_TABLE_FULL_ERROR, err);
michael@0 1130 break;
michael@0 1131 case EFAULT:
michael@0 1132 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1133 break;
michael@0 1134 case ENOMEM:
michael@0 1135 #ifdef ENOSR
michael@0 1136 case ENOSR:
michael@0 1137 #endif
michael@0 1138 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1139 break;
michael@0 1140 case EAFNOSUPPORT:
michael@0 1141 case EPROTONOSUPPORT:
michael@0 1142 #if !defined(BEOS)
michael@0 1143 case EOPNOTSUPP:
michael@0 1144 #endif
michael@0 1145 default:
michael@0 1146 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1147 break;
michael@0 1148 }
michael@0 1149 }
michael@0 1150
michael@0 1151 void _MD_unix_map_getsockname_error(int err)
michael@0 1152 {
michael@0 1153 switch (err) {
michael@0 1154 case EBADF:
michael@0 1155 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1156 break;
michael@0 1157 #if !defined(BEOS)
michael@0 1158 case ENOTSOCK:
michael@0 1159 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1160 break;
michael@0 1161 #endif
michael@0 1162 case EFAULT:
michael@0 1163 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1164 break;
michael@0 1165 #if !defined(SCO)
michael@0 1166 case ENOBUFS:
michael@0 1167 #endif /* !defined(SCO) */
michael@0 1168 case ENOMEM:
michael@0 1169 #ifdef ENOSR
michael@0 1170 case ENOSR:
michael@0 1171 #endif
michael@0 1172 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1173 break;
michael@0 1174 default:
michael@0 1175 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1176 break;
michael@0 1177 }
michael@0 1178 }
michael@0 1179
michael@0 1180 void _MD_unix_map_getpeername_error(int err)
michael@0 1181 {
michael@0 1182
michael@0 1183 switch (err) {
michael@0 1184 case EBADF:
michael@0 1185 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1186 break;
michael@0 1187 #if !defined(BEOS)
michael@0 1188 case ENOTSOCK:
michael@0 1189 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1190 break;
michael@0 1191 #endif
michael@0 1192 case ENOTCONN:
michael@0 1193 PR_SetError(PR_NOT_CONNECTED_ERROR, err);
michael@0 1194 break;
michael@0 1195 case EFAULT:
michael@0 1196 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1197 break;
michael@0 1198 #if !defined(SCO)
michael@0 1199 case ENOBUFS:
michael@0 1200 #endif /* !defined(SCO) */
michael@0 1201 case ENOMEM:
michael@0 1202 #ifdef ENOSR
michael@0 1203 case ENOSR:
michael@0 1204 #endif
michael@0 1205 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1206 break;
michael@0 1207 default:
michael@0 1208 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1209 break;
michael@0 1210 }
michael@0 1211 }
michael@0 1212
michael@0 1213 void _MD_unix_map_getsockopt_error(int err)
michael@0 1214 {
michael@0 1215 switch (err) {
michael@0 1216 case EBADF:
michael@0 1217 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1218 break;
michael@0 1219 #if !defined(BEOS)
michael@0 1220 case ENOTSOCK:
michael@0 1221 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1222 break;
michael@0 1223 #endif
michael@0 1224 case ENOPROTOOPT:
michael@0 1225 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 1226 break;
michael@0 1227 case EFAULT:
michael@0 1228 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1229 break;
michael@0 1230 case EINVAL:
michael@0 1231 PR_SetError(PR_BUFFER_OVERFLOW_ERROR, err);
michael@0 1232 break;
michael@0 1233 case ENOMEM:
michael@0 1234 #ifdef ENOSR
michael@0 1235 case ENOSR:
michael@0 1236 #endif
michael@0 1237 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1238 break;
michael@0 1239 default:
michael@0 1240 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1241 break;
michael@0 1242 }
michael@0 1243 }
michael@0 1244
michael@0 1245 void _MD_unix_map_setsockopt_error(int err)
michael@0 1246 {
michael@0 1247 switch (err) {
michael@0 1248 case EBADF:
michael@0 1249 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1250 break;
michael@0 1251 #if !defined(BEOS)
michael@0 1252 case ENOTSOCK:
michael@0 1253 PR_SetError(PR_NOT_SOCKET_ERROR, err);
michael@0 1254 break;
michael@0 1255 #endif
michael@0 1256 case ENOPROTOOPT:
michael@0 1257 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 1258 break;
michael@0 1259 case EFAULT:
michael@0 1260 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1261 break;
michael@0 1262 case EINVAL:
michael@0 1263 PR_SetError(PR_BUFFER_OVERFLOW_ERROR, err);
michael@0 1264 break;
michael@0 1265 case ENOMEM:
michael@0 1266 #ifdef ENOSR
michael@0 1267 case ENOSR:
michael@0 1268 #endif
michael@0 1269 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1270 break;
michael@0 1271 default:
michael@0 1272 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1273 break;
michael@0 1274 }
michael@0 1275 }
michael@0 1276
michael@0 1277 void _MD_unix_map_open_error(int err)
michael@0 1278 {
michael@0 1279 switch (err) {
michael@0 1280 case EACCES:
michael@0 1281 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 1282 break;
michael@0 1283 case EAGAIN:
michael@0 1284 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1285 break;
michael@0 1286 case EBUSY:
michael@0 1287 PR_SetError(PR_IO_ERROR, err);
michael@0 1288 break;
michael@0 1289 case EEXIST:
michael@0 1290 PR_SetError(PR_FILE_EXISTS_ERROR, err);
michael@0 1291 break;
michael@0 1292 case EFAULT:
michael@0 1293 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1294 break;
michael@0 1295 case EINTR:
michael@0 1296 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 1297 break;
michael@0 1298 case EINVAL:
michael@0 1299 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 1300 break;
michael@0 1301 case EIO:
michael@0 1302 PR_SetError(PR_IO_ERROR, err);
michael@0 1303 break;
michael@0 1304 case EISDIR:
michael@0 1305 PR_SetError(PR_IS_DIRECTORY_ERROR, err);
michael@0 1306 break;
michael@0 1307 case ELOOP:
michael@0 1308 PR_SetError(PR_LOOP_ERROR, err);
michael@0 1309 break;
michael@0 1310 case EMFILE:
michael@0 1311 PR_SetError(PR_PROC_DESC_TABLE_FULL_ERROR, err);
michael@0 1312 break;
michael@0 1313 case ENAMETOOLONG:
michael@0 1314 PR_SetError(PR_NAME_TOO_LONG_ERROR, err);
michael@0 1315 break;
michael@0 1316 case ENFILE:
michael@0 1317 PR_SetError(PR_SYS_DESC_TABLE_FULL_ERROR, err);
michael@0 1318 break;
michael@0 1319 case ENODEV:
michael@0 1320 case ENOENT:
michael@0 1321 case ENXIO:
michael@0 1322 PR_SetError(PR_FILE_NOT_FOUND_ERROR, err);
michael@0 1323 break;
michael@0 1324 case ENOMEM:
michael@0 1325 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1326 break;
michael@0 1327 case ENOSPC:
michael@0 1328 PR_SetError(PR_NO_DEVICE_SPACE_ERROR, err);
michael@0 1329 break;
michael@0 1330 #ifdef ENOSR
michael@0 1331 case ENOSR:
michael@0 1332 #endif
michael@0 1333 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1334 break;
michael@0 1335 case ENOTDIR:
michael@0 1336 PR_SetError(PR_NOT_DIRECTORY_ERROR, err);
michael@0 1337 break;
michael@0 1338 case EPERM:
michael@0 1339 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 1340 break;
michael@0 1341 case ETIMEDOUT:
michael@0 1342 PR_SetError(PR_REMOTE_FILE_ERROR, err);
michael@0 1343 break;
michael@0 1344 case EROFS:
michael@0 1345 PR_SetError(PR_READ_ONLY_FILESYSTEM_ERROR, err);
michael@0 1346 break;
michael@0 1347 default:
michael@0 1348 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1349 break;
michael@0 1350 }
michael@0 1351 }
michael@0 1352
michael@0 1353 void _MD_unix_map_mmap_error(int err)
michael@0 1354 {
michael@0 1355
michael@0 1356 switch (err) {
michael@0 1357 case EBADF:
michael@0 1358 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1359 break;
michael@0 1360 case EAGAIN:
michael@0 1361 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1362 break;
michael@0 1363 case EACCES:
michael@0 1364 PR_SetError(PR_NO_ACCESS_RIGHTS_ERROR, err);
michael@0 1365 break;
michael@0 1366 case ENOMEM:
michael@0 1367 PR_SetError(PR_OUT_OF_MEMORY_ERROR, err);
michael@0 1368 break;
michael@0 1369 default:
michael@0 1370 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1371 break;
michael@0 1372 }
michael@0 1373 }
michael@0 1374
michael@0 1375 void _MD_unix_map_gethostname_error(int err)
michael@0 1376 {
michael@0 1377 switch (err) {
michael@0 1378 case EFAULT:
michael@0 1379 PR_SetError(PR_ACCESS_FAULT_ERROR, err);
michael@0 1380 break;
michael@0 1381 default:
michael@0 1382 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1383 break;
michael@0 1384 }
michael@0 1385 }
michael@0 1386
michael@0 1387 void _MD_unix_map_select_error(int err)
michael@0 1388 {
michael@0 1389 switch (err) {
michael@0 1390 case EBADF:
michael@0 1391 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1392 break;
michael@0 1393 case EINTR:
michael@0 1394 PR_SetError(PR_PENDING_INTERRUPT_ERROR, err);
michael@0 1395 break;
michael@0 1396 case EINVAL:
michael@0 1397 PR_SetError(PR_INVALID_ARGUMENT_ERROR, err);
michael@0 1398 break;
michael@0 1399 default:
michael@0 1400 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1401 break;
michael@0 1402 }
michael@0 1403 }
michael@0 1404
michael@0 1405 void _MD_unix_map_poll_error(int err)
michael@0 1406 {
michael@0 1407 PRErrorCode prerror;
michael@0 1408 switch (err) {
michael@0 1409 case EAGAIN:
michael@0 1410 prerror = PR_INSUFFICIENT_RESOURCES_ERROR;
michael@0 1411 break;
michael@0 1412 case EINVAL:
michael@0 1413 prerror = PR_INVALID_ARGUMENT_ERROR;
michael@0 1414 break;
michael@0 1415 case EFAULT:
michael@0 1416 prerror = PR_ACCESS_FAULT_ERROR;
michael@0 1417 break;
michael@0 1418 default:
michael@0 1419 prerror = PR_UNKNOWN_ERROR;
michael@0 1420 break;
michael@0 1421 }
michael@0 1422 PR_SetError(prerror, err);
michael@0 1423 }
michael@0 1424
michael@0 1425 void _MD_unix_map_flock_error(int err)
michael@0 1426 {
michael@0 1427 switch (err) {
michael@0 1428 case EBADF:
michael@0 1429 case EINVAL:
michael@0 1430 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1431 break;
michael@0 1432 case EWOULDBLOCK:
michael@0 1433 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 1434 break;
michael@0 1435 default:
michael@0 1436 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1437 break;
michael@0 1438 }
michael@0 1439 }
michael@0 1440
michael@0 1441 void _MD_unix_map_lockf_error(int err)
michael@0 1442 {
michael@0 1443 switch (err) {
michael@0 1444 case EBADF:
michael@0 1445 PR_SetError(PR_BAD_DESCRIPTOR_ERROR, err);
michael@0 1446 break;
michael@0 1447 case EACCES:
michael@0 1448 PR_SetError(PR_FILE_IS_LOCKED_ERROR, err);
michael@0 1449 break;
michael@0 1450 case EDEADLK:
michael@0 1451 PR_SetError(PR_INSUFFICIENT_RESOURCES_ERROR, err);
michael@0 1452 break;
michael@0 1453 default:
michael@0 1454 PR_SetError(PR_UNKNOWN_ERROR, err);
michael@0 1455 break;
michael@0 1456 }
michael@0 1457 }
michael@0 1458
michael@0 1459 #ifdef HPUX11
michael@0 1460 void _MD_hpux_map_sendfile_error(int oserror)
michael@0 1461 {
michael@0 1462 PRErrorCode prerror;
michael@0 1463
michael@0 1464 switch (oserror) {
michael@0 1465 case ENOTSOCK:
michael@0 1466 prerror = PR_NOT_SOCKET_ERROR;
michael@0 1467 break;
michael@0 1468 case EFAULT:
michael@0 1469 prerror = PR_ACCESS_FAULT_ERROR;
michael@0 1470 break;
michael@0 1471 case ENOBUFS:
michael@0 1472 prerror = PR_INSUFFICIENT_RESOURCES_ERROR;
michael@0 1473 break;
michael@0 1474 case EINVAL:
michael@0 1475 prerror = PR_INVALID_ARGUMENT_ERROR;
michael@0 1476 break;
michael@0 1477 case ENOTCONN:
michael@0 1478 prerror = PR_NOT_CONNECTED_ERROR;
michael@0 1479 break;
michael@0 1480 case EPIPE:
michael@0 1481 prerror = PR_CONNECT_RESET_ERROR;
michael@0 1482 break;
michael@0 1483 case ENOMEM:
michael@0 1484 prerror = PR_OUT_OF_MEMORY_ERROR;
michael@0 1485 break;
michael@0 1486 case EOPNOTSUPP:
michael@0 1487 prerror = PR_NOT_TCP_SOCKET_ERROR;
michael@0 1488 break;
michael@0 1489 default:
michael@0 1490 prerror = PR_UNKNOWN_ERROR;
michael@0 1491 }
michael@0 1492 PR_SetError(prerror, oserror);
michael@0 1493 }
michael@0 1494 #endif /* HPUX11 */

mercurial