[llvm-commits] [llvm] r42090 - in /llvm/trunk: Makefile.config.in bindings/ bindings/ocaml/ bindings/ocaml/Makefile.ocaml test/Makefile

Gordon Henriksen gordonhenriksen at mac.com
Tue Sep 18 05:29:26 PDT 2007


On Sep 18, 2007, at 08:26, Gordon Henriksen wrote:

> Author: gordon
> Date: Tue Sep 18 07:26:17 2007
> New Revision: 42090
>
> URL: http://llvm.org/viewvc/llvm-project?rev=42090&view=rev
> Log: (empty)

Oops, forgot to safe my commit message file. I intended to write:

Adding ocaml to build infrastructure.

   - configure tries to find ocamlc and ocamlopt.
   - Makefile rules for ocaml libs. I put them in a separate file,  
though.
   - Tests using ocaml.exp are ignored if ocamlc was not found.
   - Tests may reference %ocamlc, which expands to something like
       ocamlc -cc g++ -I llvm/Release/lib/ocaml
   - Ocaml libs install direct into ocaml's stdlib, found using  
ocamlc -where,
     ignoring --prefix. This perhaps should be configurable, but that  
requires
     bigger configure cojones than mine.

> Added:
>     llvm/trunk/bindings/
>     llvm/trunk/bindings/ocaml/
>     llvm/trunk/bindings/ocaml/Makefile.ocaml
> Modified:
>     llvm/trunk/Makefile.config.in
>     llvm/trunk/test/Makefile
>
> Modified: llvm/trunk/Makefile.config.in
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/ 
> Makefile.config.in?rev=42090&r1=42089&r2=42090&view=diff
>
> ====================================================================== 
> ========
> --- llvm/trunk/Makefile.config.in (original)
> +++ llvm/trunk/Makefile.config.in Tue Sep 18 07:26:17 2007
> @@ -156,6 +156,8 @@
>  ETAGSFLAGS := @ETAGSFLAGS@
>  GROFF      := @GROFF@
>  GZIP       := @GZIP@
> +OCAMLC     := @OCAMLC@
> +OCAMLOPT   := @OCAMLOPT@
>  POD2HTML   := @POD2HTML@
>  POD2MAN    := @POD2MAN@
>  RUNTEST    := @RUNTEST@
>
> Added: llvm/trunk/bindings/ocaml/Makefile.ocaml
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/bindings/ocaml/ 
> Makefile.ocaml?rev=42090&view=auto
>
> ====================================================================== 
> ========
> --- llvm/trunk/bindings/ocaml/Makefile.ocaml (added)
> +++ llvm/trunk/bindings/ocaml/Makefile.ocaml Tue Sep 18 07:26:17 2007
> @@ -0,0 +1,265 @@
> +##===- tools/ml/Makefile -----------------------------------*-  
> Makefile -*-===##
> +#
> +#                     The LLVM Compiler Infrastructure
> +#
> +# This file was developed by Gordon Henriksen and is distributed  
> under the
> +# University of Illinois Open Source License. See LICENSE.TXT for  
> details.
> +#
> +##===---------------------------------------------------------------- 
> ------===##
> +#
> +# An ocaml library is a unique project type in the context of  
> LLVM, so rules are
> +# here rather than in Makefile.rules.
> +#
> +##===---------------------------------------------------------------- 
> ------===##
> +
> +include $(LEVEL)/Makefile.config
> +
> +# Find the ocaml stdlib root. /usr/local/lib/ocaml is the default  
> when built
> +# from source; distros use something like /usr/lib/ocaml/3.10.0.
> +ifndef OCAML_LIBDIR
> +OCAML_LIBDIR := $(shell $(OCAMLC) -where)
> +endif
> +
> +# CFLAGS needs to be set before Makefile.rules is included. Yes,  
> ocaml puts its
> +# includes under its libdir.
> +CFLAGS += -I$(OCAML_LIBDIR)
> +
> +include $(LEVEL)/Makefile.common
> +
> +# Intentionally ignore PROJ_prefix here. We want the ocaml stdlib.  
> However, the
> +# user can override this with OCAML_LIBDIR.
> +PROJ_libocamldir := $(DESTDIR)$(OCAML_LIBDIR)
> +OcamlDir := $(LibDir)/ocaml
> +
> +# Info from llvm-config and similar
> +ifdef UsedComponents
> +UsedLibs = $(shell $(LLVM_CONFIG) --libs $(UsedComponents))
> +UsedLibNames = $(shell $(LLVM_CONFIG) --libnames $(UsedComponents))
> +endif
> +
> +# Tools
> +OCAMLCFLAGS += -I $(OcamlDir)
> +OCAMLAFLAGS += $(patsubst %,-cclib %, \
> +                 $(filter-out -L$(LibDir),$(shell $(LLVM_CONFIG) -- 
> ldflags)) \
> +				 $(UsedLibs) -l$(LIBRARYNAME))
> +
> +Compile.CMI  := $(strip $(OCAMLC) -c $(OCAMLCFLAGS) -o)
> +Compile.CMO  := $(strip $(OCAMLC) -c $(OCAMLCFLAGS) -o)
> +Archive.CMA  := $(strip $(OCAMLC) -a -custom $(OCAMLAFLAGS) -o)
> +
> +Compile.CMX  := $(strip $(OCAMLOPT) -c $(OCAMLCFLAGS) -o)
> +Archive.CMXA := $(strip $(OCAMLOPT) -a $(OCAMLAFLAGS) -o)
> +
> +# Source files
> +OcamlSources := $(sort $(wildcard $(PROJ_SRC_DIR)/*.ml))
> +OcamlHeaders := $(OcamlSources:.ml=.mli)
> +
> +# Output and intermediate files
> +#   The .cmo files are the only intermediates; all others get  
> installed.
> +BareLibraryA := lib$(LIBRARYNAME).a
> +LibraryA     := $(OcamlDir)/$(BareLibraryA)
> +LibraryCMA   := $(OcamlDir)/$(LIBRARYNAME).cma
> +LibraryCMXA  := $(OcamlDir)/$(LIBRARYNAME).cmxa
> +ObjectsCMI   := $(OcamlSources:$(PROJ_SRC_DIR)/%.ml=$(OcamlDir)/ 
> %.cmi)
> +ObjectsCMO   := $(OcamlSources:$(PROJ_SRC_DIR)/%.ml=$(ObjDir)/%.cmo)
> +ObjectsCMX   := $(OcamlSources:$(PROJ_SRC_DIR)/%.ml=$(OcamlDir)/ 
> %.cmx)
> +
> +# Dependencies
> +#   Punting on ocamldep, since its output is only suitable for  
> builds where
> +#   objects are placed directly adjacent to sources, which is not us.
> +#   Unfortunately, this is subtly incorrect and leads to  
> occasional problems.
> +#   ocamlc/ocamlopt really need an option akin to gcc -M or gcc -MD.
> +$(ObjectsCMO): $(ObjectsCMI) $(UsedOcamLibs:%=$(OcamlDir)/%.cmi)
> +$(ObjectsCMX): $(ObjectsCMI) $(UsedOcamLibs:%=$(OcamlDir)/%.cmi)
> +
> +# Installation targets
> +DestA    := $(PROJ_libocamldir)/lib$(LIBRARYNAME).a
> +DestCMA  := $(PROJ_libocamldir)/$(LIBRARYNAME).cma
> +DestCMXA := $(PROJ_libocamldir)/$(LIBRARYNAME).cmxa
> +
> +
> +##===- Build static library from C sources  
> --------------------------------===##
> +
> +all-local:: $(LibraryA)
> +clean-local:: clean-a
> +install-local:: install-a
> +uninstall-local:: uninstall-a
> +
> +$(LibraryA): $(ObjectsO) $(OcamlDir)/.dir
> +	$(Echo) "Building $(BuildMode) $(notdir $@)"
> +	-$(Verb) $(RM) -f $@
> +	$(Verb) $(Archive) $@ $(ObjectsO)
> +	$(Verb) $(Ranlib) $@
> +
> +clean-a::
> +	-$(Verb) $(RM) -f $(LibraryA)
> +
> +install-a:: $(LibraryA)
> +	$(Echo) "Installing $(BuildMode) $(DestA)"
> +	$(Verb) $(MKDIR) $(PROJ_libocamldir)
> +	$(Verb) $(LTInstall) $(LibraryA) $(DestA)
> +	$(Verb)
> +
> +uninstall-a::
> +	$(Echo) "Uninstalling $(DestA)"
> +	-$(Verb) $(RM) -f $(DestA)
> +
> +
> +##===- Build ocaml interfaces (.mli's -> .cmi's)  
> --------------------------===##
> +
> +all-local:: build-cmis
> +clean-local:: clean-cmis
> +install-local:: install-cmis
> +uninstall-local:: uninstall-cmis
> +
> +build-cmis: $(ObjectsCMI)
> +
> +$(OcamlDir)/%.cmi: $(PROJ_SRC_DIR)/%.mli $(OcamlDir)/.dir
> +	$(Echo) "Compiling $(notdir $<) for $(BuildMode) build"
> +	$(Verb) $(Compile.CMI) $@ $<
> +
> +clean-cmis::
> +	-$(Verb) $(RM) -f $(ObjectsCMI)
> +
> +# Also install the .mli's (headers) as documentation.
> +install-cmis: $(ObjectsCMI)
> +	$(Verb) $(MKDIR) $(PROJ_libocamldir)
> +	$(Verb) for i in $(patsubst $(OcamlDir)/%,%,$(ObjectsCMI)); do \
> +	  $(EchoCmd) "Installing $(BuildMode) $(PROJ_libocamldir)/$$i"; \
> +	  $(DataInstall) $(OcamlDir)/$$i "$(PROJ_libocamldir)/$$i"; \
> +	done
> +	$(Verb) for i in $(patsubst $(PROJ_SRC_DIR)/%,%,$(OcamlHeaders));  
> do \
> +	  $(EchoCmd) "Installing $(BuildMode) $(PROJ_libocamldir)/$$i"; \
> +	  $(DataInstall) $(PROJ_SRC_DIR)/$$i "$(PROJ_libocamldir)/$$i"; \
> +	done
> +
> +uninstall-cmis::
> +	$(Verb) for i in $(patsubst $(OcamlDir)/%,%,$(ObjectsCMI)); do \
> +	  $(EchoCmd) "Uninstalling $(PROJ_libocamldir)/$$i"; \
> +	  $(RM) -f "$(PROJ_libocamldir)/$$i"; \
> +	done
> +	$(Verb) for i in $(patsubst $(PROJ_SRC_DIR)/%,%,$(OcamlHeaders));  
> do \
> +	  $(EchoCmd) "Uninstalling $(PROJ_libocamldir)/$$i"; \
> +	  $(RM) -f "$(PROJ_libocamldir)/$$i"; \
> +	done
> +
> +
> +##===- Build ocaml bytecode archive (.ml's -> .cmo's -> .cma)  
> -------------===##
> +
> +all-local:: $(LibraryCMA)
> +clean-local:: clean-cma
> +install-local:: install-cma
> +uninstall-local:: uninstall-cma
> +
> +$(LibraryCMA): $(ObjectsCMO) $(OcamlDir)/.dir
> +	$(Echo) "Archiving $(notdir $@) for $(BuildMode) build"
> +	$(Verb) $(Archive.CMA) $@ $(ObjectsCMO)
> +	$(Verb) for i in $(UsedLibNames); do \
> +	  ln -sf "$(LibDir)/$$i" "$(OcamlDir)/$$i"; \
> +	done
> +
> +$(ObjDir)/%.cmo: $(PROJ_SRC_DIR)/%.ml $(OcamlDir)/.dir
> +	$(Echo) "Compiling $(notdir $<) for $(BuildMode) build"
> +	$(Verb) $(Compile.CMO) $@ $<
> +
> +clean-cma::
> +	$(Verb) $(RM) -f $(LibraryCMA)
> +
> +install-cma:: $(LibraryCMA)
> +	$(Echo) "Installing $(BuildMode) $(DestCMA)"
> +	$(Verb) $(MKDIR) $(PROJ_libocamldir)
> +	$(Verb) $(DataInstall) $(LibraryCMA) "$(DestCMA)"
> +	$(Verb) for i in $(UsedLibNames); do \
> +	  $(EchoCmd) "Installing $(BuildMode) $(PROJ_libocamldir)/$$i"; \
> +	  ln -sf "$(PROJ_libdir)/$$i" "$(PROJ_libocamldir)/$$i"; \
> +	done
> +
> +uninstall-cma::
> +	$(Echo) "Uninstalling $(DestCMA)"
> +	-$(Verb) $(RM) -f $(DestCMA)
> +	$(Verb) for i in $(UsedLibNames); do \
> +	  $(EchoCmd) "Uninstalling $(PROJ_libocamldir)/$$i"; \
> +	  $(RM) -f "$(PROJ_libocamldir)/$$i"; \
> +	done
> +
> +
> +##===- Build optimized ocaml archive (.ml's -> .cmx's - 
> > .cmxa, .a) -------===##
> +
> +# The ocamlopt compiler is supported on a set of targets disjoint  
> from LLVM's.
> +# If unavailable, 'configure' will not define OCAMLOPT in  
> Makefile.config.
> +ifdef OCAMLOPT
> +
> +all-local:: $(LibraryCMXA)
> +clean-local:: clean-cmxa
> +install-local:: install-cmxa
> +uninstall-local:: uninstall-cmxa
> +
> +$(LibraryCMXA): $(ObjectsCMX)
> +	$(Echo) "Archiving $(notdir $@) for $(BuildMode) build"
> +	$(Verb) $(Archive.CMXA) $@ $(ObjectsCMX)
> +	$(Verb) $(RM) -f $(@:.cmxa=.o)
> +
> +$(OcamlDir)/%.cmx: $(PROJ_SRC_DIR)/%.ml
> +	$(Echo) "Compiling optimized $(notdir $<) for $(BuildMode) build"
> +	$(Verb) $(Compile.CMX) $@ $<
> +
> +clean-cmxa::
> +	$(Verb) $(RM) -f $(LibraryCMXA) $(LibraryCMXA:.cmxa=.o) \
> +	  $(LibraryCMXA:.cmxa=.a) $(ObjectsCMX)
> +
> +install-cmxa:: $(LibraryCMXA)
> +	$(Verb) $(MKDIR) $(PROJ_libocamldir)
> +	$(Echo) "Installing $(BuildMode) $(DestCMXA)"
> +	$(Verb) $(DataInstall) $(LibraryCMXA) $(DestCMXA)
> +	$(Echo) "Installing $(BuildMode) $(DestCMXA:.cmxa=.a)"
> +	$(Verb) $(DataInstall) $(LibraryCMXA:.cmxa=.a) $(DestCMXA:.cmxa=.a)
> +	$(Verb) for i in $(ObjectsCMX:$(OcamlDir)/%=%); do \
> +	  $(EchoCmd) "Installing $(BuildMode) $(PROJ_libocamldir)/$$i"; \
> +	  $(DataInstall) $(OcamlDir)/$$i "$(PROJ_libocamldir)/$$i"; \
> +	done
> +
> +uninstall-cmxa:: $(LibraryCMXA)
> +	$(Echo) "Uninstalling $(DestCMXA)"
> +	$(Verb) $(RM) -f $(DestCMXA)
> +	$(Echo) "Uninstalling $(DestCMXA:.cmxa=.a)"
> +	$(Verb) $(RM) -f $(DestCMXA:.cmxa=.a)
> +	$(Verb) for i in $(ObjectsCMX:$(OcamlDir)/%=%); do \
> +	  $(EchoCmd) "Uninstalling $(PROJ_libocamldir)/$$i"; \
> +	  $(RM) -f $(PROJ_libocamldir)/$$i; \
> +	done
> +
> +endif
> +
> +
> +##===- Debugging gunk  
> -----------------------------------------------------===##
> +printvars:: printcamlvars
> +
> +printcamlvars::
> +	$(Echo) "LLVM_CONFIG  : " '$(LLVM_CONFIG)'
> +	$(Echo) "OCAMLCFLAGS  : " '$(OCAMLCFLAGS)'
> +	$(Echo) "OCAMLAFLAGS  : " '$(OCAMLAFLAGS)'
> +	$(Echo) "OCAMLC       : " '$(OCAMLC)'
> +	$(Echo) "OCAMLOPT     : " '$(OCAMLOPT)'
> +	$(Echo) "Compile.CMI  : " '$(Compile.CMI)'
> +	$(Echo) "Compile.CMO  : " '$(Compile.CMO)'
> +	$(Echo) "Archive.CMA  : " '$(Archive.CMA)'
> +	$(Echo) "Compile.CMX  : " '$(Compile.CMX)'
> +	$(Echo) "Archive.CMXA : " '$(Archive.CMXA)'
> +	$(Echo) "CAML_LIBDIR  : " '$(CAML_LIBDIR)'
> +	$(Echo) "LibraryCMA   : " '$(LibraryCMA)'
> +	$(Echo) "LibraryCMXA  : " '$(LibraryCMXA)'
> +	$(Echo) "OcamlSources : " '$(OcamlSources)'
> +	$(Echo) "ObjectsCMI   : " '$(ObjectsCMI)'
> +	$(Echo) "ObjectsCMO   : " '$(ObjectsCMO)'
> +	$(Echo) "ObjectsCMX   : " '$(ObjectsCMX)'
> +	$(Echo) "OCAML_LIBDIR : " '$(OCAML_LIBDIR)'
> +	$(Echo) "DestA        : " '$(DestA)'
> +	$(Echo) "DestCMA      : " '$(DestCMA)'
> +	$(Echo) "DestCMXA     : " '$(DestCMXA)'
> +	$(Echo) "UsedLibs     : " '$(UsedLibs)'
> +	$(Echo) "UsedLibNames : " '$(UsedLibNames)'
> +
> +.PHONY: printcamlvars   build-cmis \
> +            clean-a     clean-cmis     clean-cma     clean-cmxa \
> +          install-a   install-cmis   install-cma   install-cmxa \
> +		uninstall-a uninstall-cmis uninstall-cma uninstall-cmxa
>
> Modified: llvm/trunk/test/Makefile
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Makefile? 
> rev=42090&r1=42089&r2=42090&view=diff
>
> ====================================================================== 
> ========
> --- llvm/trunk/test/Makefile (original)
> +++ llvm/trunk/test/Makefile Tue Sep 18 07:26:17 2007
> @@ -28,8 +28,18 @@
>  RUNTESTFLAGS := --tool $(CLEANED_TESTSUITE)
>  endif
>
> +IGNORE_TESTS :=
> +
>  ifndef RUNLLVM2CPP
> -RUNTESTFLAGS += --ignore llvm2cpp.exp
> +IGNORE_TESTS += llvm2cpp.exp
> +endif
> +
> +ifndef OCAMLC
> +IGNORE_TESTS += ocaml.exp
> +endif
> +
> +ifdef IGNORE_TESTS
> +RUNTESTFLAGS += --ignore "$(strip $(IGNORE_TESTS))"
>  endif
>
>  ifneq ($(RUNTEST),)
> @@ -89,6 +99,7 @@
>  	@echo 'set llvmgxx "$(LLVMGCC)"' >> site.tmp
>  	@echo 'set llvmgccmajvers "$(LLVMGCC_MAJVERS)"' >> site.tmp
>  	@echo 'set shlibext "$(SHLIBEXT)"' >> site.tmp
> +	@echo 'set ocamlc "$(OCAMLC) -cc $(CXX) -I $(LibDir)/ocaml"' >>  
> site.tmp
>  	@echo '## All variables above are generated by configure. Do Not  
> Edit ## ' >>site.tmp
>  	@test ! -f site.exp || \
>  	sed '1,/^## All variables above are.*##/ d' site.exp >> site.tmp
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits



— Gordon

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20070918/f1e07315/attachment.html>


More information about the llvm-commits mailing list