md5sum.c 1009 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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[MD5dlen*2+1];
  10. uchar *p;
  11. int i;
  12. p = va_arg(fmt->args, uchar*);
  13. for(i=0; i<MD5dlen; 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[MD5dlen];
  22. DigestState *s;
  23. s = md5(nil, 0, nil, nil);
  24. while((n = read(fd, buf, sizeof buf)) > 0)
  25. md5(buf, n, nil, s);
  26. md5(nil, 0, digest, s);
  27. if(name == nil)
  28. print("%M\n", digest);
  29. else
  30. print("%M\t%s\n", digest, name);
  31. }
  32. void
  33. main(int argc, char *argv[])
  34. {
  35. int i, fd;
  36. ARGBEGIN{
  37. default:
  38. fprint(2, "usage: md5sum [file...]\n");
  39. exits("usage");
  40. }ARGEND
  41. fmtinstall('M', digestfmt);
  42. if(argc == 0)
  43. sum(0, nil);
  44. else for(i = 0; i < argc; i++){
  45. fd = open(argv[i], OREAD);
  46. if(fd < 0){
  47. fprint(2, "md5sum: can't open %s: %r\n", argv[i]);
  48. continue;
  49. }
  50. sum(fd, argv[i]);
  51. close(fd);
  52. }
  53. exits(nil);
  54. }