Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
make distcheck is now successful
[simgrid.git] / src / gras / Makefile.am
index 27ed9ed..a7a6c58 100644 (file)
@@ -1,20 +1,45 @@
 SUBDIRS=. Tests
-DISTCLEANFILES=Makefile.in
+MAINTAINERCLEANFILES=Makefile.in
 INCLUDES= -I$(top_srcdir)/src/include \
-          @CFLAGS_XML@ @CFLAGS_SimGrid@
-EXTRA_DIST=                 \
-       gras_private.h      \
-       Core/dict_private.h 
-#      DataDesc/parse.yy.l      
+          @CFLAGS_SimGrid@
+EXTRA_DIST= ./gras_private.h    \
+       Core/dict_private.h \
+       Transport/transport_interface.h \
+       Virtu/virtu_interface.h \
+       Virtu/virtu_rl.h \
+       Virtu/virtu_sg.h \
+       DataDesc/ddt_parse.yy.l DataDesc/ddt_parse.yy.c
 
+VERSION_INFO= -release 20040722 -version-info 0:0:0
+# from `info libtool "Updating version info"` 
+# and  `info libtool "Release numbers"` 
+#
+# A) For stable library (interface wise), you should use --version-info:
+#
+# - Begin with C:R:A = 0:0:0 (ie here, VERSION_INFO= -version-info 0:0:0)
+# - Do not update it before public release (keep numbers small)
+#
+# ----------------------------------------------------------------------+
+# +   Interface     |  code of existing  | Interface | New version info |
+# | removal/change? | interface changed? | addition? |                  |
+# +-----------------+--------------------+-----------+------------------+
+# |      yes        |   must be yes ;)   |           |  C++ : 0   : 0   |
+# |      no         |        yes         |    yes    |  C   : R++ : A++ |
+# |      no         |        yes         |    no     |  C   : R++ : A   |
+# |      no         |        no          |    yes    |  C   : R   : A++ |
+# |      no         |        no          |    no     |  C   : R   : A   |
+# +-----------------+--------------------+-----------+------------------+
+#
+# B) For rapidely changing library, you should go for the -release flag
+#
+#  It modifies the library name, and you thus cannot say that a library
+#   using this trick is ready for a "stable" release (say, in Debian).
 
-lib_LIBRARIES= libgrasrl.a libgrassg.a
-
-#                     Core/dict_multi.c
-#  Common/gras.c      Common/gras_datadesc.c        Common/gras_msg.c            
-#   Messaging/messaging.c                       
-#   Messaging/datadesc_simple.c                 
-#   Transport/transport_sg.c 
+if HAVE_SG
+ lib_LTLIBRARIES= libgrasrl.la libgrassg.la
+else
+ lib_LTLIBRARIES= libgrasrl.la
+endif
 
 COMMON_S=\
   \
@@ -26,39 +51,33 @@ COMMON_S=\
   \
   Core/config.c                               \
   \
-  Transport/transport.c    Transport/transport_private.h      \
-  Transport/transport_plugin_file.c            \
-  Transport/transport_plugin_tcp.c            \
-  Transport/transport_plugin_sg.c             \
+  Transport/transport.c          Transport/transport_private.h  \
   \
-  DataDesc/ddt_create.c          DataDesc/ddt_declare.c \
-  DataDesc/ddt_remote.c          DataDesc/ddt_use.c     \
-  DataDesc/cbps.c                DataDesc/datadesc.c    \
-  DataDesc/datadesc_interface.h  DataDesc/datadesc_private.h
-
-#  DataDesc/datadesc.c                               \
-#  DataDesc/tools.c                                  \
-#  DataDesc/categories.h                             \
-#  DataDesc/connection.h                             \
-#  DataDesc/sequence.h                               \
-#  DataDesc/net_driver.c      DataDesc/net_driver.h        \
-#  DataDesc/net_driver_fd.c   DataDesc/net_interface_fd.h  \
-#  DataDesc/type_driver_rl.c  DataDesc/type_interface_rl.h \
-#  DataDesc/type_driver.c     DataDesc/type_driver.h       \
-#  DataDesc/message.c         DataDesc/message.h           \
-#  DataDesc/type.c            DataDesc/type.h              \
-#  DataDesc/parse.c           DataDesc/parse.yy.h             DataDesc/parse.yy.c \
-#  DataDesc/vars.c
+  DataDesc/ddt_create.c          \
+  DataDesc/ddt_convert.c         DataDesc/ddt_exchange.c     \
+  DataDesc/cbps.c                DataDesc/datadesc.c         \
+  DataDesc/datadesc_interface.h  DataDesc/datadesc_private.h \
+  DataDesc/ddt_parse.c  DataDesc/ddt_parse.yy.c DataDesc/ddt_parse.yy.h \
+  \
+  Msg/msg.c   Msg/msg_interface.h   Msg/msg_private.h \
+  \
+  Virtu/process.c
 
-DataDesc/parse.yy.c: DataDesc/parse.yy.l
-       flex -o$@ -Pgras_ddt_ $^
+# DataDesc/ddt_declare.c 
 
-libgrasrl_a_SOURCES= $(COMMON_S) \
-  Transport/rl_transport.c       \
-  Virtu/rl_process.c       Virtu/rl_time.c     Virtu/rl_conditional.c
+DataDesc/ddt_parse.yy.c: DataDesc/ddt_parse.yy.l
+       @LEX@ -o$@ -Pgras_ddt_parse_ $^
 
-libgrassg_a_SOURCES= $(COMMON_S) \
-  Transport/sg_transport.c       \
-  Virtu/sg_process.c       Virtu/sg_time.c     Virtu/sg_conditional.c
+libgrasrl_la_SOURCES= $(COMMON_S) \
+  Transport/rl_transport.c  Transport/transport_plugin_tcp.c  Transport/transport_plugin_file.c      \
+  \
+  Virtu/rl_process.c        Virtu/rl_time.c                   Virtu/rl_conditional.c
+libgrasrl_la_LDFLAGS = $(VERSION_INFO)
 
-# RL/gras_rl.c RL/gras_rl.h FIXME
+if HAVE_SG
+  libgrassg_la_SOURCES= $(COMMON_S) \
+    Transport/sg_transport.c  Transport/transport_plugin_sg.c             \
+    \
+    Virtu/sg_process.c        Virtu/sg_time.c                   Virtu/sg_conditional.c
+  libgrassg_la_LDFLAGS = $(VERSION_INFO)
+endif