在Linux中创建可执行文件

在Linux中创建可执行文件,linux,executable,file-permissions,chmod,gedit,Linux,Executable,File Permissions,Chmod,Gedit,我计划做的一件事是编写(非常简单的)Perl脚本,我希望能够在不从终端显式调用Perl的情况下运行它们。我很感激,要做到这一点,我需要授予他们执行权限。使用chmod执行此操作非常简单,但这似乎是一个稍微费力的额外步骤。我想要的是两件事之一: 首先,在保存文件时是否有方法设置execute标志?目前我正在试用gedit和geany,但如果它有这个功能的话,我愿意切换到功能类似(或更好)的编辑器 否则,是否有方法声明在特定目录中创建的所有文件都应具有执行权限 我的umask设置为022,据我所知,

我计划做的一件事是编写(非常简单的)Perl脚本,我希望能够在不从终端显式调用Perl的情况下运行它们。我很感激,要做到这一点,我需要授予他们执行权限。使用chmod执行此操作非常简单,但这似乎是一个稍微费力的额外步骤。我想要的是两件事之一:

首先,在保存文件时是否有方法设置execute标志?目前我正在试用gedit和geany,但如果它有这个功能的话,我愿意切换到功能类似(或更好)的编辑器

否则,是否有方法声明在特定目录中创建的所有文件都应具有执行权限

我的umask设置为022,据我所知,这应该是正常的,但文件似乎是作为文本文件(具有666个默认权限)而不是可执行文件(具有777个默认权限)创建的


也许我只是在偷懒,但我想一定有一种比把一个人创建的每一个脚本都编出来更方便的方法。

这真的没什么大不了的。只需使用一个命令即可生成脚本:

chmod a+x *.pl
并在创建perl文件后运行脚本。或者,您可以使用如下命令打开文件:

touch filename.pl && chmod a+x filename.pl && vi filename.pl # choose your favorite editor
使文件可执行:

chmod+x文件

查找perl的位置:

哪个perl

这应该返回类似于

/bin/perl/usr/local/bin

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

#!!“path”/perl,带有上面的路径,例如

#!/bin/perl

然后可以执行该文件

/文件


路径可能存在一些问题,因此您可能还需要更改…

您所描述的是正确的处理方法

你说过你想留在GUI中。通常可以通过文件属性菜单设置执行位。如果您愿意的话,您还可以学习如何为上下文菜单创建一个自定义操作来完成此操作。当然,这取决于您的桌面环境

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

au BufWritePost * if getline(1) =~ "^#!" | if getline(1) =~ "/bin/" | silent !chmod +x <afile> | endif | endif
au BufWritePost*如果getline(1)=~“^#!”|如果getline(1)=~”/bin/“|无提示!chmod+x | endif | endif

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

我相信这个细节是硬编码到gedit和大多数其他编辑器中的。您可以选择(a)修改自己的gedit模块,或者(b)找到一个文本编辑器,允许您为新文件的默认权限设置首选项。(对不起,我一个也不知道。)


有鉴于此,必须对文件进行chmod真的没有那么糟糕,对吗?

无需对编辑器进行黑客攻击或切换编辑器

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

这个脚本需要inotifywait,它在Ubuntu的inotify工具包中提供

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

谢谢,但那不是我的问题。我已经养成了用#开始脚本的习惯/usr/bin/perl。一旦我给了脚本可执行权限,我就可以很好地运行脚本;我只是想找一个更简单的方法。我可以推荐一下
#/是否改为使用usr/bin/env perl
env
程序基本上在路径上找到给定的参数(在本例中为“perl”),并运行该参数。当您向其他人发送脚本时,它很有用——例如,我使用Mac,Perl位于/opt/local/bin中。我更想寻找一种方法来在GUI中完成所有操作,但这可能是不可能的。是安全问题吗?是的,是安全问题。如果shell在默认情况下开始创建所有可执行文件,这可能会是一个巨大的问题。您可以为自己制作一个简单的程序。但是,老实说,您将尝试做一些在UNIX环境中编程的其他人没有真正做的事情。在目录上设置umask不是更简单吗?您必须打印每个文件的输出。您必须导入每个文件的正确库。这似乎是编程过程中的另一个步骤,也是一个很危险的规避步骤。使用此技巧,我遇到了这里提到的问题:因此,现在我使用的是稍微修改过的版本
autocmd BufWritePost*if getline(1)=~“^#!/bin/“|静默执行”!chmod a+x”| endif