This manual page is part of Xcode Tools version 3.2.2

To obtain these tools:

If you are running a version of Xcode Tools other than 3.2.2, view the documentation locally:

  • In Xcode

  • In Terminal, using the man(1) command

Reading manual pages

Manual pages are intended as a quick reference for people who already understand a technology.

  • For more information about the manual page format, see the manual page for manpages(5).

  • For more information about this technology, look for other documentation in the Apple Reference Library.

  • For general information about writing shell scripts, read Shell Scripting Primer.



CHDIR(2)                                   BSD System Calls Manual                                  CHDIR(2)

NAME
     chdir, fchdir -- change current working directory

SYNOPSIS
     #include <unistd.h>

     int
     chdir(const char *path);

     int
     fchdir(int fildes);

DESCRIPTION
     The path argument points to the pathname of a directory.  The chdir() function causes the named direc-tory directory
     tory to become the current working directory, that is, the starting point for path searches of path-names pathnames
     names not beginning with a slash, `/'.

     The fchdir() function causes the directory referenced by fildes to become the current working direc-tory, directory,
     tory, the starting point for path searches of pathnames not beginning with a slash, `/'.

     In order for a directory to become the current directory, a process must have execute (search) access
     to the directory.

RETURN VALUES
     Upon successful completion, a value of 0 is returned.  Otherwise, a value of -1 is returned and errno
     is set to indicate the error.

ERRORS
     The Chdir() system call will fail and the current working directory will be unchanged if one or more of
     the following are true:

     [EACCES]           Search permission is denied for any component of the path name.

     [EFAULT]           Path points outside the process's allocated address space.

     [EIO]              An I/O error occurred while reading from or writing to the file system.

     [ELOOP]            Too many symbolic links were encountered in translating the pathname.  This is taken
                        to be indicative of a looping symbolic link.

     [ENAMETOOLONG]     A component of a pathname exceeded {NAME_MAX} characters, or an entire path name
                        exceeded {PATH_MAX} characters.

     [ENOENT]           The named directory does not exist.

     [ENOTDIR]          A component of the path prefix is not a directory.

     Fchdir() will fail and the current working directory will be unchanged if one or more of the following
     are true:

     [EACCES]           Search permission is denied for the directory referenced by the file descriptor.

     [EBADF]            The argument fildes is not a valid file descriptor.

     [EINTR]            Fchdir() was interrupted by a signal.

     [EIO]              An I/O error occurred while reading from or writing to the file system.

     [ENOTDIR]          The file descriptor does not reference a directory.

SEE ALSO
     chroot(2)

STANDARDS
     The chdir() is expected to conform to IEEE Std 1003.1-1988 (``POSIX.1'').

HISTORY
     The fchdir() function call appeared in 4.2BSD.

4th Berkeley Distribution                     December 11, 1993                    4th Berkeley Distribution

Reporting Problems

The way to report a problem with this manual page depends on the type of problem:

Content errors
Report errors in the content of this documentation with the feedback links below.
Bug reports
Report bugs in the functionality of the described tool or API through Bug Reporter.
Formatting problems
Report formatting mistakes in the online version of these pages with the feedback links below.

Did this document help you? Yes It's good, but... Not helpful...