randomize.C 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. * CDE - Common Desktop Environment
  3. *
  4. * Copyright (c) 1993-2012, The Open Group. All rights reserved.
  5. *
  6. * These libraries and programs are free software; you can
  7. * redistribute them and/or modify them under the terms of the GNU
  8. * Lesser General Public License as published by the Free Software
  9. * Foundation; either version 2 of the License, or (at your option)
  10. * any later version.
  11. *
  12. * These libraries and programs are distributed in the hope that
  13. * they will be useful, but WITHOUT ANY WARRANTY; without even the
  14. * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  15. * PURPOSE. See the GNU Lesser General Public License for more
  16. * details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with these libraries and programs; if not, write
  20. * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
  21. * Floor, Boston, MA 02110-1301 USA
  22. */
  23. // $XConsortium: randomize.cc /main/3 1996/06/11 17:38:40 cde-hal $
  24. #include "utility/randomize.h"
  25. randomize::randomize(int sd) : rdn(sd)
  26. {
  27. }
  28. void randomize::scramble(buffer& original)
  29. {
  30. int bytes = original.content_sz();
  31. char* buf = original.get_base();
  32. for ( int i=0; i<bytes-1; i++ )
  33. char_swap(buf[i], buf[rdn.rand() % ( bytes - i ) + i]);
  34. }
  35. void randomize::restore(buffer& scrambled)
  36. {
  37. int bytes = scrambled.content_sz();
  38. char* buf = scrambled.get_base();
  39. int *pos = new int[bytes-1];
  40. int i;
  41. for ( i=0; i<bytes-1; i++ ) {
  42. pos[i] = rdn.rand() % ( bytes - i ) + i;
  43. }
  44. for ( i=bytes-2; i>=0; i-- ) {
  45. char_swap(buf[i], buf[pos[i]]);
  46. }
  47. delete [] pos;
  48. }