bytesperline.c 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /*
  2. * This file is part of the UCB release of Plan 9. It is subject to the license
  3. * terms in the LICENSE file found in the top-level directory of this
  4. * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
  5. * part of the UCB release of Plan 9, including this file, may be copied,
  6. * modified, propagated, or distributed except according to the terms contained
  7. * in the LICENSE file.
  8. */
  9. #include <u.h>
  10. #include <libc.h>
  11. #include <draw.h>
  12. static
  13. int
  14. unitsperline(Rectangle r, int d, int bitsperunit)
  15. {
  16. uint32_t l, t;
  17. if(d <= 0 || d > 32) /* being called wrong. d is image depth. */
  18. abort();
  19. if(r.min.x >= 0){
  20. l = (r.max.x*d+bitsperunit-1)/bitsperunit;
  21. l -= (r.min.x*d)/bitsperunit;
  22. }else{ /* make positive before divide */
  23. t = (-r.min.x*d+bitsperunit-1)/bitsperunit;
  24. l = t+(r.max.x*d+bitsperunit-1)/bitsperunit;
  25. }
  26. return l;
  27. }
  28. int
  29. wordsperline(Rectangle r, int d)
  30. {
  31. return unitsperline(r, d, 8*sizeof(uint32_t));
  32. }
  33. int
  34. bytesperline(Rectangle r, int d)
  35. {
  36. return unitsperline(r, d, 8);
  37. }