Merge pull request #5029 from jmarshallnz/protocol_filetype
[vuplus_xbmc] / codegenerator.mk
index 6689777..5ecb0c0 100644 (file)
@@ -18,6 +18,14 @@ else
 DOXY_XML_PATH=$(GENDIR)/doxygenxml
 endif
 
+GENERATED_JSON = $(INTERFACES_DIR)/json-rpc/ServiceDescription.h addons/xbmc.json/addon.xml
+ifeq ($(wildcard $(JSON_BUILDER)),)
+  JSON_BUILDER = $(shell which JsonSchemaBuilder)
+ifeq ($(JSON_BUILDER),)
+  JSON_BUILDER = tools/depends/native/JsonSchemaBuilder/bin/JsonSchemaBuilder
+endif
+endif
+
 GENDIR = $(INTERFACES_DIR)/python/generated
 GROOVY_DIR = $(TOPDIR)/lib/groovy
 
@@ -43,7 +51,7 @@ $(GENDIR)/%.xml: %.i $(SWIG) $(JAVA) $(GENERATE_DEPS)
        mkdir -p $(GENDIR)
        $(SWIG) -w401 -c++ -o $@ -xml -I$(TOPDIR)/xbmc -xmllang python $<
 
-codegenerated: $(DOXYGEN) $(SWIG) $(JAVA) $(GENERATED)
+codegenerated: $(DOXYGEN) $(SWIG) $(JAVA) $(GENERATED) $(GENERATED_JSON) $(GENERATED_ADDON_JSON)
 
 $(DOXY_XML_PATH): $(SWIG) $(JAVA)
        cd $(INTERFACES_DIR)/python; ($(DOXYGEN) Doxyfile > /dev/null) 2>&1 | grep -v " warning: "
@@ -63,3 +71,15 @@ $(SWIG):
        @echo This is not necessarily an error.
        @false
 
+$(GENERATED_JSON): $(JSON_BUILDER)
+       @echo Jsonbuilder: $(JSON_BUILDER)
+       make -C $(INTERFACES_DIR)/json-rpc $(notdir $@)
+
+$(JSON_BUILDER):
+ifeq ($(BOOTSTRAP_FROM_DEPENDS), yes)
+       @echo JsonSchemaBuilder not found. You didn\'t build depends. Check docs/README.\<yourplatform\>
+       @false
+else
+#build json builder - ".." because makefile is in the parent dir of "bin"
+       make -C $(abspath $(dir $@)..)
+endif