mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	* 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.
		
			
				
	
	
		
			33 lines
		
	
	
		
			770 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			770 B
		
	
	
	
		
			C
		
	
	
	
	
	
#include <stdio.h>
 | 
						|
#include <time.h>
 | 
						|
#include <unistd.h>
 | 
						|
#include <crypt.h>
 | 
						|
 | 
						|
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;
 | 
						|
}
 |