Skip to content

Commit

Permalink
Added documentation for static and shared linking suffixes
Browse files Browse the repository at this point in the history
  • Loading branch information
nickclark2016 committed Feb 24, 2022
1 parent 1cd78b4 commit ab65927
Showing 1 changed file with 16 additions and 3 deletions.
19 changes: 16 additions & 3 deletions website/docs/links.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,12 +40,12 @@ filter { "system:linux" }
filter { "system:macosx" }
-- OS X frameworks need the extension to be handled properly
links { "Cocoa.framework", "png" }
```
```

In a workspace with two projects, link the library into the executable. Note that the project name is used to specify the link; Premake will automatically figure out the correct library file name and directory and create a project dependency.

```lua
workspace "MyWorkspace"
```lua
workspace "MyWorkspace"
configurations { "Debug", "Release" }
language "C++"

Expand All @@ -59,6 +59,19 @@ filter { "system:macosx" }
files "**.cpp"
```

You may specify the linking mechanism explicitly for each library. To set the link type of a library explicitly, add a `:static` or `:shared` suffix to the library. Note that this functionality is only available for the `gcc` and `clang` toolsets.

```lua
workspace "MyWorkspace"
configurations { "Debug", "Release" }
language "C++"

project "MyExecutable"
kind "ConsoleApp"
files "**.cpp"
links { "LibraryA:static", "LibraryB:shared" }
```

You may also create links between non-library projects. In this case, Premake will generate a build dependency (the linked project will build first), but not an actual link. In this example, MyProject uses a build dependency to ensure that MyTool gets built first. It then uses MyTool as part of its build process.

```lua
Expand Down

0 comments on commit ab65927

Please sign in to comment.