-#
+#
# Copyright (C) 2008 OpenWrt.org
#
# This is free software, licensed under the GNU General Public License v2.
# See /LICENSE for more information.
#
-# $Id$
include $(TOPDIR)/rules.mk
+UCI_VERSION=12012009
+UCI_RELEASE=5
+
PKG_NAME:=uci
-PKG_VERSION:=0.1
+PKG_VERSION:=$(UCI_VERSION)$(if $(UCI_RELEASE),.$(UCI_RELEASE))
PKG_RELEASE:=1
+PKG_REV:=aa3ab8012bfbf793d2884c08ea924545a04e9544
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
-PKG_SOURCE_URL:=http://downloads.openwrt.org/sources
-PKG_MD5SUM:=f6340dce09f5f1552c4e03be98e64265
+PKG_SOURCE_URL:=git://nbd.name/uci.git
+PKG_SOURCE_SUBDIR:=uci-$(PKG_VERSION)
+PKG_SOURCE_VERSION:=$(PKG_REV)
+PKG_SOURCE_PROTO:=git
include $(INCLUDE_DIR)/package.mk
define Package/libuci
SECTION:=libs
CATEGORY:=Libraries
- DEPENDS:=+libuci
TITLE:=C library for the Unified Configuration Interface (UCI)
endef
TITLE:=Utility for the Unified Configuration Interface (UCI)
endef
-define Package/uci-sh
+define Package/ucitrigger
SECTION:=base
CATEGORY:=Base system
- DEPENDS:=@!PACKAGE_uci
- TITLE:=Old shell/awk implementation of UCI
+ DEPENDS:=+libuci-lua +lua
+ TITLE:=Automatic triggers for applying system config changes
+endef
+
+define Package/libuci-lua
+ SECTION=libs
+ CATEGORY=Libraries
+ DEPENDS:=+libuci +liblua
+ TITLE:=Lua plugin for UCI
endef
define Build/Configure
endef
-define Build/Compile
- $(MAKE) -C $(PKG_BUILD_DIR) \
+UCI_MAKEOPTS = \
$(TARGET_CONFIGURE_OPTS) \
COPTS="$(TARGET_CFLAGS)" \
DEBUG="$(DEBUG)" \
- VERSION="$(PKG_VERSION)" \
+ VERSION="$(UCI_VERSION)" \
+ CPPFLAGS="-I$(PKG_BUILD_DIR) $(TARGET_CPPFLAGS)" \
+ FPIC="$(FPIC)" \
OS="Linux"
+
+# work around a nasty gcc bug
+ifneq ($(CONFIG_GCC_VERSION_4_2_4),)
+ UCI_MAKEOPTS += WOPTS=""
+endif
+
+define Build/Compile
+ $(MAKE) -C $(PKG_BUILD_DIR) $(UCI_MAKEOPTS)
+ $(MAKE) -C $(PKG_BUILD_DIR)/lua $(UCI_MAKEOPTS)
+ $(MAKE) -C $(PKG_BUILD_DIR)/trigger $(UCI_MAKEOPTS) \
+ LIBS="$(TARGET_LDFLAGS) -L$(PKG_BUILD_DIR) -luci -llua -lcrypt -lm"
endef
define Package/libuci/install
$(CP) $(PKG_BUILD_DIR)/libuci.so* $(1)/lib/
endef
+define Package/libuci-lua/install
+ $(INSTALL_DIR) $(1)/usr/lib/lua
+ $(CP) $(PKG_BUILD_DIR)/lua/uci.so $(1)/usr/lib/lua/
+endef
+
+define Package/ucitrigger/install
+ $(INSTALL_DIR) $(1)/usr/lib/lua/uci $(1)/lib/config/trigger $(1)/usr/sbin
+ $(INSTALL_DATA) ./trigger/lib/trigger.lua $(1)/usr/lib/lua/uci/
+ $(INSTALL_DATA) ./trigger/modules/*.lua $(1)/lib/config/trigger/
+ $(INSTALL_DATA) $(PKG_BUILD_DIR)/trigger/uci_trigger.so $(1)/usr/lib/
+ $(INSTALL_BIN) ./trigger/apply_config $(1)/usr/sbin/
+endef
+
define Package/uci/install
+ $(INSTALL_DIR) $(1)/etc/uci-defaults
$(INSTALL_DIR) $(1)/sbin
$(INSTALL_BIN) $(PKG_BUILD_DIR)/uci $(1)/sbin/
- $(CP) ./files/uci/* $(1)/
+ $(CP) ./files/* $(1)/
endef
-define Package/uci-sh/install
- $(INSTALL_DIR) $(1)
- $(CP) ./files/uci-sh/* $(1)/
+define Build/InstallDev
+ $(INSTALL_DIR) $(1)/usr/include
+ $(CP) $(PKG_BUILD_DIR)/uci{,_config}.h $(1)/usr/include
+ $(INSTALL_DIR) $(1)/usr/lib
+ $(CP) $(PKG_BUILD_DIR)/libuci.so* $(1)/usr/lib
+ $(CP) $(PKG_BUILD_DIR)/libuci.a $(1)/usr/lib
endef
$(eval $(call BuildPackage,uci))
$(eval $(call BuildPackage,libuci))
-$(eval $(call BuildPackage,uci-sh))
+$(eval $(call BuildPackage,libuci-lua))
+$(eval $(call BuildPackage,ucitrigger))