Objective-C on Dreamcast: Difference between revisions

From dreamcast.wiki
Jump to navigation Jump to search
(Added the tools make section)
Line 1: Line 1:
{{Note|type=warn|text=This article is a Work in Progress. It is subject to change and utilizes repo forks that might be significantly behind the mainline repo.}}
===This article is actively being worked on===
''Work in progress - items to be added and/or edited'':  It is subject to change and utilizes repo forks that might be significantly behind the mainline repos.


<div style="float:right;">__TOC__</div>
<div style="float:right;">__TOC__</div>
Line 15: Line 16:


== Libffi ==
== Libffi ==
==== Clone the ffi repo ====
==== Clone the repo ====
     git clone git@github.com:andrewapperley/libffi.git
     git clone git@github.com:andrewapperley/libffi.git


==== Execute the configure command ====
==== Execute the configure command ====
     CC=kos-cc CXX=kos-c++ ./configure --host=sh-elf --target=sh-elf
     CC=kos-cc CXX=kos-c++ ./configure --host=sh-elf --target=sh-elf
==== Execute the make command ====
    make
==== Execute the make install command ====
    make install
== Tools Make ==
==== Clone the repo ====
    git clone git@github.com:andrewapperley/tools-make.git
==== Switch to DC branch ====
    git fetch
    git checkout origin/DC
    git pull
==== Execute the configure command ====
    CC=kos-cc CXX=kos-c++ ./configure --host=sh-elf --target=sh-elf --prefix=/opt/gnustep --enable-nxconstantstring --disable-tls --disable-icu --disable-iconv --disable-libdispatch --disable-xslt --disable-xml --enable-procfs-psinfo --enable-procfs


==== Execute the make command ====
==== Execute the make command ====

Revision as of 20:49, 6 June 2024

This article is actively being worked on

Work in progress - items to be added and/or edited: It is subject to change and utilizes repo forks that might be significantly behind the mainline repos.

Introduction

This article will cover the how to setup Objective-C and its Standard Library, Foundation. The following git repos will be used in this guide and will be described in more detail as we go:

  • Tools-Make - provides a set of make files that are used to properly configure Foundation
  • KOS - the main package for making Dreamcast Homebrew. We will need to patch your local git clone with pthread support
  • Libs-Base - provides the Foundation library for Objective-C
  • LibFFI - used for NSTimers and NSInvocation support

Important note: If you haven't setup KOS yet, you must follow the Getting Started Guide. You can then come back and continue with this one.

Preparation

We must first configure and install the prerequisites for Foundation. These include libffi and Tools-Make.

Libffi

Clone the repo

   git clone git@github.com:andrewapperley/libffi.git

Execute the configure command

   CC=kos-cc CXX=kos-c++ ./configure --host=sh-elf --target=sh-elf

Execute the make command

   make

Execute the make install command

   make install

Tools Make

Clone the repo

   git clone git@github.com:andrewapperley/tools-make.git

Switch to DC branch

   git fetch
   git checkout origin/DC
   git pull

Execute the configure command

   CC=kos-cc CXX=kos-c++ ./configure --host=sh-elf --target=sh-elf --prefix=/opt/gnustep --enable-nxconstantstring --disable-tls --disable-icu --disable-iconv --disable-libdispatch --disable-xslt --disable-xml --enable-procfs-psinfo --enable-procfs

Execute the make command

   make

Execute the make install command

   make install