gpg: Distinguish between missing and cleared key flags.
authorWerner Koch <wk@gnupg.org>
Fri, 15 Mar 2013 14:46:03 +0000 (15:46 +0100)
committerWerner Koch <wk@gnupg.org>
Fri, 4 Oct 2013 06:53:49 +0000 (08:53 +0200)
commit0a805ed1604ef3e9b27f3e22a936a2d439300e9f
treef255228c486539274ac23acaea731795c6bc9440
parent89f6706ada132d40eb6043e7576d72b2f2c27019
gpg: Distinguish between missing and cleared key flags.

* include/cipher.h (PUBKEY_USAGE_NONE): New.
* g10/getkey.c (parse_key_usage): Set new flag.
--

We do not want to use the default capabilities (derived from the
algorithm) if any key flags are given in a signature.  Thus if key
flags are used in any way, the default key capabilities are never
used.

This allows to create a key with key flags set to all zero so it can't
be used.  This better reflects common sense.
(cherry picked from commit 4bde12206c5bf199dc6e12a74af8da4558ba41bf)
g10/getkey.c
include/cipher.h