sort.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. #ifndef SCM_SORT_H
  2. #define SCM_SORT_H
  3. /* Copyright 1999-2000,2006,2008,2018
  4. Free Software Foundation, Inc.
  5. This file is part of Guile.
  6. Guile is free software: you can redistribute it and/or modify it
  7. under the terms of the GNU Lesser General Public License as published
  8. by the Free Software Foundation, either version 3 of the License, or
  9. (at your option) any later version.
  10. Guile is distributed in the hope that it will be useful, but WITHOUT
  11. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  12. FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
  13. License for more details.
  14. You should have received a copy of the GNU Lesser General Public
  15. License along with Guile. If not, see
  16. <https://www.gnu.org/licenses/>. */
  17. #include "libguile/scm.h"
  18. SCM_API SCM scm_restricted_vector_sort_x (SCM vec,
  19. SCM less,
  20. SCM startpos,
  21. SCM endpos);
  22. SCM_API SCM scm_sorted_p (SCM ls, SCM less);
  23. SCM_API SCM scm_merge (SCM ls1, SCM ls2, SCM less);
  24. SCM_API SCM scm_merge_x (SCM ls1, SCM ls2, SCM less);
  25. SCM_API SCM scm_sort (SCM ls, SCM less);
  26. SCM_API SCM scm_sort_x (SCM ls, SCM less);
  27. SCM_API SCM scm_stable_sort (SCM ls, SCM less);
  28. SCM_API SCM scm_stable_sort_x (SCM ls, SCM less);
  29. SCM_API SCM scm_sort_list (SCM ls, SCM less);
  30. SCM_API SCM scm_sort_list_x (SCM ls, SCM less);
  31. SCM_INTERNAL void scm_init_sort (void);
  32. #endif /* SCM_SORT_H */