From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on inbox.vuxu.org X-Spam-Level: X-Spam-Status: No, score=-3.3 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, MAILING_LIST_MULTI,RCVD_IN_DNSWL_MED,UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.4 Received: (qmail 12840 invoked from network); 5 Sep 2021 18:55:21 -0000 Received: from zero.zsh.org (2a02:898:31:0:48:4558:7a:7368) by inbox.vuxu.org with ESMTPUTF8; 5 Sep 2021 18:55:21 -0000 ARC-Seal: i=1; cv=none; a=rsa-sha256; d=zsh.org; s=rsa-20210803; t=1630868121; b=Ek9UbNAzusU/j5i70aG9SmSPzNwrvqNzoUVdxbhOsB/d28Zgpr529bXxMYiZ32nztKdbvpUezK opLHujF2nm+gy8mIQDIwgyKuFbAX6aqu2mGYBJGkH1T0LaPXkHfknOLryJsNrH9XPUpCrGUt80 ruRDXKnAoFtYr+laqmZRPjbzd3YLq1M6UxWfzCYCH1HX/MujtacDKZQzlxDcsvjljmZ4tymA3T 9kk1ZPCQjckiEBo7+BleCVffWFGOouo/fNtYJ0yhaJZS95jT1d17HEICTU2NFjMk6p6XttaOj2 NF5EY92af9BYmjgVXN82JwazkmaekyUfvVUPcWHGysa2Qg==; ARC-Authentication-Results: i=1; zsh.org; iprev=pass (mail-yb1-f178.google.com) smtp.remote-ip=209.85.219.178; dkim=pass header.d=brasslantern-com.20150623.gappssmtp.com header.s=20150623 header.a=rsa-sha256; dmarc=none header.from=brasslantern.com; arc=none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed; d=zsh.org; s=rsa-20210803; t=1630868121; bh=BaUXVTNSt714EzUrABTJybtIxlPMCXr8biVlqQIMbcw=; h=List-Archive:List-Owner:List-Post:List-Unsubscribe:List-Subscribe:List-Help: List-Id:Sender:Content-Type:To:Subject:Message-ID:Date:From:MIME-Version: DKIM-Signature:DKIM-Signature; b=O/P1do8kAtb5jrnYSid8HjNS8Wn8eSzFFqlZaexfAw2Eqi5bqtID2TR8zFAiefEPgM4HYXKqhm xQ5bOti3zBVj+Rff4EPZvOB+qCVWujEwLtnvB39fELsyEVRQTn4MQu0Vttsv7CyPm8eNg6+UVw gFmWK0m48Vnb4A57v36HUnEwwZjTr/tzKxTHYlNtk0c+LX/UI3MO2HDr7HkN1a/H8rgjSyYofN 7bsnwX5XyHTtTH8ypY6nG3XWiBEw246Zpy0Y7Qtax9Lc+2cL7Mm0+bXVuEfKcbwaFZ3hPxJuKf eHuyZxs5uzGgISbb4CYCCKmvAMdqr1J1+kPsLYFa4JBZxQ==; DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=zsh.org; s=rsa-20210803; h=List-Archive:List-Owner:List-Post:List-Unsubscribe: List-Subscribe:List-Help:List-Id:Sender:Content-Type:To:Subject:Message-ID: Date:From:MIME-Version:Reply-To:Cc:Content-Transfer-Encoding:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:In-Reply-To:References; bh=XdlWUyJdrw4aFxbdxdqveTz64q/taTbX/1oX1Y+kQlc=; b=DmGmeT4MInFi+2qvwqvvat29O6 9Zdp2AYVoMr6clVkI+3zixEFQUFi4hQ9WDApu64/Lx818FZhV5VEtIvAv0zllSBtz/Rm88eWtADz6 mVJS5EXyDDHMXSe2xchtP5Q0bStUsgYpvyQccmq0B2Q35UtWbohmPskGl74lea9g2vXZi+XYSiDO5 QGj4XmzIk99XV32xbc7ySLMx/taWL+pN78EpwiuTTWQlbiGhrWtSfXlF/S2RgpPLcctp0hWr/5EsZ 6DsOF4jKm4R0IkaaSRntlaHhePHOw27fNgB9PAP2ASiic6DZysGgWmOWdAlQVCLY5CAScPsPZu53q pR41utyQ==; Received: from authenticated user by zero.zsh.org with local id 1mMxIW-0000bx-TH; Sun, 05 Sep 2021 18:55:20 +0000 Authentication-Results: zsh.org; iprev=pass (mail-yb1-f178.google.com) smtp.remote-ip=209.85.219.178; dkim=pass header.d=brasslantern-com.20150623.gappssmtp.com header.s=20150623 header.a=rsa-sha256; dmarc=none header.from=brasslantern.com; arc=none Received: from mail-yb1-f178.google.com ([209.85.219.178]:34343) by zero.zsh.org with esmtps (TLS1.3:TLS_AES_128_GCM_SHA256:128) id 1mMxI2-0000JS-1F; Sun, 05 Sep 2021 18:54:50 +0000 Received: by mail-yb1-f178.google.com with SMTP id a93so9129093ybi.1 for ; Sun, 05 Sep 2021 11:54:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brasslantern-com.20150623.gappssmtp.com; s=20150623; h=mime-version:from:date:message-id:subject:to; bh=XdlWUyJdrw4aFxbdxdqveTz64q/taTbX/1oX1Y+kQlc=; b=WAVY29igYV+TrkqymDcH9l7+UD5CItvH3r1z+C0GnQOym3Jp1hJigJhuQX51q9ztCe okSrT3ZFOSzEMNP1zphjLdU4dMroC4mQyldGA9ERSJCTJ5vWl/JbmtmcXeTa0dTcVEur zkwJWuKkDSu+pqYGF7f1KENLviIGXTd5ITxxoYOdFSFw7eYn4TYcEMZn2PRpg1NTVsmB ABITC8L/1FevYakbL+vXpBkOIU1f9U/eOfLswIzRp+rHyinPqYTEeunomLLH/dMFvN/M rjINT8yfmz+H+Uzl7FiOVu2ibMcmi7ZmA7uGjGhfTkswvOmEe7FDPZcAjnz0Q9iQb9Zd ch+w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:from:date:message-id:subject:to; bh=XdlWUyJdrw4aFxbdxdqveTz64q/taTbX/1oX1Y+kQlc=; b=Oo87pvgi3RPqEFW4PadjV+htHifCpDP0ANCWIO59lPT2KKYX3FVqAXyzX9mIb7nxfH b3ubPVabU479lyirssTUU0fWJNDvOIq0zkjRsKN1uw/MRKln+u4G6uGKANt3toB46WxS Ir96F9z7UFZnymN1bYvwbIaMSY1Oa80TG/Fz8k2Zts/DHjGTGQgN4UeiVZxoRcUsZA9B HK/UX+eQ/ur05mv3I4unkxRfXi9RZUZw2fWgvZgjc1d9v6VoMtp6I9FbsebsZ37Igzpn TkZg8omaGNWEGQPR/ixtgizY0ObbV14J3VTgDB5IuRy50djNnCdi+gGHQ21Ewp3008vp dF8g== X-Gm-Message-State: AOAM531UuqzXI8kb+srZnwyrF6U4oUDmfEdWuUEhtzgLVY0wPvDBBDRO En0oPf12q5XsXlbN00ALbiQi7XguLXtmjeZwfpxfjVe14jUarQ== X-Google-Smtp-Source: ABdhPJx3kxAtmQcL1/ZvvVKNBZBYm5UBaMLHz4I7vaiq/qKOTKKpf1TGed8tSXjXLe2rFl66kI6k51q2bccHxhWPWVc= X-Received: by 2002:a25:21c5:: with SMTP id h188mr10580575ybh.23.1630868088626; Sun, 05 Sep 2021 11:54:48 -0700 (PDT) MIME-Version: 1.0 From: Bart Schaefer Date: Sun, 5 Sep 2021 11:54:37 -0700 Message-ID: Subject: autoload path completion with expansions To: Zsh hackers list Content-Type: text/plain; charset="UTF-8" X-Seq: 49376 Archived-At: X-Loop: zsh-workers@zsh.org Errors-To: zsh-workers-owner@zsh.org Precedence: list Precedence: bulk Sender: zsh-workers-request@zsh.org X-no-archive: yes List-Id: List-Help: List-Subscribe: List-Unsubscribe: List-Post: List-Owner: List-Archive: Starting from zsh -f + compinit + zstyle '*' format %d (so, no completer style) % autoload $PWD/ `vars' or `shell function' This surprised me, because % ls $PWD/ file (list of files in the current directory) Turns out this is because _typeset (which handles autoload) only calls _files when the word on the command line already begins with "/" or "~". I debated also adding \` to the pattern. Thoughts? diff --git a/Completion/Zsh/Command/_typeset b/Completion/Zsh/Command/_typeset index d3304bed0..26eab0b21 100644 --- a/Completion/Zsh/Command/_typeset +++ b/Completion/Zsh/Command/_typeset @@ -101,9 +101,9 @@ if [[ "$state" = vars_eq ]]; then elif (( $+opt_args[-w] )); then _wanted files expl 'zwc file' _files -g '*.zwc(-.)' && ret=0 elif [[ $service = autoload || -n $opt_args[(i)-[uU]] ]]; then - if [[ $PREFIX[1] = [/~] ]]; then + if [[ $PREFIX[1] = [$/~] ]] && _files; then # Autoload by absolute path - _files && ret=0 + ret=0 else args=(${^fpath}/*(-.:t)) # Filter out functions already loaded or marked for autoload.