GitXplorerGitXplorer
c

uswift

public
103 stars
9 forks
3 issues

Commits

List of commits on branch main.
Unverified
be13a7dc9ffc080581991ccd9d2a84209e9fb6bc

Update Metadata.c

ccompnerd committed 6 months ago
Verified
88e00f0ddb884274995e289e3144d8e31fd9ffdf

Update build.yml

ccompnerd committed 6 months ago
Unverified
9b9242ee7f4bdc2d5a2ce15b5939029a489526c0

Bugfix: make 'func /=' divide, not add.

rrhx committed 2 years ago
Verified
bfbce8184617d63f9cbb0d247f1f6d2eeb7fc91d

Update build.yml

ccompnerd committed 2 years ago
Unverified
0a66d2d3bc25702d71df8c3bcd265888b27e4778

CI: use latest Swift 5.6.1 release

MMaxDesiatov committed 3 years ago
Verified
4c5953af0738c0ab35ffd50dd226fd16bb2038b7

Core: add basic `BinaryInteger` on integer types

MMaxDesiatov committed 3 years ago

README

The README file for this repository.

μSwift[Core]

The Swift language is implemented as a small layer of sugar over LLVM IR. This includes the core types such as Bool. In order to support even basic constructs, the language requires the standard library to be available. The reference standard library is a large code base and has additional dependencies such as libicu. This makes the library inconvenient for certain environments.

μSwift is a minimal standard library that provides a few of the core interfaces required for using basic constructs in Swift. The long term vision for this library is to provide conditional control over the features that the implementation vends. This enables the use of Swift in embedded systems which may not be amenable to large libraries and do not need the complete core functionality from Swift (e.g. Unicode support).

Components

  1. swiftCore: the standard library.
  2. swiftOnoneSupport: the support library for building with -Onone
  3. swiftRuntime: the language runtime support (merged into swiftCore)

Build Requirements

  • clang compiler (11.0+)
  • Swift compiler (5.4+)
  • CMake (3.18+)
  • Ninja (1.8+)

Building

Building a dynamically linked version of the libraries is controlled by the BUILD_SHARED_LIBS standard parameter.

Building with CMake requires the Ninja build tool.

NOTE: There is some support which is required in the Swift compiler itself in order to build the Swift stanard library. This includes support for the architecture and the OS spelling. Without this, the target may not be recognised properly and the Standard Library may fail to compile.

The following builds a release (optimized) configuration of the statically linked variant of the standard library for a freestanding ELF environment:

cmake -B out -D BUILD_SHARED_LIBS=NO -D CMAKE_BUILD_TYPE=Release -D CMAKE_Swift_COMPILER_TARGET=aarch64-unknown-none-elf -D CMAKE_Swift_COMPILER_WORKS=YES -G Ninja -S .
ninja -C out

NOTE: This support requires patches to the Swift compiler which have not yet been merged. The changes are available at apple/swift#35970.

Parameters

  1. BUILD_SHARED_LIBS: Boolean
    Indicates if the libraries should be shared (dynamically linked) or not.

  2. CMAKE_Swift_COMPILER_TARGET: String
    Identifiers the target triple of the platform that the standard library should be built. Defaults to the build.

  3. CMAKE_Swift_COMPILER_WORKS: Boolean
    Required parameter. Must always specify a true boolean value. This is required to skip the checks that the compiler can build code for the target. The Swift compiler cannot build code without the standard library available. Because we are building the standard library, we must skip the checks and assume that the compiler functions properly.

Artifacts

swiftCore.dll/libswiftCore.so/libswiftCore.dylib
The runtime component of the standard library.
swiftCore.lib/libswiftCore.so/libswiftCore.dylib
The build/SDK component of the standard library for linking.
Swift.swiftmodule
The build/SDK component of the standard library for building.