Skip to content

Latest commit

 

History

History
 
 

sources

Xenko Sources

Folders and projects layout

###core###

  • Xenko.Core: Reference counting, dependency property system (PropertyContainer/PropertyKey), low-level serialization, low-level memory operations (Utilities and NativeStream).
  • Xenko.Core.Mathematics: Mathematics library (despite its name, no dependencies on Xenko.Core).
  • Xenko.Core.IO: Virtual File System.
  • Xenko.Core.Serialization: High-level serialization and git-like CAS storage system.
  • Xenko.Core.MicroThreading: Micro-threading library based on C# 5.0 async (a.k.a. stackless programming)
  • Xenko.Core.AssemblyProcessor: Internal tool used to patch assemblies to add various features, such as Serialization auto-generation, various memory/pinning operations, module initializers, etc...

###presentation###

  • Xenko.Core.Presentation: WPF UI library (themes, controls such as propertygrid, behaviors, etc...)
  • Xenko.Core.SampleApp: Simple property grid example.
  • Xenko.Core.Quantum: Advanced ViewModel library that gives ability to synchronize view-models over network (w/ diff), and at requested time intervals. That way, view models can be defined within engine without any UI dependencies.

###buildengine###

  • Xenko.Core.BuildEngine.Common: Common parts of the build engine. It can be reused to add new build steps, build commands, and also to build a new custom build engine client.
  • Xenko.Core.BuildEngine: Default implementation of build engine tool (executable)
  • Xenko.Core.BuildEngine.Monitor: WPF Display live results of build engine (similar to IncrediBuild)
  • Xenko.Core.BuildEngine.Editor: WPF Build engine rules editor and used by most projects.

###shaders###

  • Irony: Parsing library, used by Xenko.Core.Shaders. Should later be replaced by ANTLR4.
  • Xenko.Core.Shaders: Shader parsing, type analysis and conversion library (used by HLSL->GLSL and Xenko Shader Language)

###targets###

  • MSBuild target files to create easily cross-platform solutions (Android, iOS, WinRT, WinPhone, etc...), and define behaviors and targets globally. Extensible.

Use in your project

###Source repository###

There is two options to integrate this repository in your own repository:

###Basic use###

Simply add the projects you want to use directly in your Visual Studio solution.

###Optional: Activate assembly processor###

If you want to use auto-generated Serialization code, some of Utilities functions or ModuleInitializer, you need to use Xenko.Core.AssemblyProcessor.

Steps:

  • Include both Xenko.Core.AssemblyProcessor and Xenko.Core.AssemblyProcessor.Common in your solution.
  • Add either a Xenko.Core.PostSettings.Local.targets or a YourSolutionName.PostSettings.Local.targets in your solution folder, with this content:
<!-- Build file pre-included automatically by all projects in the solution -->
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <PropertyGroup>
    <!-- Enable assembly processor -->
    <XenkoAssemblyProcessorGlobal>true</XenkoAssemblyProcessorGlobal>
  </PropertyGroup>
</Project>