Received: from mail.proteosys.com ([213.139.130.197]) by nummer-3.proteosys with Microsoft SMTPSVC(6.0.3790.3959); Mon, 10 Aug 2009 16:56:42 +0200 Received: by mail.proteosys.com (8.14.3/8.14.3) with ESMTP id n7AEuibl018837 for ; Mon, 10 Aug 2009 16:56:44 +0200 Received: from listserv.uni-heidelberg.de (listserv.uni-heidelberg.de [129.206.100.94]) by relay2.uni-heidelberg.de (8.13.8/8.13.8) with ESMTP id n7AEpjQC021502 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Mon, 10 Aug 2009 16:51:46 +0200 Received: from listserv.uni-heidelberg.de (localhost.localdomain [127.0.0.1]) by listserv.uni-heidelberg.de (8.13.1/8.13.1) with ESMTP id n7AABWJ3014993; Mon, 10 Aug 2009 16:51:38 +0200 Received: by LISTSERV.UNI-HEIDELBERG.DE (LISTSERV-TCP/IP release 15.5) with spool id 297308 for LATEX-L@LISTSERV.UNI-HEIDELBERG.DE; Mon, 10 Aug 2009 16:51:37 +0200 Received: from relay2.uni-heidelberg.de (relay2.uni-heidelberg.de [129.206.210.211]) by listserv.uni-heidelberg.de (8.13.1/8.13.1) with ESMTP id n7AEpbnD005619 for ; Mon, 10 Aug 2009 16:51:37 +0200 Received: from rv-out-0708.google.com (rv-out-0708.google.com [209.85.198.247]) by relay2.uni-heidelberg.de (8.13.8/8.13.8) with ESMTP id n7AEpWjK021330 for ; Mon, 10 Aug 2009 16:51:36 +0200 Received: by rv-out-0708.google.com with SMTP id c5so839508rvf.10 for ; Mon, 10 Aug 2009 07:51:32 -0700 (PDT) Received: by 10.140.133.16 with SMTP id g16mr1681119rvd.202.1249915892400; Mon, 10 Aug 2009 07:51:32 -0700 (PDT) Received: from ?10.0.1.103? (219-90-169-74.ip.adam.com.au [219.90.169.74]) by mx.google.com with ESMTPS id g31sm25414709rvb.26.2009.08.10.07.51.28 (version=TLSv1/SSLv3 cipher=RC4-MD5); Mon, 10 Aug 2009 07:51:30 -0700 (PDT) Content-Type: multipart/signed; boundary=Apple-Mail-7-1025744342; micalg=sha1; protocol="application/pkcs7-signature" Mime-Version: 1.0 (Apple Message framework v935.3) References: <4A7921CF.5020803@morningstar2.co.uk> <4A7A1505.4040604@residenset.net> <4A7AD930.2090106@residenset.net> X-Mailer: Apple Mail (2.935.3) X-Spam-Whitelist: Message-ID: <8516B615-51AA-4D90-BB7D-A9E122AA0335@gmail.com> Date: Tue, 11 Aug 2009 00:21:23 +0930 Reply-To: Mailing list for the LaTeX3 project Sender: Mailing list for the LaTeX3 project From: Will Robertson Subject: Re: xparse To: LATEX-L@LISTSERV.UNI-HEIDELBERG.DE In-Reply-To: <4A7AD930.2090106@residenset.net> Precedence: list List-Help: , List-Unsubscribe: List-Subscribe: List-Owner: List-Archive: X-ProteoSys-SPAM-Score: -6.599 () BAYES_00,RCVD_IN_DNSWL_MED X-Scanned-By: MIMEDefang 2.65 on 213.139.130.197 Return-Path: owner-latex-l@LISTSERV.UNI-HEIDELBERG.DE X-OriginalArrivalTime: 10 Aug 2009 14:56:42.0672 (UTC) FILETIME=[C5D63B00:01CA19CA] Status: R X-Status: X-Keywords: X-UID: 5859 --Apple-Mail-7-1025744342 Content-Type: text/plain; charset=ISO-8859-1; format=flowed; delsp=yes Content-Transfer-Encoding: quoted-printable Hi Lars, On 06/08/2009, at 10:52 PM, Lars Hellstr=F6m wrote: > The xdoc2l3 preprocessing is more about doing things to an argument =20= > after you've grabbed it, than about changing the conditions under =20 > which it is grabbed. [...] > and refer to the scratch variables \l_tmpa_tl, \l_tmpb_tl, etc. =20 > where the values are needed, we can have #1, #2, etc. be these =20 > cleaned-up values throughout the body. [...] > Just bear in mind that what seems esoteric today may be standard =20 > practice for the programming technique you'll learn tomorrow. Sorry for the slow reply; your idea finally clicked in my brain a few =20= days ago and the idea has kinda stuck. So let's say we want to define \foo that takes an argument but has to =20= sanitise it in some way before processing it: \DeclareDocumentCommand \foo {m} { \my_sanitise:Nn \l_sanitised_tl {#1} \foo_internal:V \l_sanitised_tl } \cs_new:Nn \my_sanitise:Nn { % do something with #1 and save it in \l_sanitised_tl } \cs_new:Nn \foo_internal:n { % do whatever \foo is supposed to do with #1 } \cs_generate_variant:Nn \foo_internal:n {V} =46rom my not in-depth understanding of xdoc2l3, this can be =20 dramatically simplified (I imagine) with something like \DeclareDocumentCommand \foo { ?{\my_sanitise:n} } { % do whatever \foo is supposed to do with #1 } Just to confirm -- have I got this thing sort of right? :) With this sort of example, it seems pretty clear that this can save a =20= lot of code that's just shuffling arguments around. (In the same way =20 that manual optional argument processing consists of lots of =20 intermediate functions that simply pass their arguments around.) Best regards, Will --Apple-Mail-7-1025744342 Content-Disposition: attachment; filename=smime.p7s Content-Type: application/pkcs7-signature; name=smime.p7s Content-Transfer-Encoding: base64 MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQEHAQAAoIIGITCCAtow ggJDoAMCAQICECN4qE5kBXLk2f/jVDfSZPwwDQYJKoZIhvcNAQEFBQAwYjELMAkGA1UEBhMCWkEx JTAjBgNVBAoTHFRoYXd0ZSBDb25zdWx0aW5nIChQdHkpIEx0ZC4xLDAqBgNVBAMTI1RoYXd0ZSBQ ZXJzb25hbCBGcmVlbWFpbCBJc3N1aW5nIENBMB4XDTA5MDEyOTA1NDkxNVoXDTEwMDEyOTA1NDkx NVowQjEfMB0GA1UEAxMWVGhhd3RlIEZyZWVtYWlsIE1lbWJlcjEfMB0GCSqGSIb3DQEJARYQd3Nw cjgxQGdtYWlsLmNvbTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL0BeSiAbKuqxeRN p2qn/m8ZL+xawr/WXyPgEF0FipWgRe9l3sMXcFHokcUu0xOc97R7xkUsGcQ8EyybGHuWey6x7X1Y xJZXnoAxqcaG+eREytoYGMIKs6BhEEogLVb2ERw3lQNVnOzanSFeGo8suMAN4zzCtqAjJiA1ph7h 1pksTgECYK5EiIZbFsB6zSDa8crNk404z1CfIA6YO8ezvjbDda+D0r8NU2tq9WS9F5IaG+bW71Ya JegEcSZ+WF6Z+fs2MUMCLLu8n50Er0nuy4dxOmkdMRNfbeaM39dsEwjAAgcQnvPNmlJ215nZWQRH 49YowtSBOYUYq0ZylWRE6x8CAwEAAaMtMCswGwYDVR0RBBQwEoEQd3NwcjgxQGdtYWlsLmNvbTAM BgNVHRMBAf8EAjAAMA0GCSqGSIb3DQEBBQUAA4GBABaRP8+PDYpKIRGlFgjs1HvMmJnqu4reSqp+ ulv0zJZIjIbX/sLbIsnecl9nycHfhubPdc+hDfpCqNZ2+NGQHwwoyuDl7KOdTY0BDPp3eJLio7ob EYEr0H8rFwqfx2LWJ0G6nMhNEjLvs7sFKyriSpk++TWJnnsf86xai5m0tlOwMIIDPzCCAqigAwIB AgIBDTANBgkqhkiG9w0BAQUFADCB0TELMAkGA1UEBhMCWkExFTATBgNVBAgTDFdlc3Rlcm4gQ2Fw ZTESMBAGA1UEBxMJQ2FwZSBUb3duMRowGAYDVQQKExFUaGF3dGUgQ29uc3VsdGluZzEoMCYGA1UE CxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjEkMCIGA1UEAxMbVGhhd3RlIFBlcnNv bmFsIEZyZWVtYWlsIENBMSswKQYJKoZIhvcNAQkBFhxwZXJzb25hbC1mcmVlbWFpbEB0aGF3dGUu Y29tMB4XDTAzMDcxNzAwMDAwMFoXDTEzMDcxNjIzNTk1OVowYjELMAkGA1UEBhMCWkExJTAjBgNV BAoTHFRoYXd0ZSBDb25zdWx0aW5nIChQdHkpIEx0ZC4xLDAqBgNVBAMTI1RoYXd0ZSBQZXJzb25h bCBGcmVlbWFpbCBJc3N1aW5nIENBMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDEpjxVc1X7 TrnKmVoeaMB1BHCd3+n/ox7svc31W/Iadr1/DDph8r9RzgHU5VAKMNcCY1osiRVwjt3J8CuFWqo/ cVbLrzwLB+fxH5E2JCoTzyvV84J3PQO+K/67GD4Hv0CAAmTXp6a7n2XRxSpUhQ9IBH+nttE8YQRA HmQZcmC3+wIDAQABo4GUMIGRMBIGA1UdEwEB/wQIMAYBAf8CAQAwQwYDVR0fBDwwOjA4oDagNIYy aHR0cDovL2NybC50aGF3dGUuY29tL1RoYXd0ZVBlcnNvbmFsRnJlZW1haWxDQS5jcmwwCwYDVR0P BAQDAgEGMCkGA1UdEQQiMCCkHjAcMRowGAYDVQQDExFQcml2YXRlTGFiZWwyLTEzODANBgkqhkiG 9w0BAQUFAAOBgQBIjNFQg+oLLswNo2asZw9/r6y+whehQ5aUnX9MIbj4Nh+qLZ82L8D0HFAgk3A8 /a3hYWLD2ToZfoSxmRsAxRoLgnSeJVCUYsfbJ3FXJY3dqZw5jowgT2Vfldr394fWxghOrvbqNOUQ Gls1TXfjViF4gtwhGTXeJLHTHUb/XV9lTzGCAxAwggMMAgEBMHYwYjELMAkGA1UEBhMCWkExJTAj BgNVBAoTHFRoYXd0ZSBDb25zdWx0aW5nIChQdHkpIEx0ZC4xLDAqBgNVBAMTI1RoYXd0ZSBQZXJz b25hbCBGcmVlbWFpbCBJc3N1aW5nIENBAhAjeKhOZAVy5Nn/41Q30mT8MAkGBSsOAwIaBQCgggFv MBgGCSqGSIb3DQEJAzELBgkqhkiG9w0BBwEwHAYJKoZIhvcNAQkFMQ8XDTA5MDgxMDE0NTEyNFow IwYJKoZIhvcNAQkEMRYEFPF9X6XDfO4wMWqqWYXRpQ37hu41MIGFBgkrBgEEAYI3EAQxeDB2MGIx CzAJBgNVBAYTAlpBMSUwIwYDVQQKExxUaGF3dGUgQ29uc3VsdGluZyAoUHR5KSBMdGQuMSwwKgYD VQQDEyNUaGF3dGUgUGVyc29uYWwgRnJlZW1haWwgSXNzdWluZyBDQQIQI3ioTmQFcuTZ/+NUN9Jk /DCBhwYLKoZIhvcNAQkQAgsxeKB2MGIxCzAJBgNVBAYTAlpBMSUwIwYDVQQKExxUaGF3dGUgQ29u c3VsdGluZyAoUHR5KSBMdGQuMSwwKgYDVQQDEyNUaGF3dGUgUGVyc29uYWwgRnJlZW1haWwgSXNz dWluZyBDQQIQI3ioTmQFcuTZ/+NUN9Jk/DANBgkqhkiG9w0BAQEFAASCAQAvO7iug1NokySTZ1D9 vsRw+AvegWuTCPKHM3x06yoahIGafFE8XfCqbfkO2rsBqrVrNO9QNDZOcfKemD4xvvLFciuWf9r7 f7Zf+49JfLgh9ExxUEqbS/6uEOWWj1FGysSxTJ7YfHqKpUq/Nv5JRCZNR/8lUxq4zq8t3E0FHLC+ 8fNOdrh2uwfHulsJIH8h6DHzVcUtR/OJX6TTNh0jgaHK7uQ/7lYQafXPRQx8Y11oglzbOWgsVd1u eDtRjUj5X7nJeJtmxqqnIG16L987neSjf8qhYG55DRA37/w4pgbJ8q9CFk7M8xftWEVG1xNGhrqh 6n4ZaNPkibhYEvjEEQSiAAAAAAAA --Apple-Mail-7-1025744342--