github.com/benhoyt/goawk@v1.8.1/testdata/gawk/uninit5.awk (about) 1 #From gregfjohnson@yahoo.com Sun Aug 30 08:36:36 2009 2 #Return-Path: <gregfjohnson@yahoo.com> 3 #Received: from aahz (localhost [127.0.0.1]) 4 # by skeeve.com (8.14.1/8.14.1) with ESMTP id n7U5WoJ2003836 5 # for <arnold@localhost>; Sun, 30 Aug 2009 08:36:36 +0300 6 #X-Spam-Checker-Version: SpamAssassin 3.2.4 (2008-01-01) on server1.f7.net 7 #X-Spam-Level: 8 #X-Spam-Status: No, score=-6.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED 9 # autolearn=ham version=3.2.4 10 #X-Envelope-From: gregfjohnson@yahoo.com 11 #X-Envelope-To: <arnold@skeeve.com> 12 #Received: from server1.f7.net [64.34.169.74] 13 # by aahz with IMAP (fetchmail-6.3.7) 14 # for <arnold@localhost> (single-drop); Sun, 30 Aug 2009 08:36:36 +0300 (IDT) 15 #Received: from fencepost.gnu.org (fencepost.gnu.org [140.186.70.10]) 16 # by f7.net (8.11.7-20030920/8.11.7) with ESMTP id n7U33m709453 17 # for <arnold@skeeve.com>; Sat, 29 Aug 2009 22:03:48 -0500 18 #Received: from mail.gnu.org ([199.232.76.166]:42095 helo=mx10.gnu.org) 19 # by fencepost.gnu.org with esmtp (Exim 4.67) 20 # (envelope-from <gregfjohnson@yahoo.com>) 21 # id 1Mhai6-0004Qt-3R 22 # for bug-gawk@gnu.org; Sat, 29 Aug 2009 23:04:06 -0400 23 #Received: from Debian-exim by monty-python.gnu.org with spam-scanned (Exim 4.60) 24 # (envelope-from <gregfjohnson@yahoo.com>) 25 # id 1Mhai5-00062I-EM 26 # for bug-gawk@gnu.org; Sat, 29 Aug 2009 23:04:05 -0400 27 #Received: from web33507.mail.mud.yahoo.com ([68.142.206.156]:28597) 28 # by monty-python.gnu.org with smtp (Exim 4.60) 29 # (envelope-from <gregfjohnson@yahoo.com>) 30 # id 1Mhai5-00061w-2n 31 # for bug-gawk@gnu.org; Sat, 29 Aug 2009 23:04:05 -0400 32 #Received: (qmail 68722 invoked by uid 60001); 30 Aug 2009 03:04:03 -0000 33 #DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yahoo.com; s=s1024; t=1251601443; bh=9h2ZOOgxUh+s8Ow5/ZMWUxcviy2L4rpiaNamPAXxhEk=; h=Message-ID:X-YMail-OSG:Received:X-Mailer:Date:From:Subject:To:MIME-Version:Content-Type; b=tWxCQq/aTOT5lhtdPc5hxtXzOjDFmLU6Ao0BSlwbeeBsd9Wl6DU3JCR4gTkoL0aVUOTdjMjgRY7I72yCht+YruDiqZrvtSKvUoAvZAKcPG26RE4jzxUlxQklEHZG9mq9h2gpTIiLYehYDiC0975wukwi/e7ePADfkFwg8eTnT44= 34 #DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; 35 # s=s1024; d=yahoo.com; 36 # h=Message-ID:X-YMail-OSG:Received:X-Mailer:Date:From:Subject:To:MIME-Version:Content-Type; 37 # b=LWfhVgxojFG1eYoRrxtrS3YOfH3MTUVTYZle/4utMQEPZQfsmrn6GBwBfThryGqJyZfg38/7JfK9cz/Q3Yt+mf8+xl9/m+Srckc+Xvi42CE0OmoN439vCyhAD8A74XOJsmfKDjJ/+LtioShStUohj1iYDDmRTN4RnnP9X4xnt3c=; 38 #Message-ID: <410222.68490.qm@web33507.mail.mud.yahoo.com> 39 #X-YMail-OSG: mfjax.MVM1lI2q5gcl6bChbn6zHgNgj1fByHWJSzB8ZZUmI2QCH6pNwV_IaHxcqecu.VqjKUR6HQhXbziUnX.v5E2nOE61ass9AzqfdVOtKTEAzTPQJ8Z7QB7fq7BMtjn8yohDR6mwOyVTqv3RZh0m1Us7sLit6UmcgeSvJo2rROAmeceq.FBwk2XnEp2_QsljjPHak_WXyvtAK81klDv5qQORWQWqR9q79x7yxORL6fLWwb_x6mZZMSOUaA0p8.ucT453eqT1L8NGkthF.fXmOM3_EYd03zUgr9Sb.zvMvbDC3MCMnVr0JT1uroLmFtVIdTojrFJYFQEDFSB9zT3Ua80ZpGXrjQGx3rZw-- 40 #Received: from [71.165.246.171] by web33507.mail.mud.yahoo.com via HTTP; Sat, 29 Aug 2009 20:04:03 PDT 41 #X-Mailer: YahooMailClassic/6.1.2 YahooMailWebService/0.7.338.2 42 #Date: Sat, 29 Aug 2009 20:04:03 -0700 (PDT) 43 #From: Greg Johnson <gregfjohnson@yahoo.com> 44 #Subject: bugs in passing uninitialized array to a function 45 #To: bug-gawk@gnu.org 46 #MIME-Version: 1.0 47 #Content-Type: multipart/mixed; boundary="0-1690489838-1251601443=:68490" 48 #X-detected-operating-system: by monty-python.gnu.org: FreeBSD 6.x (1) 49 #Status: RO 50 # 51 #--0-1690489838-1251601443=:68490 52 #Content-Type: text/plain; charset=us-ascii 53 # 54 #I am using gawk version 3.1.7. 55 # 56 #The attached programs illustrate what look to me like two bugs 57 #in the handling of uninitialized variables to functions that treat 58 #them as arrays. 59 # 60 #Greg Johnson 61 # 62 # 63 # 64 #--0-1690489838-1251601443=:68490 65 #Content-Type: application/octet-stream; name=b1 66 #Content-Transfer-Encoding: base64 67 #Content-Disposition: attachment; filename="b1" 68 69 # bug? on uninitialized array, length(a) prints as 3, then the loop 70 # behaves differently, iterating once. so, length() behaves differently 71 # on two calls to the same variable, which was not changed. 72 73 function array_length(a, k, n) { 74 n = 0 75 for (k in a) n++ 76 return n 77 } 78 79 function prt1(a, len) 80 { 81 print "length: " array_length(a) 82 83 for (i = 1; i <= array_length(a); i++) 84 printf "<" i "," a[i] "> " 85 86 print "\n" 87 } 88 89 BEGIN { 90 prt1(zzz) 91 } 92 93 #--0-1690489838-1251601443=:68490 94 #Content-Type: application/octet-stream; name=b2 95 #Content-Transfer-Encoding: base64 96 #Content-Disposition: attachment; filename="b2" 97 98 # shouldn't an uninitialized array have length zero? 99 # length is printed as 1, and the loop iterates once. 100 101 function prt(a, len) 102 { 103 len = array_length(a) 104 print "length: " len 105 106 for (i = 1; i <= len; i++) 107 printf "<" i "," a[i] "> " 108 109 print "\n" 110 } 111 112 BEGIN { 113 prt(zzz) 114 } 115 116 #--0-1690489838-1251601443=:68490-- 117