UdonSharp
A compiler for compiling C# to Udon assembly
UdonSharp is a compiler that compiles C# to Udon assembly. UdonSharp is not currently conformant to any version of the C# language specification, so there are many things that are not implemented or will not work.
C# features supported
- Flow control
- Supports:
if
else
while
for
do
foreach
switch
return
break
continue
ternary operator (condition ? true : false)
??
- Supports:
- Implicit and explicit type conversions
- Arrays and array indexers
- All builtin arithmetic operators
- Conditional short circuiting
(true || CheckIfTrue())
will not execute CheckIfTrue() typeof()
- Extern methods with out or ref parameters (such as many variants of
Physics.Raycast()
) - User defined methods with parameters and return values, supports out/ref, extension methods, and
params
- User defined properties
- Static user methods
- UdonSharpBehaviour inheritence, virtual methods, etc.
- Unity/Udon event callbacks with arguments. For instance, registering a OnPlayerJoined event with a VRCPlayerApi argument is valid.
- String interpolation
- Field initializers
- Jagged arrays
- Referencing other custom UdonSharpBehaviour classes, accessing fields, and calling methods on them
- Recursive method calls are supported via the
[RecursiveMethod]
attribute
Differences from regular Unity C# to note
- For the best experience making UdonSharp scripts, make your scripts inherit from
UdonSharpBehaviour
instead ofMonoBehaviour
- If you need to call
GetComponent<UdonBehaviour>()
you will need to use(UdonBehaviour)GetComponent(typeof(UdonBehaviour))
at the moment since the generic get component is not exposed for UdonBehaviour yet.GetComponent<T>()
works for other Unity component types though. - Udon currently only supports array
[]
collections and by extension UdonSharp only supports arrays at the moment. It looks like they might supportList<T>
at some point, but it is not there yet. - Field initilizers are evaluated at compile time, if you have any init logic that depends on other objects in the scene you should use Start for this.
- Use the
UdonSynced
attribute on fields that you want to sync. - Numeric casts are checked for overflow due to UdonVM limitations
- The internal type of variables returned by
.GetType()
will not always match what you may expect since U# abstracts some types in order to make them work in Udon. For instance, any jagged array type will return a type ofobject[]
instead of something likeint[][]
for a 2D int jagged array.
Udon bugs that affect U#
- Mutating methods on structs do not modify the struct (this can be seen on things like calling Normalize() on a Vector3) https://vrchat.canny.io/vrchat-udon-closed-alpha-bugs/p/raysetorigin-and-raysetdirection-not-working
Setup
Requirements
- Unity 2019.4.31f1
- VRCSDK3 + UdonSDK
- The latest release of UdonSharp
Installation
- Read the getting started with Udon doc page https://docs.vrchat.com/docs/getting-started-with-udon this has basic installation instructions for Udon.
- Install the latest version of the VRCSDK3 linked on the getting started.
- Get the latest release of UdonSharp from here and install it to your project.
Getting started
- Make a new object in your scene
- Add an
Udon Behaviour
component to your object - Below the "New Program" button click the dropdown and select "Udon C# Program Asset"
- Now click the New Program button, this will create a new UdonSharp program asset for you
- Click the Create Script button and choose a save destination and name for the script.
- This will create a template script that's ready for you to start working on, open the script in your editor of choice and start programming
Asset explorer asset creation
Instead of creating assets from an UdonBehaviour you can also do the following:
- Right-click in your project asset explorer
- Navigate to Create > U# script
- Click U# script, this will open a create file dialog
- Choose a name for your script and click Save
- This will create a .cs script file and an UdonSharp program asset that's set up for the script in the same directory
Example scripts
The rotating cube demo
This rotates the object that it's attached to by 90 degrees every second
using UnityEngine;
using UdonSharp;
public class RotatingCubeBehaviour : UdonSharpBehaviour
{
private void Update()
{
transform.Rotate(Vector3.up, 90f * Time.deltaTime);
}
}
Other examples
For more example scripts take a look at the wiki page for examples, the Examples folder included with U#, or the community resources page on the wiki.
Credits
- See CONTRIBUTORS.md for people who have helped provide improvments to UdonSharp
- The open source project Harmony helps Udonsharp provide a better editor experience