怎么在gitlab服务器端加pre-receive钩子执行phpcs的检查

Dleno 2019-03-25 05:44:16
怎么在gitlab服务器端加pre-receive钩子执行phpcs的检查,哪位大佬知道。
phpcs检查后面要跟文件路径,而git服务器端实际上市没有那个文件路径的
...全文
759 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
Dleno 2019-03-26
  • 打赏
  • 举报
回复 1
已解决,分享出来

#!/usr/bin/env bash

# 创建临时目录
TMP_DIR=$(mktemp -d)

# 警告数
warnings_count=0
# 错误数
errors_count=0

# 空hash
EMPTY_REF='0000000000000000000000000000000000000000'

# Colors
PURPLE='\033[35m'
RED='\033[31m'
RED_BOLD='\033[1;31m'
YELLOW='\033[33m'
YELLOW_BOLD='\033[1;33m'
GREEN='\033[32m'
GREEN_BOLD='\033[1;32m'
BLUE='\033[34m'
BLUE_BOLD='\033[1;34m'
COLOR_END='\033[0m'

while read oldrev newrev ref
do
# 当push新分支的时候oldrev会不存在,删除时newrev就不存在
if [[ $oldrev != $EMPTY_REF && $newrev != $EMPTY_REF ]]; then
echo -e "\n${PURPLE}CodeSniffer check result:${COLOR_END}"
# 被检查了的文件数
checked_file_count=0
# 找出哪些文件被更新了
for line in $(git diff-tree -r $oldrev..$newrev | grep -oP '.*\.(php)' | awk '{print $5$6}')
do
# 文件状态
# D: deleted
# A: added
# M: modified
status=$(echo $line | grep -o '^.')

# 不检查被删除的文件
if [[ $status == 'D' ]]; then
continue
fi

# 文件名
file=$(echo $line | sed 's/^.//')

# 为文件创建目录
mkdir -p $(dirname $TMP_DIR/$file)
# 保存文件内容
git show $newrev:$file > $TMP_DIR/$file


output=$(phpcs --standard=PSR2 --colors --encoding=utf-8 -n -p $TMP_DIR/$file)

warning=$(echo $output | grep -oP '([0-9]+) WARNING' | grep -oP '[0-9]+')
error=$(echo $output | grep -oP '([0-9]+) ERROR' | grep -oP '[0-9]+')

if [[ $warning || $error ]]; then

msg="${file}: "

if [[ $warning > 0 ]]; then
msg="$msg${YELLOW_BOLD}${warning}${COLOR_END} ${YELLOW}warnings${COLOR_END} "

let "warnings_count = warnings_count + 1"
fi
if [[ $error > 0 ]]; then
msg="$msg${RED_BOLD}${error}${COLOR_END} ${RED}errors${COLOR_END}"

let "errors_count = errors_count + 1"
fi

echo -e " $msg"
fi

let "checked_file_count = checked_file_count + 1";

done

if [[ $checked_file_count == 0 ]]; then
echo -e " ${BLUE_BOLD}No file was checked.${COLOR_END}"
elif [[ $warnings_count == 0 && $errors_count == 0 ]]; then
echo -e "${GREEN_BOLD}$(cowsay 'Congratulations!!!')${COLOR_END}"
elif [[ $errors_count == 0 ]]; then
echo -e " ${BLUE}Good job, no errors were found!!!${COLOR_END}"
fi

fi
done

# 删除临时目录
rm -rf $TMP_DIR

if [[ $warnings_count > 0 || $errors_count > 0 ]]; then
echo -e "${RED}$(cowsay -f dragon 'PHPCS Check Error!!!')${COLOR_END}"
exit 1
fi

exit 0
下载代码方式:https://pan.quark.cn/s/a4b39357ea24 依据所提供的资料,我们深入剖析此问题以及所给出的两种算法方案。 ### 问题背景 该问题源自王晓东编撰的《算法设计与实验题解》一书,书中阐述了一个值得注意的数学议题:针对一本页码从1到n顺序编号的书籍,要求统计所有页码中数字0至9各自出现的频次。例如,若n=13,则页码序列为1、2、...、13,其中数字1出现5次(体现在1、10、11、12、13中),数字0出现1次(体现在10中)。 ### 问题描述 具体而言,我们需要开发一种算法,其输入参数为一个正整数n,输出结果需为0至9这十个数字各自出现的频次。所有页码均以十进制形式呈现,且不包含任何前导零,即不会出现如006之类的页码表示。 ### 解决方案一:时间复杂度为O(n*log10(n))的算法 首先,介绍一种时间复杂度为O(n*log10(n))的算法实现。其核心构思在于遍历从1到n的每一个数值,然后逐一分解每个数值的各个位,并统计各类数字出现的频次。具体步骤如下: 1. 初始化一个长度为10的数组`count`,用于记录0至9每个数字出现的频次,初始值均为0。 2. 从1开始遍历至n,对于每一个数值i,将其转换为整数并进行以下操作: - 利用循环结构,持续将当前数值除以10,获取余数(即当前最低位的数字),并累到对应的计数器中。 3. 遍历完成后,输出`count`数组中的每一个元素,即为所求的结果。 ### 解决方案二:优化算法 为了提升效率,提出了一种更为优越的算法。该算法基于以下观察:在1到10^n-1之间的任意区间内,每一种数字0至9出现的频次是相等的。例如,在1到999之间,每一种数字0至9出现的频次均相...

20,393

社区成员

发帖
与我相关
我的任务
社区描述
“超文本预处理器”,是在服务器端执行的脚本语言,尤其适用于Web开发并可嵌入HTML中。PHP语法利用了C、Java和Perl,该语言的主要目标是允许web开发人员快速编写动态网页。
phpphpstorm 技术论坛(原bbs)
社区管理员
  • 开源资源社区
  • phpstory
  • xuzuning
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧