在 Linux 中创建可执行文件
- 2024-11-13 08:36:00
- admin 原创
- 19
问题描述:
我计划做的一件事是编写(非常简单的)Perl 脚本,并且我希望能够在不从终端显式调用 Perl 的情况下运行它们。我明白,要做到这一点,我需要授予它们执行权限。使用 chmod 执行此操作很容易,但这似乎也是一个稍微费力的额外步骤。我想要的是以下两件事之一:
首先,有没有办法在保存文件时设置执行标志?目前我正在尝试使用 gedit 和 geany,但如果它具有此功能,我愿意切换到功能类似(或更好)的编辑器。
除此之外,有没有办法声明在特定目录中创建的所有文件都应该具有执行权限?
我的 umask 设置为 022,据我所知,这应该没问题,但看起来文件是作为文本文件(具有 666 默认权限)而不是可执行文件(具有 777 默认权限)创建的。
也许我只是太懒了,但我想一定有比对每个创建的脚本进行 chmodding 更方便的方法。
解决方案 1:
使文件可执行:
chmod +x 文件
查找 perl 的位置:
哪个 perl
这应该返回类似
/bin/perl 有时是 /usr/local/bin
然后在脚本的第一行添加:
!"path"/perl 带有上面的路径,例如
/bin/perl 的 #!/bin/perl
然后你就可以执行文件
。/文件
PATH 可能存在一些问题,因此您可能也想更改它...
解决方案 2:
无需破解你的编辑器,或者切换编辑器。
相反,我们可以编写一个脚本来监视您的开发目录和 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=" \n $WORK_DIR/dirA \n $WORK_DIR/dirC \n " # 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
解决方案 3:
您所描述的是处理此问题的正确方法。
您说您想留在 GUI 中。您通常可以通过文件属性菜单设置执行位。如果您愿意,您还可以学习如何为上下文菜单创建自定义操作来为您执行此操作。这当然取决于您的桌面环境。
如果您使用更高级的编辑器,则可以编写脚本以在保存文件时执行操作。例如(我只熟悉 vim),您可以将其添加到 .vimrc 中,以使任何以“ #!/*/bin/*
”开头的新文件都可执行。
au BufWritePost * if getline(1) =~ "^#!" | if getline(1) =~ "/bin/" | silent !chmod +x <afile> | endif | endif
解决方案 4:
这其实没什么大不了的。您只需使用以下命令编写脚本即可:
chmod a+x *.pl
并在创建 perl 文件后运行脚本。或者,你可以使用以下命令打开文件:
touch filename.pl && chmod a+x filename.pl && vi filename.pl # choose your favorite editor
解决方案 5:
我认为您遇到的问题是,即使您可以在系统中设置自己的 umask 值,但这不允许您明确控制 gedit(或您使用的任何编辑器)在新文件上设置的默认权限。
我相信这个细节是硬编码到 gedit 和大多数其他编辑器中的。你可以选择 (a) 修改你自己的 gedit 模块或 (b) 找到一个允许你设置新文件默认权限首选项的文本编辑器。(抱歉,我不知道有哪个。)
鉴于此,对文件进行 chmod 真的不是那么糟糕,对吗?
- 2024年20款好用的项目管理软件推荐,项目管理提效的20个工具和技巧
- 2024年开源项目管理软件有哪些?推荐5款好用的项目管理工具
- 项目管理软件有哪些?推荐7款超好用的项目管理工具
- 项目管理软件哪个最好用?盘点推荐5款好用的项目管理工具
- 项目管理软件有哪些最好用?推荐6款好用的项目管理工具
- 项目管理软件有哪些,盘点推荐国内外超好用的7款项目管理工具
- 2024项目管理软件排行榜(10类常用的项目管理工具全推荐)
- 项目管理软件排行榜:2024年项目经理必备5款开源项目管理软件汇总
- 2024年常用的项目管理软件有哪些?推荐这10款国内外好用的项目管理工具
- 项目管理必备:盘点2024年13款好用的项目管理软件