X-Git-Url: http://git.maemo.org/git/?p=gonvert;a=blobdiff_plain;f=Makefile;h=3592b4175d863c9a6ae5f108808e65f34189a137;hp=4ed01ef95508ff0056761bb95598bd172f8dc1cd;hb=c731620d96242924f3f80c294df21b2ae63c6eec;hpb=e98f2a42a0007992fd7484d80a5d3eb398312826 diff --git a/Makefile b/Makefile index 4ed01ef..3592b41 100644 --- a/Makefile +++ b/Makefile @@ -1,12 +1,19 @@ PROJECT_NAME=gonvert -SOURCE_PATH=src +PACKAGE_NAME=$(PROJECT_NAME) + +SOURCE_PATH=$(PACKAGE_NAME) SOURCE=$(shell find $(SOURCE_PATH) -iname "*.py") -PROGRAM=$(SOURCE_PATH)/$(PROJECT_NAME).py -DATA_PATH=data -DATA_TYPES=*.ini *.map *.glade *.png -DATA=$(foreach type, $(DATA_TYPES), $(shell find $(DATA_PATH) -iname "$(type)")) + +PROGRAM=Gonvert +ICON_SIZES=26 32 48 64 80 +ICONS=$(foreach size, $(ICON_SIZES), data/icons/$(size)/$(PROJECT_NAME).png) +PACKAGE_VARIANTS=fremantle harmattan ubuntu +DESKTOP_FILES=$(foreach variant, $(PACKAGE_VARIANTS), data/$(variant)/$(PROJECT_NAME).desktop) +SETUP_FILES=$(foreach variant, $(PACKAGE_VARIANTS), ./setup.$(variant).py) +DIST_BASE_PATH=./dist +DIST_PATHS=$(foreach variant, $(PACKAGE_VARIANTS), $(DIST_BASE_PATH)_$(variant)) $(DIST_BASE_PATH)_diablo + OBJ=$(SOURCE:.py=.pyc) -BUILD_PATH=./build TAG_FILE=~/.ctags/$(PROJECT_NAME).tags TODO_FILE=./TODO @@ -21,12 +28,13 @@ PROFILE_VIEW=python -m pstats .profile TODO_FINDER=support/todo.py CTAGS=ctags-exuberant + .PHONY: all run profile debug test build lint tags todo clean distclean all: test run: $(OBJ) - $(SOURCE_PATH)/$(PROJECT_NAME)_glade.py + $(PROGRAM) profile: $(OBJ) $(PROFILE_GEN) $(PROGRAM) @@ -38,40 +46,43 @@ debug: $(OBJ) test: $(OBJ) $(UNIT_TEST) -package: $(OBJ) - rm -Rf $(BUILD_PATH) - - mkdir -p $(BUILD_PATH)/generic - cp $(SOURCE_PATH)/constants.py $(BUILD_PATH)/generic - cp $(SOURCE_PATH)/$(PROJECT_NAME).py $(BUILD_PATH)/generic - $(foreach file, $(DATA), cp $(file) $(BUILD_PATH)/generic/$(subst /,-,$(file)) ; ) - $(foreach file, $(SOURCE), cp $(file) $(BUILD_PATH)/generic/$(subst /,-,$(file)) ; ) - #$(foreach file, $(OBJ), cp $(file) $(BUILD_PATH)/generic/$(subst /,-,$(file)) ; ) - cp support/$(PROJECT_NAME).desktop $(BUILD_PATH)/generic - cp support/builddeb.py $(BUILD_PATH)/generic - cp support/py2deb.py $(BUILD_PATH)/generic - - mkdir -p $(BUILD_PATH)/chinook - cp -R $(BUILD_PATH)/generic/* $(BUILD_PATH)/chinook - cd $(BUILD_PATH)/chinook ; python builddeb.py chinook - mkdir -p $(BUILD_PATH)/diablo - cp -R $(BUILD_PATH)/generic/* $(BUILD_PATH)/diablo - cd $(BUILD_PATH)/diablo ; python builddeb.py diablo - mkdir -p $(BUILD_PATH)/fremantle - cp -R $(BUILD_PATH)/generic/* $(BUILD_PATH)/fremantle - cd $(BUILD_PATH)/fremantle ; python builddeb.py fremantle - mkdir -p $(BUILD_PATH)/mer - cp -R $(BUILD_PATH)/generic/* $(BUILD_PATH)/mer - cd $(BUILD_PATH)/mer ; python builddeb.py mer - mkdir -p $(BUILD_PATH)/debian - cp -R $(BUILD_PATH)/generic/* $(BUILD_PATH)/debian - cd $(BUILD_PATH)/debian ; python builddeb.py debian - -upload: - dput fremantle-extras-builder $(BUILD_PATH)/fremantle/$(PROJECT_NAME)*.changes - dput diablo-extras-builder $(BUILD_PATH)/diablo/$(PROJECT_NAME)*.changes - dput chinook-extras-builder $(BUILD_PATH)/chinook/$(PROJECT_NAME)*.changes - cp $(BUILD_PATH)/debian/*.deb www/$(PROJECT_NAME).deb +_package_prep: $(OBJ) $(ICONS) $(SETUP_FILES) $(DESKTOP_FILES) + +package_diablo: _package_prep + rm -Rf $(DIST_BASE_PATH)_diablo/* + ./setup.fremantle.py sdist_diablo \ + -d $(DIST_BASE_PATH)_diablo \ + --install-purelib=/usr/lib/python2.5/site-packages +package_fremantle: _package_prep + rm -Rf $(DIST_BASE_PATH)_fremantle/* + ./setup.fremantle.py sdist_fremantle \ + -d $(DIST_BASE_PATH)_fremantle \ + --install-purelib=/usr/lib/python2.5/site-packages +package_harmattan: _package_prep + rm -Rf $(DIST_BASE_PATH)_harmattan/* + ./setup.harmattan.py sdist_harmattan \ + -d $(DIST_BASE_PATH)_harmattan \ + --install-purelib=/usr/lib/python2.6/dist-packages +package_ubuntu: _package_prep + rm -Rf $(DIST_BASE_PATH)_ubuntu/* + ./setup.ubuntu.py sdist_ubuntu \ + -d $(DIST_BASE_PATH)_ubuntu + mkdir $(DIST_BASE_PATH)_ubuntu/build + cd $(DIST_BASE_PATH)_ubuntu/build ; tar -zxvf ../*.tar.gz + cd $(DIST_BASE_PATH)_ubuntu/build ; dpkg-buildpackage -tc -rfakeroot -us -uc + +package: package_diablo package_fremantle package_harmattan package_ubuntu + +upload_diablo: + dput diablo-extras-builder $(DIST_BASE_PATH)_diablo/$(PROJECT_NAME)*.changes +upload_fremantle: + dput fremantle-extras-builder $(DIST_BASE_PATH)_fremantle/$(PROJECT_NAME)*.changes +upload_harmattan: + ./support/obs_upload.sh $(PROJECT_NAME) harmattan dist_harmattan +upload_ubuntu: + cp $(DIST_BASE_PATH)_ubuntu/*.deb www/$(PROJECT_NAME).deb + +upload: upload_diablo upload_fremantle upload_harmattan upload_ubuntu lint: $(OBJ) $(foreach file, $(SOURCE), $(LINT) $(file) ; ) @@ -82,18 +93,61 @@ todo: $(TODO_FILE) clean: rm -Rf $(OBJ) - rm -Rf $(BUILD_PATH) rm -Rf $(TODO_FILE) + rm -f $(ICONS) $(SETUP_FILES) $(DESKTOP_FILES) + rm -Rf $(DIST_PATHS) ./build -distclean: - rm -Rf $(OBJ) - rm -Rf $(BUILD_PATH) - rm -Rf $(TAG_FILE) +distclean: clean find $(SOURCE_PATH) -name "*.*~" | xargs rm -f find $(SOURCE_PATH) -name "*.swp" | xargs rm -f find $(SOURCE_PATH) -name "*.bak" | xargs rm -f find $(SOURCE_PATH) -name ".*.swp" | xargs rm -f + +$(SETUP_FILES): VARIANT=$(word 2, $(subst ., ,$@)) + +setup.fremantle.py: setup.py src/constants.py + cog.py -c \ + -D DESKTOP_FILE_PATH=/usr/share/applications/hildon \ + -D INPUT_DESKTOP_FILE=data/$(VARIANT)/$(PROJECT_NAME).desktop \ + -D ICON_CATEGORY=hildon \ + -D ICON_SIZES=26,32,48 \ + -o $@ $< + chmod +x $@ + +setup.harmattan.py: setup.py src/constants.py + cog.py -c \ + -D DESKTOP_FILE_PATH=/usr/share/applications \ + -D INPUT_DESKTOP_FILE=data/$(VARIANT)/$(PROJECT_NAME).desktop \ + -D ICON_CATEGORY=apps \ + -D ICON_SIZES=64,80 \ + -o $@ $< + chmod +x $@ + +setup.ubuntu.py: setup.py src/constants.py + cog.py -c \ + -D DESKTOP_FILE_PATH=/usr/share/applications \ + -D INPUT_DESKTOP_FILE=data/$(VARIANT)/$(PROJECT_NAME).desktop \ + -D ICON_CATEGORY=apps \ + -D ICON_SIZES=32,48 \ + -o $@ $< + chmod +x $@ + +$(ICONS): SIZE=$(word 3, $(subst /, ,$@)) +$(ICONS): data/$(PROJECT_NAME).png support/scale.py + mkdir -p $(dir $@) + support/scale.py --input $< --output $@ --size $(SIZE) + +$(DESKTOP_FILES): VARIANT=$(word 2, $(subst /, ,$@)) +$(DESKTOP_FILES): data/template.desktop + mkdir -p $(dir $@) + cog.py -d \ + -D VARIANT=$(VARIANT) \ + -D PROGRAM=$(PROGRAM) \ + -D ICON_NAME=$(PROJECT_NAME) \ + -o $@ $< + + $(TAG_FILE): $(OBJ) mkdir -p $(dir $(TAG_FILE)) $(CTAGS) -o $(TAG_FILE) $(SOURCE)