Add first-run Unsigned Help install information prompt, ensure installed help package...
[pub/USBasp.git] / LUFA / StudioIntegration / makefile
1 #
2 # LUFA Library
3 # Copyright (C) Dean Camera, 2013.
4 #
5 # dean [at] fourwalledcubicle [dot] com
6 # www.lufa-lib.org
7 #
8 # ---------------------------------------
9 # Makefile for the LUFA Atmel Studio Integration.
10 # ---------------------------------------
11
12 LUFA_ROOT := ..
13 LUFA_VERSION_NUM := $(shell grep LUFA_VERSION_STRING $(LUFA_ROOT)/Version.h | cut -d'"' -f2)
14
15 ifneq ($(LUFA_VERSION_NUM),000000)
16 EXT_VERSION_NUM := $(shell date +"%y.%m.%d").$(LUFA_VERSION_NUM)
17 EXT_VSIX_NAME := LUFA-RELEASE-$(LUFA_VERSION_NUM).vsix
18 else
19 EXT_VERSION_NUM := 0.$(shell date +"%y%m%d.%H%M%S")
20 EXT_VSIX_NAME := LUFA-TESTING-$(shell date +"%y.%m.%d-%H.%M.%S").vsix
21
22 $(warning No LUFA version set - assuming a test version should be created.)
23 endif
24
25 DOXYGEN_TAG_FILE_XML := $(LUFA_ROOT)/Documentation/lufa_doc_tags.xml
26 DOXYGEN_COMBINED_XML := $(LUFA_ROOT)/Documentation/xml/lufa_doc.xml
27 TEMP_MANIFEST_XML := manifest.xml
28 EXTENSION_OUTPUT_XML := $(LUFA_ROOT)/../extension.xml
29 MODULE_OUTPUT_XML := $(LUFA_ROOT)/asf.xml
30 MSHELP_OUTPUT_XML := $(LUFA_ROOT)/../lufa_help_$(EXT_VERSION_NUM).mshc
31 XML_FILES := $(filter-out $(TEMP_MANIFEST_FILE), $(shell ls *.xml))
32 VSIX_ASSETS := $(LUFA_ROOT)/DoxygenPages/Images/LUFA_thumb.png \
33 $(LUFA_ROOT)/DoxygenPages/Images/LUFA.png \
34 $(LUFA_ROOT)/License.txt \
35 VSIX/"[Content_Types].xml" \
36 VSIX/ASFExplorer.png \
37 VSIX/ASFWizard.png \
38 VSIX/NewExampleWizard.png \
39 VSIX/GettingStarted.htm \
40 Blob/Atmel.Studio.Services.Interfaces.dll \
41 Blob/LUFA.dll \
42 Blob/LUFA.pkgdef
43
44 MSHELP_GEN_PARAMS := --stringparam generate.toc "book toc" \
45 --stringparam chunk.quietly "1" \
46 --stringparam chunk.section.depth "3" \
47 --stringparam chunk.first.sections "1"
48
49 all: generate_xml check_filenames generate_vsix
50
51 clean:
52 @rm -f $(TEMP_MANIFEST_XML) $(MODULE_OUTPUT_XML) $(EXTENSION_OUTPUT_XML) $(DOXYGEN_TAG_FILE_XML) $(DOXYGEN_COMBINED_XML) $(MSHELP_OUTPUT_XML)
53 @rm -rf mshelp
54 @cd $(LUFA_ROOT)/.. && rm -f contents.zip exampleProjects.xml content.xml.cache extension.vsixmanifest asf-manifest.xml extension.xml helpcontentsetup.msha $(notdir $(VSIX_ASSETS)) *.vsix *.mshc
55
56 $(DOXYGEN_TAG_FILE_XML):
57 @$(MAKE) -C ../ doxygen DOXYGEN_OVERRIDE_PARAMS="GENERATE_TAGFILE=Documentation/lufa_doc_tags.xml GENERATE_HTML=no GENERATE_XML=yes"
58
59 $(DOXYGEN_COMBINED_XML): $(DOXYGEN_TAG_FILE_XML)
60 @xsltproc $(dir $@)/combine.xslt $(dir $@)/index.xml > $(DOXYGEN_COMBINED_XML)
61
62 $(TEMP_MANIFEST_XML): $(DOXYGEN_TAG_FILE_XML) $(DOXYGEN_COMBINED_XML)
63 @echo "Generating Manifest XML..."
64
65 @printf "<lufa-manifest version=\"%s\" tagfile=\"%s\" docfile=\"%s\">\n" $(LUFA_VERSION_NUM) $(DOXYGEN_TAG_FILE_XML) $(DOXYGEN_COMBINED_XML) > $@
66 @for i in $(XML_FILES); do \
67 printf "\t<xml-source filename=\"%s\"/>\n" $$i >> $@; \
68 done;
69 @echo '</lufa-manifest>' >> $@
70
71 @echo "Manifest XML file generated."
72
73 $(MODULE_OUTPUT_XML): $(TEMP_MANIFEST_XML)
74 @echo "Processing asf.xml file..."
75 @xsltproc XDK/lufa_module_transform.xslt $< | xsltproc XDK/lufa_indent_transform.xslt - > $(MODULE_OUTPUT_XML)
76 @echo "Atmel Studio asf.xml file generated."
77
78 $(EXTENSION_OUTPUT_XML): $(TEMP_MANIFEST_XML)
79 @echo "Processing extension.xml file..."
80 @xsltproc XDK/lufa_extension_transform.xslt $< | xsltproc XDK/lufa_indent_transform.xslt - > $(EXTENSION_OUTPUT_XML)
81 @echo "Atmel Studio extension.xml file generated."
82
83 $(MSHELP_OUTPUT_XML): $(DOXYGEN_COMBINED_XML)
84 @echo Converting Doxygen XML to Docbook...
85 @-mkdir mshelp 2> /dev/null
86 @xsltproc HV1/lufa_docbook_transform.xsl $(DOXYGEN_COMBINED_XML) > mshelp/lufa_docbook.xml
87 @cd mshelp && xsltproc $(MSHELP_GEN_PARAMS) ../Docbook/mshelp/docbook.xsl lufa_docbook.xml
88
89 @echo Copying help assets...
90 @-mkdir mshelp/images 2> /dev/null
91 @cp `find $(LUFA_ROOT)/DoxygenPages/Images -type f` mshelp/images
92
93 @echo Archiving help content...
94 @cd mshelp && zip ../$(MSHELP_OUTPUT_XML) -q -0 -r *.html images
95
96
97 generate_xml: $(EXTENSION_OUTPUT_XML) $(MODULE_OUTPUT_XML)
98
99 generate_vsix: $(EXTENSION_OUTPUT_XML) $(MODULE_OUTPUT_XML) $(MSHELP_OUTPUT_XML)
100 @echo "Generating ASF cache files..."
101 @rm -f $(LUFA_ROOT)/../content.xml.cache
102 @rm -f $(LUFA_ROOT)/../ExampleProjects.xml
103 @python VSIX/generate_caches.py $(LUFA_ROOT)/../
104
105 @echo "Archiving ASF content..."
106 @rm -f contents.zip
107 @cd $(LUFA_ROOT)/../ && zip contents.zip -q -0 -r --exclude=*Documentation* --exclude=*StudioIntegration* LUFA Bootloaders Demos Projects README.txt
108
109 @echo "Creating VSIX dependencies..."
110 @cp $(VSIX_ASSETS) $(LUFA_ROOT)/..
111 @xsltproc --stringparam extension-version "$(EXT_VERSION_NUM)" VSIX/lufa_vsmanifest_transform.xslt VSIX/extension.vsixmanifest > $(LUFA_ROOT)/../extension.vsixmanifest
112 @xsltproc --stringparam lufa-version "$(LUFA_VERSION_NUM)" VSIX/lufa_asfmanifest_transform.xslt VSIX/asf-manifest.xml > $(LUFA_ROOT)/../asf-manifest.xml
113 @xsltproc --stringparam extension-version "$(EXT_VERSION_NUM)" HV1/lufa_helpcontentsetup_transform.xslt HV1/helpcontentsetup.msha > $(LUFA_ROOT)/../helpcontentsetup.msha
114
115 @echo "Generating Atmel Studio VSIX file..."
116 cd $(LUFA_ROOT)/../ && zip $(EXT_VSIX_NAME) -q -9 contents.zip exampleProjects.xml content.xml.cache extension.vsixmanifest asf-manifest.xml extension.xml helpcontentsetup.msha $(notdir $(MSHELP_OUTPUT_XML)) $(notdir $(VSIX_ASSETS))
117 @echo "Atmel Studio VSIX Extension file generated."
118
119 check_filenames: $(MODULE_OUTPUT_XML)
120 @echo Verifying referenced filenames of ASF.xml modules...
121 @for f in `find $(LUFA_ROOT)/../ -name "asf.xml"`; do \
122 echo "Checking $$f..."; \
123 asf_file_dir=`dirname $$f`; \
124 xsltproc XDK/lufa_filelist_transform.xslt $$f | sed -e "/^$$/d" | while read -r i; do \
125 if ( ! test -f "$$asf_file_dir/$$i" ); then \
126 echo "Source file \"$$i\" referenced in $$f does not exist!"; \
127 exit 1; \
128 fi; \
129 done || exit 1; \
130 done;
131 @echo Verified referenced filenames of ASF.xml modules.
132
133 sanity_check:
134 python ProjectGenerator/project_generator.py -b $(LUFA_ROOT)/../ --main-ext-uuid=0e160d5c-e331-48d9-850b-e0387912171b CHECK
135
136 .PHONY: all clean generate_xml generate_vsix check_filenames sanity_check