Received: from malur.postgresql.org ([217.196.149.56]) by arkaria.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1w2a0X-000PiF-10 for pgsql-hackers@arkaria.postgresql.org; Tue, 17 Mar 2026 19:23:13 +0000 Received: from localhost ([127.0.0.1] helo=malur.postgresql.org) by malur.postgresql.org with esmtp (Exim 4.96) (envelope-from ) id 1w2a0W-004Jiz-0f for pgsql-hackers@arkaria.postgresql.org; Tue, 17 Mar 2026 19:23:12 +0000 Received: from makus.postgresql.org ([2001:4800:3e1:1::229]) by malur.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1w2a0V-004Jir-2T for pgsql-hackers@lists.postgresql.org; Tue, 17 Mar 2026 19:23:11 +0000 Received: from mail-qk1-x734.google.com ([2607:f8b0:4864:20::734]) by makus.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (Exim 4.98.2) (envelope-from ) id 1w2a0S-00000000Ena-1XBd for pgsql-hackers@postgresql.org; Tue, 17 Mar 2026 19:23:10 +0000 Received: by mail-qk1-x734.google.com with SMTP id af79cd13be357-8cd79e43da3so642386185a.1 for ; Tue, 17 Mar 2026 12:23:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=dunslane-net.20230601.gappssmtp.com; s=20230601; t=1773775389; x=1774380189; darn=postgresql.org; h=content-transfer-encoding:in-reply-to:autocrypt:content-language :references:cc:to:from:subject:user-agent:mime-version:date :message-id:from:to:cc:subject:date:message-id:reply-to; bh=yIJtiMdl+u03EiGq1NZ+cR8IcNS5ZQhj4ap0lHcs6FI=; b=xL46KUzorDh4u4BkJVdYLO5UVRqP1cHXyuCS8+OpEeqDJpC1Lyf3JghnF00wAasEVB e3a1IgX6euiwkToxrgg/Vy4EpYdTMPXkOuk10WJnTb757nW3n72XPJQ1uiQeC2L08p4s 3tbDOB/B0gD56JUPGIWc44ywIW+en/Yv3mwiwk6CRARWJ3A6MetQiyurcWGa9+67ivuN pcoHS1YrXBa9h2V30deVsx6hlv2UkmUBzHf9PhxKKNKXEQZkwdoptHXs6O0Zfo5hHw9W 0ZKDbrdZYD4BfQGPE1PVmwZs3UZeNlmpPaXgBv3uTBFd72H8Dvp8JDSXwBWe/QBZe2ON SzaA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1773775389; x=1774380189; h=content-transfer-encoding:in-reply-to:autocrypt:content-language :references:cc:to:from:subject:user-agent:mime-version:date :message-id:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=yIJtiMdl+u03EiGq1NZ+cR8IcNS5ZQhj4ap0lHcs6FI=; b=kgQcDAL9x7wrydw0NsCT9Zu3TAYhDQ7Qe8s74uH/H6pOUaktxeT1wCW5yt3A3ehz6t pws3Fd4NLJW6PA2t3OmeKUX0j3M9Nv/3xu0UInd9U++aEtHU/1sOMCHj1ZxvIwEvB5fI KLxdxAJKLModElLk1IgAwNmEyAHaZ1CJ9flkxDSSaBmIvxk623reZz3Zp4/zJtCGRXBY rJY2iFqdPurWEHGKOD43ciDLNZhQVv2vYDfbxxkM0Di69sFtYcCrkmMjqtb7AEA5Evqz xf/qkGKDDARyT5edCAZ/Cx4cy2eb2HUfLkywIE868jp44cVR6KfhxJxR1eyd8XuknNXO bD7A== X-Forwarded-Encrypted: i=1; AJvYcCW6PkXI7zmOYxKYIlGGecyq2nE6QM50gCqJ9Az+t1rhgNujHwOu2+nAClcPjiH3YITvqhGTQwX4SSy8nY7Y@postgresql.org X-Gm-Message-State: AOJu0YzBvnlDBdzQRU+YybRvr8NL8reKLE8vuT8IN2uXaLMa6vT5uKPp kcD4uvGJhBu1SJgYqL8CiJ6pSI/KyjdEsaAFE34YGg2ncIESDexjtSPzth+bfvEOy2Q= X-Gm-Gg: ATEYQzzPJcHowBPq8mavL60vw6g8S/LLqUlCKLrsog+OoqxrSTMK9mWACsUXeyVHtV4 CZNRHNc3YlJSG2NF776o4dX/vXwP3ZOu5IvYXcQZkuf/8+UrUsO3ryOszABtGDOo/dIQRKknLmw /3xwnaHDaDBi347SvUJ8u8XkK5ixeEx/lOeEZjriWAYiZVunVV0/IWbtCYvkR/BfvdBzELsWLGE nI1EgRCGqM0+kl3o3xlz1da3I6V7w4u1CGpfbiQpIPmnVy5M/fjt4rJyEv7FyHH9hAJIV6aRNyJ KFT9Phw3fJwgSlY546O8vKQVQfnKiktR0bEP/CSIuEOZTLuGVRlYSlBPdZOiWR4QCbiI5VYAmiu Jy9HRePYMBGE0Wd43lauiRpFGmo22Jzf73lpY6cVZj09RzY1LqCEao9ITXlSBo43eORhBXGFfXb 6QgWwcaxD1TMK3j+H46C2kWQb+UjnhOA== X-Received: by 2002:a05:620a:4009:b0:8c9:fb68:b942 with SMTP id af79cd13be357-8cfad2a15b6mr99816385a.34.1773775388954; Tue, 17 Mar 2026 12:23:08 -0700 (PDT) Received: from ?IPV6:2605:a601:a6b0:500::1cb? ([2605:a601:a6b0:500::1cb]) by smtp.googlemail.com with ESMTPSA id af79cd13be357-8cfacdeb785sm46902485a.16.2026.03.17.12.23.08 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 17 Mar 2026 12:23:08 -0700 (PDT) Message-ID: Date: Tue, 17 Mar 2026 15:23:07 -0400 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: IS JSON predicate support for domain base type as JSON/JSONB/BYTEA/TEXT From: Andrew Dunstan To: Kirill Reshke Cc: jian he , Tom Lane , PostgreSQL-development References: <1118236.1763485279@sss.pgh.pa.us> <5406c2b1-57c8-448b-97c7-8af295ba3869@dunslane.net> Content-Language: en-US Autocrypt: addr=andrew@dunslane.net; keydata= xsBNBE7KWFkBCAClridxur2AIc7eW2AR7izbfp3EnNefie2HbLF0izW5Ik5UjX2HBXBx4syI gY6b0ugohXrr274+baoAlvSbq6cAoQuEVrk5IZFzt20b1Xkx65FwGSEj526yiKLocqkJceSq Xr9xcA5SGY+FZv441chh5SU92v4q6z+6LPpoHOh97ptAVXZYNTtU0LevyvD5lja0TzbvJm6C eFXitJfnm1pLEr0DGJCR/iUOl/N62Kh4855zZC7NHIjQHPOvV5Stz/l5ilDhvGVk+xkXFPys SjZoUr1rXhYLpiyi5sR0X9FHXT0KnGuz1F5ERO7ZTLSSQ6fJwPj6gOk9K+vvoKvoeql5ABEB AAHNJEFuZHJldyBEdW5zdGFuIDxhbmRyZXdAZHVuc2xhbmUubmV0PsLAlwQTAQgAQQIbAwIX gAIZAQULCQgHAwUVCgkICwUWAgMBAAIeBRYhBOQ+WEYd/Hy/RGkVpZn6f8tZ/DuBBQJoGNGd BQkdEO8nAAoJEJn6f8tZ/DuBq74H/jkTR4Zi3stbw+xC7v2u3QozssK7MYPL2AsVfh7OealS h182fiWXpfvmmAB7WUHbhk9GC2RAOnHI/2d2jgKaMLAHsGYOT0YopTVIwRY43fCw/mK67yxc wmDcX+zyKfLaivNbf5A7QPLNwda98bEAMSJ8Sn652Uc6cA8t3uKGsVzbRBQOoYzjgvBCfSrE 9ql3PDNg0l4BfAqabd2f70ZUm9VAMEPrgv/v2xI7M2XiL4g5BVmqLCOwxLM8RMCotCuoweUr VO43DeBCIDwLxotMJKvGWDjBzQYlU1NPUAtNcz/gN9ITUe1VUGjyvGj4u1lxBOcQQUw7l1+T 5moZ4iZxXzvOwE0ETspYWQEIANGc4zQULOxhbqO2dyD51YhqCNRmm9oKWaqf+wmW4tpDe/VV cxAnNizd4LWCHfzpb5cHAtGkOPePMfzWVf6nvdF7d3eglbtf59+zG7O7llV0xSSoFiieQBsr GvqDInXYX/4mRRXMtyhM353/tixC9RWLs1oofyYmCPPXXY7h9R7en3B8BoVrRFcdzlIY/NFN hFGW/9dkEiGjgna2Rk6e15kln4ZvFBWUg23p93w/pqXcxY6+k/8TEk+C4R+M6w7o2PLGOjdZ +kPiUcw5H85zf/yZJwQXzisXaNduwWB6Vads9YC9dj6kPR1c4VGRqAaYL++LAEOqrlvm2Tvq QqZRtnEAEQEAAcLAfAQYAQgAJgIbDBYhBOQ+WEYd/Hy/RGkVpZn6f8tZ/DuBBQJoGNI2BQkd EODdAAoJEJn6f8tZ/DuBfw0IAKTsfD40teP/pp+bsLLMSxPXUYrrprTj7WFB5v61p6dkpSr/ qXmMlyahdxQFaPmfVgVirB1Vk/kHiWNnnGjfUV9nB2Zg9LI0Xb9/ts3LsUiRWXzG3tkMY6XL vsVOxW4XFRND9l2q+WW93aZ1DZl+fqWfYgMvsusFRhmGFOKTRfKPta2Pkv+AhA24N4+PrR5p bU4k2MO8PAGiK8eaYKGFG1bHKuAvoDoF7WXJ3FHxuWqLnKEt4dfOLm5pAe3zq1Lt6q8azT9i QWGpSAK5vQUWQHBHpiDjdPeqKZ6HiAXIIKfSmb+jrvXBqoP+D6/K7rUjG2aXiRtTIAXms9sm VRu7cmw= In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit List-Id: List-Help: List-Subscribe: List-Post: List-Owner: List-Archive: Archived-At: Precedence: bulk On 2026-03-13 Fr 9:47 AM, Andrew Dunstan wrote: > > On 2026-03-13 Fr 9:16 AM, Kirill Reshke wrote: >> On Fri, 13 Mar 2026 at 17:30, Andrew Dunstan >> wrote: >>> >>> On 2026-03-12 Th 11:55 PM, jian he wrote: >>>> Hi. >>>> >>>> The regression test was very verbose; I removed some of it. >>>> Also polished function ExecEvalJsonIsPredicate a little bit. >>> >>> >>> Here's a v4. I changed resultBaseType to exprBaseType - I think it's >>> clearer. I also trimmed the tests a bit more, and dropped the new >>> objects after testing them. The  error message now shows the domain >>> name >>> rather than the underlying base type. I think that's more useful. >>> >> >> Hi! >> V4 looks good. The only thing that I cannot explain is removing the >> `exprtype` variable inside ExecEvalJsonIsPredicate. We can just change >> its declaration to >> >> exprtype =  pred->exprBaseType if i'm not mistaken? > > > > Yeah, we can do that. > > >> >> Anyway, LGTM >> >> > > Committed with that change. cheers andrew -- Andrew Dunstan EDB: https://www.enterprisedb.com