From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!.POSTED!not-for-mail From: =?iso-8859-1?Q?Vincent_Bela=EFche?= Newsgroups: gmane.emacs.devel Subject: RE: cal-tex.el landscape patch Date: Wed, 30 Aug 2017 09:45:07 +0000 Message-ID: References: , NNTP-Posting-Host: blaine.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable X-Trace: blaine.gmane.org 1504086366 21656 195.159.176.226 (30 Aug 2017 09:46:06 GMT) X-Complaints-To: usenet@blaine.gmane.org NNTP-Posting-Date: Wed, 30 Aug 2017 09:46:06 +0000 (UTC) Cc: Edward Reingold , emacs-devel To: Glenn Morris Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Wed Aug 30 11:46:01 2017 Return-path: Envelope-to: ged-emacs-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by blaine.gmane.org with esmtp (Exim 4.84_2) (envelope-from ) id 1dmzZO-0005FJ-Th for ged-emacs-devel@m.gmane.org; Wed, 30 Aug 2017 11:45:59 +0200 Original-Received: from localhost ([::1]:49369 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dmzZV-0006Wv-V2 for ged-emacs-devel@m.gmane.org; Wed, 30 Aug 2017 05:46:06 -0400 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:53271) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dmzYg-0006WJ-3r for emacs-devel@gnu.org; Wed, 30 Aug 2017 05:45:15 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dmzYc-00082L-RM for emacs-devel@gnu.org; Wed, 30 Aug 2017 05:45:14 -0400 Original-Received: from mail-oln040092065083.outbound.protection.outlook.com ([40.92.65.83]:2080 helo=EUR01-HE1-obe.outbound.protection.outlook.com) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1dmzYc-000817-EV; Wed, 30 Aug 2017 05:45:10 -0400 Original-Received: from DB5EUR01FT014.eop-EUR01.prod.protection.outlook.com (10.152.4.54) by DB5EUR01HT133.eop-EUR01.prod.protection.outlook.com (10.152.5.223) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id 15.1.1341.15; Wed, 30 Aug 2017 09:45:07 +0000 Original-Received: from AM5PR10MB0676.EURPRD10.PROD.OUTLOOK.COM (10.152.4.53) by DB5EUR01FT014.mail.protection.outlook.com (10.152.4.242) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1385.11 via Frontend Transport; Wed, 30 Aug 2017 09:45:07 +0000 Original-Received: from AM5PR10MB0676.EURPRD10.PROD.OUTLOOK.COM ([fe80::7809:87f5:3097:fd25]) by AM5PR10MB0676.EURPRD10.PROD.OUTLOOK.COM ([fe80::7809:87f5:3097:fd25%13]) with mapi id 15.01.1385.014; Wed, 30 Aug 2017 09:45:07 +0000 Thread-Topic: cal-tex.el landscape patch Thread-Index: AQHTGod4AUzM6bbSVkywIfPXHbKr+KKUSM/QgACExcWAAJSvKIAAB9aAgAFXIAqAAAhRq4ADTzsNgAJrbls= In-Reply-To: Accept-Language: fr-FR, en-US Content-Language: fr-FR X-MS-Has-Attach: X-MS-TNEF-Correlator: x-incomingtopheadermarker: OriginalChecksum:14BC2518D3EDBD1C53413657E5ADB9F8B49292ADDB137B2C36FE595AB39153D4; UpperCasedChecksum:F0290A4AA9726D8C635522A16F9EFE3279615E8EDE228C5DAADD9888F2826F82; SizeAsReceived:7604; Count:47 x-ms-exchange-messagesentrepresentingtype: 1 x-tmn: [E6MMkZ4dvoDW0GVLer6n5AMNy3k0dwUA] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1; DB5EUR01HT133; 6:8+xkWtRAOlfmkmbSs/X7PGaOMHmUSNQFrxVFrztrV0aZdXWhnct5T/zKCHgIACyWA71e6dJaiylyEdjSM9tZ98X/zXL2sOFedam1z84RqMULo2hPovi3kzhVsnfdId0Pdr7y0nWKlsxrtmnXndk9jJkijPSmNznNsQEq1GSc7p03k6AWnrPnStboutRDn4Zar54ZWIoIckUwWDz3/CaEbUHkzkiSnQtc76fbi7fcNP2liCqZVAvjFM/+vWsN5XgWSa5YpRVEsPx837w46sTBQ7ZsHstQ2Jh9fHZSws5dg+JNuZCkeoCbCcPCWwD9CZMMbwZqWsRFvLi3M3dLXuXXKw==; 5:So+qYlOhvGqHhQ4DNJ1fuHyAbao7SjT0SlYDetkLyXuK4tL5eCSUHW8WYcVS8P+YHvUFTO6qZUIihD7XtiO6SQREWullxuq29PxHj6JykcO7WqcD3fPe/zU0nWifnrgCzkfiSY2Rru1pEQdwsVV2fg==; 24:xQ4bDBIolyb45+U0v26+Y0y4g9/5urkELYUhzi0QDOnc4hAC281W2XbjRluhte0lf+Xv8EfKoO+MOSHWxkfMNYLwHXtd1mPA1zJS5UHzQZ4=; 7:7Mf87msHQVvbrC6e1DoXtax/BaOFd3//X1yDNK6HYLYBY2VEI74LdBCZDyvUcqZEejNShCUUe1MFNDL7eWbQkfga2InfDjojoq8gDbqZzUuL6ww8SPIZKXIg4UhhGnygoDw6V5VnxGT5kJqF4J+cwj9aQqEMU0PQq0qylmz1wgSzW6JQuODd047apTleCzPL6t0AxV4phR8Og/SGM6kcob8XqCevRkRb/ x-incomingheadercount: 47 x-eopattributedmessage: 0 x-ms-office365-filtering-correlation-id: 87514f19-cc62-488b-5e7a-08d4ef8bcc78 x-microsoft-antispam: UriScan:; BCL:0; PCL:0; RULEID:(300000500095)(300135000095)(300000501095)(300135300095)(300000502095)(300135100095)(22001)(300000503095)(300135400095)(201702061074)(5061506573)(5061507331)(1603103135)(2017031320274)(2017031324274)(2017031323274)(2017031322404)(1601125374)(1603101448)(1701031045)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095); SRVR:DB5EUR01HT133; x-ms-traffictypediagnostic: DB5EUR01HT133: authentication-results: outbound.protection.outlook.com; spf=skipped (originating message); dkim=none (message not signed) header.d=none; dmarc=none action=none header.from=hotmail.fr; x-exchange-antispam-report-test: UriScan:(22074186197030); x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(444000031); SRVR:DB5EUR01HT133; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:DB5EUR01HT133; x-forefront-prvs: 041517DFAB x-forefront-antispam-report: SFV:NSPM; SFS:(7070007)(98901004); DIR:OUT; SFP:1901; SCL:1; SRVR:DB5EUR01HT133; H:AM5PR10MB0676.EURPRD10.PROD.OUTLOOK.COM; FPR:; SPF:None; LANG:en; spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM X-OriginatorOrg: outlook.com X-MS-Exchange-CrossTenant-originalarrivaltime: 30 Aug 2017 09:45:07.5078 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Internet X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB5EUR01HT133 X-detected-operating-system: by eggs.gnu.org: Windows 7 or 8 [fuzzy] X-Received-From: 40.92.65.83 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: "Emacs-devel" Xref: news.gmane.org gmane.emacs.devel:217888 Archived-At: Hello, Comments below, De : Glenn Morris Envoy=E9 : lundi 28 ao=FBt 2017 19:55 =C0 : Vincent Bela=EFche Cc : Edward Reingold; emacs-devel Objet : Re: cal-tex.el landscape patch > >Thanks, comments below. > >> --- a/lisp/calendar/cal-tex.el >> +++ b/lisp/calendar/cal-tex.el >> @@ -259,12 +259,37 @@ cal-tex-list-diary-entries >>=A0 (defun cal-tex-preamble (&optional args) >>=A0=A0=A0 "Insert the LaTeX calendar preamble into `cal-tex-buffer'. >>=A0 Preamble includes initial definitions for various LaTeX commands. >> -Optional string ARGS are included as options for the article document c= lass." >> +Optional string ARGS are included as options for the article >> +document class with inclusion of default values \"12pt\" for >> +size, and \"a4paper\" for paper unless size or paper are already >> +specified in ARGS.=A0 When ARGS is omitted, by default the option >> +\"12pt,a4paper\" is passed. > >I think in hindsight my suggestion to default to 12pt was not a good >one, because it makes the argument parsing ugly. Sorry. So you mean that I should remove the argument parsing. But it cannot be removed all together because anyway I parse this argument to detect landscape option. >And please don't default to A4 paper, since the default locale for >Emacs is the US one (spelling etc). Would it be acceptable then if letterpaper is specified. Specifying the paper is a good idea because some latex distribution can be installed with a default paper size different from letterpaper. If we want \paperwidth and \paperheight defined to the correct value in the document so that the LaTeX code compute the cell size autonmously and the users can configure what paper size they want, then it is good that paper is explicitely defined. > >> +Please note that if ARGS is \"\" then >> +\"\\documentclass[]{article}\" is inserted, while if ARGS it `t' >> +then \"\\documentclass{article}\" is inserted." > >This doesn't seem like a nice interface.=A0 Why do you need the ARGS t >case when it can be nil? If nil, then the options list is the default one, that is in the case of my path `12pt,a4paper'. It could make that an empty string generates `\documentclass{article}' instead of `\documentclass[]{article}' that would remove the need of having the `t' case. I thought that it was good to let the function caller decide what they want in the output, but since `\documentclass{article}' and `\documentclass[]{article}' are equivalent this is not really usefull. > >>=A0=A0=A0 (set-buffer (generate-new-buffer cal-tex-buffer)) >> -=A0 (insert (format "\\documentclass%s{article}\n" >> -=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (if (stringp args) >> -=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (format= "[%s]" args) >> -=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 ""))) >> +=A0 (save-match-data >> +=A0=A0=A0 (insert (format "\\documentclass%s{article}\n" >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (cond >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 ((stringp = args) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 ;; set = default size >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (unless= (string-match "\\(^\\|,\\) *[0-9]+pt *\\(,\\|$\\)" args) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (= setq args (concat args ",12pt"))) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 ;; set = default paper >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (unless= (string-match "\\(^\\|,\\) *\\([ab][4-5]\\|le\\(tter\\|gal\\)\\|executive\= \)paper *\\(,\\|$\\)" args) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (= setq args (concat args ",a4paper"))) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (when (= string=3D (substring args 0 1) ",") >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (= setq args (substring args 1))) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 (format= "[%s]" args)) >> +=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0=A0 ((null arg= s) "[12pt]") Reading the patch, I realize that I did a mistake, it should have been =A0=A0 ((null args) "[12pt,a4paper]") Or with whatever paper size you want a default. >>=20 >> + (t "")))) > >This seems overly complicated to me. I see here the main point for acceptance of this patch. Would it be more acceptabe if the (string-match blah blah blah) would be replaced by some defsubst like (cal-tex-has-size-p args) (cal-tex-has-paper-p args) >Again, it was a bad suggestion of mine to have default values. As I wrote, having the paper size explicitely configured would help if different paper sizes are to be supported in the future. And this feature is part of the TO DO list at the beginning of cal-tex.el : ;; TO DO [...] ;;=A0=A0=A0=A0 (*)=A0 Make calendar styles for A4 paper. Now, this paper and point size defaults should certainly be some defcustom. Even more, there should be one first defcustom, call it cal-tex-default-options for all the types of calendars, and one other defcustom, call it cal-tex-default-options-alist, for types calendar that need some particular configuration different from cal-tex-default-options. >string-match-p would avoid the need to save-match-data. OK, noted. I will use this in the future. =A0 Vincent.=