-CXXFLAGS+=-g3 -Wall -W -pedantic -DLINUX -I../include -I../projects/stargazer -I../stglibs/conffiles.lib -I.
-LIBS=-lpthread
-PROG=tests
+INCS = -I . \
+       -I ../include \
+       -I ../stglibs/common.lib/include \
+       -I ../stglibs/conffiles.lib/include \
+       -I ../stglibs/logger.lib/include \
+       -I ../stglibs/scriptexecuter.lib/include \
+       -I ../stglibs/crypto.lib/include \
+       -I ../projects/stargazer
+DEFS = -DLINUX \
+       -DUSE_ABSTRACT_SETTINGS
+CFLAGS += -g3 -Wall -W -Wextra $(INCS) $(DEFS)
+CXXFLAGS = $(CFLAGS)
+LIBS = -lpthread
+PROG = tests
 
-SOURCES=main.cpp \
-       test_raw_ip.cpp \
-       test_admin_conf.cpp \
-       test_tariff.cpp \
-       test_conffiles.cpp \
-       ../projects/stargazer/tariff.cpp \
-       ../stglibs/conffiles.lib/conffiles.cpp
+SOURCES = main.cpp \
+         test_raw_ip.cpp \
+         test_admin_conf.cpp \
+         test_tariff.cpp \
+         test_conffiles.cpp \
+         test_fee_charge_rules.cpp \
+         test_reconnect_on_tariff_change.cpp \
+         test_crypto.cpp \
+         test_bfstream.cpp \
+         ../projects/stargazer/tariff_impl.cpp \
+         ../projects/stargazer/user_impl.cpp \
+         ../projects/stargazer/user_property.cpp \
+         ../stglibs/conffiles.lib/conffiles.cpp \
+         ../stglibs/common.lib/common.cpp \
+         ../stglibs/logger.lib/logger.cpp \
+         ../stglibs/scriptexecuter.lib/scriptexecuter.cpp \
+         ../stglibs/crypto.lib/bfstream.cpp \
+         ../stglibs/crypto.lib/blowfish.c
 
-all: $(PROG) 
+.PHONY: all clean
 
-$(PROG): $(subst .cpp,.o,$(SOURCES))
+all: $(PROG)
+
+$(PROG): $(addsuffix .o,$(basename $(SOURCES)))
        $(CXX) $(LDFLAGS) $^ $(LIBS) -o $@
 
 clean:
-       rm -f *.o *.d
+       rm -f $(addsuffix .o,$(basename $(SOURCES))) $(addsuffix .d,$(SOURCES)) $(PROG)
 
 ifneq ($(MAKECMDGOALS),distclean)
 ifneq ($(MAKECMDGOALS),clean)
--include $(subst .cpp,.d,$(SOURCES))
+-include $(addsuffix .d,$(SOURCES))
 endif
 endif
 
-%.d: %.cpp
-       @$(CC) -MM $(CXXFLAGS) $< > $@.$$$$; \
+%.cpp.d: %.cpp
+       @$(CXX) -MM $(CXXFLAGS) $< > $@.$$$$; \
+       sed 's,\($*\).o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
+       rm -f $@.$$$$
+
+%.c.d: %.c
+       @$(CC) -MM $(CFLAGS) $< > $@.$$$$; \
        sed 's,\($*\).o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
        rm -f $@.$$$$