📄 build.sh
字号:
#!/bin/bash# build.sh -- builds JAR and XPI files for mozilla extensions# by Nickolay Ponomarev <asqueella@gmail.com># (original version based on Nathan Yergler's build script)# Most recent version is at <http://kb.mozillazine.org/Bash_build_script># This script assumes the following directory structure:# ./# chrome.manifest (optional - for newer extensions)# install.rdf# (other files listed in $ROOT_FILES)## content/ |# locale/ |} these can be named arbitrary and listed in $CHROME_PROVIDERS# skin/ |## defaults/ |# components/ |} these must be listed in $ROOT_DIRS in order to be packaged# ... |## It uses a temporary directory ./build when building; don't use that!# Script's output is:# ./$APP_NAME.xpi# ./$APP_NAME.jar (only if $KEEP_JAR=1)# ./files -- the list of packaged files## Note: It modifies chrome.manifest when packaging so that it points to # chrome/$APP_NAME.jar!/*## default configuration file is ./config_build.sh, unless another file is # specified in command-line. Available config variables:APP_NAME= # short-name, jar and xpi files name. Must be lowercase with no spacesCHROME_PROVIDERS= # which chrome providers we have (space-separated list)CLEAN_UP= # delete the jar / "files" when done? (1/0)ROOT_FILES= # put these files in root of xpi (space separated list of leaf filenames)ROOT_DIRS= # ...and these directories (space separated list)BEFORE_BUILD= # run this before building (bash command)AFTER_BUILD= # ...and this after the build (bash command)if [ -z $1 ]; then . ./config_build.shelse . $1fiif [ -z $APP_NAME ]; then echo "You need to create build config file first!" echo "Read comments at the beginning of this script for more info." exit;fiROOT_DIR=`pwd`TMP_DIR=build#uncomment to debug#set -x# remove any left-over files from previous buildrm $APP_NAME.jarrm $APP_NAME.xpirm filesrm -rf $TMP_DIR$BEFORE_BUILDmkdir --parents --verbose $TMP_DIR/chrome# generate the JAR file, excluding SVN and temporary filesJAR_FILE=$TMP_DIR/chrome/$APP_NAME.jarecho "Generating $JAR_FILE..."for CHROME_SUBDIR in $CHROME_PROVIDERS; do find $CHROME_SUBDIR -path '*.svn*' -prune -o -type f -print | grep -v \~ >> filesdonezip -0 -r $JAR_FILE `cat files`# The following statement should be used instead if you don't wish to use the JAR file#cp --verbose --parents `cat files` $TMP_DIR/chrome# prepare components and defaultsecho "Copying various files to $TMP_DIR folder..."for DIR in $ROOT_DIRS; do mkdir $TMP_DIR/$DIR FILES="`find $DIR -path '*.svn*' -prune -o -type f -print | grep -v \~`" echo $FILES >> files cp --verbose --parents $FILES $TMP_DIRdone# Copy other files to the root of future XPI.for ROOT_FILE in $ROOT_FILES install.rdf chrome.manifest; do cp --verbose $ROOT_FILE $TMP_DIR if [ -f $ROOT_FILE ]; then echo $ROOT_FILE >> files fidonecd $TMP_DIRif [ -f "chrome.manifest" ]; then echo "Preprocessing chrome.manifest..." # You think this is scary? #s/^(content\s+\S*\s+)(\S*\/)$/\1jar:chrome\/$APP_NAME\.jar!\/\2/ #s/^(skin|locale)(\s+\S*\s+\S*\s+)(.*\/)$/\1\2jar:chrome\/$APP_NAME\.jar!\/\3/ # # Then try this! (Same, but with characters escaped for bash :) sed -i -r s/^\(content\\s+\\S*\\s+\)\(\\S*\\/\)$/\\1jar:chrome\\/$APP_NAME\\.jar\\!\\/\\2/ chrome.manifest sed -i -r s/^\(skin\|locale\)\(\\s+\\S*\\s+\\S*\\s+\)\(.*\\/\)$/\\1\\2jar:chrome\\/$APP_NAME\\.jar\\!\\/\\3/ chrome.manifest # (it simply adds jar:chrome/whatever.jar!/ at appropriate positions of chrome.manifest)fi# generate the XPI fileecho "Generating $APP_NAME.xpi..."zip -r ../$APP_NAME.xpi *cd $ROOT_DIRecho "Cleanup..."if [ $CLEAN_UP = 0 ]; then # save the jar file mv $TMP_DIR/chrome/$APP_NAME.jar .else rm ./filesfi# remove the working filesrm -rf $TMP_DIRecho "Done!"$AFTER_BUILD
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -