sha1sum.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #include <u.h>
  2. #include <libc.h>
  3. #include <bio.h>
  4. #include <libsec.h>
  5. #pragma varargck type "M" uchar*
  6. static int
  7. digestfmt(Fmt *fmt)
  8. {
  9. char buf[SHA1dlen*2+1];
  10. uchar *p;
  11. int i;
  12. p = va_arg(fmt->args, uchar*);
  13. for(i=0; i<SHA1dlen; i++)
  14. sprint(buf+2*i, "%.2ux", p[i]);
  15. return fmtstrcpy(fmt, buf);
  16. }
  17. static void
  18. sum(int fd, char *name)
  19. {
  20. int n;
  21. uchar buf[8192], digest[SHA1dlen];
  22. DigestState *s;
  23. s = sha1(nil, 0, nil, nil);
  24. while((n = read(fd, buf, sizeof buf)) > 0)
  25. sha1(buf, n, nil, s);
  26. if(n < 0){
  27. fprint(2, "reading %s: %r\n", name ? name : "stdin");
  28. return;
  29. }
  30. sha1(nil, 0, digest, s);
  31. if(name == nil)
  32. print("%M\n", digest);
  33. else
  34. print("%M\t%s\n", digest, name);
  35. }
  36. void
  37. main(int argc, char *argv[])
  38. {
  39. int i, fd;
  40. ARGBEGIN{
  41. default:
  42. fprint(2, "usage: sha1sum [file...]\n");
  43. exits("usage");
  44. }ARGEND
  45. fmtinstall('M', digestfmt);
  46. if(argc == 0)
  47. sum(0, nil);
  48. else for(i = 0; i < argc; i++){
  49. fd = open(argv[i], OREAD);
  50. if(fd < 0){
  51. fprint(2, "sha1sum: can't open %s: %r\n", argv[i]);
  52. continue;
  53. }
  54. sum(fd, argv[i]);
  55. close(fd);
  56. }
  57. exits(nil);
  58. }