summaryrefslogtreecommitdiff
path: root/src/rebar_git_resource.erl
Commit message (Collapse)AuthorAgeFilesLines
* Code documentation that the PR was for backwards compatilityStuart Thackray2018-12-181-1/+5
|
* Tidy Deps plugin to provide the download/3Stuart Thackray2018-12-111-0/+4
| | | | | | For issue https://github.com/erlang/rebar3/issues/1974 Revert "add rebar.lock to template gitignore" This reverts commit 8fb8a91130e0e5c239bb837b9adc4ad71e5806b8.
* merge from upstream/mastersimonxu722018-11-131-0/+17
|\
| * check if git/hg is installedFred Hebert2018-10-201-0/+19
| | | | | | | | | | | | | | | | | | | | This PR is a simpler and mergeable version of #1853 by @shamis, since the provider changed format enough to make merging difficult. Compared to #1853, this also puts the responsibility on each resource to check rather than adding a new optional callback. The process dictionary is use as a warning/check cache.
* | Merge remote-tracking branch 'upstream/master'simonxu722018-10-161-22/+47
|\ \ | |/
| * support for hex v2, multiple repository fetching, private organizations (#1884)Tristan Sloughter2018-09-131-22/+47
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * update to hex_core for hex-v2 repo support (#1865) * update to hex_core for hex-v2 repo support This patch adds only single repo hex-v2 support through hex_core. Packages no longer filtered out by buildtool metadata and the package index is updated per-package instead of fetched as one large ets dump. * tell travis to also build hex_core branch * support list of repos for hex packages (#1866) * support list of repos for hex packages repos are defined under the hex key in rebar configs. They can be defined at the top level of a project or globally, but not in profiles and the repos configured in dependencies are also ignored. Searching for packages involves first checking for a match in the local repo index cache, in the order repos are defined. If not found each repo is checked through the hex api for any known versions of the package and the first repo with a version that fits the constraint is used. * add {repos, replace, []} for overriding the global & default repos * add hex auth handling for repos (#1874) auth token are kept in a hex.config file that is modified by the rebar3 hex plugin. Repo names that have a : separating a parent and child are considered organizations. The parent repo's auth will be included with the child. So an organization named hexpm:rebar3_test will include any hexpm auth tokens found in the rebar3_test organization's configuration. * move packages to top level of of hexpm cache dir (#1876) * move packages to top level of of hexpm cache dir * append organization name to parent's repo_url when parsing repos * only eval config scripts and apply overrides once per app (#1879) * only eval config scripts and apply overrides once per app * move new resource behaviour to rebar_resource_v2 and keep v1 * cleanup use of rebar_resource module and unused functions * cleanup error messages and unused code * when discovering apps support mix packages as unbuilt apps (#1882) * use hex_core tarball unpacking support in pkg resource (#1883) * use hex_core tarball unpacking support in pkg resource * ignore etag if package doesn't exist and delete if checksum fails * add back tests for bad package checksums * improve bad registry checksum error message
* | combine []/Opt case options into one @ get_git_options/0simonxu722018-07-261-2/+1
| |
* | add git clone --reference path supportsimonxu722018-07-261-12/+31
|/
* [#1675] Disable color in git log commandJuan Facorro2017-11-291-1/+1
|
* OTP-21 readiness, Full Unicode supportFred Hebert2017-11-161-9/+10
| | | | | | | | | | | | This replaces all deprecated function usage by alternative ones based on a version switch enacted at compile time, preventing all warnings. This will likely introduce some possible runtime errors in using a Rebar3 compiled on OTP-20 or OTP-21 back in versions 19 and earlier, but we can't really work around that. A bunch of dependencies have been updated to support OTP-21 without warnings as well.
* git vsn from tag both strip 'v' prefixTristan Sloughter2017-11-021-0/+3
|
* Warn user when a local git or hg resource is usedFred Hebert2017-10-051-0/+14
| | | | Those aren't supported and so a warning should be output. Fixes #1003
* Unicode support in all the placesFred Hebert2017-08-061-24/+23
| | | | | | | | | | | | | | | | | | | | | | | | | | | | This is done through 3 main change groups: - replacing `~s` by `~ts` in format strings, so that strings that contain unicode are properly printed rather than crashing - adding the `unicode` argument to all function of the `re` module to ensure transformations on strings containing unicode data are valid instead of crashing (see issue #1302) - replacing `ec_cnv:to_binary/1` and `ec_cnv:to_list/1` with matching functions in `rebar_utils`. The last point has been done, rather than modifying and updating erlware commons, because binary and list conversions can be a contentious subject. For example, if what is being handled is actually bytes from a given binary stream, then forcing a byte-oriented interpretation of the data can corrupt it. As such, it does not appear safe to modify erlware commons' conversion functions since it may not be safe for all its users. Instead, rebar3 reimplements a subset of them (only converting atoms and chardata, ignoring numbers) with the explicit purpose of handling unicode string data. Tests were left as unchanged as possible. This may impact the ability to run rebar3's own suites in a unicode path, but respects a principle of least change for such a large patch.
* Fix git SHAs comparison for update.Alin Popa2017-03-121-9/+7
| | | | | | | 86e883b8d8d1d16487e245fff02eba8c83da2cdd always returns the full length SHA, therefore when using a dependency having the short SHA, it'll always consider that the SHAs are different, hence it'll alway return true for .
* Use different git commands for different git versionsBjörn-Egil Dahlberg2016-12-071-13/+59
| | | | | | | | | | The option --single-branch was introduced in git version 1.7.10 and thus rebar3 cannot fetch git dependencies on systems where earlier git versions are install. This commit will select other git clone commands if an earlier git version is detected. If the git version cannot be determined rebar3 falls back on the previous behavior and uses --single-branch.
* Fixes for windows environment: 1) copy empty directories when cloning (since ↵Steve Strong2016-06-281-1/+1
| | | | git occasionally has a refs directory with no files in it - if the directory is not present, then git does not believe it is a git repo) and 2) change order of git rev-parse arguments to match git docs
* Debug log updateStuart Thackray2016-05-271-1/+1
|
* #1185 fix windows git working directoryPost hawk2016-05-181-2/+9
| | | fix issue #1185 git working directory issues due to command line options in Windows
* Fixed git version bugYakov2016-04-041-1/+1
| | | | | | | | | | | | | | | | | I've tried to compile project with git in .app.src vsn Project was tagged as 1.0.0, but resulting .app vsn becomes 1.0.0+build.6.reff0aec24 ```git lg * f0aec24 - (80 минут назад) Fixed ct — Kozlov Yakov (HEAD -> master, tag: 1.0.0, origin/master) ... 5 commits before ``` ``` $ git log --oneline --no-walk --tags --decorate f0aec24 (HEAD -> master, tag: 1.0.0, origin/master) Fixed ct ``` I've found that `HEAD -> master` doest match pattern in [rebar_git_resource](https://github.com/erlang/rebar3/blob/master/src/rebar_git_resource.erl#L204)
* only need to compare ref and not ref+url in git resourceTristan Sloughter2016-01-081-2/+2
|
* if not in a git repo but have 'git' as vsn, fallback to 0.0.0Tristan Sloughter2015-10-041-23/+30
|
* Improve semantic versioning from git between tagsZachary Hueras2015-09-211-1/+7
| | | | | | | | | | | | | | In the scenario we that we have selected a commit that is between two tags, we should base the version on the most recent tag we can see in the revision history, but we should not treat this as the tag version. `git describe --tags --abbrev=0` finds the most recent tag visible in the revision history from the current HEAD. Return this as the version string and undefined as the tag to trigger ref counting.
* Only match current HEAD tag in git semverZachary Hueras2015-09-211-1/+1
| | | | | | | | | In the scenario that someone had cloned an entire repository and then checked out an older version tag, the semantic versioning would detect the newest tag, not the checked out tag. Look for the HEAD string prior to tag: to indicate the currently selected tag.
* make v prefix in git tag version optionalTristan Sloughter2015-09-191-1/+1
|
* Revert "Improved git versioning"Tristan Sloughter2015-09-191-8/+2
|
* Improve semantic versioning from git between tagsZachary Hueras2015-09-161-1/+7
| | | | | | | | | | | | | In the scenario we that we have selected a commit that is between two tags, we should base the version on the most recent tag we can see in the revision history, but we should not treat this as the tag version. `git describe --tags` finds the most recent tag visible in the revision history from the current HEAD. Return this as the version string and undefined as the tag to trigger ref counting.
* Only match current HEAD tag in git semverZachary Hueras2015-09-161-1/+1
| | | | | | | | | In the scenario that someone had cloned an entire repository and then checked out an older version tag, the semantic versioning would detect the newest tag, not the checked out tag. Look for the HEAD string prior to tag: to indicate the currently selected tag.
* Make the v-prefix optional in git semverZachary Hueras2015-09-161-1/+1
| | | | | | Not all repositories use a v-prefix for version tags. All tags should be considered valid versions.
* Modify parse_git_url to be more genericDavid Leach2015-08-111-14/+21
| | | | | | Changes parse_git url function to use Using RFC3986 standard to validate git uri instead of matching strings in function head. Also accepts scp style syntax for parsing.
* Escape paths and args in shell commandsFred Hebert2015-07-181-9/+19
| | | | | | | Basic escaping is done only. Fancy hex sequences are not covered, but this should otherwise take care of the most common issues. Fixes #497
* Fix missing 'cd' that depended on cwd changesFred Hebert2015-07-101-1/+3
|
* Only have the port cd, not rebar3 as a wholeFred Hebert2015-07-081-15/+10
|
* handle http:// git deps in check fif upgrade neededTristan Sloughter2015-07-061-0/+4
|
* Fix common test run duplication on windowsViacheslav Kovalev2015-06-261-1/+1
|
* fix rebar_git_resourcederwinlu2015-05-071-14/+16
| | | | | | * fix shell commands relying on non windows shell commands * fix shell commands using wrong quotes * implement native wc -l
* only fetch branch needed, remove rebar_vsn_plugins from erlware_commonsTristan Sloughter2015-05-031-1/+1
|
* on upgrade of git branch check against remoteTristan Sloughter2015-05-031-4/+7
|
* Fix typo in error messageViacheslav V. Kovalev2015-03-101-1/+1
|
* use rebar_utils:sh for git and hg commands to have better errors and logsTristan Sloughter2015-03-031-15/+32
|
* replace package management with hex.pmTristan Sloughter2015-02-171-9/+9
|
* needs_update: on ref defined deps only have to match prefix if 7+ charsTristan Sloughter2015-02-161-8/+15
|
* fixes for dialyzer findingsTristan Sloughter2014-11-301-6/+1
|
* fix git resource update check, bad url comparisonTristan Sloughter2014-11-221-14/+27
|
* handle throw by relxTristan Sloughter2014-11-081-6/+6
|
* properly reset cwd after finding version of git resourceTristan Sloughter2014-11-051-1/+1
|
* support branch/tag/ref-less git depsTristan Sloughter2014-11-051-2/+4
|
* add make_vsn to rebar_resource for replacing app vsnsTristan Sloughter2014-11-031-1/+66
|
* run legacy style hooks for compile providerTristan Sloughter2014-11-011-0/+2
|
* verify checked out dep is the same as specified in the config and update if notTristan Sloughter2014-11-011-1/+36
|
* create rebar_resource behaviour and create git resourceTristan Sloughter2014-10-301-0/+44