3 #     Copyright (C) Dean Camera, 2013.
 
   5 #  dean [at] fourwalledcubicle [dot] com
 
   8 # ---------------------------------------
 
   9 #  Makefile for the LUFA Atmel Studio Integration.
 
  10 # ---------------------------------------
 
  13 LUFA_VERSION_NUM     := $(shell grep LUFA_VERSION_STRING $(LUFA_ROOT)/Version.h | cut -d'"' -f2)
 
  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
 
  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
 
  22   $(warning No LUFA version set - assuming a test version should be created.)
 
  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                                \
 
  38                         VSIX/LUFAHelpMenu.png                               \
 
  39                         VSIX/NewExampleWizard.png                           \
 
  40                         VSIX/GettingStarted.htm                             \
 
  43 VSIX_GEN_PARAMS     := --stringparam extension-version "$(EXT_VERSION_NUM)" \
 
  44                        --stringparam lufa-version "$(LUFA_VERSION_NUM)"
 
  45 MSHELP_GEN_PARAMS   := --stringparam generate.toc "book toc"                \
 
  46                        --stringparam chunk.quietly "1"                      \
 
  47                        --stringparam chunk.section.depth "3"                \
 
  48                        --stringparam chunk.first.sections "1"               \
 
  49                        --stringparam chapter.autolabel "0"                  \
 
  50                        --stringparam root.filename "LUFA"                   \
 
  51                        --stringparam html.stylesheet "lufa_studio_help_styling.css"
 
  53 all: generate_xml check_filenames generate_vsix
 
  56         @rm -f $(TEMP_MANIFEST_XML) $(MODULE_OUTPUT_XML) $(EXTENSION_OUTPUT_XML) $(DOXYGEN_TAG_FILE_XML) $(DOXYGEN_COMBINED_XML) $(MSHELP_OUTPUT_XML)
 
  58         @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
 
  60 $(DOXYGEN_TAG_FILE_XML):
 
  61         @$(MAKE) -C ../ doxygen DOXYGEN_OVERRIDE_PARAMS="GENERATE_TAGFILE=Documentation/lufa_doc_tags.xml GENERATE_HTML=no GENERATE_XML=yes"
 
  63 $(DOXYGEN_COMBINED_XML): $(DOXYGEN_TAG_FILE_XML)
 
  64         @xsltproc $(dir $@)/combine.xslt $(dir $@)/index.xml > $(DOXYGEN_COMBINED_XML)
 
  66 $(TEMP_MANIFEST_XML): $(DOXYGEN_TAG_FILE_XML) $(DOXYGEN_COMBINED_XML)
 
  67         @echo "Generating Manifest XML..."
 
  69         @printf "<lufa-manifest version=\"%s\" tagfile=\"%s\" docfile=\"%s\">\n" $(LUFA_VERSION_NUM) $(DOXYGEN_TAG_FILE_XML) $(DOXYGEN_COMBINED_XML) > $@
 
  70         @for i in $(XML_FILES); do \
 
  71                 printf "\t<xml-source filename=\"%s\"/>\n" $$i >> $@; \
 
  73         @echo '</lufa-manifest>' >> $@
 
  75         @echo "Manifest XML file generated."
 
  77 $(MODULE_OUTPUT_XML): $(TEMP_MANIFEST_XML)
 
  78         @echo "Processing asf.xml file..."
 
  79         @xsltproc XDK/lufa_module_transform.xslt $< | xsltproc XDK/lufa_indent_transform.xslt - > $(MODULE_OUTPUT_XML)
 
  80         @echo "Atmel Studio asf.xml file generated."
 
  82 $(EXTENSION_OUTPUT_XML): $(TEMP_MANIFEST_XML)
 
  83         @echo "Processing extension.xml file..."
 
  84         @xsltproc XDK/lufa_extension_transform.xslt $< | xsltproc XDK/lufa_indent_transform.xslt - > $(EXTENSION_OUTPUT_XML)
 
  85         @echo "Atmel Studio extension.xml file generated."
 
  87 $(MSHELP_OUTPUT_XML): $(DOXYGEN_COMBINED_XML)
 
  88         @echo Converting Doxygen XML to Docbook...
 
  89         @-mkdir mshelp 2> /dev/null
 
  90         @xsltproc HV1/lufa_docbook_transform.xslt $(DOXYGEN_COMBINED_XML) > mshelp/lufa_docbook.xml
 
  92         @echo Converting Docbook XML to Microsoft Help 1.0...
 
  93         @cd mshelp && xsltproc $(MSHELP_GEN_PARAMS) ../HV1/lufa_hv1_transform.xslt lufa_docbook.xml
 
  95         @echo Copying help assets...
 
  96         @cp HV1/lufa_studio_help_styling.css mshelp
 
  97         @-mkdir mshelp/images 2> /dev/null
 
  98         @cp `find $(LUFA_ROOT)/DoxygenPages/Images -type f` mshelp/images
 
 100         @echo Archiving help content...
 
 101         @cd mshelp && zip ../$(MSHELP_OUTPUT_XML) -q -0  -r *.html *.css images
 
 103 generate_help: $(MSHELP_OUTPUT_XML)
 
 105 generate_xml: $(EXTENSION_OUTPUT_XML) $(MODULE_OUTPUT_XML)
 
 107 generate_vsix: $(EXTENSION_OUTPUT_XML) $(MODULE_OUTPUT_XML) $(MSHELP_OUTPUT_XML)
 
 108         @echo "Generating ASF cache files..."
 
 109         @rm -f $(LUFA_ROOT)/../content.xml.cache
 
 110         @rm -f $(LUFA_ROOT)/../ExampleProjects.xml
 
 111         @python VSIX/generate_caches.py $(LUFA_ROOT)/../
 
 113         @echo "Archiving ASF content..."
 
 115         @cd $(LUFA_ROOT)/../ && zip contents.zip -q -0 -r --exclude=*Documentation* --exclude=*StudioIntegration* LUFA Bootloaders Demos Projects README.txt
 
 117         @echo "Creating VSIX dependencies..."
 
 118         @cp $(VSIX_ASSETS) $(LUFA_ROOT)/..
 
 119         @xsltproc $(VSIX_GEN_PARAMS) VSIX/lufa_vsmanifest_transform.xslt VSIX/extension.vsixmanifest > $(LUFA_ROOT)/../extension.vsixmanifest
 
 120         @xsltproc $(VSIX_GEN_PARAMS) VSIX/lufa_asfmanifest_transform.xslt VSIX/asf-manifest.xml > $(LUFA_ROOT)/../asf-manifest.xml
 
 121         @xsltproc $(VSIX_GEN_PARAMS) HV1/lufa_helpcontentsetup_transform.xslt HV1/helpcontentsetup.msha > $(LUFA_ROOT)/../helpcontentsetup.msha
 
 123         @echo "Generating Atmel Studio VSIX file..."
 
 124         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))
 
 125         @echo "Atmel Studio VSIX Extension file generated."
 
 127 check_filenames: $(MODULE_OUTPUT_XML)
 
 128         @echo Verifying referenced filenames of ASF.xml modules...
 
 129         @for f in `find $(LUFA_ROOT)/../ -name "asf.xml"`; do \
 
 130                 echo "Checking $$f..."; \
 
 131                 asf_file_dir=`dirname $$f`; \
 
 132                 xsltproc XDK/lufa_filelist_transform.xslt $$f | sed -e "/^$$/d" | while read -r i; do \
 
 133                         if ( ! test -f "$$asf_file_dir/$$i" ); then \
 
 134                                 echo "Source file \"$$i\" referenced in $$f does not exist!"; \
 
 139         @echo Verified referenced filenames of ASF.xml modules.
 
 142         python ProjectGenerator/project_generator.py -b $(LUFA_ROOT)/../ --main-ext-uuid=0e160d5c-e331-48d9-850b-e0387912171b CHECK
 
 144 .PHONY: all clean generate_help generate_xml generate_vsix check_filenames sanity_check