From mboxrd@z Thu Jan 1 00:00:00 1970 From: Danny Milosavljevic Subject: bug#34531: Guix profile fails on Overdrive 1000 Date: Sun, 24 Feb 2019 13:12:07 +0100 Message-ID: <20190224131204.21fdc1e5@scratchpost.org> References: <20190218200552.GB1881@jurong> <87mumsom9l.fsf@fastmail.com> <20190219082728.GA5650@jurong> <87lg2bvrne.fsf@elephly.net> <20190219161954.47234638@scratchpost.org> <20190220115136.422bdf5b@scratchpost.org> <87va1eu1gp.fsf@elephly.net> <20190220142634.56868dba@scratchpost.org> <87k1hutpvw.fsf@elephly.net> <20190220172603.1a675f61@scratchpost.org> <87a7iq5gh8.fsf@elephly.net> <20190220230857.2282d9b1@scratchpost.org> <87ef7y3g61.fsf@elephly.net> <20190224114034.5f339ae3@scratchpost.org> <878sy52yw1.fsf@elephly.net> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; boundary="Sig_/C9Z09VBlqZncJLHLIJNgTVo"; protocol="application/pgp-signature" Return-path: Received: from eggs.gnu.org ([209.51.188.92]:56279) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gxseY-0005OJ-TD for bug-guix@gnu.org; Sun, 24 Feb 2019 07:13:08 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gxseX-0005WE-DO for bug-guix@gnu.org; Sun, 24 Feb 2019 07:13:06 -0500 Received: from debbugs.gnu.org ([209.51.188.43]:36328) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1gxseU-0005Un-11 for bug-guix@gnu.org; Sun, 24 Feb 2019 07:13:03 -0500 Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from ) id 1gxseT-0003ur-OO for bug-guix@gnu.org; Sun, 24 Feb 2019 07:13:01 -0500 Sender: "Debbugs-submit" Resent-Message-ID: In-Reply-To: <878sy52yw1.fsf@elephly.net> List-Id: Bug reports for GNU Guix List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: bug-guix-bounces+gcggb-bug-guix=m.gmane.org@gnu.org Sender: "bug-Guix" To: Ricardo Wurmus Cc: 34531@debbugs.gnu.org --Sig_/C9Z09VBlqZncJLHLIJNgTVo Content-Type: multipart/mixed; boundary="MP_/VpRHHE=oKH54+=l9R=eqpsl" --MP_/VpRHHE=oKH54+=l9R=eqpsl Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: quoted-printable Content-Disposition: inline Hi Ricardo, On Sun, 24 Feb 2019 12:45:34 +0100 Ricardo Wurmus wrote: > Danny Milosavljevic writes: >=20 > > Final version attached. Works fine now. =20 >=20 > The loop looks a bit more complicated than it needs to be, I think. Did > my version not work for you? It did, but I wanted to make sure the port did exactly the same as the original generate.py--maybe I overdid it, but I didn't want to break it by porting it. What skip_comments in the original does is strip comments, but not strip "comment-like things" that are in string literals ("/*blah*/"). (as far as I can tell, at least) I agree your version is easier but does it do the same thing? Attached a v2 where I fixed a bug in literal handling related to that (oops= ). WDYT? --MP_/VpRHHE=oKH54+=l9R=eqpsl Content-Type: text/x-scheme Content-Transfer-Encoding: quoted-printable Content-Disposition: attachment; filename=generate.scm ;; -*- geiser-scheme-implementation: guile -*- ;;; Implementation: Danny Milosavljevic ;;; Based on: Implementation in Python by Vicent Marti. ;;; License: ISC, like the original generate.py in clar. (use-modules (ice-9 ftw)) (use-modules (ice-9 regex)) (use-modules (ice-9 getopt-long)) (use-modules (ice-9 rdelim)) (use-modules (ice-9 match)) (use-modules (ice-9 textual-ports)) (use-modules (srfi srfi-1)) (define (render-callback cb) (if cb (string-append " { \"" (assoc-ref cb "short-name") "\", &" (assoc-ref cb "symbol") " }") " { NULL, NULL }")) (define (replace needle replacement haystack) "Replace all occurences of NEEDLE in HAYSTACK by REPLACEMENT. NEEDLE is a regular expression." (regexp-substitute/global #f needle haystack 'pre replacement 'post)) (define (skip-comments* text) (call-with-input-string text (lambda (port) (let loop ((result '()) (section #f)) (define (consume-char) (cons (read-char port) result)) (define (skip-char) (read-char port) result) (match section (#f (match (peek-char port) (#\/ (loop (consume-char) 'almost-in-block-comment)) (#\" (loop (consume-char) 'in-string-literal)) (#\' (loop (consume-char) 'in-character-literal)) ((? eof-object?) result) (_ (loop (consume-char) section)))) ('almost-in-block-comment (match (peek-char port) (#\* (loop (consume-char) 'in-block-comment)) (#\/ (loop (consume-char) 'in-line-comment)) ((? eof-object?) result) (_ (loop (consume-char) #f)))) ('in-line-comment (match (peek-char port) (#\newline (loop (consume-char) #f)) ((? eof-object?) result) (_ (loop (skip-char) section)))) ('in-block-comment (match (peek-char port) (#\* (loop (skip-char) 'almost-out-of-block-comment)) ((? eof-object?) result) (_ (loop (skip-char) section)))) ('almost-out-of-block-comment (match (peek-char port) (#\/ (loop (cons (read-char port) (cons #\* result)) #f)) (#\* (loop (skip-char) 'almost-out-of-block-comment)) ((? eof-object?) result) (_ (loop (skip-char) 'in-block-comment)))) ('in-string-literal (match (peek-char port) (#\\ (loop (consume-char) 'in-string-literal-escape)) (#\" (loop (consume-char) #f)) ((? eof-object?) result) (_ (loop (consume-char) section)))) ('in-string-literal-escape (match (peek-char port) ((? eof-object?) result) (_ (loop (consume-char) 'in-string-literal)))) ('in-character-literal (match (peek-char port) (#\\ (loop (consume-char) 'in-character-literal-escape)) (#\' (loop (consume-char) #f)) ((? eof-object?) result) (_ (loop (consume-char) section)))) ('in-character-literal-escape (match (peek-char port) ((? eof-object?) result) (_ (loop (consume-char) 'in-character-literal))))))))) (define (skip-comments text) (list->string (reverse (skip-comments* text)))) (define (maybe-only items) (match items ((a) a) (_ #f))) (define (Module name path excludes) (let* ((clean-name (replace "_" "::" name)) (enabled (not (any (lambda (exclude) (string-prefix? exclude clean-name)) excludes)))) (define (parse contents) (define (cons-match match prev) (cons `(("declaration" . ,(match:substring match 1)) ("symbol" . ,(match:substring match 2)) ("short-name" . ,(match:substring match 3))) prev)) (let* ((contents (skip-comments contents)) (entries (fold-matches (make-regexp (string-append "^(void\\s+(test_" name "__(\\w+))\\s*\\(\\s*vo= id\\s*\\))\\s*\\{") regexp/newline) contents '() cons-match)) (callbacks (filter (lambda (entry) (match (assoc-ref entry "short-name") ("initialize" #f) ("cleanup" #f) (_ #t))) entries))) (if (> (length callbacks) 0) `(("name" . ,name) ("enabled" . ,(if enabled "1" "0")) ("clean-name" . ,clean-name) ("initialize" . ,(maybe-only (filter-map (lambda (entry) (match (assoc-ref ent= ry "short-name") ("initialize" entry) (_ #f))) entries))) ("cleanup" . ,(maybe-only (filter-map (lambda (entry) (match (assoc-ref entry = "short-name") ("cleanup" entry) (_ #f))) entries))) ("callbacks" . ,callbacks)) #f))) (define (refresh path) (and (file-exists? path) (parse (call-with-input-file path get-string-all)))) (refresh path))) (define (generate-TestSuite path output excludes) (define (load) (define enter? (const #t)) (define (leaf file stat result) (let* ((module-root (string-drop (dirname file) (string-length path))) (module-root (filter-map (match-lambda ("" #f) (a a)) (string-split module-root #\/)))) (define (make-module path) (let* ((name (string-join (append module-root (list (string-d= rop-right (basename path) (string-length ".c")))) "_")) (name (replace "-" "_" name))) (Module name path excludes))) (if (string-suffix? ".c" file) (let ((module (make-module file))) (if module (cons module result) result)) result))) (define (down dir stat result) result) (define (up file state result) result) (define skip (const #f)) (define error (const #f)) ; FIXME (file-system-fold enter? leaf down up skip error '() path)) (define (CallbacksTemplate module) (string-append "static const struct clar_func _clar_cb_" (assoc-ref module "name") "[] =3D {\n" (string-join (map render-callback (assoc-ref module "callbacks")) ",\n") "\n};\n")) (define (DeclarationTemplate module) (string-append (string-join (map (lambda (cb) (string-append "extern " (assoc-ref cb "decl= aration") ";")) (assoc-ref module "callbacks")) "\n") "\n" (if (assoc-ref module "initialize") (string-append "extern " (assoc-ref (assoc-ref mod= ule "initialize") "declaration") ";\n") "") (if (assoc-ref module "cleanup") (string-append "extern " (assoc-ref (assoc-ref mod= ule "cleanup") "declaration") ";\n") ""))) (define (InfoTemplate module) (string-append " { \"" (assoc-ref module "clean-name") "\", " (render-callback (assoc-ref module "initialize")) ", " (render-callback (assoc-ref module "cleanup")) ", _clar_cb_" (assoc-ref module "name") ", " (number->string (length (assoc-ref module "callbacks"))) ", " (assoc-ref module "enabled") " }")) (define (Write data) (define (name< module-a module-b) (stringstring (suite-count))) (callback-count-str (number->string (callback-count)))) (display-x "static const size_t _clar_suite_count =3D ") (display-x suite-count-str) (display-x ";\n") (display-x "static const size_t _clar_callback_count =3D ") (display-x callback-count-str) (display-x ";\n") (display (string-append "Written `clar.suite` (" callback-count-str " tests in " suite-count-str " suites)")) (newline)) #t) (call-with-output-file (string-append output "/clar.suite") Write)) ;;; main (define (main) (define option-spec '((force (single-char #\f) (value #f)) (exclude (single-char #\x) (value #t)) (output (single-char #\o) (value #t)) (help (single-char #\h) (value #f)))) (define options (getopt-long (command-line) option-spec #:stop-at-first-n= on-option #t)) (define args (reverse (option-ref options '() '()))) (when (> (length args) 1) (display "More than one path given\n") (exit 1)) (if (< (length args) 1) (set! args '("."))) (let* ((path (car args)) (output (option-ref options 'output path)) (excluded (filter-map (match-lambda (('exclude . value) value) (_ #f)) options))) (generate-TestSuite path output excluded))) (main) --MP_/VpRHHE=oKH54+=l9R=eqpsl-- --Sig_/C9Z09VBlqZncJLHLIJNgTVo Content-Type: application/pgp-signature Content-Description: OpenPGP digital signature -----BEGIN PGP SIGNATURE----- iQEzBAEBCAAdFiEEds7GsXJ0tGXALbPZ5xo1VCwwuqUFAlxyihcACgkQ5xo1VCww uqUs5Af/f7aY+mEgiIxPAqTB6eND4vLo4XF0JdSQI5ZUKiQLJS4AlZhMeBY9QMh+ BRzF0nQqx+uNSARZ4xicAnDSPrKb+8xEeDNBmpxzeGNn889J/mx2TtQDVRdFpZDh B4edM97tpseoTKMZmKn9u+JrlZVIjA2VJ81iXF9z5WiCb0T6RUmDhszFk+V8+8Ce xFnz6jZr3WuVM9aeqTu9ehiOIHyWdpMwdXS973+9PABYRl9bmOL9fw5iKGy1XJLm v0r/yDLQYkYOmxLUXq4uEPBrCbuLAhh/Id1eQW6imW0orCVIVXg2zgJDnhv1l9ty PRJopkHQ6En1PmO54t8qnl2sYAIqgA== =RV1a -----END PGP SIGNATURE----- --Sig_/C9Z09VBlqZncJLHLIJNgTVo--