From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail From: Maxim Cournoyer Newsgroups: gmane.lisp.guile.devel Subject: [PATCH v6 11/16] module: Add (scheme sort). Date: Sat, 2 Dec 2023 20:37:12 -0500 Message-ID: <20231203014115.26985-12-maxim.cournoyer@gmail.com> References: <20231203014115.26985-1-maxim.cournoyer@gmail.com> Mime-Version: 1.0 Content-Transfer-Encoding: 8bit Injection-Info: ciao.gmane.io; posting-host="blaine.gmane.org:116.202.254.214"; logging-data="29164"; mail-complaints-to="usenet@ciao.gmane.io" Cc: Maxim Cournoyer To: guile-devel@gnu.org Original-X-From: guile-devel-bounces+guile-devel=m.gmane-mx.org@gnu.org Sun Dec 03 02:42:34 2023 Return-path: Envelope-to: guile-devel@m.gmane-mx.org Original-Received: from lists.gnu.org ([209.51.188.17]) by ciao.gmane.io with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1r9bVB-0007Gq-3Q for guile-devel@m.gmane-mx.org; Sun, 03 Dec 2023 02:42:33 +0100 Original-Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1r9bUl-0001bp-5V; Sat, 02 Dec 2023 20:42:09 -0500 Original-Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1r9bUa-0001Rg-Mg for guile-devel@gnu.org; Sat, 02 Dec 2023 20:41:56 -0500 Original-Received: from mail-qk1-x72d.google.com ([2607:f8b0:4864:20::72d]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1r9bUL-0001YU-0V for guile-devel@gnu.org; Sat, 02 Dec 2023 20:41:56 -0500 Original-Received: by mail-qk1-x72d.google.com with SMTP id af79cd13be357-77dd54d9da2so229379385a.0 for ; Sat, 02 Dec 2023 17:41:40 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1701567700; x=1702172500; darn=gnu.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=iVNlEPwAkHGJb4bb1ILyKfk/qy/ZpWj3xa8Oy9EpJ6U=; b=ZYNsthPDcsPD5pCE217vJpSs8r2bf7BcaCIZU8GAPXR5uvGpW8y9quzdc5Y6Fjev/Q 1DX/SYqu0m1aJ2qd825KaQhT+//GVy/DGdzl05P2QKUK9Pxxl9RzWt6G4xC4E6Hq5Uxf qKcmZD8uVUtYyxT0JmqpR3Zr1dbSvJLeNB3M1RtFgZ8f7KrsTfqcKr2Co33Ii3evye5i aRT00johsgO5fSzfI+yb8G0MCicL6Kp6SFxyJj30iEPelAnT+MsLb4bSuSa+mjeO8lK6 XQvkDNgq5UJTlZMeXFCp/t0J2SpLJ88sid1OErTpSqZZdWZokeayAiapBwFvvyJZwntI TjMA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1701567700; x=1702172500; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=iVNlEPwAkHGJb4bb1ILyKfk/qy/ZpWj3xa8Oy9EpJ6U=; b=sfHy89RUbaEaMy9dWFtH2UOPi6VxYw+HmRZflwTLNP76iD3o/dgWlHnMCDS4akFLTz UVbc/gEt14fTTmV9Bmiajw8xiOZRVL0pv/N/2UPaKmvLWsg4jb0smfQasbCg+ZdQPD1Z ITSpNynA2bO44G9rD2GM69cmcKUhn8pBXl9l7CV/z0Kz8IsNkb48R874U1vbYEmlyb8m c09faKoS5HsecxmCezXBvx7GBxk0ua95jeX6k9GjYjbdTb741EiPWLkhdsxYK5EBr6ge 8Tjx9RTc7XC+1yE7AaLKwnIRwpMhk+pmPDSrhj+R5DecDX63vtls6/s+doZgLl9sGB0R adbw== X-Gm-Message-State: AOJu0YxKleInvm9w97tkj+VQQ4HXgYPsWgnKJAOoOOLQhba8CQyCubjo VEeLzz6uPTGYawfFWOyHc6kNseGMN4M= X-Google-Smtp-Source: AGHT+IH8tw4waOq+3Tw6/xJnNCJ2Vm+e0KpHEs7+23WhQE9CpEU1/xenuf8PVqE1bC6CWZdeHvzWig== X-Received: by 2002:a05:620a:5624:b0:77d:cfd8:e8e8 with SMTP id vv4-20020a05620a562400b0077dcfd8e8e8mr11385101qkn.74.1701567699806; Sat, 02 Dec 2023 17:41:39 -0800 (PST) Original-Received: from localhost.localdomain (dsl-10-141-196.b2b2c.ca. [72.10.141.196]) by smtp.gmail.com with ESMTPSA id t15-20020a05620a450f00b0077dca8ed9a4sm2869664qkp.133.2023.12.02.17.41.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 02 Dec 2023 17:41:39 -0800 (PST) X-Mailer: git-send-email 2.41.0 In-Reply-To: <20231203014115.26985-1-maxim.cournoyer@gmail.com> Received-SPF: pass client-ip=2607:f8b0:4864:20::72d; envelope-from=maxim.cournoyer@gmail.com; helo=mail-qk1-x72d.google.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_FROM=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: guile-devel@gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: "Developers list for Guile, the GNU extensibility library" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: guile-devel-bounces+guile-devel=m.gmane-mx.org@gnu.org Original-Sender: guile-devel-bounces+guile-devel=m.gmane-mx.org@gnu.org Xref: news.gmane.io gmane.lisp.guile.devel:22163 Archived-At: * module/scheme/sort.sld: New R7RS library shim for (rnrs sorting). * am/bootstrap.am (SOURCES): Register it. * NEWS: Update NEWS. --- (no changes since v5) Changes in v5: - Update NEWS NEWS | 1 + am/bootstrap.am | 1 + module/scheme/sort.sld | 21 +++++++++++++++++++++ 3 files changed, 23 insertions(+) create mode 100644 module/scheme/sort.sld diff --git a/NEWS b/NEWS index 45023d9fb..614a2bc7f 100644 --- a/NEWS +++ b/NEWS @@ -24,6 +24,7 @@ the compiler reports it as "possibly unused". ** Add (srfi 126), a hash tables library ** Add (srfi 128), a comparators library ** Add (scheme comparator) +** Add (scheme sort) * Bug fixes diff --git a/am/bootstrap.am b/am/bootstrap.am index 614d56d0d..e0517f69d 100644 --- a/am/bootstrap.am +++ b/am/bootstrap.am @@ -289,6 +289,7 @@ SOURCES = \ scheme/r5rs.scm \ scheme/read.scm \ scheme/repl.scm \ + scheme/sort.sld \ scheme/time.scm \ scheme/write.scm \ \ diff --git a/module/scheme/sort.sld b/module/scheme/sort.sld new file mode 100644 index 000000000..d8b560d1f --- /dev/null +++ b/module/scheme/sort.sld @@ -0,0 +1,21 @@ +;;; sorting.sld --- R7RS library exposing (rnrs sorting). + +;;; Copyright (C) 2023 Free Software Foundation, Inc. +;;; +;;; This library is free software: you can redistribute it and/or modify +;;; it under the terms of the GNU Lesser General Public License as +;;; published by the Free Software Foundation, either version 3 of the +;;; License, or (at your option) any later version. +;;; +;;; This library is distributed in the hope that it will be useful, but +;;; WITHOUT ANY WARRANTY; without even the implied warranty of +;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +;;; Lesser General Public License for more details. +;;; +;;; You should have received a copy of the GNU Lesser General Public +;;; License along with this program. If not, see +;;; . + +(define-library (scheme sort) + (export list-sort vector-sort vector-sort!) + (import (rnrs sorting))) -- 2.41.0