From 6d7496e846fa69d886a8f524003262f6d981cdf0 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Tue, 29 Feb 2000 06:34:39 +0000 Subject: Update. * crypt/crypt.texi: Moved to... * crypt/examples/genpass.c: Moved to... * manual/examples/genpass.c: ...here. * crypt/examples/mygenpass.c: Moved to... * manual/examples/mygenpass.c: ...here. * crypt/examples/testpass.c: Moved to... * manual/examples/testpass.c: ...here. * manual/Makefile (chapters): Add crypt. * manual/conf.texi: Add usual header for not-last chapter. * manual/crypt.texi: Add special header for last chapter. --- ChangeLog | 14 ++++++++++++-- crypt/examples/genpass.c | 32 -------------------------------- crypt/examples/mygetpass.c | 25 ------------------------- crypt/examples/testpass.c | 26 -------------------------- manual/Makefile | 5 +++-- manual/conf.texi | 4 +--- manual/crypt.texi | 3 ++- manual/examples/genpass.c | 32 ++++++++++++++++++++++++++++++++ manual/examples/mygetpass.c | 25 +++++++++++++++++++++++++ manual/examples/testpass.c | 26 ++++++++++++++++++++++++++ 10 files changed, 101 insertions(+), 91 deletions(-) delete mode 100644 crypt/examples/genpass.c delete mode 100644 crypt/examples/mygetpass.c delete mode 100644 crypt/examples/testpass.c create mode 100644 manual/examples/genpass.c create mode 100644 manual/examples/mygetpass.c create mode 100644 manual/examples/testpass.c diff --git a/ChangeLog b/ChangeLog index aebf39d283..d06207cd4c 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,7 +1,17 @@ 2000-02-28 Ulrich Drepper - * crypt/tcrypt.texi: Moved to... + * crypt/crypt.texi: Moved to... * manual/crypt.texi: ...here. + * crypt/examples/genpass.c: Moved to... + * manual/examples/genpass.c: ...here. + * crypt/examples/mygenpass.c: Moved to... + * manual/examples/mygenpass.c: ...here. + * crypt/examples/testpass.c: Moved to... + * manual/examples/testpass.c: ...here. + + * manual/Makefile (chapters): Add crypt. + * manual/conf.texi: Add usual header for not-last chapter. + * manual/crypt.texi: Add special header for last chapter. 2000-02-28 Geoff Keating @@ -9,7 +19,7 @@ * sysdeps/unix/sysv/linux/configure.in (inhibit_glue): Don't complain if there is no crypt add-on. * crypt/configure: Removed. - + * crypt/crypt.texi: Update documentation of US export restrictions to match the 14 Jan 2000 regulations. diff --git a/crypt/examples/genpass.c b/crypt/examples/genpass.c deleted file mode 100644 index a7626dbed5..0000000000 --- a/crypt/examples/genpass.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include -#include -#include - -int -main(void) -{ - unsigned long seed[2]; - char salt[] = "$1$........"; - const char *const seedchars = - "./0123456789ABCDEFGHIJKLMNOPQRST" - "UVWXYZabcdefghijklmnopqrstuvwxyz"; - char *password; - int i; - - /* Generate a (not very) random seed. - You should do it better than this... */ - seed[0] = time(NULL); - seed[1] = getpid() ^ (seed[0] >> 14 & 0x30000); - - /* Turn it into printable characters from `seedchars'. */ - for (i = 0; i < 8; i++) - salt[3+i] = seedchars[(seed[i/5] >> (i%5)*6) & 0x3f]; - - /* Read in the user's password and encrypt it. */ - password = crypt(getpass("Password:"), salt); - - /* Print the results. */ - puts(password); - return 0; -} diff --git a/crypt/examples/mygetpass.c b/crypt/examples/mygetpass.c deleted file mode 100644 index 6fe06f4637..0000000000 --- a/crypt/examples/mygetpass.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -ssize_t -my_getpass (char **lineptr, size_t *n, FILE *stream) -{ - struct termios old, new; - int nread; - - /* Turn echoing off and fail if we can't. */ - if (tcgetattr (fileno (stream), &old) != 0) - return -1; - new = old; - new.c_lflag &= ~ECHO; - if (tcsetattr (fileno (stream), TCSAFLUSH, &new) != 0) - return -1; - - /* Read the password. */ - nread = getline (lineptr, n, stream); - - /* Restore terminal. */ - (void) tcsetattr (fileno (stream), TCSAFLUSH, &old); - - return nread; -} diff --git a/crypt/examples/testpass.c b/crypt/examples/testpass.c deleted file mode 100644 index 5bd616d2a0..0000000000 --- a/crypt/examples/testpass.c +++ /dev/null @@ -1,26 +0,0 @@ -#include -#include -#include -#include - -int -main(void) -{ - /* Hashed form of "GNU libc manual". */ - const char *const pass = "$1$/iSaq7rB$EoUw5jJPPvAPECNaaWzMK/"; - - char *result; - int ok; - -/*@group*/ - /* Read in the user's password and encrypt it, - passing the expected password in as the salt. */ - result = crypt(getpass("Password:"), pass); -/*@end group*/ - - /* Test the result. */ - ok = strcmp (result, pass) == 0; - - puts(ok ? "Access granted." : "Access denied."); - return ok ? 0 : 1; -} diff --git a/manual/Makefile b/manual/Makefile index cc4e200c8a..51ada2c6af 100644 --- a/manual/Makefile +++ b/manual/Makefile @@ -55,7 +55,8 @@ chapters = $(addsuffix .texi, \ intro errno memory ctype string charset locale \ message search pattern io stdio llio filesys \ pipe socket terminal math arith time setjmp \ - signal startup process job nss users sysinfo conf) + signal startup process job nss users sysinfo conf\ + crypt) add-chapters = $(wildcard $(foreach d, $(add-ons), ../$d/$d.texi)) appendices = lang.texi header.texi install.texi maint.texi contrib.texi @@ -69,7 +70,7 @@ examples = $(filter-out $(foreach d, $(add-ons), ../$d/%.c.texi), \ $(filter %.c.texi, $(texis))) # Kludge: implicit rule so Make knows the one command does it all. -chapters.% top-menu.%: libc-texinfo.sh $(texis) +chapters.% top-menu.%: libc-texinfo.sh $(texis) Makefile AWK=$(AWK) $(SHELL) $< '$(chapters)' '$(add-chapters)' '$(appendices)' libc.dvi libc.pdf libc.info: chapters.texi top-menu.texi libm-err.texi diff --git a/manual/conf.texi b/manual/conf.texi index bd866eccaa..a684a5b2e2 100644 --- a/manual/conf.texi +++ b/manual/conf.texi @@ -1,6 +1,4 @@ -@c This node must have no pointers. -@node System Configuration -@c @node System Configuration, , System Information, Top +@node System Configuration, Cryptographic Functions, System Information, Top @c %MENU% Parameters describing operating system limits @chapter System Configuration Parameters diff --git a/manual/crypt.texi b/manual/crypt.texi index 1a4177a024..f17fab9b59 100644 --- a/manual/crypt.texi +++ b/manual/crypt.texi @@ -1,5 +1,6 @@ +@c This node must have no pointers. @node Cryptographic Functions -@c @node Cryptographic Functions, , Top, Top +@c @node Cryptographic Functions, , System Configuration, Top @chapter DES Encryption and Password Handling @c %MENU% DES encryption and password handling diff --git a/manual/examples/genpass.c b/manual/examples/genpass.c new file mode 100644 index 0000000000..a7626dbed5 --- /dev/null +++ b/manual/examples/genpass.c @@ -0,0 +1,32 @@ +#include +#include +#include +#include + +int +main(void) +{ + unsigned long seed[2]; + char salt[] = "$1$........"; + const char *const seedchars = + "./0123456789ABCDEFGHIJKLMNOPQRST" + "UVWXYZabcdefghijklmnopqrstuvwxyz"; + char *password; + int i; + + /* Generate a (not very) random seed. + You should do it better than this... */ + seed[0] = time(NULL); + seed[1] = getpid() ^ (seed[0] >> 14 & 0x30000); + + /* Turn it into printable characters from `seedchars'. */ + for (i = 0; i < 8; i++) + salt[3+i] = seedchars[(seed[i/5] >> (i%5)*6) & 0x3f]; + + /* Read in the user's password and encrypt it. */ + password = crypt(getpass("Password:"), salt); + + /* Print the results. */ + puts(password); + return 0; +} diff --git a/manual/examples/mygetpass.c b/manual/examples/mygetpass.c new file mode 100644 index 0000000000..6fe06f4637 --- /dev/null +++ b/manual/examples/mygetpass.c @@ -0,0 +1,25 @@ +#include +#include + +ssize_t +my_getpass (char **lineptr, size_t *n, FILE *stream) +{ + struct termios old, new; + int nread; + + /* Turn echoing off and fail if we can't. */ + if (tcgetattr (fileno (stream), &old) != 0) + return -1; + new = old; + new.c_lflag &= ~ECHO; + if (tcsetattr (fileno (stream), TCSAFLUSH, &new) != 0) + return -1; + + /* Read the password. */ + nread = getline (lineptr, n, stream); + + /* Restore terminal. */ + (void) tcsetattr (fileno (stream), TCSAFLUSH, &old); + + return nread; +} diff --git a/manual/examples/testpass.c b/manual/examples/testpass.c new file mode 100644 index 0000000000..5bd616d2a0 --- /dev/null +++ b/manual/examples/testpass.c @@ -0,0 +1,26 @@ +#include +#include +#include +#include + +int +main(void) +{ + /* Hashed form of "GNU libc manual". */ + const char *const pass = "$1$/iSaq7rB$EoUw5jJPPvAPECNaaWzMK/"; + + char *result; + int ok; + +/*@group*/ + /* Read in the user's password and encrypt it, + passing the expected password in as the salt. */ + result = crypt(getpass("Password:"), pass); +/*@end group*/ + + /* Test the result. */ + ok = strcmp (result, pass) == 0; + + puts(ok ? "Access granted." : "Access denied."); + return ok ? 0 : 1; +} -- cgit v1.2.3-70-g09d2