• Stars
    star
    236
  • Rank 165,023 (Top 4 %)
  • Language
    C#
  • License
    MIT License
  • Created about 5 years ago
  • Updated over 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

This plugin resolves git url dependencies in the package for Unity Package Manager. You can use a git url as a package dependency!

Git Dependency Resolver For Unity

This plugin resolves git-based dependencies in the package for Unity Package Manager.
You can use git repositories url as a package dependencies! 👍

logo

PRs Welcome

<< Description | Install | Usage | Development Note | Contributing | Change log >>





Description

In Unity 2018.3, the Unity Package Manager (UPM) supported Git. :)

This update allows us to quickly install packages on code hosting services such as GitHub.

However, UPM does not support git-based dependencies in the package. :(

[ package-a/package.json ]
{
  "name": "com.coffee.package-a",
  "version": "0.1.0",
  "dependencies": {
    "com.coffee.core-a" : "https://github.com/mob-sakai/GitPackageTest#core-a-0.1.0"
  }
}

When the above package is installed, the following error occur. console

Git-based dependencies in packages feature is on the roadmap for 2020, but no specific ETA.


This plugin resolves git-based dependencies in the package.
You can use git repositories url as a package dependencies! 👍

Features

  • Easy to use: just install
  • Resolve git-based dependencies in packages
  • Automatically uninstall unused packages that is installed by this plugin
  • Support GitHub, Bitbucket, GitLab, etc.
  • Support private repository
  • Support Unity 2018.3 or later
  • Support .Net 3.5 and 4.x
  • Update package with a specific tag/branch/hash
  • Deterministic package installation
  • Support CI environment
  • Support path query parameter (sub-directory) even Unity 2019.2 or earlier
    • path must be a relative path to the root of the repository.
    • path query parameter must be placed before the revision anchor. The reverse order will fail.
    • A package manifest (package.json) is expected in the specified path.
    • e.g. With Path query parameter: https://github.com/user/repo.git?path=/example/folder
    • e.g. With revision anchor and path query parameter: https://github.com/user/repo.git?path=/example/folder#v1.2.3

Notes

From: https://forum.unity.com/threads/git-support-on-package-manager.573673/page-3#post-4552084

There is no conflict detection and/or resolution algorithm. The lastest package found with the same name is used. This is not how the package manager resolve dependency (See https://docs.unity3d.com/Manual/upm-conflicts-auto.html).

In Unity's algorithm, package conflicts are resolved by "dependency-level from root".
The all packages resolved by this plugin are "dependency-level=1".
Therefore, in some cases, the package of the intended version may not be installed.

For example, in the case of a project with a dependency graph like this:

project (root)
 ├ package A: 1.0.0
 │  └ package X: 2.0.0
 └ package B: 1.0.0
    └ package C: 2.0.0
       └ package X: 2.0.1

This plugin's algorithm

Install -> A: 1.0.0, B: 1.0.0, C: 2.0.0, X: 2.0.1

Unity's algorithm

Install -> A: 1.0.0, B: 1.0.0, C: 2.0.0, X: 2.0.0





Installation

Requirement

  • Unity 2018.3 or later

Using OpenUPM

This package is available on OpenUPM. You can install it via openupm-cli.

openupm add com.coffee.git-dependency-resolver

Using Git

Find the manifest.json file in the Packages directory in your project and edit it as follows:

{
  "dependencies": {
    "com.coffee.git-dependency-resolver": "https://github.com/mob-sakai/GitDependencyResolverForUnity.git",
    ...
  },
}

To update the package, change suffix #{version} to the target version.

  • e.g. "com.coffee.git-dependency-resolver": "https://github.com/mob-sakai/GitDependencyResolverForUnity.git#1.2.0",

Or, use UpmGitExtension to install and update the package.





Usage

For package user

  • Install this plugin.
  • If the dependencies are not resolved successfully, reopen the project. If that does not work, try the following:
    1. Close the project.
    2. Delete Library/ScriptAssemblies directory in the project.
    3. Open the project.
  • When Unity Package Manager Error window is opens, click Continue.
    window
  • Add Packages/.* to .gitignore to hide auto-installed package.

For package developer

  • Find the package.json file in your package and edit it as follows:
{
  ...
  "gitDependencies": {
    "your.package": "https://github.com/yourname/yourpackage.git#v1.2.3",
    ...
  }
}
  • You can use path query parameter (sub-directory) even Unity 2019.2 or earlier.
    • e.g. "your.package": "https://github.com/yourname/yourpackage.git?path=/pkg/dir#v1.2.3"
    • path must be a relative path to the root of the repository.
    • path query parameter must be placed before the revision anchor. The reverse order will fail.
    • A package manifest (package.json) is expected in the specified path.
  • You must use gitDependencies instead of dependencies to define git-based dependencies for the package.
    • This plugin also supports dependencies to resolve git-based dependencies, but if dependencies include packages that UPM can't resolve, it will fail to start Unity in CI environment.
  • You must announce to your package users that they must install com.coffee.git-dependency-resolver.
  • It is recommended to use SemVer as a tag or branch name.
    • e.g. 1.0.0, 0.5.0-preview10, 0.1.0-alpha+daily5





Contributing

Issues

Issues are very valuable to this project.

  • Ideas are a valuable source of contributions others can make
  • Problems show where this project is lacking
  • With a question you show where contributors can improve the user experience

Pull Requests

Pull requests are, a great way to get your ideas into this repository.
See CONTRIBUTING.md.

Support

This is an open source project that I am developing in my spare time.
If you like it, please support me.
With your support, I can spend more time on development. :)






License

Author

mob-sakai

See Also

More Repositories

1

UIEffect

UIEffect is an effect component for uGUI element in Unity. Let's decorate your UI with effects!
C#
5,248
star
2

ParticleEffectForUGUI

Render particle effect in UnityUI(uGUI). Maskable, sortable, and no extra Camera/RenderTexture/Canvas.
C#
3,747
star
3

SoftMaskForUGUI

UI Soft Mask is a smooth masking component for Unity UI (uGUI) elements.
C#
1,778
star
4

UpmGitExtension

This package extends the UI of Unity Package Manager (UPM) for the packages installed from git repository.
C#
738
star
5

UnmaskForUGUI

A reverse masking solution for uGUI element in Unity.
C#
738
star
6

ShinyEffectForUGUI

Shiny effect of uGUI, which does not need mask or normal map.
C#
353
star
7

CSharpCompilerSettingsForUnity

Change the C# compiler (csc) used on your Unity project, as you like!
C#
274
star
8

StaticBluredScreen

Non-realtime (=static) screen blur for Unity. Easy to use background for dialogs.
C#
182
star
9

MeshEffectForTextMeshPro

Mesh effect components for TextMeshPro in Unity.
C#
141
star
10

AtlasImage

AtlasImage is a graphic component use SpriteAtlas for uGUI. In addition, add useful sprite selector and border editor to the inspector.
C#
127
star
11

UIEffectSnapshot

Capture a screenshot with effect and display it. Light-weight, non-realtime, no-camera (and no-PostProcessingStack), but be effective enough. The captured snapshot can be used as a background for a UI panel.
C#
127
star
12

MirrorReflectionEffectForUGUI

A simple mirror reflection effect for a uGUI without reflection probes or shaders.
C#
112
star
13

CompositeCanvasRenderer

CompositeCanvasRenderer bakes multiple source graphics into a bake-buffer (RenderTexture) and renders it. Additional material modification, mesh modification, and baking effects are supported! Let's enjoy the effects that were difficult to implement with UI shaders, such as blur, soft outline, and soft shadow!
C#
109
star
14

DissolveEffectForTMPro

DissolveEffectForTMPro provide dissolve effect component for TextMeshPro in Unity.
C#
102
star
15

SubAssetEditor

Editor for SubAsset in unity project.
C#
101
star
16

OpenSesameCompilerForUnity

A Roslyn compiler to access internals/privates for Unity. In other words, you can access to any internals/privates in other assemblies, without reflection. Let's say, "Open sesame!"
C#
100
star
17

ProjectBuilder

A tool for easy automating and customizing build process for Unity.
C#
94
star
18

UnityEventDrawerEx

This plugin extends the UnityEventDrawer to display runtime calls in the inspector.
C#
92
star
19

ShinyEffectForTMPro

ShinyEffectForTMPro provide shiny effect component for TextMeshPro in Unity.
C#
89
star
20

DissolveEffectForUGUI

A dissolve effect for uGUI, without material instancing. Please star and watch this project :)
C#
77
star
21

unity-activate

A tool to activate Unity license.
TypeScript
75
star
22

UITransition

C#
55
star
23

CompositeToggle

Composite toggle system for unity
C#
44
star
24

ButtonEx

C#
43
star
25

docker-unity

New series of CI-specialised docker images for Unity. Superseding the famous gableroux/unity3d images.
Dockerfile
34
star
26

BlurringAtlasForUGUI

A blur effect for uGUI in Unity, that is effective even for atlas images including dynamic fonts.
C#
34
star
27

SymbolCatalog

A tool for edit script symbol define for Unity.
C#
34
star
28

OpenSesame

A custom Roslyn compiler that allows access to internals/privates in other assemblies. Say "Open, Sesame!"
C#
30
star
29

MainWindowTitleModifierForUnity

A demo to change the text displayed in UnityEditor's title bar
C#
29
star
30

unity-changeset

Get/List Unity editor changeset
TypeScript
27
star
31

SimpleBuildInterface

A simple build interface for Unity CLI. Support all platforms without executeMethod option.
C#
25
star
32

unity.package-manager.metadata

Contains metadata used by the com.unity.package-manager package to fulfill client requests
Shell
25
star
33

RotateMe

Rotate the object. (This repo is a tutorial for "How to develop a package for UnityPackageManager")
Shell
23
star
34

InternalAccessibleCompilerForUnity

Compile a c# project to a internal accessible dll (for Unity)
C#
22
star
35

UISystem

C#
20
star
36

ScrollEx

C#
15
star
37

AssetSystem

C#
15
star
38

UnityBuiltinShaders

Unity's built-in shaders.
ShaderLab
13
star
39

VertexTextureFetchForUGUI

C#
11
star
40

InternalAccessibleCompiler

Compile a c# project to a internal accessible dll
C#
8
star
41

UniIx

Interactive Extensions for Unity for Unity
C#
7
star
42

Demos

6
star
43

JobcanExtensionForChrome

JavaScript
5
star
44

git-snapshot

git-snapshot is a command-line tool to take a snapshot of the directory and creates/updates another branch, like git subtree split --squash.
JavaScript
5
star
45

Coffee.Internal

Tools and snippets for package development
C#
5
star
46

unity-changeset-action

[GitHub Action] Get Unity editor change set for specific version
JavaScript
5
star
47

AtlasSystem

Atlas system for Unity
C#
4
star
48

unity-list-action

[GitHub Action] Get Unity editor versions for next jobs
JavaScript
3
star
49

UnityAdventCalendar2021

https://qiita.com/items/37978a030d6a6e262065
C#
3
star
50

ApiSystem

C#
3
star
51

mob-sakai.github.io

3
star
52

actionsflow-workflow-test

2
star
53

mob-sakai

1
star
54

UnityGitDependencyTest

A test repo for GitDependencyResolverForUnity
C#
1
star