mirror of
https://github.com/fish-shell/fish-shell.git
synced 2025-01-19 20:12:45 +08:00
Factor out building lexicon_filter into separate script
This adds a new script build_tools/build_lexicon_filter.sh that builds the lexicon filter. It is factored out from the Makefile, and both the Makefile and CMake build invoke it.
This commit is contained in:
parent
6ff0f86606
commit
f044084f3a
19
CMakeFiles/Docs.cmake
Normal file
19
CMakeFiles/Docs.cmake
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
# Files in ./share/completions/
|
||||||
|
FILE(GLOB COMPLETIONS_DIR_FILES share/completions/*.fish)
|
||||||
|
|
||||||
|
# Files in ./share/functions/
|
||||||
|
FILE(GLOB FUNCTIONS_DIR_FILES share/functions/*.fish)
|
||||||
|
|
||||||
|
# Build lexicon_filter
|
||||||
|
ADD_CUSTOM_COMMAND(OUTPUT lexicon_filter
|
||||||
|
COMMAND build_tools/build_lexicon_filter.sh
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/share/completions/
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/share/functions/
|
||||||
|
< lexicon_filter.in
|
||||||
|
> ${CMAKE_CURRENT_BINARY_DIR}/lexicon_filter
|
||||||
|
&& chmod a+x ${CMAKE_CURRENT_BINARY_DIR}/lexicon_filter
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
DEPENDS ${COMPLETIONS_DIR_FILES} ${FUNCTIONS_DIR_FILES}
|
||||||
|
doc_src/commands.hdr lexicon_filter.in
|
||||||
|
share/functions/__fish_config_interactive.fish
|
||||||
|
build_tools/build_lexicon_filter.sh)
|
|
@ -59,6 +59,9 @@ INCLUDE(CMakeFiles/PCRE2.cmake)
|
||||||
# Set up muparser.
|
# Set up muparser.
|
||||||
INCLUDE(CMakeFiles/MuParser.cmake)
|
INCLUDE(CMakeFiles/MuParser.cmake)
|
||||||
|
|
||||||
|
# Set up the docs.
|
||||||
|
INCLUDE(CMakeFiles/Docs.cmake)
|
||||||
|
|
||||||
# Define a function to link dependencies.
|
# Define a function to link dependencies.
|
||||||
FUNCTION(FISH_LINK_DEPS target)
|
FUNCTION(FISH_LINK_DEPS target)
|
||||||
TARGET_LINK_LIBRARIES(${target} ${CURSES_LIBRARIES} Threads::Threads)
|
TARGET_LINK_LIBRARIES(${target} ${CURSES_LIBRARIES} Threads::Threads)
|
||||||
|
|
48
Makefile.in
48
Makefile.in
|
@ -440,36 +440,6 @@ doc_src/index.hdr: toc.txt doc_src/index.hdr.in | show-AWK
|
||||||
@echo " AWK CAT $(em)$@$(sgr0)"
|
@echo " AWK CAT $(em)$@$(sgr0)"
|
||||||
$v cat $@.in | $(AWK) '{if ($$0 ~ /@toc@/){ system("cat toc.txt");} else{ print $$0;}}' >$@
|
$v cat $@.in | $(AWK) '{if ($$0 ~ /@toc@/){ system("cat toc.txt");} else{ print $$0;}}' >$@
|
||||||
|
|
||||||
#
|
|
||||||
# To enable the lexicon filter, we first need to be aware of what fish
|
|
||||||
# considers to be a command, function, or external binary. We use
|
|
||||||
# command_list_toc.txt for the base commands. Scan the share/functions
|
|
||||||
# directory for other functions, some of which are mentioned in the docs, and
|
|
||||||
# use /share/completions to find a good selection of binaries. Additionally,
|
|
||||||
# colour defaults from __fish_config_interactive to set the docs colours when
|
|
||||||
# used in a 'cli' style context.
|
|
||||||
#
|
|
||||||
lexicon.txt: doc_src/commands.hdr $(FUNCTIONS_DIR_FILES) $(COMPLETIONS_DIR_FILES) share/functions/__fish_config_interactive.fish | show-SED show-FGREP
|
|
||||||
$v rm -f lexicon.tmp lexicon_catalog.tmp lexicon_catalog.txt $@
|
|
||||||
# Scan sources for commands/functions/binaries/colours. If GNU sed was portable, this could be much smarter.
|
|
||||||
@echo " SEDFGREP $(em)$@$(sgr0)"
|
|
||||||
$v $(SED) <command_list_toc.txt >>lexicon.tmp -n \
|
|
||||||
-e "s|^.*>\([a-z][a-z_]*\)</a>|'\1'|w lexicon_catalog.tmp" \
|
|
||||||
-e "s|'\(.*\)'|bltn \1|p"; mv lexicon_catalog.tmp lexicon_catalog.txt
|
|
||||||
$v printf "%s\n" $(COMPLETIONS_DIR_FILES) | $(SED) -n \
|
|
||||||
-e "s|[^ ]*/\([a-z][a-z_-]*\).fish|'\1'|p" | $(FGREP) -vx -f lexicon_catalog.txt | $(SED) >>lexicon.tmp -n \
|
|
||||||
-e 'w lexicon_catalog.tmp' \
|
|
||||||
-e "s|'\(.*\)'|cmnd \1|p"; cat lexicon_catalog.tmp >> lexicon_catalog.txt;
|
|
||||||
$v printf "%s\n" $(FUNCTIONS_DIR_FILES) | $(SED) -n \
|
|
||||||
-e "s|[^ ]*/\([a-z][a-z_-]*\).fish|'\1'|p" | $(FGREP) -vx -f lexicon_catalog.txt | $(SED) >>lexicon.tmp -n \
|
|
||||||
-e 'w lexicon_catalog.tmp' \
|
|
||||||
-e "s|'\(.*\)'|func \1|p";
|
|
||||||
$v $(SED) <share/functions/__fish_config_interactive.fish >>lexicon.tmp -n \
|
|
||||||
-e '/set_default/s/.*\(fish_[a-z][a-z_]*\).*$$/clrv \1/p'; \
|
|
||||||
$(SED) <lexicon_filter.in >>lexicon.tmp -n \
|
|
||||||
-e '/^#.!#/s/^#.!# \(.... [a-z][a-z_]*\)/\1/p';
|
|
||||||
$v mv lexicon.tmp lexicon.txt; rm -f lexicon_catalog.tmp lexicon_catalog.txt;
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Compile Doxygen Input Filter from the lexicon. This is an executable sed
|
# Compile Doxygen Input Filter from the lexicon. This is an executable sed
|
||||||
# script as Doxygen opens it via popen()(3) Input (doc.h) is piped through and
|
# script as Doxygen opens it via popen()(3) Input (doc.h) is piped through and
|
||||||
|
@ -480,19 +450,11 @@ lexicon.txt: doc_src/commands.hdr $(FUNCTIONS_DIR_FILES) $(COMPLETIONS_DIR_FILES
|
||||||
# HTML, a style context can be applied through the /fish{style} block and
|
# HTML, a style context can be applied through the /fish{style} block and
|
||||||
# providing suitable CSS in user_doc.css.in
|
# providing suitable CSS in user_doc.css.in
|
||||||
#
|
#
|
||||||
lexicon_filter: lexicon.txt lexicon_filter.in | show-SED
|
lexicon_filter: doc_src/commands.hdr $(FUNCTIONS_DIR_FILES) $(COMPLETIONS_DIR_FILES) \
|
||||||
$v rm -f $@.tmp $@
|
lexicon_filter.in build_tools/build_lexicon_filter.sh \
|
||||||
@echo " SED $(em)$@.tmp$(sgr0)"
|
share/functions/__fish_config_interactive.fish
|
||||||
# Set the shebang as sed can reside in multiple places.
|
$v build_tools/build_lexicon_filter.sh share/functions/ share/completions/ < lexicon_filter.in > $@
|
||||||
$v $(SED) <$@.in >$@.tmp -e 's|@sed@|'$(SED)'|'
|
$v chmod a+x lexicon_filter
|
||||||
# Scan through the lexicon, transforming each line to something useful to Doxygen.
|
|
||||||
$v if echo x | $(SED) "/[[:<:]]x/d" 2>/dev/null; then \
|
|
||||||
WORDBL='[[:<:]]'; WORDBR='[[:>:]]'; \
|
|
||||||
else \
|
|
||||||
WORDBL='\\<'; WORDBR='\\>'; \
|
|
||||||
fi; $(SED) <lexicon.txt >>$@.tmp -n -e "s|^\([a-z][a-z][a-z][a-z]\) \([a-z_-]*\)$$|s,$$WORDBL\2$$WORDBR,@\1{\2},g|p" -e '$$G;s/.*\n/b tidy/p';
|
|
||||||
$v mv $@.tmp $@; test -x $@ || chmod a+x $@;
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# doc.h is a compilation of the various snipptes of text used both for
|
# doc.h is a compilation of the various snipptes of text used both for
|
||||||
|
|
49
build_tools/build_lexicon_filter.sh
Executable file
49
build_tools/build_lexicon_filter.sh
Executable file
|
@ -0,0 +1,49 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Builds the lexicon filter
|
||||||
|
# Usage: build_lexicon_filter.sh FUNCTIONS_DIR COMPLETIONS_DIR < lexicon_filter.in > lexicon_filter
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# To enable the lexicon filter, we first need to be aware of what fish
|
||||||
|
# considers to be a command, function, or external binary. We use
|
||||||
|
# command_list_toc.txt for the base commands. Scan the share/functions
|
||||||
|
# directory for other functions, some of which are mentioned in the docs, and
|
||||||
|
# use /share/completions to find a good selection of binaries. Additionally,
|
||||||
|
# colour defaults from __fish_config_interactive to set the docs colours when
|
||||||
|
# used in a 'cli' style context.
|
||||||
|
rm -f lexicon.tmp lexicon_catalog.tmp lexicon_catalog.txt lexicon.txt
|
||||||
|
|
||||||
|
SED=$(which sed)
|
||||||
|
|
||||||
|
FUNCTIONS_DIR_FILES=${1}/*.fish
|
||||||
|
COMPLETIONS_DIR_FILES=${2}/*.fish
|
||||||
|
|
||||||
|
# Scan sources for commands/functions/binaries/colours. If GNU sed was portable, this could be much smarter.
|
||||||
|
$SED <command_list_toc.txt >>lexicon.tmp -n \
|
||||||
|
-e "s|^.*>\([a-z][a-z_]*\)</a>|'\1'|w lexicon_catalog.tmp" \
|
||||||
|
-e "s|'\(.*\)'|bltn \1|p"; mv lexicon_catalog.tmp lexicon_catalog.txt
|
||||||
|
printf "%s\n" ${COMPLETIONS_DIR_FILES} | $SED -n \
|
||||||
|
-e "s|[^ ]*/\([a-z][a-z_-]*\).fish|'\1'|p" | grep -F -vx -f lexicon_catalog.txt | $SED >>lexicon.tmp -n \
|
||||||
|
-e 'w lexicon_catalog.tmp' \
|
||||||
|
-e "s|'\(.*\)'|cmnd \1|p"; cat lexicon_catalog.tmp >> lexicon_catalog.txt;
|
||||||
|
printf "%s\n" ${FUNCTIONS_DIR_FILES} | $SED -n \
|
||||||
|
-e "s|[^ ]*/\([a-z][a-z_-]*\).fish|'\1'|p" | grep -F -vx -f lexicon_catalog.txt | $SED >>lexicon.tmp -n \
|
||||||
|
-e 'w lexicon_catalog.tmp' \
|
||||||
|
-e "s|'\(.*\)'|func \1|p";
|
||||||
|
$SED <share/functions/__fish_config_interactive.fish >>lexicon.tmp -n \
|
||||||
|
-e '/set_default/s/.*\(fish_[a-z][a-z_]*\).*$$/clrv \1/p'; \
|
||||||
|
$SED <lexicon_filter.in >>lexicon.tmp -n \
|
||||||
|
-e '/^#.!#/s/^#.!# \(.... [a-z][a-z_]*\)/\1/p';
|
||||||
|
$v mv lexicon.tmp lexicon.txt; rm -f lexicon_catalog.tmp lexicon_catalog.txt;
|
||||||
|
|
||||||
|
# Copy the filter to stdout. We're going to append sed commands to it after.
|
||||||
|
$SED -e 's|@sed@|'$SED'|'
|
||||||
|
|
||||||
|
# Scan through the lexicon, transforming each line to something useful to Doxygen.
|
||||||
|
if echo x | $SED "/[[:<:]]x/d" 2>/dev/null; then
|
||||||
|
WORDBL='[[:<:]]'; WORDBR='[[:>:]]';
|
||||||
|
else
|
||||||
|
WORDBL='\\<'; WORDBR='\\>';
|
||||||
|
fi;
|
||||||
|
$SED < lexicon.txt -n -e "s|^\([a-z][a-z][a-z][a-z]\) \([a-z_-]*\)$|s,$WORDBL\2$WORDBR,@\1{\2},g|p" -e '$G;s/.*\n/b tidy/p';
|
Loading…
Reference in New Issue
Block a user