496 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			HTML
		
	
	
	
			
		
		
	
	
			496 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			HTML
		
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="en">
 | |
|  <head>
 | |
|   <meta charset="utf-8"/>
 | |
|   <title>
 | |
|    Compilation
 | |
|   </title>
 | |
|   <style>
 | |
|    /* Page tweaks */
 | |
|     .preview-page {
 | |
|       margin-top: 64px;
 | |
|       margin-bottom: 21px;
 | |
|     }
 | |
|     /* User-content tweaks */
 | |
|     .timeline-comment-wrapper > .timeline-comment:after,
 | |
|     .timeline-comment-wrapper > .timeline-comment:before {
 | |
|       content: none;
 | |
|     }
 | |
|     /* User-content overrides */
 | |
|     .discussion-timeline.wide {
 | |
|       width: 920px;
 | |
|     }
 | |
|   </style>
 | |
|   <link href="style.css" rel="stylesheet"/>
 | |
|  </head>
 | |
|  <body>
 | |
|   <div class="page">
 | |
|    <div class="preview-page" data-autorefresh-url="" id="preview-page">
 | |
|     <main id="js-repo-pjax-container">
 | |
|      <div class="clearfix new-discussion-timeline container-xl px-3 px-md-4 px-lg-5">
 | |
|       <div class="repository-content">
 | |
|        <div class="clearfix">
 | |
|         <div class="Layout Layout--flowRow-until-md Layout--sidebarPosition-end Layout--sidebarPosition-flowRow-end">
 | |
|          <div class="Layout-main">
 | |
|           <div class="Box md Box--responsive" id="readme">
 | |
|            <div class="Box-header d-flex border-bottom-0 flex-items-center flex-justify-between color-bg-default rounded-top-2">
 | |
|             <div class="d-flex flex-items-center">
 | |
|              <h2 class="Box-title">
 | |
|               Compilation
 | |
|              </h2>
 | |
|             </div>
 | |
|            </div>
 | |
|            <div class="Box-body px-5 pb-5">
 | |
|             <article class="markdown-body entry-content container-lg" id="grip-content">
 | |
|              <p>
 | |
|               Compilation should be working on Linux, Windows with MinGW and Mac OS X. You will need header files of Puredata, as well as
 | |
|               <a href="http://curl.haxx.se/" rel="nofollow">
 | |
|                libcurl
 | |
|               </a>
 | |
|               ,
 | |
|               <a href="https://github.com/json-c/json-c">
 | |
|                json-c
 | |
|               </a>
 | |
|               , and
 | |
|               <a href="http://liboauth.sourceforge.net/" rel="nofollow">
 | |
|                liboauth
 | |
|               </a>
 | |
|               .
 | |
|              </p>
 | |
|              <p>
 | |
|               The package build script uses the Makefile template from
 | |
|               <a href="https://github.com/pure-data/pd-lib-builder">
 | |
|                pd-lib-builder
 | |
|               </a>
 | |
|               .
 | |
|              </p>
 | |
|              <p>
 | |
|               To enable multi-instance support, add
 | |
|               <code>
 | |
|                multi=true
 | |
|               </code>
 | |
|               to the make command.
 | |
|              </p>
 | |
|              <p>
 | |
|               If you have gotten the source code from git, you will first have to init the
 | |
|               <a href="http://troydhanson.github.io/uthash/" rel="nofollow">
 | |
|                uthash
 | |
|               </a>
 | |
|               and pd-lib-builder submodule by running
 | |
|               <code>
 | |
|                git submodule update --init
 | |
|               </code>
 | |
|               .
 | |
|              </p>
 | |
|              <p>
 | |
|               OS X and Linux build scripts do not include dependencies in the resulting pd_linux or pd_darwin files. For making a distributable version of the library, there is a collection of bash scripts for the different platforms.
 | |
|              </p>
 | |
|              <p>
 | |
|               The manual is generated from the
 | |
|               <a href="https://github.com/residuum/PuRestJson/wiki">
 | |
|                Github wiki
 | |
|               </a>
 | |
|               . To generate it as well, a copy of the wiki is necessary (get it via
 | |
|               <code>
 | |
|                git clone https://github.com/residuum/PuRestJson.wiki.git
 | |
|               </code>
 | |
|               ). The python script is called
 | |
|               <code>
 | |
|                create_manual.py
 | |
|               </code>
 | |
|               and needs
 | |
|               <a href="https://github.com/joeyespo/grip">
 | |
|                grip
 | |
|               </a>
 | |
|               and
 | |
|               <a href="https://pypi.python.org/pypi/BeautifulSoup" rel="nofollow">
 | |
|                BeautifulSoup
 | |
|               </a>
 | |
|               . Install those via
 | |
|               <code>
 | |
|                pip install grip beautifulsoup lxml
 | |
|               </code>
 | |
|               .
 | |
|              </p>
 | |
|              <h2>
 | |
|               <a aria-hidden="true" class="anchor" href="#circle-ci-builds---general-information" id="user-content-circle-ci-builds---general-information">
 | |
|                <span aria-hidden="true" class="octicon octicon-link">
 | |
|                </span>
 | |
|               </a>
 | |
|               Circle CI Builds - General Information
 | |
|              </h2>
 | |
|              <p>
 | |
|               PuREST JSON is configured to build on
 | |
|               <a href="https://app.circleci.com/pipelines/github/residuum/PuRestJson" rel="nofollow">
 | |
|                Circle CI
 | |
|               </a>
 | |
|               . The bash scripts in the folder
 | |
|               <code>
 | |
|                circleci-scripts
 | |
|               </code>
 | |
|               may serve as secondary documentation for building:
 | |
|              </p>
 | |
|              <ul>
 | |
|               <li>
 | |
|                <code>
 | |
|                 */before_install.sh
 | |
|                </code>
 | |
|                sets up the build environment
 | |
|               </li>
 | |
|               <li>
 | |
|                <code>
 | |
|                 */script.sh
 | |
|                </code>
 | |
|                is the command to build the binaries
 | |
|               </li>
 | |
|               <li>
 | |
|                <code>
 | |
|                 */pack.sh
 | |
|                </code>
 | |
|                generates the manual and creates deken packages
 | |
|               </li>
 | |
|               <li>
 | |
|                <code>
 | |
|                 upload.sh
 | |
|                </code>
 | |
|                uploads the resulting package to my personal ownCloud instance
 | |
|               </li>
 | |
|              </ul>
 | |
|              <h2>
 | |
|               <a aria-hidden="true" class="anchor" href="#linux" id="user-content-linux">
 | |
|                <span aria-hidden="true" class="octicon octicon-link">
 | |
|                </span>
 | |
|               </a>
 | |
|               Linux
 | |
|              </h2>
 | |
|              <p>
 | |
|               As a guideline, look at the scripts in the
 | |
|               <code>
 | |
|                circleci-scripts/linux-amd64
 | |
|               </code>
 | |
|               folder, as the scripts in forder
 | |
|               <code>
 | |
|                linux-i386
 | |
|               </code>
 | |
|               are used to build 32 bit i386 packages on a 64 bit amd64 system.
 | |
|              </p>
 | |
|              <ol>
 | |
|               <li>
 | |
|                You need build-essentials, header files for puredata, libjson-c, libcurl4, liboauth. If you have Debian or a derivative (e.g. Ubuntu, Linux Mint), you can install the build utils and needed headers with
 | |
|                <code>
 | |
|                 apt-get install build-essential puredata-dev libjson-c-dev libcurl4-openssl-dev liboauth-dev
 | |
|                </code>
 | |
|                . If you are not root, prefix the command with
 | |
|                <code>
 | |
|                 sudo
 | |
|                </code>
 | |
|                .
 | |
|               </li>
 | |
|               <li>
 | |
|                Drop the sources in a directory and run
 | |
|                <code>
 | |
|                 make
 | |
|                </code>
 | |
|                . You will get files with a suffix of pd_linux for each object (json-decode.pd_linux, json-encode.pd_linux, rest.pd_linux, oauth.pd_linux). These are needed to use the library.
 | |
|               </li>
 | |
|               <li>
 | |
|                (optional) To create a distributable version, you have to install patchelf, e.g.
 | |
|                <code>
 | |
|                 apt-get install patchelf
 | |
|                </code>
 | |
|                . Run
 | |
|                <code>
 | |
|                 bash dependencies/linux.sh *.pdlinux
 | |
|                </code>
 | |
|                . This will copy dependencies to the current folder and rewrite linking information in the files to point to these dependencies.
 | |
|               </li>
 | |
|              </ol>
 | |
|              <h3>
 | |
|               <a aria-hidden="true" class="anchor" href="#building-for-different-architectures" id="user-content-building-for-different-architectures">
 | |
|                <span aria-hidden="true" class="octicon octicon-link">
 | |
|                </span>
 | |
|               </a>
 | |
|               Building for Different Architectures
 | |
|              </h3>
 | |
|              <p>
 | |
|               Building for different architectures is possible. I will outline a way to do it on Debian based systems, e.g. Ubuntu.
 | |
|              </p>
 | |
|              <ol>
 | |
|               <li>
 | |
|                Install debootstrap, e.g. via
 | |
|                <code>
 | |
|                 apt-get install debootstrap
 | |
|                </code>
 | |
|                .
 | |
|               </li>
 | |
|               <li>
 | |
|                Set up a directory as the root for your new chroot, e.g. for
 | |
|                <code>
 | |
|                 /tmp/buildroot
 | |
|                </code>
 | |
|                on Ubuntu Trusty for i386 with
 | |
|               </li>
 | |
|              </ol>
 | |
|              <pre><code>   sudo debootstrap \
 | |
|        --variant=buildd \
 | |
|       	--include=build-essential \
 | |
|        --arch=i386 \
 | |
|        trusty /tmp/buildroot http://archive.ubuntu.com/ubuntu/
 | |
| </code></pre>
 | |
|              <ol start="3">
 | |
|               <li>
 | |
|                Install the basic build system in that directory, and install the necessary dependencies for that architecture e.g. with
 | |
|               </li>
 | |
|              </ol>
 | |
|              <pre><code>   echo deb http://archive.ubuntu.com/ubuntu/ \
 | |
|        $DIST restricted universe multiverse \
 | |
|        | sudo tee -a /tmp/buildroot/etc/apt/sources.list
 | |
|    sudo chroot /tmp/buildroot bash -c "apt-get update"
 | |
|    sudo chroot /tmp/buildroot bash -c "apt-get install -qq -y build-essential \
 | |
|        puredata-dev libjson-c-dev libcurl4-nss-dev liboauth-dev"
 | |
| </code></pre>
 | |
|              <ol start="4">
 | |
|               <li>
 | |
|                Copy the files to a subfolder in the chroot folder, e.g.
 | |
|                <code>
 | |
|                 /tmp/buildroot/PuRestJson
 | |
|                </code>
 | |
|               </li>
 | |
|               <li>
 | |
|                Run
 | |
|                <code>
 | |
|                 make
 | |
|                </code>
 | |
|                via chroot:
 | |
|               </li>
 | |
|              </ol>
 | |
|              <pre><code>   sudo chroot /tmp/buildroot bash -c "cd PuRestJson && make"
 | |
| </code></pre>
 | |
|              <ol start="6">
 | |
|               <li>
 | |
|                (optional) To create a distributable version, you have to install patchelf, e.g.
 | |
|                <code>
 | |
|                 sudo chroot /tmp/buildroot bash -c "apt-get install patchelf"
 | |
|                </code>
 | |
|                . Run
 | |
|                <code>
 | |
|                 sudo chroot ${CHROOTDIR} bash -c "cd PuRestJson && bash ./dependencies/linux.sh *.pd_linux"
 | |
|                </code>
 | |
|                . This will copy dependencies to the /tmp/buildroot and rewrite linking information in the files to point to these dependencies.
 | |
|               </li>
 | |
|              </ol>
 | |
|              <h2>
 | |
|               <a aria-hidden="true" class="anchor" href="#windows-with-mingw" id="user-content-windows-with-mingw">
 | |
|                <span aria-hidden="true" class="octicon octicon-link">
 | |
|                </span>
 | |
|               </a>
 | |
|               Windows with MinGW
 | |
|              </h2>
 | |
|              <p>
 | |
|               This is possible, but I have given up on it, and only cross-compile the library with MXE.
 | |
|              </p>
 | |
|              <h2>
 | |
|               <a aria-hidden="true" class="anchor" href="#compilation-on-mac-os-x" id="user-content-compilation-on-mac-os-x">
 | |
|                <span aria-hidden="true" class="octicon octicon-link">
 | |
|                </span>
 | |
|               </a>
 | |
|               Compilation on Mac OS X
 | |
|              </h2>
 | |
|              <p>
 | |
|               As a guideline, look at the scripts in the
 | |
|               <code>
 | |
|                circleci-scripts/osx
 | |
|               </code>
 | |
|               folder.
 | |
|              </p>
 | |
|              <ol>
 | |
|               <li>
 | |
|                Install
 | |
|                <a href="https://developer.apple.com/xcode/" rel="nofollow">
 | |
|                 XCode
 | |
|                </a>
 | |
|                , and
 | |
|                <a href="http://stackoverflow.com/a/9353468/124983" rel="nofollow">
 | |
|                 install the command line tools
 | |
|                </a>
 | |
|                to get
 | |
|                <code>
 | |
|                 gcc
 | |
|                </code>
 | |
|                and
 | |
|                <code>
 | |
|                 otool
 | |
|                </code>
 | |
|                .
 | |
|               </li>
 | |
|               <li>
 | |
|                Install
 | |
|                <a href="http://brew.sh/" rel="nofollow">
 | |
|                 Homebrew
 | |
|                </a>
 | |
|                to later install the dependencies.
 | |
|               </li>
 | |
|               <li>
 | |
|                Install dependencies via Homebrew:
 | |
|               </li>
 | |
|              </ol>
 | |
|              <pre><code>   brew update
 | |
|    brew install json-c curl liboauth --universal
 | |
| </code></pre>
 | |
|              <ol start="4">
 | |
|               <li>
 | |
|                Find the path to Pd.
 | |
|               </li>
 | |
|               <li>
 | |
|                Drop the sources in a directory and run
 | |
|                <code>
 | |
|                 make pdincludepath=/path/to/pd/Contents/Resources/src
 | |
|                </code>
 | |
|               </li>
 | |
|               <li>
 | |
|                (optional) You are now able to use the library on a machine, if the dependencies are installed via Homebrew. To move the necessary dylibs to the current directory and change the links of the pd_darwin files, run
 | |
|                <code>
 | |
|                 ./dependencies/osx.sh
 | |
|                </code>
 | |
|                . This makes the whole folder distributable.
 | |
|               </li>
 | |
|              </ol>
 | |
|              <h2>
 | |
|               <a aria-hidden="true" class="anchor" href="#cross-compilation-for-windows-on-unix-like-systems-linux--bsd--mac-os-x-with-mxe" id="user-content-cross-compilation-for-windows-on-unix-like-systems-linux--bsd--mac-os-x-with-mxe">
 | |
|                <span aria-hidden="true" class="octicon octicon-link">
 | |
|                </span>
 | |
|               </a>
 | |
|               Cross-compilation for Windows on UNIX-like systems (Linux / *BSD / Mac OS X) with MXE
 | |
|              </h2>
 | |
|              <p>
 | |
|               As a guideline, look at the scripts in the
 | |
|               <code>
 | |
|                circleci-scripts/windows32
 | |
|               </code>
 | |
|               folder.
 | |
|              </p>
 | |
|              <ol>
 | |
|               <li>
 | |
|                Get the development version of MXE from
 | |
|                <a href="https://github.com/mxe/mxe">
 | |
|                 their Github repository
 | |
|                </a>
 | |
|                and setup MXE, so that the cross compilation tools are in your PATH environmental variable.
 | |
|               </li>
 | |
|               <li>
 | |
|                Build the required libraries by running
 | |
|                <code>
 | |
|                 make curl json-c liboauth pthreads
 | |
|                </code>
 | |
|                .
 | |
|               </li>
 | |
|               <li>
 | |
|                Download the Windows version of Pd and unzip it in a folder. You should have the following structure of files:
 | |
|               </li>
 | |
|              </ol>
 | |
|              <pre><code>   pd/src/(source files including m_pd.h)
 | |
|    pd/bin/pd.dll
 | |
| </code></pre>
 | |
|              <ol start="4">
 | |
|               <li>
 | |
|                Run
 | |
|                <code>
 | |
|                 make
 | |
|                </code>
 | |
|                with some environmental variables to tell the compiler to use the cross compiler, and where to find the Pd source and pd.dll. Here is an example from my setup:
 | |
|               </li>
 | |
|              </ol>
 | |
|              <pre><code>   #!/bin/bash
 | |
|    MXE_DIR=/usr/lib/mxe
 | |
|    MXE_GCC=${MXE_DIR}/usr/bin/i686-w64-mingw32.static-gcc
 | |
|    PD_DIR=/tmp/pd
 | |
|    
 | |
|    make \
 | |
|      system=Windows \
 | |
|      machine=i386 \
 | |
|      uname=MINGW \
 | |
|      pdincludepath=${PD_DIR}/src \
 | |
|      pdbinpath=${PD_DIR}/bin \
 | |
|      CC=${MXE_GCC} \
 | |
|      arch.c.flags='-march=pentium4 -msse -msse2 -mfpmath=sse -I \
 | |
|        "/usr/lib/mxe/usr/i686-w64-mingw32.static/include"' \
 | |
|      ldflags='-L "/usr/lib/mxe/usr/i686-w64-mingw32.static/lib"'
 | |
| </code></pre>
 | |
|             </article>
 | |
|            </div>
 | |
|           </div>
 | |
|          </div>
 | |
|         </div>
 | |
|        </div>
 | |
|       </div>
 | |
|      </div>
 | |
|     </main>
 | |
|    </div>
 | |
|   </div>
 | |
|   <script>
 | |
|    function showCanonicalImages() {
 | |
|       var images = document.getElementsByTagName('img');
 | |
|       if (!images) {
 | |
|         return;
 | |
|       }
 | |
|       for (var index = 0; index < images.length; index++) {
 | |
|         var image = images[index];
 | |
|         if (image.getAttribute('data-canonical-src') && image.src !== image.getAttribute('data-canonical-src')) {
 | |
|           image.src = image.getAttribute('data-canonical-src');
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     function scrollToHash() {
 | |
|       if (location.hash && !document.querySelector(':target')) {
 | |
|         var element = document.getElementById('user-content-' + location.hash.slice(1));
 | |
|         if (element) {
 | |
|            element.scrollIntoView();
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     function autorefreshContent(eventSourceUrl) {
 | |
|       var initialTitle = document.title;
 | |
|       var contentElement = document.getElementById('grip-content');
 | |
|       var source = new EventSource(eventSourceUrl);
 | |
|       var isRendering = false;
 | |
| 
 | |
|       source.onmessage = function(ev) {
 | |
|         var msg = JSON.parse(ev.data);
 | |
|         if (msg.updating) {
 | |
|           isRendering = true;
 | |
|           document.title = '(Rendering) ' + document.title;
 | |
|         } else {
 | |
|           isRendering = false;
 | |
|           document.title = initialTitle;
 | |
|           contentElement.innerHTML = msg.content;
 | |
|           showCanonicalImages();
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       source.onerror = function(e) {
 | |
|         if (e.readyState === EventSource.CLOSED && isRendering) {
 | |
|           isRendering = false;
 | |
|           document.title = initialTitle;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     window.onhashchange = function() {
 | |
|       scrollToHash();
 | |
|     }
 | |
| 
 | |
|     window.onload = function() {
 | |
|       scrollToHash();
 | |
|     }
 | |
| 
 | |
|     showCanonicalImages();
 | |
| 
 | |
|     var autorefreshUrl = document.getElementById('preview-page').getAttribute('data-autorefresh-url');
 | |
|     if (autorefreshUrl) {
 | |
|       autorefreshContent(autorefreshUrl);
 | |
|     }
 | |
|   </script>
 | |
|  </body>
 | |
| </html> |