在Linux中创建可执行文件

我打算做的一件事是编写(非常简单的)Perl脚本,并且我希望能够运行它们而无需从终端显式调用Perl。 我对此表示赞赏,我需要授予他们执行权限。 使用chmod做到这一点很容易,但是这似乎是一个稍微费力的额外步骤。 我想要的是以下两件事之一:

首先,在保存文件时是否可以设置执行标志? 目前,我正在尝试使用gedit和geany,但如果具有此功能,则愿意切换到功能类似(或更好)的编辑器。

失败了,有没有办法声明在特定目录中创建的所有文件都应具有执行权限?

据我了解,我的umask设置为022,应该可以,但是看起来文件是作为文本文件(具有666个默认权限)创建的,而不是作为可执行文件(具有777个默认权限)创建的。

也许我只是在偷懒,但是我认为必须有一种更便利的方法,而不是修改一个人创建的每个脚本。

5个解决方案
86 votes

使文件可执行:

chmod + x文件

查找perl的位置:

哪个Perl

这应该返回类似

/ bin / perl有时是/ usr / local / bin

然后在脚本的第一行中添加:

#!“ path” / perl,例如上方有路径

#!/ bin / perl

然后您可以执行文件

。/文件

PATH可能存在一些问题,因此您可能还需要更改它...

answered 2020-08-06T20:21:43Z
6 votes

无需修改您的编辑器,也无需切换编辑器。

相反,我们可以提供一个脚本来监视开发目录和chmod文件的创建过程。 这是我在所附的bash脚本中所做的。 您可能想要通读注释并根据需要编辑“ config”部分,然后建议将其放在$ HOME / bin /目录中,并将其执行添加到$ HOME / .login或类似文件中。 或者,您也可以从终端运行它。

此脚本确实需要inotifywait,它位于Ubuntu的inotify-tools软件包中,

sudo apt-get install inotify-tools

欢迎提出建议/修改/改进。

#!/usr/bin/env bash

# --- usage --- #
# Depends: 'inotifywait' available in inotify-tools on Ubuntu
# 
# Edit the 'config' section below to reflect your working directory, WORK_DIR,
# and your watched directories, WATCH_DIR. Each directory in WATCH_DIR will
# be logged by inotify and this script will 'chmod +x' any new files created
# therein. If SUBDIRS is 'TRUE' this script will watch WATCH_DIRS recursively.
# I recommend adding this script to your $HOME/.login or similar to have it
# run whenever you log into a shell, eg 'echo "watchdirs.sh &" >> ~/.login'.
# This script will only allow one instance of itself to run at a time.

# --- config --- #

WORK_DIR="$HOME/path/to/devel" # top working directory (for cleanliness?)
WATCH_DIRS=" \
    $WORK_DIR/dirA \
    $WORK_DIR/dirC \
    "                          # list of directories to watch
SUBDIRS="TRUE"                 # watch subdirectories too
NOTIFY_ARGS="-e create -q"     # watch for create events, non-verbose


# --- script starts here --- #
# probably don't need to edit beyond this point

# kill all previous instances of myself
SCRIPT="bash.*`basename $0`"
MATCHES=`ps ax | egrep $SCRIPT | grep -v grep | awk '{print $1}' | grep -v $$`
kill $MATCHES >& /dev/null

# set recursive notifications (for subdirectories)
if [ "$SUBDIRS" = "TRUE" ] ; then
    RECURSE="-r"
else
    RECURSE=""
fi

while true ; do
    # grab an event
    EVENT=`inotifywait $RECURSE $NOTIFY_ARGS $WATCH_DIRS`

    # parse the event into DIR, TAGS, FILE
    OLDIFS=$IFS ; IFS=" " ; set -- $EVENT
    E_DIR=$1
    E_TAGS=$2
    E_FILE=$3
    IFS=$OLDIFS

    # skip if it's not a file event or already executable (unlikely)
    if [ ! -f "$E_DIR$E_FILE" ] || [ -x "$E_DIR$E_FILE" ] ; then
        continue
    fi

    # set file executable
    chmod +x $E_DIR$E_FILE
done
Dylan answered 2020-08-06T20:22:17Z
3 votes

您所描述的是处理此问题的正确方法。

您说过要保留在GUI中。 通常,您可以通过文件属性菜单设置执行位。 您也可以学习如何为上下文菜单创建自定义操作,以便在您愿意时为您执行此操作。 当然,这取决于您的桌面环境。

如果使用更高级的编辑器,则可以对保存文件时执行的操作编写脚本。 例如(我只是非常熟悉vim),可以将其添加到.vimrc中,以创建任何以“ #!/*/bin/*”开头的新文件。

au BufWritePost * if getline(1) =~ "^#!" | if getline(1) =~ "/bin/" | silent !chmod +x <afile> | endif | endif
JimB answered 2020-08-06T20:22:46Z
2 votes

确实没什么大不了的。 您可以只使用单个命令来编写脚本:

chmod a+x *.pl

并在创建一个perl文件后运行脚本。 或者,您可以使用以下命令打开文件:

touch filename.pl && chmod a+x filename.pl && vi filename.pl # choose your favorite editor
BobbyShaftoe answered 2020-08-06T20:23:10Z
0 votes

我认为您遇到的问题是,即使您可以在系统中设置自己的umask值,也不允许您通过gedit(或使用的任何编辑器)显式控制对新文件设置的默认权限。 。

我相信这个细节会被硬编码到gedit和大多数其他编辑器中。 更改它的选项是(a)修改自己的gedit模式,或(b)查找文本编辑器,该文本编辑器可让您为新文件的默认权限设置首选项。 (对不起,我一无所知。)

鉴于此,必须对文件进行chmod的确不是那么糟糕,对吧?

grossvogel answered 2020-08-06T20:23:40Z
translate from https://stackoverflow.com:/questions/817060/creating-executable-files-in-linux