diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2010-03-28 17:03:15 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2010-03-28 17:03:15 +0200 |
commit | 5d5e07be511d9f80de2b2b0bc20f59bd3fed82f5 (patch) | |
tree | 2026d5cf794ff534538b94ea167e9b0397994f7c /hurd/porting/guidelines.mdwn | |
parent | cb73320ae8e99626f783800459b1d5bae8bbfd02 (diff) | |
parent | 061ccb4858a2ac58af5663d0ff24bf6033427f19 (diff) |
Merge branch 'master' of flubber:~hurd-web/hurd-web
Diffstat (limited to 'hurd/porting/guidelines.mdwn')
-rw-r--r-- | hurd/porting/guidelines.mdwn | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/hurd/porting/guidelines.mdwn b/hurd/porting/guidelines.mdwn index bcfc8dd5..8dd27a52 100644 --- a/hurd/porting/guidelines.mdwn +++ b/hurd/porting/guidelines.mdwn @@ -232,3 +232,40 @@ Not implemented, not POSIX. Try to disable the feature in the package. ## <a name="parport"> <linux/parport.h> <linux/ppdev.h> </a> There is no programming interface for the parallel port on GNU/Hurd yet. + +## <a name="errno"> `errno` values </a> + +When dealing with `errno`, you should always use the predefined error codes defined with the `E*` constants, instead of manually comparing/assigning/etc with their values. + +For example (C/C++): + + /* check whether it does not exist */ + if (errno == 2) + ... + +or Python: + + # check whether it does not exist + try: + ... + except OSError, err: + err.errno == 2: + ... + +This is wrong, as [the actual values of the `E*` are unspecified (per POSIX)](http://www.opengroup.org/onlinepubs/009695399/functions/xsh_chap02_03.html#tag_02_03). You must always use the predefined constants for the possible errors. + +For example (C/C++): + + /* check whether it does not exist */ + if (errno == ENOENT) + ... + +With Python, you can use the [`errno` module](http://docs.python.org/library/errno.html) for the various constants: + + # check whether it does not exist + try: + ... + except OSError, err: + import errno + err.errno == errno.ENOENT: + ... |