pub/scm/linux/kernel/git/jejb/gnupg.git  about / heads / tags
GnuPG with TPM2 key storage
$ git log --pretty=format:'%h %s (%cs)%d'
7262d602d common: Rename w32-misc.c to w32-cmdline.c (2021-03-04)
	(HEAD -> master)
089c94396 common,w32: Implement globing of command line args. (2021-03-04)
20c600768 common,w32: Refine the command line parsing for \ in quotes. (2021-03-04)
8e15506d6 gpg: Prepare for globing with UTF-8. (2021-03-04)
deb6c9436 common: First take on handling Unicode command line args. (2021-03-04)
be2da2445 gpg: Keep temp files when opening images via xdg-open (2021-03-01)
5ed1567e7 po: Make agent/commands.c translatable and update German translation. (2021-02-26)
f5897b3d2 po: Update Simplified Chinese Translation. (2021-02-26)
e54cd36bb doc: Typo fixes for dirmngr.texi (2021-02-25)
c032066d6 kbx: Log debug fixes (2021-02-25)
...

$ git cat-file blob HEAD:README
                       The GNU Privacy Guard 2
                      =========================
                         Version 2.3 (devel)

          Copyright 1997-2019 Werner Koch
          Copyright 1998-2021 Free Software Foundation, Inc.
          Copyright 2003-2021 g10 Code GmbH


* INTRODUCTION

  GnuPG is a complete and free implementation of the OpenPGP standard
  as defined by RFC4880 (also known as PGP).  GnuPG enables encryption
  and signing of data and communication, and features a versatile key
  management system as well as access modules for public key
  directories.

  GnuPG, also known as GPG, is a command line tool with features for
  easy integration with other applications.  A wealth of frontend
  applications and libraries are available that make use of GnuPG.
  Starting with version 2 GnuPG provides support for S/MIME and Secure
  Shell in addition to OpenPGP.

  GnuPG is Free Software (meaning that it respects your freedom). It
  can be freely used, modified and distributed under the terms of the
  GNU General Public License.

  Note that the 2.0 series of GnuPG will reach end-of-life on
  2017-12-31.  It is not possible to install a 2.2.x version along
  with any 2.0.x version.  However, it is possible to install GnuPG
  1.4 along with any 2.x version.


* BUILD INSTRUCTIONS

  GnuPG 2.3 depends on the following GnuPG related packages:

    npth         (https://gnupg.org/ftp/gcrypt/npth/)
    libgpg-error (https://gnupg.org/ftp/gcrypt/libgpg-error/)
    libgcrypt    (https://gnupg.org/ftp/gcrypt/libgcrypt/)
    libksba      (https://gnupg.org/ftp/gcrypt/libksba/)
    libassuan    (https://gnupg.org/ftp/gcrypt/libassuan/)

  You should get the latest versions of course, the GnuPG configure
  script complains if a version is not sufficient.

  Several other standard libraries are also required.  The configure
  script prints diagnostic messages if one of these libraries is not
  available and a feature will not be available..

  You also need the Pinentry package for most functions of GnuPG;
  however it is not a build requirement.  Pinentry is available at
  https://gnupg.org/ftp/gcrypt/pinentry/ .

  After building and installing the above packages in the order as
  given above, you may continue with GnuPG installation (you may also
  just try to build GnuPG to see whether your already installed
  versions are sufficient).

  As with all packages, you just have to do

    ./configure
    make
    make check
    make install

  The "make check" is optional but highly recommended.  To run even
  more tests you may add "--enable-all-tests" to the configure run.
  Before running the "make install" you might need to become root.

  If everything succeeds, you have a working GnuPG with support for
  OpenPGP, S/MIME, ssh-agent, and smartcards.

  In case of problem please ask on the gnupg-users@gnupg.org mailing
  list for advise.

  Instruction on how to build for Windows can be found in the file
  doc/HACKING in the section "How to build an installer for Windows".
  This requires some experience as developer.

  You may run

    gpgconf --list-dirs

  to view the directories used by GnuPG.

  To quickly build all required software without installing it, the
  Speedo method may be used:

    make -f build-aux/speedo.mk  native

  This method downloads all required libraries and does a native build
  of GnuPG to PLAY/inst/.  GNU make is required and you need to set
  LD_LIBRARY_PATH to $(pwd)/PLAY/inst/lib to test the binaries.

** Specific build problems on some machines:

*** Apple OSX 10.x using XCode

  On some versions the correct location of a header file can't be
  detected by configure.  To fix that you should run configure like
  this

    ./configure  gl_cv_absolute_stdint_h=/usr/include/stdint.h

  Add other options as needed.


*** Systems without a full C99 compiler

  If you run into problems with your compiler complaining about dns.c
  you may use

    ./configure --disable-libdns

  Add other options as needed.



* RECOMMENDATIONS

** Socket directory

  GnuPG uses Unix domain sockets to connect its components (on Windows
  an emulation of these sockets is used).  Depending on the type of
  the file system, it is sometimes not possible to use the GnuPG home
  directory (i.e. ~/.gnupg) as the location for the sockets.  To solve
  this problem GnuPG prefers the use of a per-user directory below the
  the /run (or /var/run) hierarchy for the the sockets.  It is thus
  suggested to create per-user directories on system or session
  startup.  For example the following snippet can be used in
  /etc/rc.local to create these directories:

      [ ! -d /run/user ] && mkdir /run/user
      awk -F: </etc/passwd '$3 >= 1000 && $3 < 65000 {print $3}' \
        | ( while read uid rest; do
              if [ ! -d "/run/user/$uid" ]; then
                mkdir /run/user/$uid
                chown $uid /run/user/$uid
                chmod 700 /run/user/$uid
              fi
            done )


* DOCUMENTATION

  The complete documentation is in the texinfo manual named
  `gnupg.info'.  Run "info gnupg" to read it.  If you want a a
  printable copy of the manual, change to the "doc" directory and
  enter "make pdf" For a HTML version enter "make html" and point your
  browser to gnupg.html/index.html.  Standard man pages for all
  components are provided as well.  An online version of the manual is
  available at [[https://gnupg.org/documentation/manuals/gnupg/]] .  A
  version of the manual pertaining to the current development snapshot
  is at [[https://gnupg.org/documentation/manuals/gnupg-devel/]] .


* Unsing the legacy version GnuPG 1.4

  The 1.4 version of GnuPG is only intended to allow decryption of old
  data material using legacy keys which are not anymore supported by
  GnuPG 2.x.  To install both versions alongside, it is suggested to
  rename the 1.4 version of "gpg" to "gpg1" as well as the
  corresponding man page.  Newer releases of the 1.4 branch will
  likely do this by default.


* HOW TO GET MORE INFORMATION

  A description of new features and changes since version 2.1 can be
  found in the file "doc/whats-new-in-2.1.txt" and online at
  "https://gnupg.org/faq/whats-new-in-2.1.html" .

  The primary WWW page is "https://gnupg.org"
  The primary FTP site is "https://gnupg.org/ftp/gcrypt/"

  See [[https://gnupg.org/download/mirrors.html]] for a list of
  mirrors and use them if possible.  You may also find GnuPG mirrored
  on some of the regular GNU mirrors.

  We have some mailing lists dedicated to GnuPG:

     gnupg-announce@gnupg.org   For important announcements like new
                                versions and such stuff.  This is a
                                moderated list and has very low traffic.
                                Do not post to this list.

     gnupg-users@gnupg.org      For general user discussion and
                                help (English).

     gnupg-de@gnupg.org         German speaking counterpart of
                                gnupg-users.

     gnupg-ru@gnupg.org         Russian speaking counterpart of
                                gnupg-users.

     gnupg-devel@gnupg.org      GnuPG developers main forum.

  You subscribe to one of the list by sending mail with a subject of
  "subscribe" to x-request@gnupg.org, where x is the name of the
  mailing list (gnupg-announce, gnupg-users, etc.). See
  https://gnupg.org/documentation/mailing-lists.html for archives
  of the mailing lists.

  Please direct bug reports to [[https://bugs.gnupg.org]] or post them
  direct to the mailing list <gnupg-devel@gnupg.org>.

  Please direct questions about GnuPG to the users mailing list or one
  of the PGP newsgroups; please do not direct questions to one of the
  authors directly as we are busy working on improvements and bug
  fixes.  The English and German mailing lists are watched by the
  authors and we try to answer questions when time allows us.

  Commercial grade support for GnuPG is available; for a listing of
  offers see https://gnupg.org/service.html .  Maintaining and
  improving GnuPG requires a lot of time.  Since 2001, g10 Code GmbH,
  a German company owned and headed by GnuPG's principal author Werner
  Koch, is bearing the majority of these costs.  To keep GnuPG in a
  healthy state, they need your support.

  Please consider to donate at https://gnupg.org/donate/ .


# This file is Free Software; as a special exception the authors gives
# unlimited permission to copy and/or distribute it, with or without
# modifications, as long as this notice is preserved. For conditions
# of the whole package, please see the file COPYING.  This file is
# distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY, to the extent permitted by law; without even the implied
# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#
# Local Variables:
# mode:org
# End:

# heads (aka `branches'):
$ git for-each-ref --sort=-creatordate refs/heads \
	--format='%(HEAD) %(refname:short) %(subject) (%(creatordate:short))'
  master-tpm-daemon Add Support for the Intel TSS (2021-03-09)
* master       common: Rename w32-misc.c to w32-cmdline.c (2021-03-04)
  stable-2-2-tpm-daemon tpm2daemon: convert to new options format (2021-01-16)
  stable-2-2   Release 2.2.27 (2021-01-11)

# tags:
$ git for-each-ref --sort=-creatordate refs/tags \
	--format='%(refname:short) %(subject) (%(creatordate:short))'
# no tags, yet...

# associated public inboxes:
# (number on the left is used for dev purposes)
        438 ../../../../../../../lkml
        117 qemu-devel
        112 netdev
        111 u-boot
         97 linux-arm-kernel
         71 stable
         54 linux-devicetree
         46 buildroot
         42 dpdk-dev
         42 dri-devel
         41 linux-fsdevel
         41 linux-mm
         41 linuxppc-dev
         38 xen-devel
         38 kvm
         38 intel-gfx
         37 git
         33 linux-media
         32 linux-wireless
         32 openembedded-core
         26 linux-xfs
         25 linux-scsi
         24 bpf
         24 alsa-devel
         20 linux-block
         20 linux-omap
         19 linux-samsung-soc
         18 netfilter-devel
         17 linux-gpio
         17 linux-bluetooth
         17 linux-arch
         16 linux-rdma
         16 amd-gfx
         15 linux-btrfs
         14 linux-crypto
         14 linux-mips
         14 linux-clk
         14 openembedded-devel
         13 linux-nfs
         13 linux-arm-msm
         13 kvmarm
         13 linux-doc
         12 ltp
         12 cluster-devel
         11 linux-mtd
         11 linux-acpi
         11 linux-fbdev
         10 linux-security-module
         10 linux-mmc
         10 linux-raid
          9 linux-nvme
          9 linux-mediatek
          9 linux-iommu
          9 linux-usb
          9 linux-pci
          9 linux-f2fs-devel
          9 virtualization
          9 linux-s390
          9 linux-patches
          9 qemu-riscv
          8 fstests
          8 linux-pm
          8 linux-renesas-soc
          8 selinux
          8 linux-ext4
          8 linux-ide
          8 linux-tegra
          8 linux-sh
          8 yocto
          7 linux-riscv
          7 linux-integrity
          7 linux-kselftest
          7 linux-serial
          7 linux-api
          7 linux-spi
          7 dm-devel
          7 linux-perf-users
          7 lustre-devel
          7 kernel-janitors
          7 kexec
          7 poky
          7 lvm-devel
          6 linux-amlogic
          6 linux-parisc
          6 linux-leds
          6 linux-sparse
          6 linux-can
          6 fio
          6 iwd
          6 linux-um
          5 linux-rtc
          5 linux-input
          5 driverdev-devel
          5 linux-iio
          5 dmaengine
          5 linux-watchdog
          5 linux-trace-devel
          5 rcu
          5 util-linux
          5 linux-audit
          5 ceph-devel
          5 linux-rockchip
          5 platform-driver-x86
          5 openbmc
          5 keyrings
          5 linux-sctp
          5 mptcp
          5 nvdimm
          5 yocto-meta-arago
          5 intel-wired-lan
          5 grub-devel
          5 kvm-ppc
          4 linux-fscrypt
          4 linux-nvdimm
          4 linux-next
          4 linux-hyperv
          4 linux-wpan
          4 backports
          4 linux-man
          4 linux-i2c
          4 linux-cxl
          4 ofono
          4 yocto-meta-ti
          4 openrisc
          4 batman
          4 intel-xe
          4 lvs-devel
          4 igt-dev
          3 cocci
          3 linux-efi
          3 linux-cifs
          3 linux-snps-arc
          3 linux-hwmon
          3 kernel-hardening
          3 linux-rt-users
          3 io-uring
          3 lttng-dev
          3 linux-kbuild
          3 containers
          3 ath10k
          3 ath11k
          3 sparclinux
          3 linux-staging
          3 llvm
          3 yocto-meta-arm
          3 yocto-docs
          3 outreachy
          3 cgroups
          3 linux-alpha
          3 linux-hams
          3 linux-hexagon
          3 linux-nilfs
          3 lm-sensors
          3 perfbook
          2 linux-edac
          2 linux-erofs
          2 linux-modules
          2 linux-m68k
          2 linux-csky
          2 linux-remoteproc
          2 linux-bcache
          2 xdp-newbies
          2 phone-devel
          2 target-devel
          2 soc
          2 ocfs2-devel
          2 nouveau
          2 linux-phy
          2 linux-sunxi
          2 linux-coco
          2 linux-bcachefs
          2 ell
          2 yocto-meta-freescale
          2 yocto-toaster
          2 bitbake-devel
          2 yocto-meta-virtualization
          2 chrome-platform
          2 ntb
          2 loongarch
          2 ath12k
          2 linux-trace-kernel
          2 fsverity
          2 virtio-comment
          2 linux-ia64
          2 autofs
          2 dccp
          2 initramfs
          2 linux-btrace
          2 reiserfs-devel
          2 linux-x25
          2 bridge
          2 virtio-fs
          2 fuego
          1 live-patching
          1 kernelnewbies
          1 linux-sgx
          1 workflows
          1 selinux-refpolicy
          1 linux-i3c
          1 linux-spdx
          1 ksummit-discuss
          1 wireguard
          1 linux-kernel-mentees
          1 tpmdd-devel
          1 linux-unionfs
          1 linux-firmware
          1 cip-dev
          1 linux-dash
          1 mm-commits
          1 linux-pwm
          1 linux-fpga
          1 linux-hardening
          1 dash
          1 rust-for-linux
          1 regressions
          1 ksummit
          1 b43-dev
          1 linux-nfc
          1 ath9k-devel
          1 ntfs3
          1 xenomai
          1 damon
          1 asahi
          1 imx
          1 b4-sent
          1 oe-lkp
          1 oe-linux-nfc
          1 oe-kbuild-all
          1 oe-chipsec
          1 virtio-dev
          1 v9fs
          1 ecryptfs
          1 kbd
          1 cpufreq
          1 devicetree-spec
          1 devicetree-compiler
          1 hail-devel
          1 kvm-ia64
          1 linux-8086
          1 kernel-testers
          1 linux-embedded
          1 linux-hotplug
          1 linux-laptop
          1 linux-sound
          1 trinity
          1 linux-metag
          1 netfilter
          1 linux-oxnas
          1 u-boot-amlogic
          1 acpica-devel
          1 smatch
          1 wireless-regdb
          1 powertop

git clone https://yhbt.net/lore/pub/scm/linux/kernel/git/jejb/gnupg.git