Compare commits

...

848 Commits

Author SHA1 Message Date
akkaradej
dcd06d80a3 Fix missing host from ssh source 2018-03-28 16:35:57 +02:00
akkaradej
51a00ff433 Add test for shallow cloning when source is a ssh protocol 2018-03-28 16:35:57 +02:00
Adam Stankiewicz
add601795f Update year in licenses one last time, fixes #2476 2018-03-28 15:25:36 +02:00
Adam Stankiewicz
8e34328466 Run tests on all node versions and fix test suite, closes #2495 (#2505) 2018-03-28 15:17:31 +02:00
Michael Kühnel
c3e9c94833 Expose non-interactive option to CLI help (#2404) 2018-03-28 13:20:11 +02:00
Madan
dd19bafa37 docs: highlight "-allow-root" (#2496) 2018-03-28 13:17:55 +02:00
Martin Page
74af42c176 Only replace last @ after (if any) last / with # (#2395) 2018-03-28 13:16:09 +02:00
Guido Bouman
a6308bf8f8 Remove duplicate space setting from .editorconfig. (#2480) 2017-09-26 08:11:42 -05:00
Adam Stankiewicz
e1dc0105d2 Reduce node versions on appveyor 2017-09-26 10:57:16 +02:00
Adam Stankiewicz
ce210e4f16 Install grunt on appveyor 2017-09-26 10:55:11 +02:00
Adam Stankiewicz
e483e9bc2c Reduce tested node versions 2017-09-26 10:48:43 +02:00
Adam Stankiewicz
b0c3859699 Fix a test 2017-09-26 10:37:59 +02:00
Adam Stankiewicz
e6d1b2d82e Try to fix appveyor build 2017-09-26 10:36:09 +02:00
Adam Stankiewicz
d4345bb254 Use Yarn on travis and appveyor 2017-09-14 18:08:22 +02:00
Adam Stankiewicz
975f9bdcdb Lock dependencies 2017-09-14 18:05:08 +02:00
Adam Stankiewicz
a969a9c557 Bump bower-config 2017-09-14 18:04:12 +02:00
Adam Stankiewicz
6500b421ce Migrate bower.herokuapp.com to registry.bower.io 2017-09-13 18:59:52 +02:00
Adam Stankiewicz
0641167b96 Remove opencollective for now to prevent installation issues 2017-09-13 18:55:23 +02:00
yanca018
0d03374dab Update LICENSE (#2475)
Update year to 2017
2017-08-14 12:41:32 +02:00
Xavier Damman
765d8e739d Activating Open Collective (#2450) 2017-05-30 18:15:09 +02:00
Thomas Grainger
0bd318de53 Add yarn and webpack recommendation (#2458) 2017-05-19 20:29:15 +02:00
Juan Olvera
aa6b51edc0 Replace gitter references with discord on documentation (#2453) 2017-04-18 18:12:36 -05:00
Adam Stankiewicz
2c2e5309fd Run tests on node 7 as well 2017-03-22 14:03:31 +01:00
Eugene Kenny
b716bc4e3a Prefer exact versions when dissecting dependencies (#2371) 2016-11-08 09:11:29 +01:00
Adam Stankiewicz
bda400634c Bump to 1.8.0 2016-11-07 10:53:30 +01:00
Adam Stankiewicz
b01243ac3c Fix eslint issues 2016-11-07 10:47:29 +01:00
Adam Stankiewicz
89902a6919 Mark release in changelog 2016-11-07 10:46:10 +01:00
Adam Stankiewicz
80308a41a6 Update changelog 2016-11-07 10:34:39 +01:00
Adam Stankiewicz
47cc2262e1 Download tar archives from https://github when possible (#2263) 2016-11-07 02:33:43 +01:00
Guillermo Ignacio Enriquez Gutierrez
f7c5154490 Fix ssl handling by not setting GIT_SSL_NO_VERIFY=false (#2361) 2016-11-07 01:50:57 +01:00
Ali MoezGholami
cba4b2a4cd Allow for removing components with url instead of name (#2368) 2016-11-07 01:48:41 +01:00
Leo.liang
bdabf6a4e6 Show in warning message location of malformed bower.json (#2357) 2016-11-07 01:29:17 +01:00
GvS
7896224384 Improve handling of non-semver versions in git resolver (#2316) 2016-11-07 01:27:14 +01:00
Johannes Faigle
3209cda975 docs: Update package repository information (#2351) 2016-11-07 01:21:27 +01:00
Vytautas Jakutis
38501a0b93 Fix handling of cached releases pluginResolverFactory (#2356) 2016-11-07 01:19:41 +01:00
Adam Stankiewicz
e60d236b25 Add bower-config changes to changelog 2016-11-06 23:04:07 +01:00
Adam Stankiewicz
044896e708 Bump bower-config to 1.4.0 2016-11-06 23:03:56 +01:00
Adam Stankiewicz
fc4c260de4 Update changelog 2016-11-06 22:56:42 +01:00
Adam Stankiewicz
d405917b4a Remove non-working issue stats 2016-07-05 11:16:26 +02:00
Martin Page
22bbb3fcaf Allow @ to be used as a divider with cli: install and info. (#2322) 2016-07-04 23:31:06 +02:00
Adam Stankiewicz
8b6c8eeaa9 Run tests also on 4.0 and 4.1 2016-06-12 14:22:36 +02:00
Adam Stankiewicz
58ddb59104 Revert "Rename .travis.yml to travis.yml"
This reverts commit 9317bb6e33.
2016-06-12 14:19:04 +02:00
Adam Stankiewicz
f26fe38c30 Fix CI badges 2016-06-12 14:18:29 +02:00
Adam Stankiewicz
9317bb6e33 Rename .travis.yml to travis.yml 2016-06-12 14:04:50 +02:00
Adam Stankiewicz
2693bae8ed Improve appveyor.yml 2016-06-12 14:04:28 +02:00
Adam Stankiewicz
8368539a93 Change appveyor badge to new project
[skip ci]
2016-06-12 01:40:45 +02:00
Adam Stankiewicz
8947400487 Disable deploy in appveyor.yml 2016-06-12 01:19:50 +02:00
Adam Stankiewicz
44eeb60529 Improve appveyor.yml 2016-06-12 01:18:32 +02:00
Adam Stankiewicz
2309cd80c6 Add missing return in promise 2016-06-11 02:49:22 +02:00
Adam Stankiewicz
684ab0c0a6 Simplify travis configuration 2016-06-10 20:48:44 +02:00
Adam Stankiewicz
1f6b32a48e Test node 6 also on appveyor 2016-06-10 17:41:11 +02:00
Adam Stankiewicz
e4f0295ef1 Test node 4, 5, and 6 2016-06-10 17:37:53 +02:00
Adam Stankiewicz
85e39cf190 Try to fix svn tests 2016-06-10 17:24:42 +02:00
Adam Stankiewicz
16c134f0f9 Update devDependencies 2016-06-10 17:14:47 +02:00
Adam Stankiewicz
bcbff32716 Pass through eslint 2016-06-10 16:40:46 +02:00
Adam Stankiewicz
809117ea73 Merge bower-endpoint-parser repository 2016-06-10 14:24:55 +02:00
Adam Stankiewicz
af448ba484 Merge bower-registry-client repository 2016-06-10 13:44:43 +02:00
Adam Stankiewicz
89069784bb Merge bower-logger repository 2016-06-10 13:32:03 +02:00
Adam Stankiewicz
57cc6f7a40 Merge bower-json repository 2016-06-10 13:22:15 +02:00
Adam Stankiewicz
cea728c7bc Merge bower-config repository 2016-06-10 13:18:55 +02:00
Adam Stankiewicz
f6be8e5e28 Improve issue template a little 2016-06-09 20:34:14 +02:00
Ben
c6f7ec36de Add issue template (#2305) 2016-06-09 20:29:26 +02:00
Ben
3235b3c0d3 Fix typo in README 2016-06-02 13:36:10 +02:00
Adam Stankiewicz
6ca5d434a4 [docs] Change info at the top of readme 2016-06-02 12:38:49 +02:00
Evan Bowling
eb27ae8fdc Added integration tests for installing nested components (#1513) (#2297) 2016-05-30 11:16:53 +02:00
Ben
353a399f75 Fix test & build for shorthand resolver 2016-05-10 10:46:07 +02:00
Ben
c718541a4e Merge pull request #2282 from evanjbowling/master
Correct typo in command descriptions, followup for #2280
2016-05-08 20:08:40 +02:00
Evan Bowling
1f4372299a Correct typo in command descriptions, followup for #2280 2016-05-08 11:39:45 -05:00
Adam Stankiewicz
e640d0ec5c Improve search / lookup command descriptions, closes #2280 2016-05-06 11:57:26 +02:00
Ben
2e5acfe076 Remove analytics from example config 2016-05-04 19:55:27 +02:00
Ben
19f3c53c70 Merge pull request #54 from evanjbowling/master
Update README.md to be more descriptive
2016-05-04 08:52:38 +02:00
Evan Bowling
26902aec27 Update README.md to be more descriptive 2016-05-03 22:18:05 -05:00
Ben
08feaf2b0a Merge pull request #2271 from rajzshkr/bower-register-info
info message added for bower register
Closing #2075
2016-04-28 12:46:17 +02:00
Ben
db1ed1c08f Fix build errors #2
Related to the change from git:// to https://
2016-04-28 12:32:13 +02:00
Ben
3c2562ca0e Fix failing tests 2016-04-28 12:23:54 +02:00
Raja Sekar
b1f1b8fae3 info message added for bower register 2016-04-28 15:16:10 +05:30
Ben
f1c874b202 Merge pull request #2270 from rajzshkr/bower-cache
fix for 2264
2016-04-28 07:27:15 +02:00
Raja Sekar
4757e7353f fix for 2264 2016-04-28 10:20:19 +05:30
Adam Stankiewicz
249ac47b9c 1.4.0 2016-04-22 00:35:39 +02:00
Adam Stankiewicz
dc59913098 Change default shorthandResolver from git:// to https:// 2016-04-22 00:35:23 +02:00
Oskar Cieślik
343e6ac8bc Implement postuninstall hooks with tests (#2252) 2016-04-14 15:02:07 +02:00
Adam Stankiewicz
e729829174 Make bower version behavior consistent with spec (#2232) 2016-04-12 19:18:36 +02:00
Oskar Cieślik
40e3ee091b Support single-char repo names and package names (#2249) 2016-04-12 19:15:24 +02:00
Oskar Cieślik
8ee2d78779 Add support for registering package with github's orgname/reponame (#2248) 2016-04-12 18:57:44 +02:00
Oskar Cieślik
7c54812ecf Allow to type the entire version when conflict occured (#2243) 2016-04-10 13:24:29 +02:00
Adam Stankiewicz
3251051d20 Fix tests given the new registry 2016-04-10 13:15:57 +02:00
Adam Stankiewicz
81052830f2 Merge pull request #52 from bamsy/topic-unreachable-code
Remove unreachable code from parse function
2016-04-09 18:18:53 +02:00
Justin Barnes
7b2fd5dcd1 Remove unreachable code from parse function 2016-04-09 09:14:04 -05:00
Adam Stankiewicz
bbc9b35cb1 Update grunt to 1.0.1 2016-04-06 13:45:43 +02:00
Adam Stankiewicz
3aebb34f1d Fix typo in changelog 2016-04-05 13:48:21 +02:00
Adam Stankiewicz
8065e5c64a 1.7.9 2016-04-05 13:44:58 +02:00
Adam Stankiewicz
b8e6f36a91 Add changelog entries for 1.7.9 2016-04-05 13:36:52 +02:00
Adam Stankiewicz
12d41aeb8c Warn instead of erroring for invalida package names, #2233 2016-04-05 13:34:06 +02:00
Adam Stankiewicz
8c624bbda6 0.8.1 2016-04-04 21:45:44 +02:00
Adam Stankiewicz
7ee1686cf4 Add changelog for 0.8.1 2016-04-04 21:45:39 +02:00
Adam Stankiewicz
8e181c1792 Make name validation far less strict 2016-04-04 21:37:50 +02:00
Adam Stankiewicz
9569a8074d Add missing changelog entry, #2233 2016-04-04 20:42:55 +02:00
Adam Stankiewicz
e8e4c8fdbc Fix typo in changelog 2016-04-04 19:20:57 +02:00
Adam Stankiewicz
9e5cd572f8 1.7.8 2016-04-04 19:00:08 +02:00
Adam Stankiewicz
69cd360551 Update changelog 2016-04-04 18:59:44 +02:00
Adam Stankiewicz
4793fc0d1c Bump year in license 2016-04-04 18:38:28 +02:00
Adam Stankiewicz
aaaa9cd530 Don't ask for git credentials in non-interactive session
This is done by setting GIT_TERMINAL_PROMPT variable

- fixes #956
- fixes #1009
2016-04-04 18:17:04 +02:00
Adam Stankiewicz
c2e0dc9d23 Prevent swallowing exceptions with programmatic api, fixes #2187 2016-04-04 17:33:19 +02:00
Adam Stankiewicz
fc4446247c Update graceful-fs to 4.x 2016-04-04 14:26:26 +02:00
Adam Stankiewicz
f4e0b3dfba Update bower-json to 0.8.0 and update tests 2016-04-04 14:18:23 +02:00
Adam Stankiewicz
4d7cdb0556 0.8.0 2016-04-04 14:11:41 +02:00
Adam Stankiewicz
037bbff17e Update changelog 2016-04-04 14:11:37 +02:00
Adam Stankiewicz
f05cd5fb94 Update bower-json to 0.7.1 2016-04-04 13:49:22 +02:00
Adam Stankiewicz
358a73b98e 0.7.1 2016-04-04 13:47:56 +02:00
Adam Stankiewicz
32cbb5a0e8 Update graceful-fs 2016-04-04 13:47:10 +02:00
bamsy
8679ad77ae Fix grammar in contributing file.
- remove trailing whitespace

- "anyway" -> "any way"
2016-04-03 13:18:06 +02:00
Kyle Pollock
1b1d8bdad6 Remove jscs inline error suppression comments.
- jscs is removed from the project.
2016-04-02 14:26:04 +02:00
Kyle Pollock
aecdf3f365 Merge pull request #2229 from bamsy/master
Fix typos/grammar in first paragraph of contributing file.
2016-04-01 20:30:51 -05:00
Justin Barnes
1cf87041cc Fix typos/grammar in first paragraph of contributing file. 2016-04-01 19:36:04 -05:00
Adam Stankiewicz
5116fec1ab Update decompress-zip to 0.2.1 2016-04-01 17:51:46 +02:00
Adam Stankiewicz
8f2668a24d Bump config-store to 2.0.0 2016-04-01 17:36:06 +02:00
Adam Stankiewicz
e7516e4bcb Bump bower-config to 1.3.1 2016-04-01 17:32:50 +02:00
Adam Stankiewicz
3853d1297e Add changelog entry 2016-04-01 17:28:23 +02:00
Adam Stankiewicz
1e398f999b Update dependencies 2016-04-01 17:27:18 +02:00
Adam Stankiewicz
3a0ea968f4 Update graceful-fs dependency 2016-04-01 17:24:12 +02:00
Adam Stankiewicz
7de2e5d601 Remove moduleType from from "bower init" result, fixes #1229 2016-04-01 16:19:51 +02:00
Adam Stankiewicz
b1c45bb586 Resolve pluggable resolvers using cwd and fallback to global module 2016-04-01 14:57:36 +02:00
Adam Stankiewicz
f4cb047e9d Allow to install custom resolver globally, fixes #1919 2016-04-01 03:22:42 +02:00
Adam Stankiewicz
f494ae7ddd [refactor] Fix tests for previous commit 2016-04-01 01:39:09 +02:00
Adam Stankiewicz
44e71267c1 [refactor] Put bower-registry-client instantiation in one place 2016-03-31 22:10:10 +02:00
Adam Stankiewicz
52aa684949 [refactor] Move abbreviations to utils 2016-03-31 19:29:55 +02:00
Adam Stankiewicz
46655b7c4e Final .eslintrc configuration 2016-03-31 19:27:12 +02:00
Adam Stankiewicz
16cde3118a Revert "Merge pull request #2197 from albertinadx/albertinad/fix-scripts-hooks"
This reverts commit 0a81308e98, reversing
changes made to f2884656c0.
2016-03-31 01:36:05 +02:00
Adam Stankiewicz
7c2dfc1146 Fix peerDependency of grunt-exec 2016-03-31 00:55:47 +02:00
Adam Stankiewicz
53eeca97d3 Use eslint instead jscs 2016-03-31 00:27:17 +02:00
Adam Stankiewicz
9201a379d6 Update to grunt 1.0 2016-03-30 22:30:57 +02:00
Adam Stankiewicz
2052ba3eed Remove jshint 2016-03-30 22:12:24 +02:00
Adam Stankiewicz
b32bd8b877 Merge pull request #2225 from echavezNS/master
Reuse the files selected in jshint for jscs
2016-03-28 12:19:38 +02:00
echavezNS
233f685c61 Reuse the files selected in jshint for jscs 2016-03-28 00:39:05 -07:00
Kun Yan
5fe8df2e0a Merge pull request #2224 from kunyan/bugfix/test-case
Fix message unit test error
2016-03-28 14:35:35 +08:00
Kun Yan
a3ae3b66b7 Fix message unit test error 2016-03-28 14:11:02 +08:00
Ben
2000d2f5db Merge pull request #2212 from echavezNS/master
Extend conflict message to be more expressive how to choose an option
2016-03-27 08:01:03 +02:00
echavezNS
84d8d8c57f Typo 2016-03-26 12:39:35 -07:00
echavezNS
f9ea3846e2 Extend conflict message 2016-03-26 01:25:10 -07:00
Yan Kun
8b6c20239e Merge pull request #2208 from kunyan/bugfix/grunt-file-json-error
Fix Gruntfile error
2016-03-20 22:43:33 -05:00
Kun Yan
73171766e7 Fix Gruntfile error 2016-03-21 11:16:51 +08:00
Adam Stankiewicz
88b3655829 Merge pull request #2204 from echavezNS/master
Add jsonPackage for refactoring purposes
2016-03-17 10:00:59 +01:00
Jorge Chavez
3241e8ed62 Add jsonPackage for refactoring purposes 2016-03-16 18:12:43 -07:00
Albertina Durante
0a81308e98 Merge pull request #2197 from albertinadx/albertinad/fix-scripts-hooks
Fix hooks to support shell operators
2016-03-05 21:54:22 -03:00
Albertina Durante
8d76b87d65 Supporting shell operators in hooks scripts.
- Removing module "shell-quote"
- Adding tests for hooks scripts with shell operators
- This fixes issue #1594
2016-03-05 21:50:05 -03:00
Adam Stankiewicz
f2884656c0 Merge pull request #2196 from prometheansacrifice/handlebars-vulnerability
Handlebars vulnerability
2016-03-06 01:17:19 +01:00
Manas
6fff6fa707 Upgrades handlebars to 4.0.5 to address #2195
Adds test for template util methods
Upgrades handlebars
Fixes RangeError due to `length` attribute in rpad helper
2016-03-06 01:37:20 +05:30
Ben
1357f63a1b Merge pull request #2191 from nirajkaushal/master
Update: Copyright Year from 2015 to 2016
2016-02-29 09:23:52 +01:00
Niraj Kaushal
529d702959 Update Copyright Year from 2015 to 2016
This commit will change copyright year from 2015 to current year(2016)
2016-02-29 11:13:06 +05:30
Ben
0155a70457 Merge pull request #2186 from yash14123/master
Changelog is still in 2015
2016-02-24 11:37:21 +01:00
yash14123
a6ca2ae9bb Changelog is still in 2015 2016-02-24 05:34:44 +05:30
Adam Stankiewicz
78e443db0a Merge pull request #2177 from oliamb/eslintrc-indent
[eslint] fix indentation to 4 spaces
2016-02-17 15:59:54 +01:00
Sivakumar Kailasam
5f24eab32d Merge pull request #2175 from sivakumar-kailasam/bowerrc-placeholder-replacement-fix
Replace all occurrences of % character in hook commands.
2016-02-17 13:27:12 +05:30
Olivier Amblet
f4620b28ab [eslint] fix indentation to 4 spaces
Changed the indentation from 2 to 4 spaces in .eslintrc files.
All the code is using this convention and .jscsrc already define 4 as
the right value.
2016-02-16 23:22:46 +01:00
Sivakumar Kailasam
9f4c2384ea Replace all occurrences of % character in hook commands.
Fixes #2174 % character replaced once in .bowerrc scripts
2016-02-15 20:34:01 +05:30
Adam Stankiewicz
e85a5f778f Update opn package to 4.0.0, fixes #2169 2016-02-13 21:41:35 +01:00
Adam Stankiewicz
5283a132bc Add name check that reflects reality 2016-02-10 04:33:26 +01:00
Adam Stankiewicz
db1453f7c0 Add findSync and readSync to the README 2016-02-10 02:55:24 +01:00
Adam Stankiewicz
878a228a7d Fix linting error 2016-02-10 02:44:53 +01:00
Adam Stankiewicz
b33041c3ec [test] Remove unnecessary check 2016-02-10 02:42:33 +01:00
Stefan Grönke
c8a6ff38a0 test validation against all registred packages 2016-02-10 02:38:55 +01:00
Adam Stankiewicz
573b84f7f4 Update bower-json to 0.7.0 2016-02-10 02:34:30 +01:00
Adam Stankiewicz
ef67955c21 Bump to 0.7.0 2016-02-10 02:22:34 +01:00
Adam Stankiewicz
36a14b9b37 Add getIssues function and make validate less restrictive 2016-02-10 01:54:31 +01:00
Adam Stankiewicz
96d986f436 Merge pull request #2161 from blcook223/feature/save-bowerrc-config
add support for save and save-exact in .bowerrc
2016-01-29 12:27:44 +01:00
blcook223
394dd7c8d2 add support for save and save-exact in .bowerrc
The install command now supports designating "save" and "save-exact"
values in .bowerrc. If the `--save` flag is not used, but the config
file sets "save" to true, the command will behave as if the `--save`
option was specified. The same is true of `--save-exact` if
"save-exact" is set to true in `.bowerrc`.

The uninstall command will also behave as if the `--save` flag had
been specified if "save" is set to true in `.bowerrc`.
2016-01-28 21:10:17 -06:00
Adam Stankiewicz
6c67d07cc8 Add missing lib/bin/bower.js file 2016-01-27 15:37:13 +01:00
Adam Stankiewicz
cd7bbab310 Bump to 1.7.7 2016-01-27 15:05:27 +01:00
Adam Stankiewicz
4b4a854ed8 Restore directory structure for published bower
It's because people are depending on internals of bower, like
"bower/lib/renderers/StandardRenderer"

Instead we move templates and bin to lib directory and leave
paths intact. Additionally we alias bin/bower to lib/bin/bower.
2016-01-27 14:47:18 +01:00
Adam Stankiewicz
8194bcb4c6 Revert bin/bower location and bump to 1.7.6 2016-01-27 12:06:48 +01:00
Adam Stankiewicz
e5d478a1cc Bump to 1.7.5 and update changelog 2016-01-26 22:35:22 +01:00
Adam Stankiewicz
bbaaee67a1 Update publishing script to bundle all modules 2016-01-25 22:57:07 +01:00
Adam Stankiewicz
ad27112b58 Do not assume package.json location 2016-01-25 19:40:54 +01:00
Adam Stankiewicz
38c3cee1a7 Perform test on fake .git directory 2016-01-25 19:40:54 +01:00
Adam Stankiewicz
b485c5d3cb Remove bundledDependencies from package.json
bundledDependencies will be filled only just before publish
2016-01-25 19:40:54 +01:00
Adam Stankiewicz
d63047b4ee Merge pull request #2137 from pwielgolaski/#2129
when strictSsl is false set GIT_SSL_NO_VERIFY=true for git command
2016-01-24 18:14:38 +01:00
Piotr Wielgolaski
f0a54d0018 set GIT_SSL_NO_VERIFY for opposite value than strictSsl 2016-01-23 20:29:28 +01:00
Piotr Wielgolaski
1d73764788 when strictSsl is false set GIT_SSL_NO_VERIFY=true for git command
Solves #2129
2016-01-23 14:26:48 +01:00
Adam Stankiewicz
9d2681b0c4 Ignore test files in published package 2016-01-21 13:43:17 +01:00
Adam Stankiewicz
f3330e8612 Update changelog and bump to 1.7.3 2016-01-20 18:23:27 +01:00
Adam Stankiewicz
11996c04b7 Update to fs-write-stream@1.0.8 2016-01-20 14:18:44 +01:00
Adam Stankiewicz
35e73a619a Tolerate failure in covealls reporting 2016-01-20 14:06:48 +01:00
Adam Stankiewicz
fe615fd517 Merge pull request #2150 from bower/feature/analytics
Remove analytics from Bower, fixes #1102
2016-01-20 13:35:55 +01:00
Adam Stankiewicz
3e3b64218d Remove analytics from Bower, fixes #1102
They caused more issues than useful they were.

Instead, we'll focus on fetching statistics from
NPM registry to watch Bower's popularity, and
GitHub stars over time to watch packages' popularity.
2016-01-20 12:30:54 +01:00
Adam Stankiewicz
afe76e57f8 Remove HOOKS.md as they are now properly documented, thanks @dvidsilva! 2016-01-18 22:05:17 +01:00
Adam Stankiewicz
6ee3ef7aa8 Merge pull request #2071 from prometheansacrifice/adding-tests-plugin-resolver
Adds tests for pluginResolverFactory.js
2016-01-18 12:34:50 +01:00
Manas
64db869bd4 Adds tests for pluginResolverFactory.js 2016-01-18 01:22:07 +05:30
Adam Stankiewicz
a4ea05800d Add prepublish script for easy and reliable bower releasing 2016-01-17 00:13:07 +01:00
Adam Stankiewicz
8cf897cd19 Merge pull request #2145 from bower/sjs/use-caret-on-install-save
Use caret on install save
2016-01-12 21:19:55 +00:00
Sam Saccone
d06af7a3d7 Default to ^ operator on --save
This fix brings us inline with how npm installs work and also brings us
more inline with how semver is supposed to be used.

Fixes #2144
2016-01-10 18:28:42 -08:00
Jaime Olmo
d4fd71986e Merge pull request #2140 from jamesxv7/master
Changes to license file and package.json
2016-01-07 20:55:31 -04:00
Jaime Olmo
3154444556 Update CHANGELOG.md
Updated as per 1.7.2 release
2016-01-07 01:59:49 -04:00
Jaime Olmo
24f8b913b9 Update LICENSE
Update license year to 2016.
2016-01-07 01:50:58 -04:00
Jaime Olmo
fe6b6863ea Update package.json
Version updated as per [1.7.2](https://github.com/bower/bower/releases/tag/v1.7.2) release.
2016-01-07 01:49:41 -04:00
Adam Stankiewicz
671c23ad50 Merge pull request #2130 from gronke/enhancement/absolute-paths-1914
support absolute path in .bowerrc directory option
2016-01-05 12:28:09 +01:00
Stefan Grönke
5384fa54b1 refactor, address feedback and add more unit tests 2016-01-05 05:23:19 +01:00
Adam Stankiewicz
4bfa8227d9 Merge pull request #2133 from azbshiri/display-logged-in-username
Display the logged in user's name
2016-01-05 00:32:16 +01:00
Alireza Bashiri
55d78f7928 Display the logged in user's name 2016-01-05 02:24:08 +03:30
Stefan Grönke
2110148830 support absolute path in .bowerrc 'directory' option
fixes #1914
2016-01-04 01:46:53 +01:00
Alireza Bashiri
afc4bfbd42 Revert "Display login message when user login via normal and 2 factor auth mode."
This reverts commit ed881e3f29.
2016-01-04 00:58:03 +03:30
Alireza Bashiri
9c42a008aa Merge pull request #2102 from reavowed/fix-extract-name-clashes
Fix name clashes in package extraction
2016-01-01 12:29:55 +03:30
Alireza Bashiri
67884744c3 Merge pull request #2127 from azbshiri/display-info-message-bower-login
Display login message when user login via bower login
2016-01-01 00:19:01 +03:30
Raja Sekar
ed881e3f29 Display login message when user login via normal and 2 factor auth mode.
Displaying info message when user login via bower login

Login message added for 2 factor authentication also

Fix unreachable code

Fix code quality issues
2015-12-31 23:31:16 +03:30
Vlad Filippov
e6e60d5d5e Merge pull request #2125 from bower/fix-write-stream-regression
Lock fs-write-steam-atomic to 1.0.5
2015-12-30 20:52:29 -05:00
Sam Saccone
d8f166a933 Lock fs-write-steam-atomic to 1.0.5
context: https://github.com/bower/bower/issues/2118#issuecomment-168097858

Fixes #2118
2015-12-30 16:22:54 -08:00
Adam Stankiewicz
bb626d1605 Merge pull request #2122 from kevdez/master
Added the --force docs to the --help command
2015-12-29 10:46:45 +01:00
Kevin H
daa5b8ddf9 Added the --force documentation to the --help command 2015-12-28 21:27:13 -08:00
Adam Stankiewicz
db087dfe13 Log-level is actually loglevel, closes #2112 2015-12-21 06:14:22 +01:00
Adam Stankiewicz
848e401efd Link back to invitation form 2015-12-21 05:18:45 +01:00
Adam Stankiewicz
c17c725057 Merge pull request #48 from mithun/no-env-in-hooks
Ignore hook scripts for environment variable expansion
2015-12-18 10:00:05 +01:00
Mithun Ayachit
2b31f6c07a Ignore hook scripts for environment variable expansion 2015-12-17 20:38:48 -06:00
Iain Monro
3cf597fccf Fix jshint errors
Add missing semicolons to test file.
2015-12-15 15:32:13 +00:00
Vlad Filippov
e2adbc37f1 Merge pull request #2103 from Rogerkael/master
Typo fix resolverFactory.js
2015-12-14 17:21:14 -05:00
Roger Rodriguez Texido
6c3b7dbf58 Fixed typo. 2015-12-14 17:12:30 -05:00
Rob Simpson
d3ab3c1fa7 remove freenode as support option 2015-12-14 12:57:24 -05:00
Iain Monro
b1ba9be7f6 Fix name clashes in package extraction
Prevent extraction failing if a package archive contains a file with
the same name as the archive, or a single directory with a subdirectory
with the same name.
2015-12-14 16:58:02 +00:00
Adam Stankiewicz
1e5122c023 Merge pull request #2092 from Utsav2/gzip
Decompress gzip files
2015-12-13 11:16:33 +01:00
Utsav Shah
4255d7d4a8 Add tests for decoding gzipped files 2015-12-12 18:08:19 -06:00
Utsav Shah
cdf45239f4 Decompress gzip files
Update request lib
2015-12-12 18:08:19 -06:00
Adam Stankiewicz
8b2fad32f6 Revert "Change entry in changelog"
This reverts commit d1ae0b1982.
2015-12-11 21:53:31 +01:00
Adam Stankiewicz
d1ae0b1982 Change entry in changelog 2015-12-11 21:53:00 +01:00
Adam Stankiewicz
87cf578ba8 Update changelog 2015-12-11 21:51:30 +01:00
Adam Stankiewicz
3ead440c7c Update changelog 2015-12-11 21:50:50 +01:00
Adam Stankiewicz
e168c894a2 Bump to 1.7.1 2015-12-11 21:43:21 +01:00
Adam Stankiewicz
75e3661371 Update changelog 2015-12-11 21:42:34 +01:00
Adam Stankiewicz
baf8f7bf6b Fix missing parenthesis 2015-12-11 21:37:08 +01:00
Adam Stankiewicz
88758cd98c Revert "Add bower update --save functionality"
This reverts commit d2ba80e6e9.
2015-12-11 21:33:45 +01:00
Adam Stankiewicz
3bd2d62e67 Revert "Add failing tests for single package updates, optimize older tests"
This reverts commit 6616d09f47.
2015-12-11 21:32:47 +01:00
Adam Stankiewicz
d3eef5772a Revert "Only update packages requested by the user"
This reverts commit e3f402fc66.
2015-12-11 21:25:15 +01:00
Adam Stankiewicz
7c714901d4 Fix test for StandardRenderer 2015-12-11 20:33:54 +01:00
Adam Stankiewicz
7792b6d35d Use coveralls as npm script (fix certain versions of node) 2015-12-11 20:24:40 +01:00
Adam Stankiewicz
2db983dba3 Better formatting of help 2015-12-11 20:16:54 +01:00
Adam Stankiewicz
b9718bb309 Fix search command on no arguments, fixes #2066 2015-12-11 20:15:04 +01:00
Adam Stankiewicz
26f609e614 Ignore for now failing windows build on node 5 2015-12-10 21:25:01 +01:00
Adam Stankiewicz
4c2b56096b Merge pull request #2096 from contolini/readme-clean-up
Readme updates
2015-12-10 17:56:08 +01:00
Chris Contolini
5af929f0be Clean up readme 2015-12-09 20:08:44 -05:00
Adam Stankiewicz
6a18cde782 Merge pull request #33 from bower/paulohp-patch-1
added coveralls badge.
2015-12-09 13:03:21 +01:00
Adam Stankiewicz
32c5538fc5 Merge pull request #46 from bower/paulohp-patch-1
added coveralls badge
2015-12-09 13:03:03 +01:00
Paulo Pires
57478d86c7 added 2015-12-09 03:53:47 -08:00
Paulo Pires
42107e6fea added coveralls badge 2015-12-09 03:52:47 -08:00
Adam Stankiewicz
686e883d87 Merge pull request #2094 from accommodavid/tar-test
Add test for tar archives
2015-12-09 11:34:57 +01:00
Adam Stankiewicz
f2767648e7 Merge pull request #2093 from contolini/hide-prereleases
Hide prerelease versions from `bower info`
2015-12-09 11:33:54 +01:00
Accommodavid
9e4bdd270d Add test for tar archives
Adds a test that checks if dependencies that point to tar archives (not
tar.gz) are handled and extracted correctly. Also removes a test from
`test/commands/install.js` that was duplicated.

Re-add postinstall test
2015-12-09 09:05:13 +01:00
Chris Contolini
7cb88ab49f Add renderer tests for prereleases 2015-12-08 17:59:21 -05:00
Chris Contolini
a532c55dca Hide prereleases when showing package info 2015-12-08 17:59:21 -05:00
Adam Stankiewicz
c559432c19 Properly call coveralls script 2015-12-08 20:05:04 +01:00
Adam Stankiewicz
9aae3b8d7e Merge pull request #45 from paulohp/grunt-travis
added grunt travis script to .travis.yml
2015-12-08 19:54:52 +01:00
Adam Stankiewicz
322c49edf4 Get rid of STRICT_REQUIRE flag for coverage testing 2015-12-08 19:52:10 +01:00
Adam Stankiewicz
34ec39507c Merge pull request #32 from paulohp/sync-functions
added synchronous functions to read and find
2015-12-08 19:20:40 +01:00
Adam Stankiewicz
fe9b27a647 Try to fix appveyor build with npm-env 2015-12-08 19:15:06 +01:00
Paulo Pires
304bb36bbc Added coveralls support
added missing packages

added test coverage files to gitignore

remove unecessary files

added missing coveralls package
2015-12-08 09:48:42 -08:00
Paulo Pires
376a2de600 added synchronous functions to read and find
added .readSync function

Added coverage
2015-12-08 05:33:38 -08:00
Adam Stankiewicz
1605374a25 Properly run code coverage on appveyor 2015-12-08 14:32:05 +01:00
Adam Stankiewicz
ac244a1400 Run coverage on appveyor as well 2015-12-08 14:21:05 +01:00
Adam Stankiewicz
9e58bbca31 Merge pull request #31 from paulohp/coveralls
Added coverage report. 📄
2015-12-08 13:54:36 +01:00
Paulo Pires
027a0694f7 Added coverage 2015-12-08 04:16:44 -08:00
Adam Stankiewicz
d50e50f3b5 Add discord chat link, closes #2088 2015-12-08 11:14:33 +01:00
Adam Stankiewicz
3030469c59 Update update-notifier to 0.6.0 2015-12-08 11:00:51 +01:00
Adam Stankiewicz
977e0ddc52 Update changelog 2015-12-07 20:34:47 +01:00
Adam Stankiewicz
de3e1089da Better formatting of help message 2015-12-07 20:32:33 +01:00
Adam Stankiewicz
7897ad7dba Move bug reports to the top 2015-12-07 16:35:19 +01:00
Adam Stankiewicz
accdab3ece Link bug reports to wiki 2015-12-07 16:34:26 +01:00
David DeSandro
612aaa88eb add help menu for update --save, update --save-dev
Ref #2035
2015-12-07 08:42:17 -05:00
Adam Stankiewicz
338ac99080 Bump to 1.7.0 2015-12-07 13:34:01 +01:00
Adam Stankiewicz
9605bbea5f Bump bower-config to 1.3.0 2015-12-07 13:08:58 +01:00
Adam Stankiewicz
7bc97a1241 Add changelog entry for array notation in env 2015-12-07 11:45:36 +01:00
Adam Stankiewicz
bd2c253f99 Bump to 1.3.0 2015-12-07 11:43:12 +01:00
Adam Stankiewicz
f1efce7d1f Merge pull request #44 from bower/feature/env
Allow for arrays in env fields (includes a test)
2015-12-07 11:39:17 +01:00
Adam Stankiewicz
844cc5a527 Add test for accept array from process env feature 2015-12-07 11:31:09 +01:00
Peng Wang
0e27b6f813 restore spacing and code formating 2015-12-07 11:31:09 +01:00
Adam Stankiewicz
3791aee9d6 Merge pull request #2085 from pertrai1/feature/eslintrc
adding eslintrc for new ruleset option
2015-12-06 15:48:52 +01:00
Rob Simpson
20a223a959 adding eslintrc for new ruleset option 2015-12-06 06:10:13 -05:00
Adam Stankiewicz
9219f54718 Merge pull request #43 from prometheansacrifice/adding-changelog
Adding CHANGELOG.md
2015-12-06 11:27:30 +01:00
Adam Stankiewicz
ea5bd51327 Merge pull request #2083 from prometheansacrifice/updating-changelog
Adds changelog for release 1.7.0
2015-12-06 11:26:26 +01:00
Manas
5a2272cab1 Adds CHANGELOG.md 2015-12-06 01:19:11 +05:30
Manas
b94c20b8da Release 1.7.0 2015-12-05 22:28:18 +05:30
Adam Stankiewicz
b81ba140e3 Bump to 1.6.9 and release 2015-12-04 22:28:09 +01:00
Adam Stankiewicz
4ffdb500b9 Update to npm version of fs-write-stream-atomic 2015-12-04 22:28:09 +01:00
Adam Stankiewicz
609607b096 Merge pull request #42 from mithun/allow-env-vars
Allow the use of environment variables in .bowerrc
2015-12-03 12:30:43 +01:00
Mithun Ayachit
e9657668a9 Allow the use of environment variables in .bowerrc
Similar to npmrc

Expand '~/' to user's home directory
2015-12-03 05:20:23 -06:00
Adam Stankiewicz
1696cde273 Merge pull request #2074 from eppeters/bower-search-prompt-before-listing-all
Prompt before listing all repos when running `bower search` without a query param
2015-12-03 00:21:57 +01:00
Adam Stankiewicz
94ffc35b25 Merge pull request #2070 from contolini/dont-update-all
Only update the packages requested by the user
2015-12-02 23:14:58 +01:00
Edward Peters
5a1e5eb9c7 Make 'bower search' show the help display when a user does not enter a
search term. Keep current behavior when running with config.json
enabled, or in non-interactive mode.

Rewrite bower search tests to cover the different cases of using the
command without a query parameter (interactive w/o config.json,
interactive w/ config.json, and non-interactive)
2015-12-02 17:07:27 -05:00
Chris Contolini
8c1f30b1c8 Format test files to comply with new jscs rules 2015-12-02 14:10:33 -05:00
Chris Contolini
e3f402fc66 Only update packages requested by the user 2015-12-02 14:10:28 -05:00
Chris Contolini
6616d09f47 Add failing tests for single package updates, optimize older tests 2015-12-02 14:10:28 -05:00
Adam Stankiewicz
25ad2ef946 Merge pull request #2076 from prometheansacrifice/instructions-for-squashing-commits
Adds instructions for squashing commits
2015-12-02 13:51:13 +01:00
Manas
ba4a1a9d45 Adds instructions for squashing commits 2015-12-02 13:30:45 +05:30
Adam Stankiewicz
3a37202dc5 Rollback to original fs-write-stream-atomic 2015-12-01 15:58:18 +01:00
Adam Stankiewicz
12258324d3 More code style rules to enforce 2015-11-30 11:06:57 +01:00
Adam Stankiewicz
2adb0b0807 Merge pull request #2063 from AnthonyBobsin/style-guide
Implements jscs to enforce a newly created style guide for the repo.
2015-11-30 10:54:40 +01:00
AnthonyBobsin
19fc84007d Implements jscs to enforce a newly created style guide for the repo. Uses jscs to fix some minor style guide warnings. 2015-11-29 16:22:58 -05:00
Adam Stankiewicz
8fcbd3671d Merge pull request #2062 from contolini/update-save
Add `bower update --save` functionality
2015-11-28 19:29:40 +01:00
Chris Contolini
0eadbef02d Merge branch 'master' into update-save 2015-11-28 08:42:43 -08:00
Adam Stankiewicz
107ad1d3fc Merge pull request #2060 from Utsav2/remove-at
Remove @ in temporary directories
2015-11-28 13:14:30 +01:00
Chris Contolini
d2ba80e6e9 Add bower update --save functionality 2015-11-28 05:40:24 -05:00
Adam Stankiewicz
f18b38cde5 Merge pull request #40 from ryantemple/master
Updated so cwd is set from command line and correct directory tree used
2015-11-28 10:57:22 +01:00
Ryan Temple
e6f1805df0 Added tests 2015-11-27 19:31:24 +00:00
Ryan Temple
4da1b62542 Updated so cwd is set from command line and correct directory tree used 2015-11-27 19:30:08 +00:00
Utsav Shah
852a586d5c Replace temp directory name with md5 hash
Fixes issues with characters like @ interfering with directory name
lookups
2015-11-27 13:17:36 -06:00
Utsav Shah
e8a2d92785 Remove @ in temporary directories 2015-11-27 11:36:14 -06:00
Adam Stankiewicz
50ed13e4ee Release 1.6.8 2015-11-27 15:53:52 +01:00
Adam Stankiewicz
cb9b737b9d Merge pull request #2058 from bower/enotdir-coverage
Add directory test for install command
2015-11-27 15:19:10 +01:00
Adam Stankiewicz
700b46162c Remove minor bumps of node from Travis 2015-11-27 14:47:11 +01:00
Accommodavid
0e1153f610 Add ENOTDIR test for install command 2015-11-27 14:43:22 +01:00
Adam Stankiewicz
8669ed2aac Bump bower-config to 1.2.3 2015-11-27 14:08:50 +01:00
Adam Stankiewicz
6d12ef291b Properly restore env variables if they are undefined 2015-11-27 13:53:36 +01:00
Adam Stankiewicz
ca0a36abcf Make downloader work on all platforms, fixes #2050 2015-11-27 13:45:19 +01:00
Adam Stankiewicz
4c6fdc905f Revert "Fix tests on Windows (cleanup of downloaded files)"
This reverts commit bb7c02b07b.
2015-11-27 00:33:15 +01:00
Adam Stankiewicz
cdbc4a123c Merge pull request #2040 from bower/fix-shallow-host
Fix shallow clone host
2015-11-26 18:25:49 +01:00
Adam Stankiewicz
bb7c02b07b Fix tests on Windows (cleanup of downloaded files) 2015-11-26 18:06:26 +01:00
Adam Stankiewicz
4f42aeabd7 Fix tests for abbreviations on Windows 2015-11-26 16:20:59 +01:00
Adam Stankiewicz
b77517ef64 Remove iojs from versions tested on travis (node 4.0 should be enough) 2015-11-26 14:35:52 +01:00
Adam Stankiewicz
b9c3f750eb Remove npm-shrinkwrap.json (bundledDependencies are enough..) 2015-11-26 14:25:14 +01:00
Adam Stankiewicz
aaecbfab17 evert "Merge pull request #2027 from watilde/patch/supports-tilde"
This reverts commit 2ff53fc448, reversing
changes made to 89286e628b.
2015-11-26 14:23:19 +01:00
Adam Stankiewicz
c4539aa603 Update npm-shrinkwrap.json 2015-11-26 14:01:10 +01:00
Adam Stankiewicz
7f801319bf Merge branch 'release-1.6.6' 2015-11-26 12:37:35 +01:00
Adam Stankiewicz
1a990f4563 Release 1.6.7 2015-11-26 12:31:53 +01:00
Trevor Heins
944a328f30 Merge pull request #2051 from kunyan/improve/2049
Add badge links to readme #2048 #2049
2015-11-26 00:00:46 -05:00
Kun Yan
e11b60d812 Add badge links to readme #2048 #2049
Signed-off-by: Kun Yan <kyan@redhat.com>
2015-11-26 10:38:35 +08:00
Adam Stankiewicz
c91e99b782 Merge pull request #2045 from zzarcon/chore/move_abbreviations_from_index
Move abbreviations to a different file
2015-11-26 00:01:43 +01:00
Hector Leon Zarco Garcia
da8ec1e4ab Move abbreviations to a different file 2015-11-25 23:58:30 +01:00
Adam Stankiewicz
c8d5199815 Merge pull request #33 from adriaanthomas/handle-default-ca
Load custom CA file for "default"
2015-11-25 18:32:44 +01:00
Vlad Filippov
e7868f0fb1 Changelog updates
[skip ci]
2015-11-25 10:54:11 -05:00
Adam Stankiewicz
eca46dbd85 Merge pull request #2042 from paulohp/update-node-version-appveyor
Added major versions (5 and 4) to appveyor
2015-11-25 16:47:13 +01:00
Vlad Filippov
67bd5d026f Bump to 1.6.6 2015-11-25 10:45:42 -05:00
Paulo Pires
51de67cc73 added major versions 5 and 4 to appveyor 2015-11-25 09:33:03 -02:00
Vlad Filippov
3d4f9cd919 Fix shallow clone host 2015-11-24 14:21:27 -05:00
Adam Stankiewicz
cd8d397e63 Merge pull request #38 from bower/revert-36-master
Revert "updated to respect the bowerrc in the cwd passed in as command line argument"
2015-11-24 16:53:09 +01:00
Riyadh Al Nur
5a9c099188 Revert "updated to respect the bowerrc in the cwd passed in as command line argument" 2015-11-24 21:25:11 +06:00
Adam Stankiewicz
2137089a70 Merge pull request #37 from riyadhalnur/update-node-versions-travis
Added newer Node versions to Travis
2015-11-24 13:11:17 +01:00
Riyadh Al Nur
fbd02852a3 Added newer Node versions to Travis
ADDED/UPDATED:
- Updated Travis file to not test against `iojs` anymore
- Added versions 4 and 5 of Node to test against on Travis
2015-11-24 13:11:54 +06:00
Riyadh Al Nur
f2584ade24 Merge pull request #36 from ryantemple/master
updated to respect the bowerrc in the cwd passed in as command line argument
2015-11-24 13:06:05 +06:00
Rob Simpson
2f72cd4b7d Adding contributing link to CONTRIBUTING.md
We now have a section in the wiki for contributors so I added a link to this until all of it can be merged together.
2015-11-24 00:10:47 -05:00
Ryan Temple
50bfd14968 updated to respect the bowerrc in the cwd passed in as command line argument 2015-11-23 22:45:45 +00:00
Adam Stankiewicz
2ff53fc448 Merge pull request #2027 from watilde/patch/supports-tilde
Supports ~/ paths to cwd field in .bowerrc
2015-11-21 16:32:52 +01:00
Daijiro Wachi
42cd2e584f Update npm-shrinkwrap.json to add untildify 2015-11-19 23:46:22 +01:00
Daijiro Wachi
49de3cca62 Add a test case to support ~/ paths to cwd field 2015-11-19 23:31:22 +01:00
Daijiro Wachi
718db0309f Supports ~/ paths to cwd field in .bowerrc
+ Add untildify module
+ Update config.js to convert tilde path to home path

Fixes #1784
2015-11-19 21:36:28 +01:00
Adam Stankiewicz
d867095f50 Merge pull request #34 from kevcenteno/bowerrc-dir-error
Show error if .bowerrc is a directory
2015-11-19 18:17:24 +01:00
kevcenteno
e51bf20e72 Show error if .bowerrc is a directory 2015-11-19 10:35:22 -05:00
Adam Stankiewicz
89286e628b Update to fixed version of fs-write-stream-atomic 2015-11-18 15:06:46 +01:00
Adam Stankiewicz
c8042b4781 Fix tests on node 0.10 by updating nock 2015-11-18 14:50:00 +01:00
Adriaan Thomas
15f8a30cd4 Also load custom CA file for "default" 2015-11-17 13:31:40 +01:00
Adam Stankiewicz
9fdd96c92b Update fs-write-stream-atomic to fork with timing fix
It turned out that removing files synchronously on windows can cause
issues. This commit makes Appveyor build for Windows little better.
2015-11-17 12:13:26 +01:00
Adam Stankiewicz
ce15df27ca Properly destroy read stream for downloads 2015-11-17 12:13:26 +01:00
Rob Simpson
468657bfe2 bug report link fix on readme 2015-11-16 21:27:54 -05:00
Rob Simpson
814180d129 update bug report link to point to wiki 2015-11-16 21:25:48 -05:00
Rob Simpson
93be2fef6d Update README.md 2015-11-16 16:08:04 -05:00
Rob Simpson
3ab71f27ff Update README.md 2015-11-16 16:06:11 -05:00
Adam Stankiewicz
38fa1b6858 Downgrade spawn-sync to 1.0.13 (windows build) 2015-11-15 13:18:33 +01:00
Adam Stankiewicz
c6ed215260 Re-order scripts for appveyor build 2015-11-15 13:15:05 +01:00
Adam Stankiewicz
74eba8d2e8 Move spawn-sync back to devDependencies... 2015-11-15 13:14:28 +01:00
Adam Stankiewicz
5a72dae2c8 Build on both node 0.10 and 0.12 on appveyor 2015-11-15 13:10:10 +01:00
Adam Stankiewicz
6194821643 Skip installing npm and svn for appveyor 2015-11-15 13:06:16 +01:00
Adam Stankiewicz
37aab9c72e Downgrade spawn-sync for appveyor 2015-11-15 13:01:24 +01:00
Adam Stankiewicz
0a0dc8cef9 Update spawn-sync to fix appveyor tests 2015-11-15 12:51:41 +01:00
Adam Stankiewicz
c6d89b79b4 Remove npm-shrinkwrap from devDependencies (issues with npm@3.x) 2015-11-15 12:02:39 +01:00
Adam Stankiewicz
8a435dff27 Update to newest npm in appveyor builds 2015-11-15 11:51:45 +01:00
Michael Robinson
459925eba7 Merge pull request #1972 from pwielgolaski/#1958
fix passing options to request
2015-11-15 22:22:12 +13:00
Adam Stankiewicz
6614a43658 Bump to 1.6.5 2015-11-14 15:56:13 +01:00
Adam Stankiewicz
88fd65ae34 Merge pull request #1988 from faceleg/travis-node-versions
Run travis tests in all versions of node
2015-11-14 15:52:47 +01:00
Adam Stankiewicz
83da088024 Update CONTRIBUTING.md 2015-11-14 15:39:41 +01:00
Piotr Wielgolaski
51a986d0d4 add test for download.js and fix download behavior to not leave temporary files in case of error 2015-11-07 18:26:48 +01:00
Michael Robinson
0aefe8fc0e Be more specific with node version 5 2015-11-05 10:47:39 +13:00
Michael Robinson
2845984169 Use environment vars for node versions because OS X 2015-11-05 10:47:24 +13:00
Michael Robinson
2a91dc5fb1 Updated travis tests to run in supported node versions 2015-11-05 10:43:02 +13:00
Michael Robinson
5eca9274ee Added language to travis.yml 2015-11-05 10:40:44 +13:00
Michael Robinson
d57d81ca85 Run travis tests in all versions of node 2015-11-05 10:38:15 +13:00
Adam Stankiewicz
a5dcf9cc24 Merge pull request #1973 from gronke/remove-insecure-suggestion-from-readme
remove hint to use --allow-root flag from readme
2015-10-26 10:30:59 +01:00
Stefan Grönke
484c8985ed remove hint to use --allow-root flag from readme 2015-10-26 01:14:09 +01:00
Piotr Wielgolaski
931b0a8905 fix passing options to request
options from download need to be pass to request library that make HTTP
request

Also when there is http error stream need to be closed otherwise there
is issue reported that unlink operation is not permitted on Windows
2015-10-24 16:52:22 +02:00
Adam Stankiewicz
bfd1e93325 Install stable version on npm on appveyor 2015-10-24 12:01:59 +02:00
Adam Stankiewicz
bf23751549 Bump to 1.6.4 2015-10-24 11:51:50 +02:00
Adam Stankiewicz
b79034fbb9 Merge pull request #1956 from bower/strip-trailing-slash
strip trailing slash in urlResolver
2015-10-24 11:09:32 +02:00
Adam Stankiewicz
eaa05ac6c1 Merge pull request #1960 from bower/add-user-agent
add User-Agent to downloadd
2015-10-24 11:08:31 +02:00
Adam Stankiewicz
8f0a3d727e Merge pull request #1969 from chrisjons/svn_improvements
use --non-interactive when running svn client
2015-10-24 10:41:21 +02:00
Adam Stankiewicz
b6a524e6b4 Merge pull request #1970 from twalpole/ignore2
fix issue #1962 - ignoredDependenices multiple install run
2015-10-24 10:39:20 +02:00
Thomas Walpole
43d00deb88 fix issue #1962 - ignoredDependenices multiple install run 2015-10-23 11:52:40 -07:00
Christian Jönsson
4836a0cae9 use --non-interactive when running svn client
If there is a problem in connecting to the Subversion server,
e.g. credential or certificate related, the CLI client will pause to
ask the user for input on the console. This is not handled by bower
Subversion Resolver, causing the install process to hang forever
with no message printed to the bower user.

Running the Subversion CLI client with the option --non-interactive
will instead cause the client to exit upon such an error.This is
detected by the bower resolver and the message printed to the user,
making it much easier to investigate and solve the underlying problem.
2015-10-23 13:05:16 +02:00
Adam Stankiewicz
302c4ade51 Leave link only to Support Declaration 2015-10-22 12:19:42 +02:00
Adam Stankiewicz
75d80e014a Mention about Support Declaration and BountySource 2015-10-22 12:15:50 +02:00
Patrick Kettner
0f790f4293 add User-Agent to downloadd 2015-10-20 13:51:50 -07:00
Patrick Kettner
452217e9fa strip trailing slash in urlResolver 2015-10-17 21:48:10 -05:00
Adam Stankiewicz
f66c0cfe5c Update npm to 2.0.0 on travis 2015-10-16 12:05:36 +02:00
Adam Stankiewicz
30898c13d3 Update changelog 2015-10-16 12:01:25 +02:00
Adam Stankiewicz
2330d59ffa Bump to 1.6.3 2015-10-16 11:49:04 +02:00
Adam Stankiewicz
1316be57dc Update bower-config to 1.2.2 2015-10-16 11:46:51 +02:00
Adam Stankiewicz
b7c19695e7 Bump to 1.2.2 2015-10-16 11:38:06 +02:00
Adam Stankiewicz
b85cf2683c Fix registry configuration expanding, closes bower/bower#1950 2015-10-16 11:37:41 +02:00
Adam Stankiewicz
ff0f2a8f83 Use stat instead of lstat for checking if something is directory, fixes #1951 2015-10-16 11:17:03 +02:00
Adam Stankiewicz
7e5184d342 Merge pull request #1954 from scottaddie/master
Replace README file msysgit references with Git for Windows
2015-10-16 11:05:35 +02:00
Scott Addie
8fa1fd55e9 Replace README file msysgit references with Git for Windows 2015-10-15 22:18:30 -05:00
Adam Stankiewicz
52463dea09 Bump and update npm-shrinkwrap.json for bower 1.6.2 2015-10-15 16:15:51 +02:00
Adam Stankiewicz
8cf09f5444 Revert "Bump to 1.6.1 and update npm-shrinkwrap.json"
This reverts commit 20a6190ed8.
2015-10-15 16:12:42 +02:00
Adam Stankiewicz
20a6190ed8 Bump to 1.6.1 and update npm-shrinkwrap.json 2015-10-15 15:56:23 +02:00
Adam Stankiewicz
402a9f3017 Add node-uuid back to npm-shrinkwrap 2015-10-15 14:10:25 +02:00
Adam Stankiewicz
af09872fba Set default bower.config again 2015-10-15 13:50:36 +02:00
Adam Stankiewicz
2311d7dc44 Update npm-shrinkwrap.json with npm-shrinkwrap tool 2015-10-15 13:29:56 +02:00
Adam Stankiewicz
b261bf8a76 Update npm-shrinkwrap.json for bower 1.6.0 2015-10-15 13:13:21 +02:00
Adam Stankiewicz
140c6d963f Update changelog and bump 2015-10-15 13:03:30 +02:00
Adam Stankiewicz
0c5e457359 Merge pull request #1948 from bower/feature/bundle
Shrinkwrap all dependencies and add them to bundledDependencies
2015-10-15 13:01:13 +02:00
Adam Stankiewicz
bfa4295606 Try to use container-based infrastructure on Travis 2015-10-15 12:53:18 +02:00
Adam Stankiewicz
8ac68ede5d Shrinkwrap all dependencies and add them to bundledDependencies 2015-10-15 12:45:38 +02:00
Adam Stankiewicz
a019f887e9 Update chmodr to fix chmod behavior on windows 2015-10-15 11:14:49 +02:00
Adam Stankiewicz
eba2c69308 Update bower-config to fix proxy behavior on windows 2015-10-15 11:14:35 +02:00
Adam Stankiewicz
8df5970300 Bump to 1.2.1 2015-10-14 21:30:26 +02:00
Adam Stankiewicz
db265d471f fix: Setting HTTP_PROXY on Windows (case insensitivity) 2015-10-14 21:30:09 +02:00
Adam Stankiewicz
0bb1536c99 Better manage file handles, properly close streams 2015-10-14 19:31:53 +02:00
Adam Stankiewicz
64eb7d598a Use lstat instead of stat for rimraf util 2015-10-14 17:24:54 +02:00
Adam Stankiewicz
df8e5a16be Fix readdir call on Windows
Sometimes it return ENOENT instead of ENODIR for normal files.

This broke code paths in few places. Also, see:
https://github.com/isaacs/chmodr/pull/8
2015-10-14 16:09:38 +02:00
Adam Stankiewicz
3ce2dd3989 Replace all fs with graceful-fs 2015-10-14 14:31:13 +02:00
Adam Stankiewicz
99105fbb57 Try chmod 777 + rimraf as fallback on rimraf in all places 2015-10-14 12:50:41 +02:00
Adam Stankiewicz
96f1e98859 test: Fix url for js-event-emitter 2015-10-13 17:56:42 +02:00
Adam Stankiewicz
d614b057c9 fix: Set environment variable as string, not number 2015-10-13 17:27:27 +02:00
Adam Stankiewicz
aafe02f3e9 Update bower-registry-client and bower-config 2015-09-28 19:42:35 +02:00
Adam Stankiewicz
0441e16bdb Bump to 1.2.0 2015-09-28 19:37:58 +02:00
Adam Stankiewicz
30a489535e Prevent defaulting cwd to process.cwd() 2015-09-28 19:37:44 +02:00
Adam Stankiewicz
ac88ece259 Bump to 1.0.0 2015-09-28 19:15:26 +02:00
Adam Stankiewicz
9b45c76744 Change ~ ranges to ^ 2015-09-28 19:14:58 +02:00
Adam Stankiewicz
059a5f83b7 Require using explicitly bower-config 2015-09-28 19:14:58 +02:00
Adam Stankiewicz
cf5cd61995 Pass proxy configuration via env variables instead of directly, closes #22 2015-09-28 19:14:58 +02:00
Adam Stankiewicz
a499cc5103 Update bower.json dependency 2015-09-28 19:14:58 +02:00
Adam Stankiewicz
123779bbd1 Remove client-side check for register command, closes bower/registry#23 2015-09-28 18:01:46 +02:00
Adam Stankiewicz
5365c7b428 Disable client-side check for registering git:// endpoints 2015-09-28 17:46:58 +02:00
Adam Stankiewicz
da961a9c42 Pass proxy configuration to request.js via env variables 2015-09-28 17:34:06 +02:00
de Winter, Anton
8ff0e0e2d1 Components that are not installed by bower should be left alone
Rework of commit by @wibblymat for PR #1363
Make compatible with existing tests
Uses fs.readdirSync() (once!) instead of async method.
Added new test
2015-09-28 17:18:36 +02:00
Adam Stankiewicz
ffde6bd228 Remove version generation from "bower init" command, closes #1343 2015-09-28 17:07:29 +02:00
Adam Stankiewicz
bebb4fb33b Fix one more upper case spelling 2015-09-27 19:46:43 +02:00
Adam Stankiewicz
2c243ea5b7 tests: Fix camel casing 2015-09-27 19:42:16 +02:00
JD Isaacks
498fe84b99 Use values from package.json as defaults if exists 2015-09-27 19:39:46 +02:00
Adam Stankiewicz
9b8b66ed83 Merge pull request #1838 from yasinkocak/patch-1
Added keywords tag
2015-09-27 18:22:51 +02:00
Adam Stankiewicz
9cc3dd4c92 Pass certificate for GitHubResolver and UrlResolver, closes #1869 2015-09-27 18:18:11 +02:00
Adam Stankiewicz
bf23d81c9e Update bower-config and fix tests for ignoreDependenies 2015-09-27 18:18:11 +02:00
Adam Stankiewicz
f53100d8d3 Bump version to 1.1.2 2015-09-27 17:08:55 +02:00
Adam Stankiewicz
acbe60cdf1 Perform only camelcase normalization before merging configs 2015-09-27 17:08:42 +02:00
Adam Stankiewicz
4c7f37e0f8 Bump to 1.1.1 2015-09-27 16:41:44 +02:00
Adam Stankiewicz
3ba696937c Merge extra config after normalisation 2015-09-27 16:41:32 +02:00
Adam Stankiewicz
1647994471 Bump to 1.1.0 2015-09-27 16:35:01 +02:00
Adam Stankiewicz
674e09dc56 Allow for overwriting options 2015-09-27 16:34:51 +02:00
Adam Stankiewicz
4c129d470f Bump to 1.0.1 2015-09-27 15:03:33 +02:00
Adam Stankiewicz
c630f01baa Update dependencies 2015-09-27 15:02:48 +02:00
Adam Stankiewicz
6018fc13b2 Bump version to 1.0.0 2015-09-27 14:45:53 +02:00
Adam Stankiewicz
c4fc6cd0e2 Typo in readme 2015-09-27 14:41:54 +02:00
Adam Stankiewicz
eed8735238 Fix formatting in the readme 2015-09-27 14:41:17 +02:00
Adam Stankiewicz
8c0155e8bd Normalize config right away in load method 2015-09-27 14:33:22 +02:00
Adam Stankiewicz
b2d4412e59 Remove unused methods and better document .restore method 2015-09-27 14:14:35 +02:00
John Andersen
4e3e45a88b Support for setting and restoring proxy related env variables 2015-09-27 14:05:17 +02:00
Adam Stankiewicz
af9b386d8a Suport backward-compatible ca certificate embedding 2015-09-27 13:34:17 +02:00
Adriaan Thomas
201b8a3bc6 Load CA file contents instead of keeping the path, so the request library can use it. 2015-09-27 13:34:17 +02:00
Adam Stankiewicz
6e1a994c26 Merge pull request #1922 from pwang2/feature/allow-resolver-passed-via-cli
allow --config.resolvers={required package}
2015-09-27 12:31:37 +02:00
Thomas Walpole
2ccc05cb98 get ignoredDependencies from .bowerrc instead of bower.json 2015-09-27 12:27:39 +02:00
Thomas Walpole
e7d22ffb11 install and update tests for ignoredDependencies 2015-09-27 12:27:39 +02:00
SignalDancer
4805c3615b Allow Ignore For Child Dependencies
Fix for bug #927. Ignore package if name matches specified in bower.json.
Permit fetch if package is explicitly declared in dependencies or devDependencies.
Designed for users who need tighter control of versions due to corporate liscence restrictions or other reasons.

Code Review Comments
2015-09-27 12:27:38 +02:00
Adam Stankiewicz
44a5260050 test: Clear analytics config for test environment 2015-09-27 12:22:40 +02:00
Adam Stankiewicz
d72d01823d Bump inquirer to 0.10, closes #1883 2015-09-27 12:03:25 +02:00
Adam Stankiewicz
1e166189ba Merge pull request #1917 from lukemelia/improve-version-failure-message
Include package name in error info when a version is not found.
2015-09-24 14:17:13 +02:00
Adam Stankiewicz
66310523d1 Bump to 1.5.3 2015-09-24 13:58:05 +02:00
Adam Stankiewicz
87a041a212 Fix --save-exact feature for github endpoints, fixes #1925 2015-09-24 13:34:49 +02:00
Adam Stankiewicz
9c52ec2751 Revert "Auto-sort bower.json dependencies alphabetically, fixes #1373"
This reverts commit 9dd79a8061.
2015-09-24 11:06:55 +02:00
Adam Stankiewicz
9010269236 Merge pull request #1923 from mex/feature/insight-prompt
Bumps Insight to reduce prompt friction
2015-09-18 12:11:36 +02:00
Michael Storgaard
aac254d275 Bumped Insight to reduce prompt friction
- Insight now checks for `process.env.CI` before prompting
 - Insight now times out after 30 seconds of no response to prompt
2015-09-18 11:18:08 +02:00
Peng Wang
889b54f309 allow --config.resolvers={required package} 2015-09-17 16:25:05 -05:00
Luke Melia
5d13ffda09 Include package name in error info when a version is not found.
Prior to this commit, when specifying a package version that cannot
be resolved, but other versions are available, the error message
did not state which what package failed, allowing for confusion.

For example, you might see:

```
bower ENORESTARGET  No tag found that was able to satisfy 1.0.2

Additional error details:
Available versions: 1.0.1, 1.0.0
```

After this change, in the above situation the svn and git resolvers
will produce the following:

```
bower ENORESTARGET  No tag found that was able to satisfy 1.0.2

Additional error details:
Available versions in somelib: 1.0.1, 1.0.0
```
2015-09-12 21:10:01 -04:00
Adam Stankiewicz
31b6d5971c Merge pull request #1819 from bak/init_private
Allow boolean values in bower.json file created by `bower init`
2015-09-11 22:55:52 +02:00
Ben Cullen-Kerney
304b6393d4 Allow whitelisted values in bower.json file created by bower init
A change in the behavior of `mout.lang.isEmpty()` in Mout v0.10.0
introduced a bug in `bower init`, preventing it from including Boolean
values in "bower.json".

This commit explicitly whitelists the types that are used in the
bower.json spec - Object, Array, String, Boolean - as well as Number for
future compatibility.
2015-09-11 12:40:20 -07:00
Sindre Sorhus
490f63a838 modularize the MD5 util function 2015-09-03 11:00:38 +07:00
Adam Stankiewicz
64d990ba10 Add changelog for 1.5.2 2015-08-25 22:37:23 +02:00
Adam Stankiewicz
cb019c405b Bump version to 1.5.2 2015-08-25 22:31:13 +02:00
Adam Stankiewicz
26f80d25be Put smart host detection behind a configuration, fixes #1764 2015-08-25 22:26:26 +02:00
Adam Stankiewicz
fe9a1bb5fc Revert "upgrade to newer semver, fixes #1817,#1845,#1851"
This reverts commit 8744449016.
2015-08-25 17:12:51 +02:00
Adam Stankiewicz
79679f9b08 Revert "Make bower commands work from subdirectories"
This reverts commit 7acafc26d6.
2015-08-25 17:11:48 +02:00
Adam Stankiewicz
5ef5403d69 Update changelog 2015-08-25 11:20:57 +02:00
David DeSandro
a23f66d889 Merge pull request #27 from cvrebert/patch-1
0.6.0
2015-07-22 15:31:40 -04:00
Chris Rebert
a1596bb63c 0.6.0 2015-07-13 19:17:20 -07:00
David DeSandro
19af145166 Merge pull request #25 from cvrebert/normalize
Remove non-spec-compliant comma-separated string interpretation of main
2015-07-01 14:14:15 -04:00
David DeSandro
4ed81be0c6 Merge pull request #26 from cvrebert/validate-main
Validate that `main` conforms to the bower.json spec
2015-07-01 08:55:23 -04:00
Chris Rebert
1c62adcdb6 Validate that main conforms to the bower.json spec 2015-06-30 23:16:00 -07:00
Chris Rebert
95f46930a5 Remove non-spec-compliant comma-separated string interpretation of main
See https://github.com/bower/bower.json-spec/#main
2015-06-30 23:04:13 -07:00
Web Artisan
50b0186c06 Added keywords tag
Added keywords tag
2015-06-30 11:40:05 +02:00
Adam Stankiewicz
76dd504589 Merge pull request #27 from pdehaan/patch-1
Update license attribute
2015-05-21 12:31:51 +02:00
Peter deHaan
938c69c816 Update license attribute
specifying the type and URL is deprecated:

https://docs.npmjs.com/files/package.json#license
http://npm1k.org/
2015-05-20 16:57:57 -07:00
Sindre Sorhus
d5fc402a89 0.5.0 2015-05-19 22:07:12 +02:00
Sindre Sorhus
065a7a1f1b bump deps 2015-05-19 22:06:59 +02:00
Sindre Sorhus
ccadffea73 Update package.json 2015-04-28 12:54:04 +07:00
Sindre Sorhus
b3390ce201 use package.json files object to reduce the package size
https://docs.npmjs.com/files/package.json#files
2015-04-28 12:50:37 +07:00
Sindre Sorhus
6039f6c691 minor package.json tweak 2015-04-28 12:50:10 +07:00
Sindre Sorhus
c65cdc8699 use package.json files object to reduce the package size
https://docs.npmjs.com/files/package.json#files
2015-04-28 12:42:26 +07:00
Sindre Sorhus
7603886e04 minor package.json tweak 2015-04-28 12:41:43 +07:00
Sindre Sorhus
406a96e4d1 use package.json files object to reduce the package size
https://docs.npmjs.com/files/package.json#files
2015-04-28 12:40:35 +07:00
Adam Stankiewicz
7d74d7d8f6 0.3.0 2015-04-01 00:24:38 -07:00
Adam Stankiewicz
e98d8139bc Bump bower-config version (bower/config#25) 2015-04-01 00:24:22 -07:00
Adam Stankiewicz
8a47aab01d Bump to 0.6.1 2015-03-31 22:27:07 -07:00
Adam Stankiewicz
395b208a0c Merge all .bowerrc upwards directory tree, fixes #25 2015-03-31 22:26:39 -07:00
Adam Stankiewicz
f6178c2f75 Bump to 0.6.0 2015-03-30 01:19:35 -07:00
Adam Stankiewicz
f1e04e5629 Merge branch 'kodypeterson-fixes-bower/bower/1689'
Conflicts:
	test/test.js
2015-03-30 01:15:56 -07:00
Adam Stankiewicz
cc913a728a Merge pull request #23 from zanona/npm-config
Allow NPM config variables. Resolve bower/bower#1711
2015-03-30 01:14:02 -07:00
Kody Peterson
f8c179b153 Cleanup 2015-03-27 11:05:41 -04:00
Kody Peterson
bea46fb879 Children should be source 2015-03-26 14:32:35 -04:00
Kody Peterson
379de05a61 Correct the logic 2015-03-26 14:25:42 -04:00
Kody Peterson
c2f222760a Fixes https://github.com/bower/bower/issues/1689 and actually adds tests and testing ability 2015-03-25 13:42:44 -04:00
Marcus Zanona
9aef3b7f1d Allow NPM config variables. Resolve bower/bower#1711 2015-03-12 17:42:32 +00:00
Adam Stankiewicz
c93bbbd302 Bump to 0.2.4 2015-03-04 22:38:12 -08:00
Adam Stankiewicz
009e5ce0c8 Better error messages for unregistering 2015-03-04 22:25:46 -08:00
Adam Stankiewicz
61bb4f53c0 Increase timeout for test 2015-03-04 22:25:46 -08:00
Sindre Sorhus
b6dd5e445e minor tweaks 2015-02-08 21:12:31 +07:00
Sindre Sorhus
6f4b77a440 Update .travis.yml 2015-02-08 20:47:09 +07:00
Sindre Sorhus
463584ea10 Update .travis.yml 2015-02-08 20:46:55 +07:00
Sindre Sorhus
fd8d603831 Update .travis.yml 2015-02-08 20:45:29 +07:00
Sindre Sorhus
a1ec83b002 0.2.3 2015-01-22 17:43:09 +08:00
Sindre Sorhus
041d3f2843 minor tweaks 2015-01-22 17:23:36 +08:00
Sindre Sorhus
0b22127906 Merge pull request #19 from tchajed/duplicate-package-error
Change duplicate package status code to 403
2015-01-22 16:46:52 +08:00
Sindre Sorhus
0b0b507827 Merge pull request #20 from masakura/fix-node11-proxy-failed
Fix error bower command behind proxy.
2015-01-22 16:45:12 +08:00
Tomo Masakura
16de289942 Fix error bower command behind proxy. 2015-01-21 13:57:28 +09:00
patrick kettner
02dc97e413 Merge pull request #18 from tmcw/error-message
Adds an error message to errors. Fixes #16
2015-01-13 10:43:04 -08:00
Adam Stankiewicz
703eae72eb Bump to 0.2.2 2015-01-05 01:50:06 +01:00
Adam Stankiewicz
6a629e963c fix: Duplicate package has now 403 error code
According to change in bower/registry#74ae4d34b68df239b8db876a4f871b100ef3c540
2015-01-05 01:47:00 +01:00
Tej Chajed
f242e60c1a Change duplicate package status code to 403
Registry no longer sends 406 so clients would previously just see
"Unknown error: 403 if they tried to register a duplicate package.
2014-11-01 09:08:58 -04:00
Ray Shan
6d335abe21 Merge pull request #21 from bower/fix/appdata
Use local appdata for cache, fixes bower/bower#1536
2014-09-23 09:58:17 -07:00
Adam Stankiewicz
179b8a28b4 Use local appdata for cache, fixes bower/bower#1536 2014-09-23 16:43:22 +02:00
Tom MacWright
fc13328e2a Adds an error message to errors. Fixes #16
This could be better if it could distinguish between server errors
and actually unknown errors (known unknowns), but that would require
the server to provide JSON errors.
2014-08-19 12:30:04 -04:00
Ray Shan
b3f28fac64 Update README.md 2014-08-12 11:08:42 -07:00
Ray Shan
f65af7a308 Update README.md 2014-08-12 11:06:53 -07:00
Ray Shan
559f50a3e3 Merge pull request #3 from ncthis/patch-1
Fixing minor syntax errors
2014-08-12 11:05:27 -07:00
Sindre Sorhus
18b809314c Update README.md 2014-08-12 11:06:11 +02:00
Sindre Sorhus
aa1f819c0d Merge pull request #20 from rayshan/patch-1
Update README.md w/ npm instructions
2014-08-12 11:04:43 +02:00
Ray Shan
5a8cecf499 Update README.md 2014-08-11 17:56:54 -07:00
Adam Stankiewicz
79f362abee Merge pull request #21 from bower/docs_npm
Update README.md
2014-08-12 00:08:17 +02:00
Ray Shan
42db74b522 Update README.md 2014-08-11 15:03:34 -07:00
Adam Stankiewicz
3309e9f53f Merge pull request #19 from stephanebachelier/patch-1
fix typo in README
2014-08-08 17:02:10 +02:00
Stéphane Bachelier
ae3a017143 fix typo in README 2014-08-08 16:59:47 +02:00
Adam Stankiewicz
43d7a11ba8 Bump version to 0.2.2 2014-06-20 23:01:20 +02:00
Adam Stankiewicz
02e12e17d6 Prepend # to ambiguous branch name, fixes bower/bower#1308 2014-06-20 23:00:14 +02:00
Adam Stankiewicz
4f838685d6 Bump to 0.5.2 2014-06-09 03:28:08 +02:00
Adam Stankiewicz
6339ba09f0 "Merge pull request #18 from mdasberg/master\n\nFix for Overriding .bowerrc with a relative tmp path that breaks downloading of bower modules with ignores" 2014-06-09 03:26:33 +02:00
Sindre Sorhus
23c2e82c97 Merge pull request #18 from shinnn/master
Update dependencies and .jshintrc
2014-06-03 11:22:57 +02:00
Shinnosuke Watanabe
7138d3518e Fix CI setting to pass the test against Node v0.8 2014-06-02 17:22:49 +09:00
Shinnosuke Watanabe
f852325906 Update graceful-fs and mocha 2014-06-02 14:43:08 +09:00
Shinnosuke Watanabe
3c9082ece3 Update .jshintrc for JSHint v2.5.x 2014-06-02 14:42:43 +09:00
Adam Stankiewicz
98c77ffe18 Bump to 0.2.1 2014-05-21 14:20:25 +02:00
Mischa Dasberg
b95d5f9f23 moved tmp resolve from load to normalize method 2014-05-21 11:02:19 +02:00
Nadeesha Cabral
adf59d78d7 Fixing minor syntax errors 2014-05-21 12:22:13 +05:30
Adam Stankiewicz
904ae3eab7 Merge pull request #9 from geigerzaehler/update-config-version
Use the same version of bower-config as bower
2014-05-21 02:17:33 +02:00
Adam Stankiewicz
44d2309700 Bump version 2014-05-21 00:17:40 +02:00
Adam Stankiewicz
5dd6a3883a Add info about unimplemented features, closes #11 2014-05-20 23:47:47 +02:00
Mischa Dasberg
5f0a3fe1c1 See: https://github.com/bower/bower/issues/1299 and https://github.com/bower/config/issues/17 2014-05-13 14:25:45 +02:00
Sindre Sorhus
bc3079332c Merge pull request #7 from sheerun/patch-1
perf: Use the same mout version as bower
2014-04-12 23:22:47 +02:00
Sindre Sorhus
3c0395b19f Merge pull request #16 from sheerun/fix/mout
perf: Use only relevant parts of mout
2014-04-12 23:21:41 +02:00
Sindre Sorhus
9e7b591c78 Merge pull request #8 from sheerun/fix/mout
Use only relevant parts of mout
2014-04-12 23:21:18 +02:00
Adam Stankiewicz
b6107a1198 Use only relevant parts of mout 2014-04-12 22:23:12 +02:00
Adam Stankiewicz
2d94018f12 perf: Use only relevant parts of mout 2014-04-12 22:17:56 +02:00
Adam Stankiewicz
42f0268829 perf: Use the same mout version as bower 2014-04-12 22:10:37 +02:00
shinnn
4812c380c4 Add a validation for description length
closes #17
2014-04-05 13:06:09 +02:00
Sven Lito
0e833c155a Merge pull request #10 from wibblymat/unregister
Add 'unregister' feature
2014-04-01 17:32:33 +02:00
Mat Scales
9ebb1b17d1 Added tests and fixed code-style 2014-04-01 15:57:08 +01:00
Mat Scales
3397cf053c Removed a debug line 2014-04-01 15:29:35 +01:00
Mat Scales
6e73b5934e Add 'unregister' feature 2014-04-01 13:26:35 +01:00
Thomas Scholtes
a5c49d89d5 Use tilde to match bower-config version 2014-02-27 00:26:34 +01:00
Thomas Scholtes
1f9a92e6ad Use the same version of bower-config as bower
Make loading this package from bower faster. Used `>=` to specify version so it
doesn't break that fast when bower starts using a version `>=0.6.0`.
2014-02-26 15:38:10 +01:00
Sindre Sorhus
6280611aea Merge pull request #13 from geigerzaehler/master
Use same mout version as bower
2014-02-25 21:51:08 +01:00
Thomas Scholtes
20c0e6e12b Use same mout version as bower
We don't need to load mout twice, which takes a lot of time.
2014-02-25 19:53:50 +01:00
reiz
d3ccc73796 Adding validation for package name
Closes #15
2014-01-31 14:54:40 +01:00
Sven Lito
53d3ac570e Merge pull request #7 from clientlab/master
fix a bug
2013-12-26 07:32:13 -08:00
周培公
237022baae add a test.
add a test 'calling the lookup instance method with two registries, and
the first missing', and adjust the test sequence.
2013-12-26 08:08:29 +08:00
周培公
bccfd7bbbb fix a bug. 2013-12-24 15:03:03 +08:00
Sven Lito
597853cd6c bump version 2013-12-11 10:43:50 +00:00
Sven Lito
1bd6568f94 Merge pull request #6 from xiaojue/master
add headers for request to fix userAgent not work.
2013-12-11 02:39:42 -08:00
xiaojue
4b2235aef2 add userAgent test 2013-12-11 18:32:13 +08:00
xiaojue
faf1c26669 add headers for request to fix userAgent not work. 2013-12-11 15:17:08 +08:00
Mat Scales
c385c08e2f Close GH-2: Add checkbox prompt. 2013-12-06 22:11:00 +00:00
André Cruz
ab7e7ac12a Bump version. 2013-09-28 15:11:01 +01:00
Sven Lito
3788e8d7b3 Merge pull request #5 from bower/md5
Append a truncated hash to prevent case issues in case insensitive fs.
2013-09-28 02:15:53 -07:00
André Cruz
041290e1c7 Append a truncated hash to prevent case issues in case insensitive fs. 2013-09-28 00:54:33 +01:00
André Cruz
1099e786df Bump version. 2013-08-29 19:51:13 +01:00
André Cruz
be95169c1b Add DEFAULT_REGISTRY, #6. 2013-08-29 19:50:46 +01:00
André Cruz
a899cb48b3 Bump version. 2013-08-28 08:21:13 +01:00
André Cruz
ed8ac01f07 Do not crash if home is not set. 2013-08-28 08:20:55 +01:00
André Cruz
12cde3ddce Doc typo. 2013-08-21 18:48:21 +01:00
André Cruz
860d70551f Bump version. 2013-08-21 18:46:05 +01:00
André Cruz
6db6fcc414 Small tweaks to last PR. 2013-08-21 18:45:46 +01:00
André Cruz
25c229de73 Merge pull request #9 from alexwhitman/nested-env-vars
Allow nested environment variables using '__'
2013-08-21 10:26:31 -07:00
Alex Whitman
d954a54017 Handle nesting in environment variables
Nested configuration variables can now be specified by environment
variable. Levels are split by '__' (double underscore). Single
underscores are converted to '-'.

`bower_foo__bar-baz` -> `foo.bar-baz`
2013-08-21 11:41:46 +01:00
André Cruz
78bbf1f04f Bump version. 2013-08-20 21:48:55 +01:00
André Cruz
52938202bd Fix target not being added if source does not look like a source. 2013-08-20 21:48:26 +01:00
André Cruz
0f29818030 Bump version. 2013-08-20 01:03:01 +01:00
André Cruz
dd39a25dd0 Update deps. 2013-08-20 01:02:39 +01:00
André Cruz
6ed4be9135 Merge branch 'master' of github.com:bower/logger 2013-08-20 00:42:32 +01:00
André Cruz
02b6a21276 Bump version. 2013-08-20 00:42:17 +01:00
André Cruz
794ca573b8 Trim answers automatically. 2013-08-20 00:41:15 +01:00
André Cruz
032f771996 Simplify. 2013-08-19 09:01:45 +01:00
Andre Cruz
3dfd7a9ab1 Bump version. 2013-08-19 00:57:39 +01:00
Andre Cruz
1713e5e2eb Minor improvement in argv.config parsing. 2013-08-19 00:57:30 +01:00
Andre Cruz
1d7342573b Bump version. 2013-08-19 00:43:41 +01:00
Andre Cruz
64fc295ecc Add prompt(). 2013-08-19 00:43:17 +01:00
Andre Cruz
6b6dc8311a Bump version. 2013-08-18 17:29:00 +01:00
Andre Cruz
b1d8c3c1e3 Interactive is now set to auto (null). 2013-08-18 17:28:35 +01:00
Andre Cruz
71037cb482 Bump version. 2013-08-18 13:08:43 +01:00
Andre Cruz
1f4e5cadd2 Generate a fake user instead of using 'unknown'. 2013-08-18 13:08:15 +01:00
André Cruz
0de9cc82f6 Bump version. 2013-08-16 09:43:39 +01:00
André Cruz
7dba46df9b Temp folder is now suffixed with the user and "bower". 2013-08-16 09:30:40 +01:00
André Cruz
9cb09feb65 Bump version. 2013-08-14 09:10:24 +01:00
André Cruz
fb084fa4cd Cast buffer to string. 2013-08-14 09:10:08 +01:00
André Cruz
846b8fb57e Bump version 2013-08-14 08:36:54 +01:00
Salehen Shovon Rahman
cb649830a0 Close GH-7: Empty .bowerrc files should not throw an error.. 2013-08-14 08:35:00 +01:00
André Cruz
89510f40d3 Bump version. 2013-08-11 18:24:25 +01:00
André Cruz
9f2207eb1f Change git folder to empty (was not being used anyway). 2013-08-11 18:24:13 +01:00
André Cruz
dfb18b305d Bump version. 2013-08-11 14:46:33 +01:00
André Cruz
1606395546 Close GH-12: Ignore component(1) files.. 2013-08-11 14:45:55 +01:00
André Cruz
8dbd79d49b Bump version. 2013-08-07 08:29:40 +01:00
André Cruz
e2c67fa25a Use a known user agent by default when a proxy. 2013-08-07 08:28:50 +01:00
André Cruz
cf85177c7f DRY. 2013-08-06 09:12:13 +01:00
André Cruz
bc4a0f448b Bump version. 2013-08-06 00:02:54 +01:00
André Cruz
14ef86456f Typo. 2013-08-06 00:02:31 +01:00
André Cruz
12efc85baf Bump version. 2013-08-05 23:40:52 +01:00
André Cruz
68124dfdbe Bum version. 2013-08-05 23:39:15 +01:00
André Cruz
ee4158e90b Append the username when using the temporary folder. 2013-08-05 23:38:19 +01:00
André Cruz
0b3b7efccf Minor improvement. 2013-08-05 23:36:11 +01:00
André Cruz
6064269936 Bump version. 2013-08-05 14:22:51 +01:00
André Cruz
d0929896cf Update README. 2013-08-05 14:22:41 +01:00
André Cruz
990e87de1f Tweaks to the last PR. 2013-08-05 14:16:53 +01:00
Nick Heiner
8da47dcd00 Close GH-10: Find .bower.json if it exists. 2013-08-05 14:10:57 +01:00
André Cruz
c63d88d987 Bump version. 2013-08-03 12:44:18 +01:00
André Cruz
c21bde192b Fix failing test. 2013-08-03 12:44:07 +01:00
André Cruz
39f1f8aff5 Improve retry error messages.
Also fixed "undefined" being printed as the url.
2013-08-03 12:38:21 +01:00
André Cruz
8b699c58ae Bump rc version. 2013-08-02 21:12:54 +01:00
André Cruz
743a97c784 Merge branch 'master' of github.com:bower/config 2013-08-02 21:10:39 +01:00
André Cruz
ea7ae5698a Do not set undefined values in array. 2013-08-02 21:10:31 +01:00
André Cruz
3ed9b3ec39 Fix default values being mutated. 2013-08-02 21:10:10 +01:00
André Cruz
e8f3e3b88a Set timeout default value to 30sec. 2013-08-02 21:09:54 +01:00
André Cruz
82d16fbfde Change timeout to 30sec. 2013-08-02 08:25:35 +01:00
André Cruz
766dcd0dd5 Bump version. 2013-07-29 23:14:27 +01:00
André Cruz
87302d6d86 Merge pull request #3 from bower/trim
Add trim to everything.
2013-07-29 15:11:07 -07:00
André Cruz
05b94d1d15 Add more tests and fix stuff. 2013-07-28 18:54:04 +01:00
André Cruz
ed0c93aec3 Add trim to everything. 2013-07-28 18:21:24 +01:00
André Cruz
03b4467173 Update deps. 2013-07-28 03:20:46 +01:00
André Cruz
f027cc6a3e Bump version. 2013-07-28 03:03:56 +01:00
André Cruz
634ce6829a Use bower-config to normalise the config object. 2013-07-28 03:03:39 +01:00
André Cruz
64b5f9af78 Bump to 0.2.0 rc1. 2013-07-28 02:58:08 +01:00
André Cruz
9269fcb8a7 Add normalisation, fixes #5.
Refactor a lot of code.
2013-07-28 02:57:24 +01:00
André Cruz
f0d29cb755 Bump to 0.1.0. 2013-07-27 22:30:51 +01:00
André Cruz
897e0f1ba6 Bump to 0.1.0. 2013-07-27 22:28:56 +01:00
André Cruz
4cfa94d304 Bump to 0.2.0. 2013-07-27 22:26:17 +01:00
André Cruz
5e2abb8a33 Add .file property to errors throw in read(). 2013-07-27 22:21:21 +01:00
Sven Lito
0dc5052e36 Close GH-9: adds grunt. 2013-07-27 20:44:16 +01:00
Sven Lito
774ad1e2ff remove inline jshint rule
this setting is covered by local node:true setting
2013-07-27 20:43:33 +01:00
Sven Lito
52e91cc309 Merge pull request #8 from bower/better-api
Changes to the api.
2013-07-27 12:09:12 -07:00
André Cruz
d3e6274939 Remove unused var. 2013-07-27 11:25:38 +01:00
Sven Lito
ec904eb8a4 adds list tests [#4] 2013-07-26 16:02:42 +01:00
André Cruz
95a09c5463 Fix README typos as suggested. 2013-07-25 23:31:33 +01:00
André Cruz
125fb598d5 Adjust README to the api changes. 2013-07-25 22:19:09 +01:00
André Cruz
f8c13f939c Changes to the api.
- Read now accepts directories and finds the bower json to read inside
- Add normalise and validate methods
- Add options to the parse and read methods to enable/disable normalisation and validation.
2013-07-25 22:06:42 +01:00
André Cruz
c846b24ebb Bump rc. 2013-07-24 09:00:53 +01:00
Sven Lito
85324d9109 Merge pull request #3 from bower/lookup-bug
Fix lookup and list bug for multiple registries.
2013-07-24 00:10:36 -07:00
André Cruz
10b410d46f Fix multiple registries in the list method. 2013-07-23 23:20:56 +01:00
André Cruz
c87fe7c265 Fix lookup bug for multiple registries.
Improve and fix tests.
2013-07-23 22:56:17 +01:00
André Cruz
ce0984573b Fix tests. 2013-07-23 22:55:00 +01:00
André Cruz
b38c3a5035 Add missing dep. 2013-07-23 22:51:24 +01:00
André Cruz
15dca65bd1 Set timeout to 60sec. 2013-07-23 22:50:40 +01:00
André Cruz
e1aa43147d Minor tweaks. 2013-07-23 22:49:58 +01:00
André Cruz
057b18e4be Bump to 0.1.0 2013-07-23 21:01:51 +01:00
André Cruz
d4f2ced6a3 Add paths tests, simply with regexp. 2013-07-23 21:01:30 +01:00
André Cruz
0b6c92fcd2 Merge pull request #2 from redking/master
Endpoints with backslashes should be recognized as sources
2013-07-23 12:57:27 -07:00
Sven Lito
4491e71ee2 Merge pull request #2 from neoziro/fix-registry-search
Fix search in multiple registries
2013-07-23 09:07:23 -07:00
Greg Bergé
d09f78801c fix search in multiple registries 2013-07-23 18:00:21 +02:00
Cormac Flynn
f26ea32897 Endpoints with backslashes should be recognized as sources 2013-07-23 15:41:22 +02:00
André Cruz
86dbea7ddb Update reps. 2013-07-20 23:18:09 +01:00
André Cruz
4221ddbb35 Bump rc. 2013-07-20 22:06:34 +01:00
André Cruz
eeb0c22d90 Integrate logger. 2013-07-20 22:05:36 +01:00
André Cruz
eb801e66ae Remove replay from register. 2013-07-20 22:05:07 +01:00
André Cruz
4d0d4ca6ea README typos. 2013-07-20 20:22:30 +01:00
André Cruz
56cdae67c3 Document log levels 2013-07-20 20:21:00 +01:00
André Cruz
b50017cad4 Initial commit. 2013-07-20 20:18:39 +01:00
André Cruz
c85c38cde3 Bump rc version. 2013-07-20 19:49:41 +01:00
André Cruz
f606eda18d Add replay to requests. 2013-07-20 19:49:13 +01:00
André Cruz
08c9e2dde3 CS. 2013-07-20 19:48:42 +01:00
André Cruz
882bf7b020 Bump rc version. 2013-07-18 19:31:52 +01:00
André Cruz
da4e70bc60 Merge branch 'master' of github.com:bower/endpoint-parser 2013-07-18 19:31:02 +01:00
André Cruz
f75f720c8a Merge branch 'master' of github.com:bower/registry-client 2013-07-18 19:30:44 +01:00
André Cruz
8d3aff5ff1 Update editorconfig. 2013-07-18 19:30:27 +01:00
André Cruz
4e8c9078f7 Update editorconfig. 2013-07-18 19:30:13 +01:00
André Cruz
41e4efcf1f Merge branch 'master' of github.com:bower/config 2013-07-18 19:29:38 +01:00
André Cruz
f55e6138a5 Remove git config. 2013-07-18 19:29:30 +01:00
André Cruz
147e24d835 Update editorconfig. 2013-07-18 19:29:22 +01:00
André Cruz
4a94858ed1 Update editorconfig. 2013-07-18 19:29:11 +01:00
André Cruz
12c90bae04 Another README typo. 2013-07-18 08:13:10 +01:00
André Cruz
6f7f10b2f7 Update README.md 2013-07-16 20:03:16 +01:00
André Cruz
430a2ea2f6 Bump rc. 2013-07-16 19:52:46 +01:00
André Cruz
87569617ae Add spec link. 2013-07-16 19:52:32 +01:00
André Cruz
b17beaccf1 Add timeout config. 2013-07-16 19:52:24 +01:00
Sven Lito
cddba64151 call next instead of done 2013-07-16 16:10:07 +01:00
André Cruz
a006bfeb24 Fix git@ endpoints not being interpreted as sources. 2013-07-16 07:09:20 +01:00
André Cruz
71e1a8666d Add tests and made some changes. 2013-07-15 22:29:23 +01:00
André Cruz
16e7872a82 Typo. 2013-07-15 00:42:47 +01:00
André Cruz
aa4ebb07f8 Fix title. 2013-07-15 00:36:56 +01:00
André Cruz
4366d6a8c7 Fix test script, wtf! 2013-07-15 00:35:59 +01:00
André Cruz
aa76d49234 Improve README. 2013-07-15 00:34:38 +01:00
André Cruz
d9df06644e Initial commit. 2013-07-15 00:30:44 +01:00
André Cruz
554ee01263 Force camelCase. 2013-07-15 00:30:27 +01:00
André Cruz
b3055067d8 Force camelCase. 2013-07-15 00:30:18 +01:00
André Cruz
7f997d4b59 Force camelCase. 2013-07-15 00:30:08 +01:00
André Cruz
d2d959f455 Upgrade deps. 2013-07-14 17:21:45 +01:00
André Cruz
a9e497f878 Upgrade deps. 2013-07-14 17:21:29 +01:00
André Cruz
e423e9ffba Upgrade deps. 2013-07-14 17:21:17 +01:00
André Cruz
ff99fae928 Bump rc version. 2013-07-13 23:07:19 +01:00
André Cruz
3c9983ca12 Merge branch 'master' of github.com:bower/registry-client 2013-07-13 22:35:48 +01:00
André Cruz
d3412e7de6 Stupid typos, I was drunk when I did that. 2013-07-13 22:35:23 +01:00
Sven Lito
2841942899 more cache related tests 2013-07-11 10:33:47 +01:00
André Cruz
415e79b523 Bump rc version. 2013-07-10 20:39:30 +01:00
André Cruz
9a6fdaa42b Do not remove invalid files, throw instead. 2013-07-10 20:39:02 +01:00
Sven Lito
0cdbe998cb [tests] adds cache test 2013-07-10 17:14:24 +01:00
Sven Lito
35b0c49da5 clarify cache docs 2013-07-10 15:46:52 +01:00
Sven Lito
d43c9f006b fix module references 2013-07-10 15:01:18 +01:00
Sven Lito
01a6ae61d2 replace chai with expect.js 2013-07-10 14:53:48 +01:00
André Cruz
4b4b233377 Bump rc version. 2013-07-09 23:38:15 +01:00
André Cruz
ccc9907034 Change from bower_new to bower. 2013-07-09 23:36:15 +01:00
André Cruz
26520abe2b Merge branch 'master' of github.com:bower/json 2013-07-09 21:02:08 +01:00
André Cruz
1397c3248d Bump rc version. 2013-07-09 21:01:53 +01:00
André Cruz
c40dc39b88 Merge branch 'master' of github.com:bower/registry-client 2013-07-09 21:01:33 +01:00
André Cruz
a2753bb27d Bump rc version. 2013-07-09 21:01:19 +01:00
André Cruz
1c5529691b Bump rc version. 2013-07-09 21:00:58 +01:00
André Cruz
8e5bdc6b2b BC change. 2013-07-09 21:00:39 +01:00
André Cruz
39324d6b55 Merge pull request #6 from btford/master
Fix typos.
2013-07-08 11:18:57 -07:00
Brian Ford
b1ad187d1b Fix typos. 2013-07-08 11:12:40 -07:00
Sven Lito
606f15fec5 [tests] basic offline check 2013-07-08 14:23:55 +01:00
André Cruz
09a0eb26d1 Improve sentence. 2013-07-07 03:00:18 +01:00
André Cruz
bf9e8048ff Sort deps. 2013-07-07 02:51:55 +01:00
André Cruz
21ebc226e4 Sort deps. 2013-07-07 02:51:04 +01:00
André Cruz
8e3fef9096 Sort deps. 2013-07-07 02:50:47 +01:00
André Cruz
829dccc1b6 Bump rc version. 2013-07-07 02:38:53 +01:00
André Cruz
a65caa62b3 Add name validation. 2013-07-07 02:38:43 +01:00
André Cruz
ddb6f9c5b4 Merge branch 'master' of github.com:bower/config 2013-07-07 02:26:18 +01:00
André Cruz
e152ab6cf2 Use our own rc implementation. 2013-07-07 02:26:06 +01:00
André Cruz
4085af023a Typo. 2013-07-07 02:25:13 +01:00
André Cruz
686e401368 Add del. 2013-07-07 02:24:54 +01:00
André Cruz
2fdfa64b13 Typo. 2013-07-06 22:42:16 +01:00
André Cruz
f406cfcebb Change from toJson to toObject. 2013-07-06 22:40:37 +01:00
André Cruz
80f35725e6 Require relatively. 2013-07-06 22:31:05 +01:00
André Cruz
6741d99681 Fix rc version and update mocha. 2013-07-06 21:56:53 +01:00
André Cruz
ad4ec14778 Add editor config. 2013-07-06 21:55:53 +01:00
André Cruz
2bf16ad88b Fix rc name and update mocha. 2013-07-06 21:55:43 +01:00
André Cruz
6c56581c15 Typo. 2013-07-06 21:55:16 +01:00
André Cruz
ce89d9fbe0 Initial commit. 2013-07-06 21:53:04 +01:00
André Cruz
e298f74310 Improve sentence. 2013-07-06 14:55:43 +01:00
André Cruz
c550c1373e Merge branch 'master' of github.com:bower/registry-client 2013-07-06 14:39:33 +01:00
André Cruz
6a1bb88c3b Update README. 2013-07-06 14:39:24 +01:00
André Cruz
a585e96fdf Improve clear runtime cache. 2013-07-06 14:39:13 +01:00
Sven Lito
e78ef493a1 [tests] don't test for private methods 2013-07-06 14:28:25 +01:00
André Cruz
c139378694 Add comment. 2013-07-06 14:09:11 +01:00
André Cruz
d0eb3e760f Bump rc version. 2013-07-06 13:55:59 +01:00
André Cruz
9cfa3e5002 Changes to the reset & clear runtime cache.
Minor tweak to the grunt file.
2013-07-06 13:48:53 +01:00
Sven Lito
82278037ec [tests] adds comments and clearCache tests 2013-07-05 13:08:42 +01:00
Sven Lito
0b592f86d0 [tests] tidy up nock call 2013-07-05 12:50:25 +01:00
Sven Lito
ee4e003c2d [tests] fix method call 2013-07-05 12:50:08 +01:00
Sven Lito
b2904bc6fb [tests] mock search endpoint 2013-07-05 12:36:36 +01:00
Sven Lito
67b94cf52e sets nock as npm dependency 2013-07-05 11:53:08 +01:00
Sven Lito
c308d2c9dd adds nock fixture 2013-07-05 11:51:28 +01:00
Sven Lito
e36370b080 removes fixtures 2013-07-05 11:51:15 +01:00
Sven Lito
d0f005a6f1 adjust fixtures path 2013-07-05 10:54:51 +01:00
Sven Lito
a461fa9137 move fixture 2013-07-05 10:54:39 +01:00
Sven Lito
22e969fb59 fix npm module name
meh..
2013-07-05 10:52:25 +01:00
Sven Lito
34527c8395 [tests] fix breaking test 2013-07-05 10:49:53 +01:00
Sven Lito
012f4d68bc [wip] update tests 2013-07-05 10:46:48 +01:00
Sven Lito
724283433a adds lookup method tests 2013-07-04 15:55:10 +01:00
Sven Lito
aea19b93b1 rename client -> registry
because that's what it is right?
2013-07-04 15:11:44 +01:00
Sven Lito
73020a711d tweaking docs 2013-07-04 15:00:15 +01:00
Sven Lito
7e62e671e3 updates testrunner 2013-07-04 14:51:29 +01:00
Sven Lito
2e845ac0ab adds createError tests 2013-07-04 14:51:17 +01:00
Sven Lito
2df41e52ed adds Cache tests 2013-07-04 14:51:09 +01:00
Sven Lito
bf8e93f581 adds search tests 2013-07-04 14:51:03 +01:00
Sven Lito
f5eec3283c adds register tests 2013-07-04 14:50:54 +01:00
Sven Lito
223161c7d6 adds list tests 2013-07-04 14:50:47 +01:00
Sven Lito
b8ba6e4827 adds index tests 2013-07-04 14:50:39 +01:00
Sven Lito
15c8259ac2 adds lookup tests 2013-07-04 14:50:32 +01:00
Sven Lito
720492932f update Client.js tests 2013-07-04 10:40:36 +01:00
Sven Lito
a08a0fb084 add tests to jshint 2013-07-04 10:40:21 +01:00
Sven Lito
827fbaac1f update jshint settings 2013-07-04 10:40:03 +01:00
André Cruz
297224bd31 Merge branch 'master' of github.com:bower/registry-client 2013-07-03 16:20:38 +01:00
André Cruz
9dc835c60c Bump rc version. 2013-07-03 16:18:50 +01:00
André Cruz
67a96bc2f3 Typo ignoring ENOENT errors. 2013-07-03 16:18:22 +01:00
Sven Lito
ff5bf16111 fix file reference 2013-07-02 23:33:52 +01:00
Sven Lito
8d22059462 adds grunt travis setup 2013-07-02 23:26:07 +01:00
Sven Lito
91d144f5f7 Merge branch 'master' of https://github.com/bower/registry-client 2013-07-02 22:51:50 +01:00
Sven Lito
c894b1d335 adds grunt and test runner setup 2013-07-02 22:51:43 +01:00
Sven Lito
d30a7bf6a1 adds .editorconfig 2013-07-02 22:50:26 +01:00
André Cruz
649d5f56c9 Minor doc typo. 2013-07-02 09:41:17 +01:00
André Cruz
36b033c2f7 Switch to graceful-fs. 2013-07-01 20:28:37 +01:00
André Cruz
dc9bce915b Switch to graceful-fs. 2013-07-01 20:28:11 +01:00
André Cruz
c9a7cfafd0 Bump rc version! 2013-06-28 21:59:56 +01:00
André Cruz
9d9585ecba Ignore ENOENT erros when deleting from the cache. 2013-06-28 21:59:24 +01:00
André Cruz
0ebd7e6a58 Small typo in README. 2013-06-24 14:51:54 +01:00
André Cruz
a100abc3b6 Bump rc version. 2013-06-24 14:48:36 +01:00
André Cruz
94f6945d5a Complete README, change cleanRuntimeCache to clearRuntimeCache. 2013-06-24 14:48:20 +01:00
André Cruz
442d771a7a Bump rc version. 2013-06-23 17:44:29 +01:00
André Cruz
242e11eefc Add register. 2013-06-23 17:43:52 +01:00
André Cruz
7fbbae8cd4 Bump (rc3). 2013-06-22 17:05:13 +01:00
André Cruz
b80d96d9c7 Fix tests. 2013-06-22 14:15:35 +01:00
André Cruz
d8e69360b9 Add search command, other fixes/changes.
- Use LRU to prevent huge memory usage when using the module in long-living programs
- Lookup no longer throws when a package is not found (null is returned instead).
- Cache mechanism improvements.
- Misc fixes.
2013-06-22 14:11:11 +01:00
André Cruz
83ae9b66a3 Add license note, misc tweaks. 2013-06-22 14:07:51 +01:00
André Cruz
4ac052c10b Oops. 2013-05-26 13:17:54 +01:00
André Cruz
f1717f8319 Move force and offline options to the constructor. 2013-05-26 13:12:54 +01:00
André Cruz
cb000549bd Small tweaks. 2013-05-26 12:46:45 +01:00
André Cruz
2712aa2ae2 Merge branch 'master' of github.com:bower/json 2013-05-24 22:55:03 +01:00
André Cruz
7dcefa6bee Add repository to package.json and fix URL's, also bump rc version. 2013-05-24 22:54:41 +01:00
André Cruz
70e3528809 Add repository to package.json and bump rc version. 2013-05-24 22:53:52 +01:00
André Cruz
c7780a2708 Try next registry endpoint on 404. 2013-05-24 22:53:17 +01:00
André Cruz
26bab84d04 Fix parse usage in README. 2013-05-19 14:27:36 +02:00
André Cruz
efea6136e7 Merge pull request #2 from badunk/find-readme
Quick fix for bowerJson.find() example
2013-05-19 05:26:42 -07:00
Duncan Wong
c56026c18a quick fix for bowerJson.find() example 2013-05-18 19:26:49 -06:00
André Cruz
1d9504d0f0 Bump rc. 2013-05-17 13:14:53 +01:00
André Cruz
780b1f8acc Fix various bugs. 2013-05-17 13:13:47 +01:00
André Cruz
9b6c5741de Move cache did creation to appropriate class, small pert improvement.. 2013-05-13 11:10:10 +01:00
André Cruz
0742e18edd Oops. 2013-05-11 14:00:11 +01:00
André Cruz
cb59c2489b Change main file. 2013-05-11 13:56:48 +01:00
André Cruz
3158b544d5 Minor lang change. 2013-05-11 13:42:23 +01:00
André Cruz
e80270d1fa Add correct maxAge for the cache entries. 2013-05-11 13:40:59 +01:00
André Cruz
99b37f24bb Slightly different strategy, implement lookup cache. 2013-05-11 13:33:40 +01:00
André Cruz
fdbdcc4130 More doc typos. 2013-05-10 20:01:35 +01:00
André Cruz
08104966b2 Improve doc. 2013-05-10 19:54:30 +01:00
André Cruz
1c99133177 Change package to bower-registry-client.
Some changes to the codebase.
2013-05-10 19:46:52 +01:00
André Cruz
28780dc67e Wrong async usage of doUntil. 2013-05-09 21:15:49 +01:00
André Cruz
423ce54d8a Add empty tests and add cache TODO. 2013-05-09 13:18:59 +01:00
André Cruz
73bab73db6 Initial implementation of lookup. 2013-05-09 13:11:57 +01:00
André Cruz
3e90471fa2 Setup project. 2013-05-07 17:38:53 +01:00
André Cruz
7f2db8a9a7 Setup project. 2013-05-07 17:30:29 +01:00
André Cruz
d5fc147ffd Merge pull request #1 from dylang/human-friendly-error-message
Made the error message more understandable.
2013-05-07 09:29:32 -07:00
André Cruz
77ffd7bbf9 Merge branch 'master' of github.com:bower/bower-json 2013-05-07 17:26:32 +01:00
André Cruz
42775d3477 Improve gitignore. 2013-05-07 17:26:22 +01:00
André Cruz
6932b8c378 Better license format. 2013-05-07 17:26:10 +01:00
Dylan Greene
cff641ef80 add quotes around the path and fix the test 2013-05-06 22:16:52 -04:00
André Cruz
373abf1b24 Update README.md 2013-05-06 23:11:51 +02:00
Dylan Greene
f668596667 Made the error message more understandable. 2013-05-06 17:02:57 -04:00
André Cruz
93e0e815d7 Fix indentation. 2013-05-05 03:03:56 +01:00
André Cruz
05275c8938 Improve README. 2013-05-05 04:02:15 +02:00
André Cruz
19475db7dd Typos. 2013-05-05 04:00:55 +02:00
André Cruz
aa315d7c97 Merge branch 'master' of github.com:bower/bower-json 2013-04-23 23:58:48 +01:00
André Cruz
080b25e30c Update .gitignore. 2013-04-23 23:58:35 +01:00
André Cruz
a7c8c08183 Update README.md 2013-04-23 10:12:47 +02:00
André Cruz
bb98627d2b Made parse async for consistency, tweak error codes. 2013-04-20 12:17:00 +01:00
André Cruz
3060866586 Add test for invalid json. 2013-04-20 11:37:15 +01:00
André Cruz
eacf121f78 Update README. 2013-04-20 11:23:24 +01:00
André Cruz
c39535fdd0 Merge branch 'master' of github.com:bower/bower-json 2013-04-20 11:21:31 +01:00
André Cruz
c3311df2a8 Initial implementation and tests. 2013-04-20 11:20:41 +01:00
André Cruz
5a17314b2c Oops. 2013-04-19 22:00:24 +02:00
André Cruz
07281f050c Change to just bower-json. 2013-04-19 13:58:18 +01:00
André Cruz
9c3757fb0c Doc improv. 2013-04-19 12:33:07 +01:00
André Cruz
f5d5e59040 Typo. 2013-04-19 12:31:04 +01:00
André Cruz
70880c066f Add LICENSE and README. 2013-04-19 12:29:20 +01:00
André Cruz
5508c70f3a Setup module. 2013-04-19 11:19:47 +01:00
246 changed files with 13498 additions and 1831 deletions

46
.appveyor.yml Normal file
View File

@@ -0,0 +1,46 @@
# http://www.appveyor.com/docs/appveyor-yml
# Set build version format here instead of in the admin panel.
version: "{build}"
# Fix line endings in Windows. (runs before repo cloning)
init:
- git config --global core.autocrlf input
# Test against these versions of Node.js.
environment:
matrix:
- nodejs_version: "0.10"
- nodejs_version: "0.12"
- nodejs_version: "4"
- nodejs_version: "6"
- nodejs_version: "8"
- nodejs_version: "9"
# Finish on first failed build
matrix:
fast_finish: true
# Install node, display versions, install dependencies
install:
- ps: Install-Product node 8
- node --version && npm --version
- git --version && svn --version
- npm install -g yarn grunt
- yarn
- ps: Install-Product node $env:nodejs_version
# Post-install test scripts.
test_script:
- cmd: npm run ci
# Make clone much faster
shallow_clone: true
# Disable Visual Studio build and deploy
build: off
deploy: off
# Cache node modules, and refresh if package.json changes
cache:
- "%LOCALAPPDATA%\\Yarn"

View File

@@ -15,5 +15,4 @@ trim_trailing_whitespace = false
insert_final_newline = false
[{package,bower}.json]
indent_style = space
indent_size = 2

52
.eslintrc Normal file
View File

@@ -0,0 +1,52 @@
{
"env": {
"node": true,
"mocha": true
},
"rules": {
"no-bitwise": 0,
"curly": 0,
"eqeqeq": 0,
"guard-for-in": 0,
"no-use-before-define": 0,
"no-caller": 2,
"no-new": 2,
"no-plusplus": 0,
"no-undef": 2,
"no-unused-vars": 0,
"strict": 0,
"semi": 0,
"comma-spacing": 2,
"quote-props": [2, "consistent", { "keywords": true }],
"quotes": [2, "single", "avoid-escape"],
"indent": [2, 4],
"no-cond-assign": [ 2, "except-parens" ],
"no-debugger": 2,
"no-dupe-args": 2,
"no-dupe-keys": 2,
"no-duplicate-case": 2,
"no-unreachable": 2,
"valid-typeof": 2,
"no-fallthrough": 2,
"no-ex-assign": 2,
"no-eq-null": 0,
"no-eval": 0,
"no-unused-expressions": 0,
"block-scoped-var": 0,
"no-iterator": 0,
"no-loop-func": 2,
"no-script-url": 0,
"no-shadow": 0,
"no-new-func": 2,
"no-new-wrappers": 2,
"no-invalid-this": 0,
"space-before-blocks": [2, "always"],
"space-before-function-paren": [2, {"anonymous": "always", "named": "never"}],
"space-infix-ops": 2,
"keyword-spacing": 2,
"new-parens": 2,
"no-multiple-empty-lines": [2, { max: 2}],
"eol-last": 2,
"no-trailing-spaces": 2
}
}

44
.github/ISSUE_TEMPLATE.md vendored Normal file
View File

@@ -0,0 +1,44 @@
<!--
If you are reporting a new issue, make sure that we do not have any duplicates.
You can ensure this by searching the issue list for this repository.
You are welcome to open issues to discuss important general topics concerning Bower.
However for support questions, please consider using http://stackoverflow.com or
asking for help in our Discord channel: https://discordapp.com/invite/0fFM7QF0KpZaDeN9
# BUG REPORT
Use the commands below to provide key information to reproduce:
You do NOT have to include this information if this is a FEATURE REQUEST OR DISCUSSION
For more information about reporting bugs, see:
https://github.com/bower/bower/wiki/Report-a-Bug
-->
**Output of `bower -v && npm -v && node -v`:**
```
(paste your output here)
```
**Additional environment details (proxy, private registry, etc.):**
**Steps to reproduce the issue:**
1.
2.
3.
**Describe the results you received:**
**Describe the results you expected:**
**Additional information:**

3
.gitignore vendored
View File

@@ -9,3 +9,6 @@
/bower.json
/component.json
/bower_components
/test/sample
!/test/sample/bower.json
/npm-shrinkwrap.json

View File

@@ -1,25 +1,43 @@
sudo: false
language: node_js
# Use node 8 for build
node_js:
- "8"
# Then test with specific node version
env:
- NODE_VERSION=0.10
- NODE_VERSION=0.11
- TEST_NODE_VERSION="0.10"
- TEST_NODE_VERSION="0.12"
- TEST_NODE_VERSION="4"
- TEST_NODE_VERSION="6"
- TEST_NODE_VERSION="8"
- TEST_NODE_VERSION="9"
before_install:
- node --version
- curl -o- -L https://yarnpkg.com/install.sh | bash -s -- --version 1.5.1
- export PATH=$HOME/.yarn/bin:$PATH
cache:
yarn: true
install:
- test $TRAVIS_OS_NAME = "osx" && brew install nvm && source $(brew --prefix nvm)/nvm.sh || test $TRAVIS_OS_NAME = "linux"
- nvm install $NODE_VERSION
- node --version
- npm --version
- git --version
- svn --version | head -n 1
- npm install -g grunt-cli
- npm install
- yarn
- nvm install $TEST_NODE_VERSION
- npm install -g grunt
os:
- osx
- linux
matrix:
fast_finish: true
allow_failures:
- os: osx
- env: "NODE_VERSION=0.11"
script:
- nvm use $TEST_NODE_VERSION
- node --version && npm --version && git --version && svn --version | head -n 1
- grunt travis

View File

@@ -1,5 +1,203 @@
# Changelog
## 1.8.0 - 2016-11-07
- Download tar archives from GitHub when possible (#2263)
- Change default shorthand resolver for github from `git://` to `https://`
- Fix ssl handling by not setting GIT_SSL_NO_VERIFY=false (#2361)
- Allow for removing components with url instead of name (#2368)
- Show in warning message location of malformed bower.json (#2357)
- Improve handling of non-semver versions in git resolver (#2316)
- Fix handling of cached releases pluginResolverFactory (#2356)
- Allow to type the entire version when conflict occured (#2243)
- Allow `owner/reponame` shorthand for registering components (#2248)
- Allow single-char repo names and package names (#2249)
- Make `bower version` no longer honor `version` in bower.json (#2232)
- Add `postinstall` hook (#2252)
- Allow for `@` instead of `#` for `install` and `info` commands (#2322)
- Upgrade all bundled modules
## 1.7.9 - 2016-04-05
- Show warnings for invalid bower.json fields
- Update bower-json
- Less strict validation on package name (allow spaces, slashes, and "@")
## 1.7.8 - 2016-04-04
- Don't ask for git credentials in non-interactive session, fixes #956 #1009
- Prevent swallowing exceptions with programmatic api, fixes #2187
- Update graceful-fs to 4.x in all dependences, fixes nodejs/node#5213
- Resolve pluggable resolvers using cwd and fallback to global modules, fixes #1919
- Upgrade handlebars to 4.0.5, closes #2195
- Replace all % chatacters in defined scripts, instead of only first one, fixes #2174
- Update opn package to fix issues with "bower open" command on Windows
- Update bower-config
- Do not interpolate environment variables in script hooks, fixes bower/config#47
- Update bower-json
- Validate package name more strictly and allow only latin letters, dots, dashes and underscores
- Add support for "save" and "save-exact" in .bowerrc, #2161
## 1.7.7 - 2016-01-27
Revert locations of all files while still packaging `node_modules`.
It's because people are depending on internals of bower, like
`bower/lib/renderers/StandardRenderer`. We want to preserve this
implicit contract, but we discourage it. The only official way
to use bower programmatically is through `require('bower')`.
## 1.7.6 - 2016-01-27
- Revert location of "bin/bower" as developers are using it directly ([#2157](https://github.com/bower/bower/issues/2157))
Note: Correctly, you should use an alias created in `npm bin --global`.
## 1.7.5 - 2016-01-26
- Remove analytics from Bower, fixes ([#2150](https://github.com/bower/bower/pull/2150))
- Default to ^ operator on `bower install --save` ([#2145](https://github.com/bower/bower/pull/2145))
- Support absolute path in .bowerrc directory option ([#2130](https://github.com/bower/bower/pull/2130))
- Display user's name upon `bower login` command ([#2133](https://github.com/bower/bower/pull/2133))
- Decompress gzip files ([#2092](https://github.com/bower/bower/pull/2092))
- Prevent name clashes in package extraction ([#2102](https://github.com/bower/bower/pull/2102))
- When strictSsl is false, set GIT_SSL_NO_VERIFY=true ([#2129](https://github.com/bower/bower/issues/2129))
- Distribute bower with npm@3 for better Windows support ([#2146](https://github.com/bower/bower/issues/2146))
- Update request to 2.67.0 and fs-write-stream-atomic to 1.0.8
- Documentation improvements
## 1.7.4 - 2016-01-21
Unpublished because of issue with npm distribution:
https://github.com/npm/npm/issues/11227
## 1.7.3 - 2016-01-20
Unpublished because of issue with npm distribution:
https://github.com/npm/npm/issues/11227
## 1.7.2 - 2015-12-31
- Lock "fs-write-stream-atomic" to 1.0.5
## 1.7.1 - 2015-12-11
- Rollback "Add `bower update --save` functionality", it causes issues and needs more testing
- Fix backward-compatibility of `bower search --json` ([#2066](https://github.com/bower/bower/issues/2066))
- Ignore prerelease versions from `bower info` output
- Update update-notifier to 0.6.0
- Better formatting of help messages (https://github.com/bower/bower/commit/de3e1089da80f47ea3667c5ab80d301cddfd8c3e)
- Add help menu for update `--save` and `update --save-dev` (https://github.com/bower/bower/commit/612aaa88eb4d4b268b2d8665c338ac086af3a5b0)
## 1.7.0 - 2015-12-07
- Add `bower update --save` functionality ([#2035](https://github.com/bower/bower/issues/2035))
- `bower search` shows help message when no package name is specified ([#2066](https://github.com/bower/bower/issues/2066))
- Update only those packages that are explicitly requested by the user. Related Issues
- [#256](https://github.com/bower/bower/issues/256)
- [#924](https://github.com/bower/bower/issues/924)
- [#1770](https://github.com/bower/bower/issues/1770)
- Allow for @ in username for SVN on windows ([#1650](https://github.com/bower/bower/issues/1650))
- Update bower config
- Loads the .bowerrc file from the cwd specified on the command line
- Allow the use of environment variables in .bowerrc ([#41](https://github.com/bower/config/issues/41))
- Allow for array notation in ENV variables ([#44](https://github.com/bower/config/issues/44))
## 1.6.9 - 2015-12-04
- Change git version of fs-write-stream-atomic back to npm version ([#2079](https://github.com/bower/bower/issues/2079))
## 1.6.8 - 2015-11-27
- Use fs-write-stream-atomic for downloads
- Improved downloader that properly cleans after itself
- Fix shallow host detection ([#2040](https://github.com/bower/bower/pull/2040))
- Upgrade to ([bower-config#1.2.3](https://github.com/bower/config/releases/tag/1.2.3))
- Properly restore env variables if they are undefined at the beginning
- Properly handle `default` setting for config.ca
- Display proper error if .bowerrc is a directory instead of file
## 1.6.7 - 2015-11-26
- Bundless all the dependencies again
## 1.6.6 - 2015-11-25
- Fixes regression with the published npm version
## 1.6.5 - 2015-10-24
- Updates to tests and documentation
- Fixes passing options when requesting downloads
## 1.6.4 - 2015-10-24
- Fix ignoring dependencies on multiple install run ([#1970](https://github.com/bower/bower/pull/1970))
- Use --non-interactive when running svn client ([#1969](https://github.com/bower/bower/pull/1969))
- Fix downloading of URLs ending with slash ([#1956](https://github.com/bower/bower/pull/1956))
- Add user-agent field for downloads by Bower ([#1960](https://github.com/bower/bower/pull/1960))
## 1.6.3 - 2015-10-16
Fixes regression issues introduced with 1.6.2, specifically:
- Allow for bower_components to be a symlink
- Allow setting custom registry in .bowerrc
## 1.6.2 - 2015-10-15
Fix dependency issues of 1.6.1. First published release of 1.6.x.
## 1.6.1 - 2015-10-15
Fix dependency issues of 1.6.0. Reverted release.
## 1.6.0 - 2015-10-15
- Shrinkwrap all dependencies and add them to bundledDependencies ([#1948](https://github.com/bower/bower/pull/1948))
- Allow for ignoring of child dependencies ([#1394](https://github.com/bower/bower/pull/1394))
- Allow passing `--config.resolvers` through CLI ([#1922](https://github.com/bower/bower/pull/1922))
- Use defaults values from package.json if it exists (bower init) ([#1731](https://github.com/bower/bower/issues/1731))
- Properly use cerificates set in .bowerrc ([#1869](https://github.com/bower/bower/pull/1869))
- Include package name when version conflict occurs ([#1917](https://github.com/bower/bower/pull/1917))
- Add timeout for permission check ([yeoman/insight#35](https://github.com/yeoman/insight/pull/35))
- Close file-handles when possible. Prevents all sorts of permission issues on Windows ([0bb1536](https://github.com/bower/bower/commit/0bb1536c9972e13f3be06bea9a8619632966c664))
- Prevent ENOENT error on Windows when in VM environment ([isaacs/chmodr#8](https://github.com/isaacs/chmodr/pull/8))
Reverted release.
## 1.5.4 - 2015-11-24
- [fix] Lock lru-cache dependency to 2.7.0
## 1.5.3 - 2015-09-24
- Revert auto sorting of bower dependencies, fixes ([#1897](https://github.com/bower/bower/issues/1897))
- Fix --save-exact feature for github endpoints, fixes ([#1925](https://github.com/bower/bower/issues/1925))
- Fix `bower init` to support private flag again ([#1819](https://github.com/bower/bower/pull/1819))
- Bump insight dependency to support prompt timeout ([#1102](https://github.com/bower/bower/issues/1102))
## 1.5.2 - 2015-08-25
- Revert update semver version from 2.x to 5.x, fixes ([#1896](https://github.com/bower/bower/issues/1896))
- Make bower commands work from subdirectories, fixes ([#1893](https://github.com/bower/bower/issues/1893))
- Put auto shallow cloning for git behind a flag, fixes ([#1764](https://github.com/bower/bower/issues/1764))
## 1.5.1 - 2015-08-24
- If cwd provided explicitly, force using it, fixes #1866
## 1.5.0 - 2015-08-24
- Pluggable Resolvers! http://bower.io/docs/pluggable-resolvers/
- Update semver version from 2.x to 5.x ([#1852](https://github.com/bower/bower/issues/1852))
- Auto-sort dependencies alphabetically ([#1381](https://github.com/bower/bower/issues/1381))
- Make bower commands work from subdirectories ([#1866](https://github.com/bower/bower/issues/1866))
- No longer prefer installing bower as global module ([#1865](https://github.com/bower/bower/issues/1865))
## 1.4.2 - 2015-11-24
- [fix] Lock lru-cache dependency to 2.7.0
## 1.4.1 - 2015-04-01
- [fix] Reading .bowerrc upwards directory tree ([#1763](https://github.com/bower/bower/issues/1763))

View File

@@ -1,35 +1,26 @@
# Contributing to Bower
Bower is a large community project with many different developers contributing at all levels to the project. We're **actively** looking for more contributors right now. (Jan 2014)
Bower is a large community project with many different developers contributing at all levels to the project. We're **actively** looking for more contributors right now. If you're interested in becoming a Bower maintainer or supporting in any way, please fill the following form: http://goo.gl/forms/P1ndzCNoiG. There is more information about [contributing](https://github.com/bower/bower/wiki/Contributor-Guidelines) in the Wiki.
<a name="bugs"></a>
## 🐛 [Bug reports](https://github.com/bower/bower/wiki/Report-a-Bug)
## Casual Involvement
* Improve the bower.io site ([tickets](https://github.com/bower/bower.github.io/issues))
* Move forward [bower.io redesign](https://github.com/bower/bower.github.io/issues/7)
* Attend team meetings
* Comment on issues and drive to resolution
## High-impact Involvement
* Maintaining the bower client.
* [Authoring client tests](https://github.com/bower/bower/issues/801)
* Maintaining the bower client.
* Read [Architecture doc](https://github.com/bower/bower/wiki/Rewrite-architecture)
* Triage, close, fix and resolve [issues](https://github.com/bower/bower/issues)
* Developing the [new registry server](https://github.com/bower/registry/tree/node_rewrite)
* Hooking in to Elastic Search rather than the in-memory search
* Getting bower/registry-client to talk to the new server without breaking backwards compatibility
* DevOps for the server
## Team Meetings
We meet on Monday at 1:00pm PST, 9:00pm UTC in #bower on Freenode. [The meeting notes](http://goo.gl/NJZ1o2).
<hr>
Following these guidelines helps to communicate that you respect the time of
the developers managing and developing this open source project. In return,
they should reciprocate that respect in addressing your issue, assessing
changes, and helping you finalize your pull requests.
We communicate through a channel on Discord https://discord.gg/0fFM7QF0KpZRh2cY
If you'd like to attend the meetings, please fill the [support form](http://goo.gl/forms/P1ndzCNoiG), and you'll get an invite.
## Using the issue tracker
@@ -38,57 +29,15 @@ The issue tracker is the preferred channel for [bug reports](#bugs),
requests](#pull-requests), but please respect the following restrictions:
* Please **do not** use the issue tracker for personal support requests. Use
[Stack Overflow](http://stackoverflow.com/questions/tagged/bower), our
[Mailing List](http://groups.google.com/group/twitter-bower)
[Stack Overflow](http://stackoverflow.com/questions/tagged/bower),
[Discord Channel](https://discordapp.com/channels/119103197720739842/123728452816732160),
[Mailing List](http://groups.google.com/group/twitter-bower),
(twitter-bower@googlegroups.com), or
[#bower](http://webchat.freenode.net/?channels=bower) on Freenode.
* Please **do not** derail or troll issues. Keep the discussion on topic and
respect the opinions of others.
<a name="bugs"></a>
## Bug reports
A bug is a _demonstrable problem_ that is caused by the code in the repository.
Good bug reports are extremely helpful - thank you!
Guidelines for bug reports:
1. **Use the GitHub issue search** &mdash; check if the issue has already been
reported.
2. **Check if the issue has been fixed** &mdash; try to reproduce it using the
latest `master` or development branch in the repository.
3. **Isolate the problem** &mdash; ideally create a [reduced test
case](http://css-tricks.com/6263-reduced-test-cases/).
A good bug report shouldn't leave others needing to chase you up for more
information. Please try to be as detailed as possible in your report. What is
your environment? What steps will reproduce the issue? What OS experiences the
problem? What would you expect to be the outcome? All these details will help
people to fix any potential bugs.
Example:
> Short and descriptive example bug report title
>
> A summary of the issue and the browser/OS environment in which it occurs. If
> suitable, include the steps required to reproduce the bug.
>
> 1. This is the first step
> 2. This is the second step
> 3. Further steps, etc.
>
> `<url>` - a link to the reduced test case
>
> Any other information you want to share that is relevant to the issue being
> reported. This might include the lines of code that you have identified as
> causing the bug, and potential solutions (and your opinions on their
> merits).
<a name="features"></a>
## Feature requests
@@ -172,6 +121,8 @@ included in the project:
force push to your remote feature branch. You may also be asked to squash
commits.
10. If you are asked to squash your commits, then please use `git rebase -i master`. It will ask you to pick your commits - pick the major commits and squash the rest.
**IMPORTANT**: By submitting a patch, you agree to license your work under the
same license as that used by the project.

View File

@@ -1,11 +1,20 @@
'use strict';
var tmp = require('tmp');
var childProcess = require('child_process');
var arraydiff = require('arr-diff');
var fs = require('fs');
var wrench = require('wrench');
var inquirer = require('inquirer');
var path = require('path');
module.exports = function (grunt) {
require('load-grunt-tasks')(grunt);
grunt.initConfig({
jshint: {
eslint: {
options: {
jshintrc: '.jshintrc'
fix: true
},
files: [
'Gruntfile.js',
@@ -14,6 +23,7 @@ module.exports = function (grunt) {
'test/**/*.js',
'!test/assets/**/*',
'!test/reports/**/*',
'!test/sample/**/*',
'!test/tmp/**/*'
]
},
@@ -33,28 +43,171 @@ module.exports = function (grunt) {
}
},
exec: {
assets: {
'assets': {
command: 'node test/packages.js && node test/packages-svn.js'
},
'assets-force': {
command: 'node test/packages.js --force && node test/packages-svn.js --force'
},
cover: {
command: 'STRICT_REQUIRE=1 node node_modules/istanbul/lib/cli.js cover --dir ./test/reports node_modules/mocha/bin/_mocha -- --timeout 30000 -R dot test/test.js'
'cover': {
command: 'node node_modules/istanbul/lib/cli.js cover --dir ./test/reports node_modules/mocha/bin/_mocha -- --timeout 30000 -R dot test/test.js'
},
coveralls: {
command: 'node node_modules/.bin/coveralls < test/reports/lcov.info'
'coveralls': {
command: 'npm run coveralls < test/reports/lcov.info',
exitCodes: [0, 1, 2, 3] // Alow for failure for coverage report
}
},
watch: {
files: ['<%= jshint.files %>'],
tasks: ['jshint', 'simplemocha:short']
files: ['<%= eslint.files %>'],
tasks: ['eslint', 'simplemocha:short']
}
});
grunt.registerTask('assets', ['exec:assets-force']);
grunt.registerTask('test', ['jshint', 'exec:assets', 'simplemocha:full']);
grunt.registerTask('test', ['eslint', 'exec:assets', 'simplemocha:full']);
grunt.registerTask('cover', 'exec:cover');
grunt.registerTask('travis', ['jshint', 'exec:assets', 'exec:cover', 'exec:coveralls']);
grunt.registerTask('travis', ['eslint', 'exec:assets', 'exec:cover', 'exec:coveralls']);
grunt.registerTask('default', 'test');
grunt.task.registerTask('publish', 'Perform final checks and publish Bower', function () {
var npmVersion = JSON.parse(childProcess.execSync('npm version --json').toString()).npm.split('.');
var npmMajor = parseInt(npmVersion[0], 10);
var npmMinor = parseInt(npmVersion[1], 10);
var jsonPackage = require('./package');
if (npmMajor !== 3 || npmMinor < 5) {
grunt.log.writeln('You need to use at least npm@3.5 to publish bower.');
grunt.log.writeln('It is because npm 2.x produces too long paths that Windows does not handle.');
grunt.log.writeln('Please upgrade it: npm install -g npm');
process.exit(1);
}
var version = jsonPackage.version;
var changelog = fs.readFileSync('./CHANGELOG.md');
if (changelog.indexOf('## ' + version) === -1) {
grunt.log.writeln('Please add changelog.md entry for this bower version (' + version + ')');
var lastRelease = childProcess.execSync('git tag | tail -1').toString().trim();
grunt.log.writeln('Commits since last release (' + lastRelease + '): \n');
grunt.log.writeln(childProcess.execSync('git log --oneline ' + lastRelease + '..').toString());
process.exit(1);
}
if (childProcess.execSync('git rev-parse --abbrev-ref HEAD').toString().trim() !== 'master') {
grunt.log.writeln('You need to release bower from the "master" branch');
process.exit(1);
}
if (process.env.SKIP_TESTS !== '1') {
grunt.log.writeln('Reinstalling dependencies...');
childProcess.execSync('rm -rf node_modules && npm install', { stdio: [0, 1, 2] });
grunt.log.writeln('Running test suite...');
childProcess.execSync('grunt test', { stdio: [0, 1, 2] });
}
var dir = tmp.dirSync().name;
wrench.copyDirSyncRecursive(__dirname, dir, {
forceDelete: true,
include: function (path) {
return !path.match(/node_modules|\.git|test/);
}
});
grunt.log.writeln('Installing production dependencies...');
childProcess.execSync('npm install --production --silent', { cwd: dir, stdio: [0, 1, 2] });
delete jsonPackage.dependencies;
delete jsonPackage.devDependencies;
delete jsonPackage.scripts;
fs.writeFileSync(path.resolve(dir, 'package.json'), JSON.stringify(jsonPackage, null, ' ') + '\n');
grunt.log.writeln('Moving node_modules to lib directory...');
wrench.copyDirSyncRecursive(path.resolve(dir, 'node_modules'), path.resolve(dir, 'lib', 'node_modules'));
wrench.rmdirSyncRecursive(path.resolve(dir, 'node_modules'));
grunt.log.writeln('Testing bower on sample project...');
childProcess.execSync(
'cd test/sample && rm -rf bower_components && ' + dir + '/bin/bower install --force', { stdio: [0, 1, 2] }
);
var expectedPackages = (
'SHA-1 ace-builds almond angular angular-animate angular-bootstrap angular-charts angular-contenteditable ' +
'angular-deckgrid angular-fullscreen angular-gravatar angular-hotkeys angular-local-storage angular-marked ' +
'angular-moment angular-sanitize angular-touch angular-ui-router angular-ui-sortable ' +
'angulartics asEvented bootstrap coffee-script d3 es6-shim font-awesome howler jquery ' +
'jquery-ui jquery-waypoints js-beautify lodash lz-string marked moment ng-file-upload peerjs ' +
'requirejs restangular slimScroll slimScrollHorizontal venturocket-angular-slider'
).split(' ');
var installedPackages = fs.readdirSync('./test/sample/bower_components');
var installedDiff = arraydiff(expectedPackages, installedPackages);
if (installedDiff.length > 0) {
grunt.log.writeln('ERROR. Some packages were not installed by bower: ');
grunt.log.writeln(installedDiff.join(', '));
process.exit(1);
}
grunt.log.writeln('\nBower production bundle installed in:');
grunt.log.writeln(dir + '\n');
var questions = [
{
type: 'confirm',
name: 'review',
message: 'Did you review all the changes with "git diff"?',
default: false
},
{
type: 'confirm',
name: 'changelog',
message: 'Are you sure the CHANGELOG.md contains all changes?',
default: false
},
{
type: 'confirm',
name: 'tests',
message: 'Are you sure all tests are passing on Travis and Appveyor?',
default: false
},
{
type: 'confirm',
name: 'publish',
message: 'Are you SURE you want to publish ' + jsonPackage.name + '@' + jsonPackage.version + '?',
default: false
}
];
var done = this.async();
inquirer.prompt(questions, function (answers) {
if (!answers.review || !answers.changelog || !answers.tests || !answers.publish) {
grunt.log.writeln('Please publish bower after you fix this issue');
process.exit(1);
}
grunt.log.writeln('\nPlease remember to tag this relese, and add a release on Github!');
grunt.log.writeln('\nAlso, please remember to test published Bower one more time!');
grunt.log.writeln('\nPublishing Bower...');
childProcess.execSync('npm publish --tag beta', { cwd: dir, stdio: [0, 1, 2] });
done();
});
});
};

View File

@@ -1,21 +0,0 @@
# Install and Uninstall Hooks
Bower provides 3 separate hooks that can be used to trigger other automated tools during Bower usage. Importantly, these hooks are intended to allow external tools to help wire up the newly installed components into the parent project and other similar tasks. These hooks are not intended to provide a post-installation build step for component authors. As such, the configuration for these hooks is provided in the `.bowerrc` file in the parent project's directory.
## Configuring
In `.bowerrc` do:
```js
{
"scripts": {
"preinstall": "<your command here>",
"postinstall": "<your command here>",
"preuninstall": "<your command here>"
}
}
```
The value of each script hook may contain a % character. When your script is called, the % will be replaced with a space-separated list of components being installed or uninstalled.
Your script will also include an environment variable `BOWER_PID` containing the PID of the parent Bower process that triggered the script. This can be used to verify that a `preinstall` and `postinstall` steps are part of the same Bower process.

View File

@@ -1,4 +1,4 @@
Copyright (c) 2015 Twitter and other contributors
Copyright (c) 2013-present Twitter and other contributors
Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in

112
README.md
View File

@@ -1,10 +1,18 @@
# Bower
# Bower - A package manager for the web
[![Build Status](https://travis-ci.org/bower/bower.svg?branch=master)](https://travis-ci.org/bower/bower) [![Windows Build](https://ci.appveyor.com/api/projects/status/jr6vfra8w84plh2g/branch/master?svg=true)](https://ci.appveyor.com/project/sheerun/bower/history) [![Coverage Status](https://img.shields.io/coveralls/bower/bower.svg)](https://coveralls.io/r/bower/bower?branch=master)
[![Backers on Open Collective](https://opencollective.com/bower/backers/badge.svg)](#backers)
[![Sponsors on Open Collective](https://opencollective.com/bower/sponsors/badge.svg)](#sponsors)
> ..psst! While Bower is maintained, we recommend [yarn](https://yarnpkg.com/) and [webpack](https://webpack.js.org/) for new front-end projects!
[![Unix CI](https://img.shields.io/travis/bower/bower/master.svg?maxAge=2592000)](https://travis-ci.org/bower/bower)
[![Windows CI](https://img.shields.io/appveyor/ci/bower/bower/master.svg)](https://ci.appveyor.com/project/bower/bower)
[![Coverage Status](https://img.shields.io/coveralls/bower/bower.svg)](https://coveralls.io/r/bower/bower?branch=master)
[![Discord chat](https://img.shields.io/badge/discord-join%20chat%20%E2%86%92-brightgreen.svg?style=flat)](https://discord.gg/0fFM7QF0KpZRh2cY)
<img align="right" height="300" src="http://bower.io/img/bower-logo.png">
> A package manager for the web
---
Bower offers a generic, unopinionated solution to the problem of **front-end package management**, while exposing the package dependency model via an API that can be consumed by a more opinionated build stack. There are no system wide dependencies, no dependencies are shared between different apps, and the dependency tree is flat.
@@ -45,7 +53,7 @@ $ bower install <package>#<version> --save
We discourage using bower components statically for performance and security reasons (if component has an `upload.php` file that is not ignored, that can be easily exploited to do malicious stuff).
The best approach is to process components installed by bower with build tool (like [Grunt](http://gruntjs.com/) or [gulp](http://gulpjs.com/)), and serve them concatenated or using module loader (like [RequireJS](http://requirejs.org/)).
The best approach is to process components installed by bower with build tool (like [Grunt](http://gruntjs.com/) or [gulp](http://gulpjs.com/)), and serve them concatenated or using a module loader (like [RequireJS](http://requirejs.org/)).
### Uninstalling packages
@@ -59,18 +67,19 @@ $ bower uninstall <package-name>
On `prezto` or `oh-my-zsh`, do not forget to `alias bower='noglob bower'` or `bower install jquery\#1.9.1`
### Running commands with sudo
### Never run Bower with sudo
Bower is a user command, there is no need to execute it with superuser permissions.
However, if you still want to run commands with sudo, use `--allow-root` option.
Bower is a user command; there is no need to execute it with superuser permissions.
### Windows users
To use Bower on Windows, you must install
[msysgit](http://msysgit.github.io/) correctly. Be sure to check the
option shown below:
[Git for Windows](http://git-for-windows.github.io/) correctly. Be sure to check the
options shown below:
![msysgit](http://f.cl.ly/items/2V2O3i1p3R2F1r2v0a12/mysgit.png)
<img src="https://cloud.githubusercontent.com/assets/10702007/10532690/d2e8991a-7386-11e5-9a57-613c7f92e84e.png" width="534" height="418" alt="Git for Windows" />
<img src="https://cloud.githubusercontent.com/assets/10702007/10532694/dbe8857a-7386-11e5-9bd0-367e97644403.png" width="534" height="418" alt="Git for Windows" />
Note that if you use TortoiseGit and if Bower keeps asking for your SSH
password, you should add the following environment variable: `GIT_SSH -
@@ -92,17 +101,15 @@ Bower can be configured using JSON in a `.bowerrc` file. Read over available opt
## Support
* [Discord chat](https://discord.gg/0fFM7QF0KpZRh2cY)
* [StackOverflow](http://stackoverflow.com/questions/tagged/bower)
* [Mailinglist](http://groups.google.com/group/twitter-bower) - twitter-bower@googlegroups.com
* [\#bower](http://webchat.freenode.net/?channels=bower) on Freenode
## Contributing
We welcome [contributions](https://github.com/bower/bower/graphs/contributors) of all kinds from anyone. Please take a moment to
review the [guidelines for contributing](CONTRIBUTING.md).
We welcome [contributions](https://github.com/bower/bower/graphs/contributors) of all kinds from anyone. Please take a moment to review the [guidelines for contributing](CONTRIBUTING.md).
* [Bug reports](CONTRIBUTING.md#bugs)
* [Bug reports](https://github.com/bower/bower/wiki/Report-a-Bug)
* [Feature requests](CONTRIBUTING.md#features)
* [Pull requests](CONTRIBUTING.md#pull-requests)
@@ -113,8 +120,81 @@ Note that on Windows for tests to pass you need to configure Git before cloning:
git config --global core.autocrlf input
```
## Backers
Support us with a monthly donation and help us continue our activities. [[Become a backer](https://opencollective.com/bower#backer)]
<a href="https://opencollective.com/bower/backer/0/website" target="_blank"><img src="https://opencollective.com/bower/backer/0/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/1/website" target="_blank"><img src="https://opencollective.com/bower/backer/1/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/2/website" target="_blank"><img src="https://opencollective.com/bower/backer/2/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/3/website" target="_blank"><img src="https://opencollective.com/bower/backer/3/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/4/website" target="_blank"><img src="https://opencollective.com/bower/backer/4/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/5/website" target="_blank"><img src="https://opencollective.com/bower/backer/5/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/6/website" target="_blank"><img src="https://opencollective.com/bower/backer/6/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/7/website" target="_blank"><img src="https://opencollective.com/bower/backer/7/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/8/website" target="_blank"><img src="https://opencollective.com/bower/backer/8/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/9/website" target="_blank"><img src="https://opencollective.com/bower/backer/9/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/10/website" target="_blank"><img src="https://opencollective.com/bower/backer/10/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/11/website" target="_blank"><img src="https://opencollective.com/bower/backer/11/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/12/website" target="_blank"><img src="https://opencollective.com/bower/backer/12/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/13/website" target="_blank"><img src="https://opencollective.com/bower/backer/13/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/14/website" target="_blank"><img src="https://opencollective.com/bower/backer/14/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/15/website" target="_blank"><img src="https://opencollective.com/bower/backer/15/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/16/website" target="_blank"><img src="https://opencollective.com/bower/backer/16/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/17/website" target="_blank"><img src="https://opencollective.com/bower/backer/17/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/18/website" target="_blank"><img src="https://opencollective.com/bower/backer/18/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/19/website" target="_blank"><img src="https://opencollective.com/bower/backer/19/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/20/website" target="_blank"><img src="https://opencollective.com/bower/backer/20/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/21/website" target="_blank"><img src="https://opencollective.com/bower/backer/21/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/22/website" target="_blank"><img src="https://opencollective.com/bower/backer/22/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/23/website" target="_blank"><img src="https://opencollective.com/bower/backer/23/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/24/website" target="_blank"><img src="https://opencollective.com/bower/backer/24/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/25/website" target="_blank"><img src="https://opencollective.com/bower/backer/25/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/26/website" target="_blank"><img src="https://opencollective.com/bower/backer/26/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/27/website" target="_blank"><img src="https://opencollective.com/bower/backer/27/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/28/website" target="_blank"><img src="https://opencollective.com/bower/backer/28/avatar.svg"></a>
<a href="https://opencollective.com/bower/backer/29/website" target="_blank"><img src="https://opencollective.com/bower/backer/29/avatar.svg"></a>
## Sponsors
Become a sponsor and get your logo on our README on Github with a link to your site. [[Become a sponsor](https://opencollective.com/bower#sponsor)]
<a href="https://opencollective.com/bower/sponsor/0/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/0/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/1/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/1/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/2/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/2/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/3/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/3/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/4/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/4/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/5/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/5/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/6/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/6/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/7/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/7/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/8/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/8/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/9/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/9/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/10/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/10/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/11/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/11/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/12/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/12/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/13/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/13/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/14/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/14/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/15/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/15/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/16/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/16/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/17/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/17/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/18/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/18/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/19/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/19/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/20/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/20/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/21/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/21/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/22/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/22/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/23/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/23/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/24/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/24/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/25/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/25/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/26/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/26/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/27/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/27/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/28/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/28/avatar.svg"></a>
<a href="https://opencollective.com/bower/sponsor/29/website" target="_blank"><img src="https://opencollective.com/bower/sponsor/29/avatar.svg"></a>
## License
Copyright (c) 2015 Twitter and [other contributors](https://github.com/bower/bower/graphs/contributors)
Copyright (c) 2012-present Twitter and [other contributors](https://github.com/bower/bower/graphs/contributors)
Licensed under the MIT License

View File

@@ -1,40 +0,0 @@
# Thanks for Grunt for template of this file!
# http://www.appveyor.com/docs/appveyor-yml
# Fix line endings in Windows. (runs before repo cloning)
init:
- git config --global core.autocrlf input
# Test against these versions of Node.js.
environment:
matrix:
- nodejs_version: "0.10"
# - nodejs_version: "0.11"
# Allow failing jobs for bleeding-edge Node.js versions.
matrix:
allow_failures:
- nodejs_version: "0.11"
# Install scripts. (runs after repo cloning)
install:
# Get the latest stable version of Node 0.STABLE.latest
- ps: Install-Product node $env:nodejs_version
# Install subversion
- choco install svn -y
# Install bower
- npm install
# Post-install test scripts.
test_script:
# Output useful info for debugging.
- node --version
- npm --version
- cmd: npm test
# Don't actually build.
build: off
# Set build version format here instead of in the admin panel.
version: "{build}"

141
bin/bower
View File

@@ -1,142 +1,3 @@
#!/usr/bin/env node
'use strict';
process.bin = process.title = 'bower';
var Q = require('q');
var mout = require('mout');
var Logger = require('bower-logger');
var userHome = require('user-home');
var bower = require('../lib');
var pkg = require('../package.json');
var cli = require('../lib/util/cli');
var rootCheck = require('../lib/util/rootCheck');
var analytics = require('../lib/util/analytics');
var options;
var renderer;
var loglevel;
var command;
var commandFunc;
var logger;
var levels = Logger.LEVELS;
options = cli.readOptions({
version: { type: Boolean, shorthand: 'v' },
help: { type: Boolean, shorthand: 'h' },
'allow-root': { type: Boolean }
});
// Handle print of version
if (options.version) {
process.stdout.write(pkg.version + '\n');
process.exit();
}
// Root check
rootCheck(options, bower.config);
// Set loglevel
if (bower.config.silent) {
loglevel = levels.error;
} else if (bower.config.verbose) {
loglevel = -Infinity;
Q.longStackSupport = true;
} else if (bower.config.quiet) {
loglevel = levels.warn;
} else {
loglevel = levels[bower.config.loglevel] || levels.info;
}
// Get the command to execute
while (options.argv.remain.length) {
command = options.argv.remain.join(' ');
// Alias lookup
if (bower.abbreviations[command]) {
command = bower.abbreviations[command].replace(/\s/g, '.');
break;
}
command = command.replace(/\s/g, '.');
// Direct lookup
if (mout.object.has(bower.commands, command)) {
break;
}
options.argv.remain.pop();
}
// Ask for Insights on first run.
analytics.setup(bower.config).then(function () {
// Execute the command
commandFunc = command && mout.object.get(bower.commands, command);
command = command && command.replace(/\./g, ' ');
// If no command was specified, show bower help
// Do the same if the command is unknown
if (!commandFunc) {
logger = bower.commands.help();
command = 'help';
// If the user requested help, show the command's help
// Do the same if the actual command is a group of other commands (e.g.: cache)
} else if (options.help || !commandFunc.line) {
logger = bower.commands.help(command);
command = 'help';
// Call the line method
} else {
logger = commandFunc.line(process.argv);
// If the method failed to interpret the process arguments
// show the command help
if (!logger) {
logger = bower.commands.help(command);
command = 'help';
}
}
// Get the renderer and configure it with the executed command
renderer = cli.getRenderer(command, logger.json, bower.config);
logger
.on('end', function (data) {
if (!bower.config.silent && !bower.config.quiet) {
renderer.end(data);
}
})
.on('error', function (err) {
if (levels.error >= loglevel) {
renderer.error(err);
}
process.exit(1);
})
.on('log', function (log) {
if (levels[log.level] >= loglevel) {
renderer.log(log);
}
})
.on('prompt', function (prompt, callback) {
renderer.prompt(prompt)
.then(function (answer) {
callback(answer);
});
});
// Warn if HOME is not SET
if (!userHome) {
logger.warn('no-home', 'HOME environment variable not set. User config will not be loaded.');
}
if (bower.config.interactive) {
var updateNotifier = require('update-notifier');
// Check for newer version of Bower
var notifier = updateNotifier({pkg: pkg});
if (notifier.update && levels.info >= loglevel) {
notifier.notify();
}
}
});
require('../lib/bin/bower');

145
lib/bin/bower.js Normal file
View File

@@ -0,0 +1,145 @@
process.bin = process.title = 'bower';
var Q = require('q');
var mout = require('mout');
var Logger = require('bower-logger');
var userHome = require('user-home');
var bower = require('../');
var version = require('../version');
var cli = require('../util/cli');
var rootCheck = require('../util/rootCheck');
var options;
var renderer;
var loglevel;
var command;
var commandFunc;
var logger;
var levels = Logger.LEVELS;
options = cli.readOptions({
'version': { type: Boolean, shorthand: 'v' },
'help': { type: Boolean, shorthand: 'h' },
'allow-root': { type: Boolean }
});
// Handle print of version
if (options.version) {
process.stdout.write(version + '\n');
process.exit();
}
// Root check
rootCheck(options, bower.config);
// Set loglevel
if (bower.config.silent) {
loglevel = levels.error;
} else if (bower.config.verbose) {
loglevel = -Infinity;
Q.longStackSupport = true;
} else if (bower.config.quiet) {
loglevel = levels.warn;
} else {
loglevel = levels[bower.config.loglevel] || levels.info;
}
// Get the command to execute
while (options.argv.remain.length) {
command = options.argv.remain.join(' ');
// Alias lookup
if (bower.abbreviations[command]) {
command = bower.abbreviations[command].replace(/\s/g, '.');
break;
}
command = command.replace(/\s/g, '.');
// Direct lookup
if (mout.object.has(bower.commands, command)) {
break;
}
options.argv.remain.pop();
}
// Execute the command
commandFunc = command && mout.object.get(bower.commands, command);
command = command && command.replace(/\./g, ' ');
// If no command was specified, show bower help
// Do the same if the command is unknown
if (!commandFunc) {
logger = bower.commands.help();
command = 'help';
// If the user requested help, show the command's help
// Do the same if the actual command is a group of other commands (e.g.: cache)
} else if (options.help || !commandFunc.line) {
logger = bower.commands.help(command);
command = 'help';
// Call the line method
} else {
logger = commandFunc.line(process.argv);
// If the method failed to interpret the process arguments
// show the command help
if (!logger) {
logger = bower.commands.help(command);
command = 'help';
}
}
// Get the renderer and configure it with the executed command
renderer = cli.getRenderer(command, logger.json, bower.config);
function handleLogger(logger, renderer) {
logger
.on('end', function (data) {
if (!bower.config.silent && !bower.config.quiet) {
renderer.end(data);
}
})
.on('error', function (err) {
if (command !== 'help' && (err.code === 'EREADOPTIONS' || err.code === 'EINVFORMAT')) {
logger = bower.commands.help(command);
renderer = cli.getRenderer('help', logger.json, bower.config);
handleLogger(logger, renderer);
} else {
if (levels.error >= loglevel) {
renderer.error(err);
}
process.exit(1);
}
})
.on('log', function (log) {
if (levels[log.level] >= loglevel) {
renderer.log(log);
}
})
.on('prompt', function (prompt, callback) {
renderer.prompt(prompt)
.then(function (answer) {
callback(answer);
});
});
}
handleLogger(logger, renderer);
// Warn if HOME is not SET
if (!userHome) {
logger.warn('no-home', 'HOME environment variable not set. User config will not be loaded.');
}
if (bower.config.interactive) {
var updateNotifier = require('update-notifier');
// Check for newer version of Bower
var notifier = updateNotifier({ pkg: { name: 'bower', version: version } });
if (notifier.update && levels.info >= loglevel) {
notifier.notify();
}
}

View File

@@ -1,8 +1,8 @@
var fs = require('graceful-fs');
var fs = require('../../util/fs');
var path = require('path');
var mout = require('mout');
var Q = require('q');
var rimraf = require('rimraf');
var rimraf = require('../../util/rimraf');
var endpointParser = require('bower-endpoint-parser');
var PackageRepository = require('../../core/PackageRepository');
var semver = require('../../util/semver');

View File

@@ -1,15 +1,15 @@
var Q = require('q');
var path = require('path');
var fs = require('graceful-fs');
var fs = require('../util/fs');
var createError = require('../util/createError');
function help(logger, name, config) {
var json;
if (name) {
json = path.resolve(__dirname, '../../templates/json/help-' + name.replace(/\s+/g, '/') + '.json');
json = path.resolve(__dirname, '../templates/json/help-' + name.replace(/\s+/g, '/') + '.json');
} else {
json = path.resolve(__dirname, '../../templates/json/help.json');
json = path.resolve(__dirname, '../templates/json/help.json');
}
return Q.promise(function (resolve) {

View File

@@ -40,7 +40,7 @@ function home(logger, name, config) {
throw createError('No homepage set for ' + pkgMeta.name, 'ENOHOME');
}
open(homepage);
open(homepage, { wait: false });
return homepage;
});
}

View File

@@ -1,5 +1,6 @@
var Q = require('q');
var Logger = require('bower-logger');
var config = require('../config');
/**
* Require commands only when called.
@@ -9,24 +10,24 @@ var Logger = require('bower-logger');
* return as soon as possible and load and execute the command asynchronously.
*/
function commandFactory(id) {
if (process.env.STRICT_REQUIRE) {
require(id);
}
function command() {
function runApi() {
var command = require(id);
var commandArgs = [].slice.call(arguments);
return withLogger(function (logger) {
commandArgs.unshift(logger);
return require(id).apply(undefined, commandArgs);
return command.apply(undefined, commandArgs);
});
}
function runFromArgv(argv) {
return withLogger(function (logger) {
var command = require(id);
var commandArgs;
var command = require(id);
var commandArgs = command.readOptions(argv);
commandArgs = command.readOptions(argv);
return withLogger(function (logger) {
commandArgs.unshift(logger);
return command.apply(undefined, commandArgs);
@@ -38,19 +39,21 @@ function commandFactory(id) {
Q.try(func, logger)
.done(function () {
config.restore();
var args = [].slice.call(arguments);
args.unshift('end');
logger.emit.apply(logger, args);
}, function (error) {
config.restore();
logger.emit('error', error);
});
return logger;
}
command.line = runFromArgv;
runApi.line = runFromArgv;
return command;
return runApi;
}

View File

@@ -2,7 +2,6 @@ var mout = require('mout');
var Q = require('q');
var endpointParser = require('bower-endpoint-parser');
var PackageRepository = require('../core/PackageRepository');
var Tracker = require('../util/analytics').Tracker;
var defaultConfig = require('../config');
function info(logger, endpoint, property, config) {
@@ -10,48 +9,51 @@ function info(logger, endpoint, property, config) {
return;
}
// handle @ as version divider
var splitParts = endpoint.split('/');
splitParts[splitParts.length - 1] = splitParts[splitParts.length - 1].replace('@', '#');
endpoint = splitParts.join('/');
var repository;
var decEndpoint;
var tracker;
config = defaultConfig(config);
repository = new PackageRepository(config, logger);
tracker = new Tracker(config);
decEndpoint = endpointParser.decompose(endpoint);
tracker.trackDecomposedEndpoints('info', [decEndpoint]);
return Q.all([
getPkgMeta(repository, decEndpoint, property),
decEndpoint.target === '*' && !property ? repository.versions(decEndpoint.source) : null
])
.spread(function (pkgMeta, versions) {
if (versions) {
return {
name: decEndpoint.source,
versions: versions,
latest: pkgMeta
};
}
.spread(function (pkgMeta, versions) {
if (versions) {
return {
name: decEndpoint.source,
versions: versions,
latest: pkgMeta
};
}
return pkgMeta;
});
return pkgMeta;
});
}
function getPkgMeta(repository, decEndpoint, property) {
return repository.fetch(decEndpoint)
.spread(function (canonicalDir, pkgMeta) {
pkgMeta = mout.object.filter(pkgMeta, function (value, key) {
return key.charAt(0) !== '_';
.spread(function (canonicalDir, pkgMeta) {
pkgMeta = mout.object.filter(pkgMeta, function (value, key) {
return key.charAt(0) !== '_';
});
// Retrieve specific property
if (property) {
pkgMeta = mout.object.get(pkgMeta, property);
}
return pkgMeta;
});
// Retrieve specific property
if (property) {
pkgMeta = mout.object.get(pkgMeta, property);
}
return pkgMeta;
});
}
// -------------------

View File

@@ -1,12 +1,11 @@
var mout = require('mout');
var fs = require('graceful-fs');
var fs = require('../util/fs');
var path = require('path');
var Q = require('q');
var endpointParser = require('bower-endpoint-parser');
var Project = require('../core/Project');
var defaultConfig = require('../config');
var GitHubResolver = require('../core/resolvers/GitHubResolver');
var GitFsResolver = require('../core/resolvers/GitFsResolver');
var cmd = require('../util/cmd');
var createError = require('../util/createError');
@@ -58,7 +57,7 @@ function readJson(project, logger) {
function saveJson(project, logger, json) {
// Cleanup empty props (null values, empty strings, objects and arrays)
mout.object.forOwn(json, function (value, key) {
if (value == null || mout.lang.isEmpty(value)) {
if (!validConfigValue(value)) {
delete json[key];
}
});
@@ -81,6 +80,18 @@ function saveJson(project, logger, json) {
});
}
// Test if value is of a type supported by bower.json[0] - Object, Array, String, Boolean - or a Number
// [0]: https://github.com/bower/bower.json-spec
function validConfigValue(val) {
return (
mout.lang.isObject(val) ||
mout.lang.isArray(val) ||
mout.lang.isString(val) ||
mout.lang.isBoolean(val) ||
mout.lang.isNumber(val)
);
}
function setDefaults(config, json) {
var name;
var promise = Q.resolve();
@@ -90,19 +101,6 @@ function setDefaults(config, json) {
json.name = path.basename(config.cwd);
}
// Version
if (!json.version) {
// Assume latest semver tag if it's a git repo
promise = promise.then(function () {
return GitFsResolver.versions(config.cwd)
.then(function (versions) {
json.version = versions[0] || '0.0.0';
}, function () {
json.version = '0.0.0';
});
});
}
// Main
if (!json.main) {
// Remove '.js' from the end of the package name if it is there
@@ -176,12 +174,6 @@ function promptUser(logger, json) {
'default': json.name,
'type': 'input'
},
{
'name': 'version',
'message': 'version',
'default': json.version,
'type': 'input'
},
{
'name': 'description',
'message': 'description',
@@ -194,12 +186,6 @@ function promptUser(logger, json) {
'default': json.main,
'type': 'input'
},
{
'name': 'moduleType',
'message': 'what types of modules does this package expose?',
'type': 'checkbox',
'choices': ['amd', 'es6', 'globals', 'node', 'yui']
},
{
'name': 'keywords',
'message': 'keywords',
@@ -247,10 +233,8 @@ function promptUser(logger, json) {
return Q.nfcall(logger.prompt.bind(logger), questions)
.then(function (answers) {
json.name = answers.name;
json.version = answers.version;
json.description = answers.description;
json.main = answers.main;
json.moduleType = answers.moduleType;
json.keywords = toArray(answers.keywords);
json.authors = toArray(answers.authors, ',');
json.license = answers.license;

View File

@@ -1,12 +1,10 @@
var endpointParser = require('bower-endpoint-parser');
var Project = require('../core/Project');
var Tracker = require('../util/analytics').Tracker;
var defaultConfig = require('../config');
function install(logger, endpoints, options, config) {
var project;
var decEndpoints;
var tracker;
options = options || {};
config = defaultConfig(config);
@@ -14,14 +12,18 @@ function install(logger, endpoints, options, config) {
options.save = config.defaultSave;
}
project = new Project(config, logger);
tracker = new Tracker(config);
// Convert endpoints to decomposed endpoints
endpoints = endpoints || [];
decEndpoints = endpoints.map(function (endpoint) {
// handle @ as version divider
var splitParts = endpoint.split('/');
splitParts[splitParts.length - 1] = splitParts[splitParts.length - 1].replace('@', '#');
endpoint = splitParts.join('/');
return endpointParser.decompose(endpoint);
});
tracker.trackDecomposedEndpoints('install', decEndpoints);
return project.install(decEndpoints, options, config);
}
@@ -32,11 +34,11 @@ install.readOptions = function (argv) {
var cli = require('../util/cli');
var options = cli.readOptions({
'force-latest': { type: Boolean, shorthand: 'F'},
'production': { type: Boolean, shorthand: 'p' },
'save': { type: Boolean, shorthand: 'S' },
'save-dev': { type: Boolean, shorthand: 'D' },
'save-exact': { type: Boolean, shorthand: 'E' }
'force-latest': {type: Boolean, shorthand: 'F'},
'production': {type: Boolean, shorthand: 'p'},
'save': {type: Boolean, shorthand: 'S'},
'save-dev': {type: Boolean, shorthand: 'D'},
'save-exact': {type: Boolean, shorthand: 'E'}
}, argv);
var packages = options.argv.remain.slice(1);

View File

@@ -1,9 +1,10 @@
var path = require('path');
var rimraf = require('rimraf');
var rimraf = require('../util/rimraf');
var Q = require('q');
var Project = require('../core/Project');
var createLink = require('../util/createLink');
var defaultConfig = require('../config');
var relativeToBaseDir = require('../util/relativeToBaseDir');
function link(logger, name, localName, config) {
if (name) {
@@ -49,7 +50,7 @@ function linkTo(logger, name, localName, config) {
localName = localName || name;
src = path.join(config.storage.links, name);
dst = path.join(config.cwd, config.directory, localName);
dst = path.join(relativeToBaseDir(config.cwd)(config.directory), localName);
// Delete destination folder if any
return Q.nfcall(rimraf, dst)

View File

@@ -63,6 +63,7 @@ function login(logger, options, config) {
return promise.then(function (result) {
configstore.set('accessToken', result.token);
logger.info('EAUTH', 'Logged in as ' + configstore.get('username'), {});
return result;
}, function (error) {
@@ -95,6 +96,7 @@ function login(logger, options, config) {
})
.then(function (result) {
configstore.set('accessToken', result.token);
logger.info('EAUTH', 'Logged in as ' + configstore.get('username'), {});
return result;
}, function () {

View File

@@ -1,5 +1,5 @@
var Q = require('q');
var RegistryClient = require('bower-registry-client');
var PackageRepository = require('../core/PackageRepository');
var defaultConfig = require('../config');
function lookup(logger, name, config) {
@@ -7,17 +7,13 @@ function lookup(logger, name, config) {
return new Q(null);
}
var registryClient;
config = defaultConfig(config);
config.cache = config.storage.registry;
registryClient = new RegistryClient(config, logger);
var repository = new PackageRepository(config, logger);
var registryClient = repository.getRegistryClient();
return Q.nfcall(registryClient.lookup.bind(registryClient), name)
.then(function (entry) {
// TODO: Handle entry.type.. for now it's only 'alias'
// When we got published packages, this needs to be adjusted
return !entry ? null : {
name: name,
url: entry && entry.url

View File

@@ -1,25 +1,26 @@
var mout = require('mout');
var Q = require('q');
var chalk = require('chalk');
var PackageRepository = require('../core/PackageRepository');
var Config = require('bower-config');
var Tracker = require('../util/analytics').Tracker;
var createError = require('../util/createError');
var defaultConfig = require('../config');
var GitHubResolver = require('../core/resolvers/GitHubResolver');
function register(logger, name, url, config) {
function register(logger, name, source, config) {
var repository;
var registryClient;
var tracker;
var force;
var url;
var githubSourceRegex = /^\w[\w-]*\/\w[\w-]*$/;
var getGithubUrl = function (source) {
return 'git@github.com:' + source + '.git';
};
config = defaultConfig(config);
force = config.force;
tracker = new Tracker(config);
name = (name || '').trim();
url = (url || '').trim();
source = (source || '').trim();
url = source.match(githubSourceRegex) ? getGithubUrl(source) : source;
// Bypass any cache
config.offline = false;
@@ -31,18 +32,6 @@ function register(logger, name, url, config) {
throw createError('Usage: bower register <name> <url>', 'EINVFORMAT');
}
// The public registry only allows git:// endpoints
// As such, we attempt to convert URLs as necessary
if (config.registry.register === Config.DEFAULT_REGISTRY) {
url = convertUrl(url, logger);
if (!mout.string.startsWith(url, 'git://')) {
throw createError('The registry only accepts URLs starting with git://', 'EINVFORMAT');
}
}
tracker.track('register');
// Attempt to resolve the package referenced by the URL to ensure
// everything is ok before registering
repository = new PackageRepository(config, logger);
@@ -84,22 +73,6 @@ function register(logger, name, url, config) {
});
}
function convertUrl(url, logger) {
var pair;
var newUrl;
if (!mout.string.startsWith(url, 'git://')) {
// Convert GitHub ssh & https to git://
pair = GitHubResolver.getOrgRepoPair(url);
if (pair) {
newUrl = 'git://github.com/' + pair.org + '/' + pair.repo + '.git';
logger.warn('convert', 'Converted ' + url + ' to ' + newUrl);
}
}
return newUrl || url;
}
// -------------------
register.readOptions = function (argv) {

View File

@@ -1,34 +1,37 @@
var Q = require('q');
var RegistryClient = require('bower-registry-client');
var Tracker = require('../util/analytics').Tracker;
var PackageRepository = require('../core/PackageRepository');
var defaultConfig = require('../config');
var cli = require('../util/cli');
var createError = require('../util/createError');
function search(logger, name, config) {
var registryClient;
var tracker;
config = defaultConfig(config);
config.cache = config.storage.registry;
registryClient = new RegistryClient(config, logger);
tracker = new Tracker(config);
tracker.track('search', name);
var repository = new PackageRepository(config, logger);
var registryClient = repository.getRegistryClient();
// If no name was specified, list all packages
if (!name) {
return Q.nfcall(registryClient.list.bind(registryClient));
// Otherwise search it
} else {
if (name) {
return Q.nfcall(registryClient.search.bind(registryClient), name);
} else {
// List all packages when in interactive mode + json enabled, and
// always when in non-interactive mode
if (config.interactive && !config.json) {
throw createError('no parameter to bower search', 'EREADOPTIONS');
}
return Q.nfcall(registryClient.list.bind(registryClient));
}
}
// -------------------
search.readOptions = function (argv) {
var cli = require('../util/cli');
var options = cli.readOptions(argv);
var name = options.argv.remain.slice(1).join(' ');
var terms = options.argv.remain.slice(1);
var name = terms.join(' ');
return [name];
};

View File

@@ -1,7 +1,6 @@
var mout = require('mout');
var Q = require('q');
var Project = require('../core/Project');
var Tracker = require('../util/analytics').Tracker;
var defaultConfig = require('../config');
function uninstall(logger, names, options, config) {
@@ -10,14 +9,10 @@ function uninstall(logger, names, options, config) {
}
var project;
var tracker;
options = options || {};
config = defaultConfig(config);
project = new Project(config, logger);
tracker = new Tracker(config);
tracker.trackNames('uninstall', names);
return project.getTree(options)
.spread(function (tree, flattened) {

View File

@@ -3,7 +3,6 @@ var Q = require('q');
var defaultConfig = require('../config');
var PackageRepository = require('../core/PackageRepository');
var Tracker = require('../util/analytics').Tracker;
var createError = require('../util/createError');
function unregister(logger, name, config) {
@@ -14,12 +13,10 @@ function unregister(logger, name, config) {
var repository;
var registryClient;
var tracker;
var force;
config = defaultConfig(config);
force = config.force;
tracker = new Tracker(config);
// Bypass any cache
config.offline = false;
@@ -30,8 +27,6 @@ function unregister(logger, name, config) {
repository = new PackageRepository(config, logger);
tracker.track('unregister');
if (!config.accessToken) {
return logger.emit('error',
createError('Use "bower login" with collaborator credentials', 'EFORBIDDEN')
@@ -64,7 +59,6 @@ function unregister(logger, name, config) {
return Q.nfcall(registryClient.unregister.bind(registryClient), name);
})
.then(function (result) {
tracker.track('unregistered');
logger.info('Package unregistered', name);
return result;

View File

@@ -1,119 +1,152 @@
var semver = require('semver');
var which = require('which');
var fs = require('fs');
var fs = require('../util/fs');
var path = require('path');
var Q = require('q');
var execFile = require('child_process').execFile;
var Project = require('../core/Project');
var defaultConfig = require('../config');
var createError = require('../util/createError');
function version(logger, versionArg, options, config) {
var project;
options = options || {};
config = defaultConfig(config);
project = new Project(config, logger);
return bump(project, versionArg, options.message);
return bump(logger, config, versionArg, options.message);
}
function bump(project, versionArg, message) {
var cwd = project._config.cwd || process.cwd();
function bump(logger, config, versionArg, message) {
var cwd = config.cwd || process.cwd();
var newVersion;
var doGitCommit = false;
return checkGit(cwd)
.then(function (hasGit) {
doGitCommit = hasGit;
})
.then(project.getJson.bind(project))
.then(function (json) {
newVersion = getNewVersion(json.version, versionArg);
json.version = newVersion;
})
.then(project.saveJson.bind(project))
.then(function () {
if (doGitCommit) {
return gitCommitAndTag(cwd, newVersion, message);
}
})
.then(function () {
console.log('v' + newVersion);
return newVersion;
});
}
function getNewVersion(currentVersion, versionArg) {
var newVersion = semver.valid(versionArg);
if (!newVersion) {
newVersion = semver.inc(currentVersion, versionArg);
if (!versionArg) {
throw createError('No <version> agrument provided', 'EREADOPTIONS');
}
if (!newVersion) {
throw createError('Invalid version argument: `' + versionArg + '`. Usage: `bower version [<newversion> | major | minor | patch]`', 'EINVALIDVERSION');
}
if (currentVersion === newVersion) {
throw createError('Version not changed', 'EVERSIONNOTCHANGED');
}
return newVersion;
}
function checkGit(cwd) {
var gitDir = path.join(cwd, '.git');
return Q.nfcall(fs.stat, gitDir)
.then(function (stat) {
if (stat.isDirectory()) {
return checkGitStatus(cwd);
return driver.check(cwd)
.then(function () {
return Q.all([driver.versions(cwd), driver.currentVersion(cwd)]);
})
.spread(function (versions, currentVersion) {
currentVersion = currentVersion || '0.0.0';
if (semver.valid(versionArg)) {
newVersion = semver.valid(versionArg);
} else {
newVersion = semver.inc(currentVersion, versionArg);
if (!newVersion) {
throw createError('Invalid <version> argument: ' + versionArg, 'EINVALIDVERSION', { version: versionArg });
}
}
return false;
}, function () {
//Ignore not found .git directory
return false;
});
}
function checkGitStatus(cwd) {
return Q.nfcall(which, 'git')
.fail(function (err) {
err.code = 'ENOGIT';
throw err;
})
.then(function () {
return Q.nfcall(execFile, 'git', ['status', '--porcelain'], {env: process.env, cwd: cwd});
})
.then(function (value) {
var stdout = value[0];
var lines = filterModifiedStatusLines(stdout);
if (lines.length) {
throw createError('Git working directory not clean.\n' + lines.join('\n'), 'EWORKINGDIRECTORYDIRTY');
newVersion = (currentVersion[0] === 'v') ? 'v' + newVersion : newVersion;
if (versions) {
versions.forEach(function (version) {
if (semver.eq(version, newVersion)) {
throw createError('Version exists: ' + newVersion, 'EVERSIONEXISTS', { versions: versions, newVersion: newVersion });
}
});
}
return true;
});
}
function filterModifiedStatusLines(stdout) {
return stdout.trim().split('\n')
.filter(function (line) {
return line.trim() && !line.match(/^\?\? /);
}).map(function (line) {
return line.trim();
});
}
function gitCommitAndTag(cwd, newVersion, message) {
var tag = 'v' + newVersion;
message = message || tag;
message = message.replace(/%s/g, newVersion);
return Q.nfcall(execFile, 'git', ['add', 'bower.json'], {env: process.env, cwd: cwd})
.then(function () {
return Q.nfcall(execFile, 'git', ['commit', '-m', message], {env: process.env, cwd: cwd});
return driver.bump(cwd, newVersion, message).then(function () {
return {
oldVersion: currentVersion,
newVersion: newVersion
}
});
})
.then(function () {
return Q.nfcall(execFile, 'git', ['tag', tag, '-am', message], {env: process.env, cwd: cwd});
.then(function (result) {
logger.info('version', 'Bumped package version from ' + result.oldVersion + ' to ' + result.newVersion, result);
return result.newVersion;
});
}
// -------------------
var driver = {
check: function (cwd) {
function checkGit(cwd) {
var gitDir = path.join(cwd, '.git');
return Q.nfcall(fs.stat, gitDir)
.then(function (stat) {
if (stat.isDirectory()) {
return checkGitStatus(cwd);
}
return false;
}, function () {
//Ignore not found .git directory
return false;
});
}
function checkGitStatus(cwd) {
return Q.nfcall(which, 'git')
.fail(function (err) {
err.code = 'ENOGIT';
throw err;
})
.then(function () {
return Q.nfcall(execFile, 'git', ['status', '--porcelain'], {env: process.env, cwd: cwd});
})
.then(function (value) {
var stdout = value[0];
var lines = filterModifiedStatusLines(stdout);
if (lines.length) {
throw createError('Version bump requires clean working directory', 'EWORKINGDIRECTORYDIRTY');
}
return true;
});
}
function filterModifiedStatusLines(stdout) {
return stdout.trim().split('\n')
.filter(function (line) {
return line.trim() && !line.match(/^\?\? /);
}).map(function (line) {
return line.trim();
});
}
return checkGit(cwd).then(function (hasGit) {
if (!hasGit) {
throw createError('Version bump currently supports only git repositories', 'ENOTGITREPOSITORY');
}
});
},
versions: function (cwd) {
return Q.nfcall(execFile, 'git', ['tag'], {env: process.env, cwd: cwd})
.then(function (res) {
var versions = res[0]
.split(/\r?\n/)
.filter(semver.valid);
return versions;
}, function () {
return [];
});
},
currentVersion: function (cwd) {
return Q.nfcall(execFile, 'git', ['describe', '--abbrev=0', '--tags'], {env: process.env, cwd: cwd})
.then(function (res) {
var version = res[0]
.split(/\r?\n/)
.filter(semver.valid)[0];
return version;
}, function () {
return undefined;
});
},
bump: function (cwd, tag, message) {
message = message || tag;
message = message.replace(/%s/g, tag);
return Q.nfcall(execFile, 'git', ['commit', '-m', message, '--allow-empty'], {env: process.env, cwd: cwd}) .then(function () {
return Q.nfcall(execFile, 'git', ['tag', tag, '-am', message], {env: process.env, cwd: cwd});
});
}
}
version.readOptions = function (argv) {
var cli = require('../util/cli');

View File

@@ -2,39 +2,24 @@ var tty = require('tty');
var object = require('mout').object;
var bowerConfig = require('bower-config');
var Configstore = require('configstore');
var findup = require('findup-sync');
var path = require('path');
var cachedConfigs = {};
var current;
function defaultConfig(config) {
config = config || {};
var cwd = config.cwd || path.dirname(findup('bower.json', {
cwd: process.cwd()
})) || process.cwd();
config.cwd = cwd;
var cachedConfig = readCachedConfig(cwd);
return object.merge(cachedConfig, config);
return readCachedConfig(config.cwd || process.cwd(), config);
}
function readCachedConfig(cwd) {
if (cachedConfigs[cwd]) {
return cachedConfigs[cwd];
}
function readCachedConfig(cwd, overwrites) {
current = bowerConfig.create(cwd).load(overwrites);
var config = current.toObject();
var config = cachedConfigs[cwd] = bowerConfig.read(cwd);
var configstore = new Configstore('bower-github').all;
object.mixIn(config, configstore);
// Delete the json attribute because it is no longer supported
// and conflicts with --json
delete config.json;
// If interactive is auto (null), guess its value
if (config.interactive == null) {
config.interactive = (
@@ -62,9 +47,17 @@ function readCachedConfig(cwd) {
return config;
}
function resetCache () {
cachedConfigs = {};
function restoreConfig() {
if (current) {
current.restore();
}
}
function resetCache() {
restoreConfig();
current = undefined;
}
module.exports = defaultConfig;
module.exports.restore = restoreConfig;
module.exports.reset = resetCache;

View File

@@ -2,14 +2,15 @@ var Q = require('q');
var mout = require('mout');
var path = require('path');
var mkdirp = require('mkdirp');
var rimraf = require('rimraf');
var fs = require('graceful-fs');
var rimraf = require('../util/rimraf');
var fs = require('../util/fs');
var endpointParser = require('bower-endpoint-parser');
var PackageRepository = require('./PackageRepository');
var semver = require('../util/semver');
var copy = require('../util/copy');
var createError = require('../util/createError');
var scripts = require('./scripts');
var relativeToBaseDir = require('../util/relativeToBaseDir');
function Manager(config, logger) {
this._config = config;
@@ -23,11 +24,13 @@ function Manager(config, logger) {
Manager.prototype.configure = function (setup) {
var targetsHash = {};
this._conflicted = {};
// Targets
this._targets = setup.targets || [];
// Targets - ignore those specified in ignoredDependencies
this._targets = mout.array.reject(setup.targets || [], function (target) {
return mout.array.contains(this._config.ignoredDependencies, target.name );
}, this);
this._targets.forEach(function (decEndpoint) {
decEndpoint.initialName = decEndpoint.name;
decEndpoint.dependants = mout.object.values(decEndpoint.dependants);
@@ -122,7 +125,7 @@ Manager.prototype.resolve = function () {
Manager.prototype.preinstall = function (json) {
var that = this;
var componentsDir = path.join(this._config.cwd, this._config.directory);
var componentsDir = relativeToBaseDir(this._config.cwd)(this._config.directory);
// If nothing to install, skip the code bellow
if (mout.lang.isEmpty(that._dissected)) {
@@ -139,7 +142,7 @@ Manager.prototype.preinstall = function (json) {
Manager.prototype.postinstall = function (json) {
var that = this;
var componentsDir = path.join(this._config.cwd, this._config.directory);
var componentsDir = relativeToBaseDir(this._config.cwd)(this._config.directory);
// If nothing to install, skip the code bellow
if (mout.lang.isEmpty(that._dissected)) {
@@ -156,6 +159,7 @@ Manager.prototype.postinstall = function (json) {
Manager.prototype.install = function (json) {
var componentsDir;
var componentsDirContents;
var that = this;
// If already resolving, error out
@@ -168,20 +172,29 @@ Manager.prototype.install = function (json) {
return Q.resolve({});
}
componentsDir = path.join(this._config.cwd, this._config.directory);
componentsDir = relativeToBaseDir(this._config.cwd)(this._config.directory);
return Q.nfcall(mkdirp, componentsDir)
.then(function () {
var promises = [];
componentsDirContents = fs.readdirSync(componentsDir);
mout.object.forOwn(that._dissected, function (decEndpoint, name) {
var promise;
var dst;
var release = decEndpoint.pkgMeta._release;
var exists = mout.array.contains(componentsDirContents, name);
that._logger.action('install', name + (release ? '#' + release : ''), that.toData(decEndpoint));
dst = path.join(componentsDir, name);
if (exists && !that._installed[name] && !that._config.force) {
// There is a folder in the components directory that has
// this name, but it was not installed by bower.
that._logger.warn('skipped', name + ' was not installed because there is already a non-bower directory with that name in the components directory (' + path.relative(that._config.cwd, dst) + '). You can force installation with --force.');
return;
}
// Remove existent and copy canonical dir
promise = Q.nfcall(rimraf, dst)
.then(copy.copyDir.bind(copy, decEndpoint.canonicalDir, dst))
@@ -373,7 +386,7 @@ Manager.prototype._onFetchSuccess = function (decEndpoint, canonicalDir, pkgMeta
// If the package is not targetable, flag it
// It will be needed later so that untargetable endpoints
// will not get * converted to ~version
// will not get * converted to ^version
if (!isTargetable) {
decEndpoint.untargetable = true;
}
@@ -445,6 +458,12 @@ Manager.prototype._parseDependencies = function (decEndpoint, pkgMeta) {
var compatible;
var childDecEndpoint = endpointParser.json2decomposed(key, value);
// Check if this depdendency should be skipped.
if (mout.array.contains(this._config.ignoredDependencies, childDecEndpoint.name)) {
this._logger.action('skipped', childDecEndpoint.name, this.toData(decEndpoint));
return;
}
// Check if a compatible one is already resolved
// If there's one, we don't need to resolve it twice
resolved = this._resolved[key];
@@ -568,6 +587,17 @@ Manager.prototype._dissect = function () {
}
}
// If they are equal and one of them is an exact target,
// give higher priority
if (!result) {
if (first.target === first.pkgMeta.version) {
return -1;
}
if (second.target === second.pkgMeta.version) {
return 1;
}
}
return result;
});
@@ -576,7 +606,7 @@ Manager.prototype._dissect = function () {
// If they are not, the resolver is incapable of handling targets
semvers.forEach(function (decEndpoint) {
if (decEndpoint.newly && decEndpoint.target === '*' && !decEndpoint.untargetable) {
decEndpoint.target = '~' + decEndpoint.pkgMeta.version;
decEndpoint.target = '^' + decEndpoint.pkgMeta.version;
decEndpoint.originalTarget = '*';
}
});
@@ -616,7 +646,7 @@ Manager.prototype._dissect = function () {
}, this);
// Filter only packages that need to be installed
componentsDir = path.resolve(that._config.cwd, that._config.directory);
componentsDir = relativeToBaseDir(this._config.cwd)(this._config.directory);
this._dissected = mout.object.filter(suitables, function (decEndpoint, name) {
var installedMeta = this._installed[name];
var dst;
@@ -659,6 +689,8 @@ Manager.prototype._electSuitable = function (name, semvers, nonSemvers) {
var save;
var choices;
var picks = [];
var versionRegex = /(?:[\d\w]\.){2}[\d\w](?:.)*/;
var picksReleases;
// If there are both semver and non-semver, there's no way
// to figure out the suitable one
@@ -814,14 +846,21 @@ Manager.prototype._electSuitable = function (name, semvers, nonSemvers) {
});
choices = picks.map(function (pick, index) { return index + 1; });
picksReleases = picks.map(function (pick) { return pick.pkgMeta._release; });
return Q.nfcall(this._logger.prompt.bind(this._logger), {
type: 'input',
message: 'Answer',
validate: function (choice) {
var invalidChoice = 'Invalid choice';
if (choice.match(versionRegex)) {
return picksReleases.indexOf(choice) != -1 ? true : invalidChoice;
}
choice = Number(mout.string.trim(choice.trim(), '!'));
if (!choice || choice < 1 || choice > picks.length) {
return 'Invalid choice';
return invalidChoice;
}
return true;
@@ -833,8 +872,13 @@ Manager.prototype._electSuitable = function (name, semvers, nonSemvers) {
// Sanitize choice
choice = choice.trim();
save = /^!/.test(choice) || /!$/.test(choice); // Save if prefixed or suffixed with !
choice = Number(mout.string.trim(choice, '!'));
pick = picks[choice - 1];
if (choice.match(versionRegex)) {
pick = picks[picksReleases.indexOf(choice)];
} else {
choice = Number(mout.string.trim(choice, '!'));
pick = picks[choice - 1];
}
// Save resolution
if (save) {

View File

@@ -1,11 +1,12 @@
var mout = require('mout');
var Q = require('q');
var RegistryClient = require('bower-registry-client');
var ResolveCache = require('./ResolveCache');
var resolverFactory = require('./resolverFactory');
var createError = require('../util/createError');
var RegistryClient = require('bower-registry-client');
function PackageRepository(config, logger) {
var registryOptions;
this._config = config;
@@ -14,6 +15,7 @@ function PackageRepository(config, logger) {
// Instantiate the registry
registryOptions = mout.object.deepMixIn({}, this._config);
registryOptions.cache = this._config.storage.registry;
this._registryClient = new RegistryClient(registryOptions, logger);
// Instantiate the resolve cache
@@ -87,7 +89,7 @@ PackageRepository.prototype.fetch = function (decEndpoint) {
}
// Otherwise check for new contents
logger.action('validate', (pkgMeta._release ? pkgMeta._release + ' against ': '') +
logger.action('validate', (pkgMeta._release ? pkgMeta._release + ' against ' : '') +
resolver.getSource() + (resolver.getTarget() ? '#' + resolver.getTarget() : ''));
return resolver.hasNew(pkgMeta)

View File

@@ -1,27 +1,22 @@
var glob = require('glob');
var path = require('path');
var fs = require('graceful-fs');
var fs = require('../util/fs');
var Q = require('q');
var mout = require('mout');
var rimraf = require('rimraf');
var rimraf = require('../util/rimraf');
var endpointParser = require('bower-endpoint-parser');
var Logger = require('bower-logger');
var md5 = require('md5-hex');
var Manager = require('./Manager');
var defaultConfig = require('../config');
var semver = require('../util/semver');
var md5 = require('../util/md5');
var createError = require('../util/createError');
var readJson = require('../util/readJson');
var validLink = require('../util/validLink');
var scripts = require('./scripts');
var sortobject = require('deep-sort-object');
var relativeToBaseDir = require('../util/relativeToBaseDir');
function Project(config, logger) {
// This is the only architecture component that ensures defaults
// on config and logger
// The reason behind it is that users can likely use this component
// directly if commands do not fulfil their needs
this._config = defaultConfig(config);
this._config = config;
this._logger = logger || new Logger();
this._manager = new Manager(this._config, this._logger);
@@ -50,7 +45,7 @@ Project.prototype.install = function (decEndpoints, options, config) {
.spread(function (json, tree) {
// It shows an error when issuing `bower install`
// and no bower.json is present in current directory
if(!that._jsonFile && decEndpoints.length === 0 ) {
if (!that._jsonFile && decEndpoints.length === 0 ) {
throw createError('No bower.json present', 'ENOENT');
}
@@ -87,23 +82,25 @@ Project.prototype.install = function (decEndpoints, options, config) {
})
.then(function (installed) {
// Handle save and saveDev options
if (that._options.save || that._options.saveDev) {
if (that._options.save || that._options.saveDev || that._options.saveExact || that._config.save || that._config.saveExact) {
// Cycle through the specified endpoints
decEndpoints.forEach(function (decEndpoint) {
var jsonEndpoint;
jsonEndpoint = endpointParser.decomposed2json(decEndpoint);
if (that._options.saveExact) {
jsonEndpoint[decEndpoint.name] = decEndpoint.pkgMeta.version;
}
if (that._options.save) {
that._json.dependencies = sortobject(mout.object.mixIn(that._json.dependencies || {}, jsonEndpoint));
if (that._options.saveExact || that._config.saveExact) {
if (decEndpoint.name !== decEndpoint.source) {
jsonEndpoint[decEndpoint.name] = decEndpoint.source + '#' + decEndpoint.pkgMeta.version;
} else {
jsonEndpoint[decEndpoint.name] = decEndpoint.pkgMeta.version;
}
}
if (that._options.saveDev) {
that._json.devDependencies = sortobject(mout.object.mixIn(that._json.devDependencies || {}, jsonEndpoint));
that._json.devDependencies = mout.object.mixIn(that._json.devDependencies || {}, jsonEndpoint);
} else {
that._json.dependencies = mout.object.mixIn(that._json.dependencies || {}, jsonEndpoint);
}
});
}
@@ -216,6 +213,20 @@ Project.prototype.update = function (names, options) {
});
};
function resolveUrlNames(names, flattened)
{
for (var i = 0; i < names.length; i++)
if (! flattened[names[i]])
{
var url = names[i].trim().replace(/\/$/, '');
var packName;
for (packName in flattened)
if (! ( !flattened[packName].source))
if (url == flattened[packName].source.trim().replace(/\/$/, ''))
names[i] = packName;
}
}
Project.prototype.uninstall = function (names, options) {
var that = this;
var packages = {};
@@ -233,6 +244,7 @@ Project.prototype.uninstall = function (names, options) {
// Fill in the packages to be uninstalled
.spread(function (json, tree, flattened) {
var promise = Q.resolve();
resolveUrlNames(names, flattened);
names.forEach(function (name) {
var decEndpoint = flattened[name];
@@ -560,9 +572,29 @@ Project.prototype._readJson = function () {
return Q.resolve(this._json);
}
// Read local json
return this._json = readJson(this._config.cwd, {
assume: { name: path.basename(this._config.cwd) || 'root' }
return Q.fcall(function () {
// This will throw if package.json does not exist
return fs.readFileSync(path.join(that._config.cwd, 'package.json'));
})
.then(function (buffer) {
// If package.json exists, use it's values as defaults
var defaults = {}, npm = JSON.parse(buffer.toString());
defaults.name = npm.name || path.basename(that._config.cwd) || 'root';
defaults.description = npm.description;
defaults.main = npm.main;
defaults.authors = npm.contributors || npm.author;
defaults.license = npm.license;
defaults.keywords = npm.keywords;
return defaults;
})
.catch(function (err) {
// Most likely no package.json so just set default name
return { name: path.basename(that._config.cwd) || 'root' };
})
.then(function (defaults) {
return that._json = readJson(that._config.cwd, { assume: defaults, logger: that._logger });
})
.spread(function (json, deprecated, assumed) {
var jsonStr;
@@ -591,7 +623,7 @@ Project.prototype._readInstalled = function () {
// Gather all folders that are actual packages by
// looking for the package metadata file
componentsDir = path.join(this._config.cwd, this._config.directory);
componentsDir = relativeToBaseDir(this._config.cwd)(this._config.directory);
return this._installed = Q.nfcall(glob, '*/.bower.json', {
cwd: componentsDir,
dot: true
@@ -632,7 +664,7 @@ Project.prototype._readLinks = function () {
var that = this;
// Read directory, looking for links
componentsDir = path.join(this._config.cwd, this._config.directory);
componentsDir = relativeToBaseDir(this._config.cwd)(this._config.directory);
return Q.nfcall(fs.readdir, componentsDir)
.then(function (filenames) {
var promises;
@@ -724,7 +756,7 @@ Project.prototype._removePackages = function (packages) {
}
// Remove from json only if successfully deleted
if (that._options.save && that._json.dependencies) {
if ((that._options.save || that._config.save) && that._json.dependencies) {
promise = promise
.then(function () {
delete that._json.dependencies[name];
@@ -747,6 +779,9 @@ Project.prototype._removePackages = function (packages) {
.then(function () {
return that.saveJson();
})
// Run post-uninstall hook before resolving with removed packages.
.then(scripts.postuninstall.bind(
null, that._config, that._logger, packages, that._installed, that._json))
// Resolve with removed packages
.then(function () {
return mout.object.filter(packages, function (dir) {

View File

@@ -1,15 +1,15 @@
var fs = require('graceful-fs');
var fs = require('../util/fs');
var path = require('path');
var mout = require('mout');
var Q = require('q');
var mkdirp = require('mkdirp');
var rimraf = require('rimraf');
var rimraf = require('../util/rimraf');
var LRU = require('lru-cache');
var lockFile = require('lockfile');
var md5 = require('md5-hex');
var semver = require('../util/semver');
var readJson = require('../util/readJson');
var copy = require('../util/copy');
var md5 = require('../util/md5');
function ResolveCache(config) {
// TODO: Make some config entries, such as:

View File

@@ -1,16 +1,17 @@
var Q = require('q');
var fs = require('graceful-fs');
var fs = require('../util/fs');
var path = require('path');
var mout = require('mout');
var resolvers = require('./resolvers');
var createError = require('../util/createError');
var resolve = require('../util/resolve');
var pluginResolverFactory = require('./resolvers/pluginResolverFactory');
function createInstance(decEndpoint, options, registryClient) {
decEndpoint = mout.object.pick(decEndpoint, ['name', 'target', 'source']);
options.version = require('../../package.json').version;
options.version = require('../version');
return getConstructor(decEndpoint, options, registryClient)
.spread(function (ConcreteResolver, decEndpoint) {
@@ -24,7 +25,7 @@ function getConstructor(decEndpoint, options, registryClient) {
// Below we try a series of async tests to guess the type of resolver to use
// If a step was unable to guess the resolver, it returns undefined
// If a step can guess the resolver, it returns with construcotor of resolver
// If a step can guess the resolver, it returns with constructor of resolver
var promise = Q.resolve();
@@ -44,12 +45,30 @@ function getConstructor(decEndpoint, options, registryClient) {
// its "match" to check if given resolves supports given decEndpoint
addResolver(function () {
var selectedResolver;
var resolverNames;
var resolverNames = config.resolvers || [];
if (Array.isArray(config.resolvers)) {
resolverNames = config.resolvers;
} else if (!!config.resolvers) {
resolverNames = config.resolvers.split(',');
} else {
resolverNames = [];
}
var resolverPromises = resolverNames.map(function (resolverName) {
var resolver = resolvers[resolverName]
|| pluginResolverFactory(require(resolverName), options);
var resolver = resolvers[resolverName];
if (resolver === undefined) {
var resolverPath = resolve(resolverName, { cwd: config.cwd });
if (resolverPath === undefined) {
throw createError('Bower resolver not found: ' + resolverName, 'ENORESOLVER')
}
resolver = pluginResolverFactory(require(resolverPath), options);
}
return function () {
if (selectedResolver === undefined) {
@@ -84,7 +103,7 @@ function getConstructor(decEndpoint, options, registryClient) {
// Git case: git git+ssh, git+http, git+https
// .git at the end (probably ssh shorthand)
// git@ at the start
addResolver(function() {
addResolver(function () {
if (/^git(\+(ssh|https?))?:\/\//i.test(source) || /\.git\/?$/i.test(source) || /^git@/i.test(source)) {
decEndpoint.source = source.replace(/^git\+/, '');

View File

@@ -1,5 +1,5 @@
var util = require('util');
var fs = require('graceful-fs');
var fs = require('../../util/fs');
var path = require('path');
var mout = require('mout');
var Q = require('q');

View File

@@ -29,16 +29,13 @@ function GitHubResolver(decEndpoint, config, logger) {
this._source += '.git';
}
// Check if it's public
this._public = mout.string.startsWith(this._source, 'git://');
// Use https:// rather than git:// if on a proxy
if (this._config.proxy || this._config.httpsProxy) {
this._source = this._source.replace('git://', 'https://');
}
// Enable shallow clones for GitHub repos
this._shallowClone = function() {
this._shallowClone = function () {
return Q.resolve(true);
};
}
@@ -49,14 +46,10 @@ mout.object.mixIn(GitHubResolver, GitRemoteResolver);
// -----------------
GitHubResolver.prototype._checkout = function () {
// Only fully works with public repositories and tags
// Could work with https/ssh protocol but not with 100% certainty
if (!this._public || !this._resolution.tag) {
return GitRemoteResolver.prototype._checkout.call(this);
}
var msg;
var tarballUrl = 'https://github.com/' + this._org + '/' + this._repo + '/archive/' + this._resolution.tag + '.tar.gz';
var name = this._resolution.tag || this._resolution.branch || this._resolution.commit;
var tarballUrl = 'https://github.com/' + this._org + '/' + this._repo + '/archive/' + name + '.tar.gz';
var file = path.join(this._tempDir, 'archive.tar.gz');
var reqHeaders = {};
var that = this;
@@ -72,7 +65,7 @@ GitHubResolver.prototype._checkout = function () {
// Download tarball
return download(tarballUrl, file, {
proxy: this._config.httpsProxy,
ca: this._config.ca.default,
strictSSL: this._config.strictSsl,
timeout: this._config.timeout,
headers: reqHeaders
@@ -121,7 +114,6 @@ GitHubResolver.prototype._checkout = function () {
return that._cleanTempDir()
.then(GitRemoteResolver.prototype._checkout.bind(that));
});
};

View File

@@ -19,14 +19,14 @@ function GitRemoteResolver(decEndpoint, config, logger) {
this._name = this._name.slice(0, -4);
}
// Get the host of this source
// Get the remote of this source
if (!/:\/\//.test(this._source)) {
this._host = url.parse('ssh://' + this._source).host;
this._remote = url.parse('ssh://' + this._source);
} else {
this._host = url.parse(this._source).host;
this._remote = url.parse(this._source);
}
this._remote = url.parse(this._source);
this._host = this._remote.host;
// Verify whether the server supports shallow cloning
this._shallowClone = this._supportsShallowCloning;
@@ -119,7 +119,7 @@ GitRemoteResolver.prototype._fastClone = function (resolution) {
return this._shallowClone().then(function (shallowCloningSupported) {
// If the host does not support shallow clones, we don't use --depth=1
if (shallowCloningSupported && !GitRemoteResolver._noShallow.get(this._host)) {
if (shallowCloningSupported && !GitRemoteResolver._noShallow.get(that._host)) {
args.push('--depth', 1);
}
@@ -191,6 +191,11 @@ GitRemoteResolver.prototype._supportsShallowCloning = function () {
return Q.resolve(false);
}
if (!this._host || !this._config.shallowCloneHosts || this._config.shallowCloneHosts.indexOf(this._host) === -1) {
return Q.resolve(false);
}
// Check for protocol - the remote check for hosts supporting shallow cloning is only required for
// HTTP or HTTPS, not for Git or SSH.
// Also check for hosts that have been checked in a previous request and have been found to support
@@ -199,7 +204,7 @@ GitRemoteResolver.prototype._supportsShallowCloning = function () {
&& !GitRemoteResolver._canShallow.get(this._host)) {
// Provide GIT_CURL_VERBOSE=2 environment variable to capture curl output.
// Calling ls-remote includes a call to the git-upload-pack service, which returns the content type in the response.
var processEnv = mout.object.merge(process.env, { 'GIT_CURL_VERBOSE': 2 });
var processEnv = mout.object.merge(process.env, { 'GIT_CURL_VERBOSE': '2' });
value = cmd('git', ['ls-remote', '--heads', this._source], {
env: processEnv

View File

@@ -1,8 +1,7 @@
var util = require('util');
var path = require('path');
var Q = require('q');
var chmodr = require('chmodr');
var rimraf = require('rimraf');
var rimraf = require('../../util/rimraf');
var mkdirp = require('mkdirp');
var which = require('which');
var LRU = require('lru-cache');
@@ -28,6 +27,18 @@ function GitResolver(decEndpoint, config, logger) {
mkdirp.sync(config.storage.empty);
process.env.GIT_TEMPLATE_DIR = config.storage.empty;
if (!config.strictSsl) {
process.env.GIT_SSL_NO_VERIFY = 'true';
}
if (!config.interactive) {
process.env.GIT_TERMINAL_PROMPT = '0';
if (!process.env.SSH_ASKPASS) {
process.env.SSH_ASKPASS = 'echo';
}
}
Resolver.call(this, decEndpoint, config, logger);
if (!hasGit) {
@@ -144,7 +155,7 @@ GitResolver.prototype._findResolution = function (target) {
throw createError('No tag found that was able to satisfy ' + target, 'ENORESTARGET', {
details: !versions.length ?
'No versions found in ' + that._source :
'Available versions: ' + versions.map(function (version) { return version.version; }).join(', ')
'Available versions in ' + that._source + ': ' + versions.map(function (version) { return version.version; }).join(', ')
});
});
});
@@ -195,23 +206,7 @@ GitResolver.prototype._findResolution = function (target) {
GitResolver.prototype._cleanup = function () {
var gitFolder = path.join(this._tempDir, '.git');
// Remove the .git folder
// Note that on windows, we need to chmod to 0777 before due to a bug in git
// See: https://github.com/isaacs/rimraf/issues/19
if (process.platform === 'win32') {
return Q.nfcall(chmodr, gitFolder, 0777)
.then(function () {
return Q.nfcall(rimraf, gitFolder);
}, function (err) {
// If .git does not exist, chmodr returns ENOENT
// so, we ignore that error code
if (err.code !== 'ENOENT') {
throw err;
}
});
} else {
return Q.nfcall(rimraf, gitFolder);
}
return Q.nfcall(rimraf, gitFolder);
};
GitResolver.prototype._savePkgMeta = function (meta) {
@@ -221,7 +216,7 @@ GitResolver.prototype._savePkgMeta = function (meta) {
version = semver.clean(this._resolution.tag);
// Warn if the package meta version is different than the resolved one
if (typeof meta.version === 'string' && semver.neq(meta.version, version)) {
if (typeof meta.version === 'string' && semver.valid(meta.version) && semver.neq(meta.version, version)) {
this._logger.warn('mismatch', 'Version declared in the json (' + meta.version + ') is different than the resolved one (' + version + ')', {
resolution: this._resolution,
pkgMeta: meta

View File

@@ -1,12 +1,13 @@
var fs = require('graceful-fs');
var fs = require('../../util/fs');
var path = require('path');
var Q = require('q');
var tmp = require('tmp');
var mkdirp = require('mkdirp');
var rimraf = require('rimraf');
var rimraf = require('../../util/rimraf');
var readJson = require('../../util/readJson');
var createError = require('../../util/createError');
var removeIgnores = require('../../util/removeIgnores');
var md5 = require('md5-hex');
tmp.setGracefulCleanup();
@@ -107,8 +108,7 @@ Resolver.prototype.isCacheable = function () {
// We don't want to cache moving targets like branches
if (this._pkgMeta &&
this._pkgMeta._resolution &&
this._pkgMeta._resolution.type === 'branch')
{
this._pkgMeta._resolution.type === 'branch') {
return false;
}
@@ -145,7 +145,7 @@ Resolver.prototype._createTempDir = function () {
return Q.nfcall(mkdirp, this._config.tmp)
.then(function () {
return Q.nfcall(tmp.dir, {
template: path.join(this._config.tmp, this._name + '-' + process.pid + '-XXXXXX'),
template: path.join(this._config.tmp, md5(this._name) + '-' + process.pid + '-XXXXXX'),
mode: 0777 & ~process.umask(),
unsafeCleanup: true
});
@@ -178,7 +178,8 @@ Resolver.prototype._readJson = function (dir) {
dir = dir || this._tempDir;
return readJson(dir, {
assume: { name: this._name }
assume: { name: this._name },
logger: that._logger
})
.spread(function (json, deprecated) {
if (deprecated) {
@@ -217,15 +218,6 @@ Resolver.prototype._savePkgMeta = function (meta) {
meta._source = this._source;
meta._target = this._target;
['main', 'ignore'].forEach(function (attr) {
if (meta[attr]) return;
that._logger.log(
'warn', 'invalid-meta',
(meta.name || 'component') + ' is missing "' + attr + '" entry in bower.json'
);
});
// Stringify contents
contents = JSON.stringify(meta, null, 2);

View File

@@ -86,13 +86,13 @@ SvnResolver.prototype._export = function () {
});
if (resolution.type === 'commit') {
promise = cmd('svn', ['export', '--force', this._source + '/trunk', '-r' + resolution.commit, this._tempDir]);
promise = cmd('svn', ['export', '--force', '--non-interactive', this._source + '/trunk', '-r' + resolution.commit, this._tempDir]);
} else if (resolution.type === 'branch' && resolution.branch === 'trunk') {
promise = cmd('svn', ['export', '--force', this._source + '/trunk', this._tempDir]);
promise = cmd('svn', ['export', '--force', '--non-interactive', this._source + '/trunk', this._tempDir]);
} else if (resolution.type === 'branch') {
promise = cmd('svn', ['export', '--force', this._source + '/branches/' + resolution.branch, this._tempDir]);
promise = cmd('svn', ['export', '--force', '--non-interactive', this._source + '/branches/' + resolution.branch, this._tempDir]);
} else {
promise = cmd('svn', ['export', '--force', this._source + '/tags/' + resolution.tag, this._tempDir]);
promise = cmd('svn', ['export', '--force', '--non-interactive', this._source + '/tags/' + resolution.tag, this._tempDir]);
}
// Throttle the progress reporter to 1 time each sec
@@ -188,7 +188,7 @@ SvnResolver.prototype._findResolution = function (target) {
throw createError('No tag found that was able to satisfy ' + target, 'ENORESTARGET', {
details: !versions.length ?
'No versions found in ' + that._source :
'Available versions: ' + versions.map(function (version) { return version.version; }).join(', ')
'Available versions in ' + that._source + ': ' + versions.map(function (version) { return version.version; }).join(', ')
});
});
});
@@ -324,7 +324,7 @@ SvnResolver.tags = function (source) {
return Q.resolve(value);
}
value = cmd('svn', ['list', source + '/tags', '--verbose'])
value = cmd('svn', ['list', source + '/tags', '--verbose', '--non-interactive'])
.spread(function (stout) {
var tags = SvnResolver.parseSubversionListOutput(stout.toString());
@@ -349,7 +349,7 @@ SvnResolver.branches = function (source) {
return Q.resolve(value);
}
value = cmd('svn', ['list', source + '/branches', '--verbose'])
value = cmd('svn', ['list', source + '/branches', '--verbose', '--non-interactive'])
.spread(function (stout) {
var branches = SvnResolver.parseSubversionListOutput(stout.toString());

View File

@@ -1,6 +1,6 @@
var util = require('util');
var path = require('path');
var fs = require('graceful-fs');
var fs = require('../../util/fs');
var url = require('url');
var request = require('request');
var Q = require('q');
@@ -55,7 +55,7 @@ UrlResolver.prototype._hasNew = function (pkgMeta) {
// Make an HEAD request to the source
return Q.nfcall(request.head, this._source, {
proxy: this._remote.protocol === 'https:' ? this._config.httpsProxy : this._config.proxy,
ca: this._config.ca.default,
strictSSL: this._config.strictSsl,
timeout: this._config.timeout,
headers: reqHeaders
@@ -104,8 +104,18 @@ UrlResolver.prototype._resolve = function () {
// -----------------
UrlResolver.prototype._parseSourceURL = function (_url) {
return url.parse(path.basename(_url)).pathname;
};
UrlResolver.prototype._download = function () {
var fileName = url.parse(path.basename(this._source)).pathname;
var fileName = this._parseSourceURL(this._source);
if (!fileName) {
this._source = this._source.replace(/\/(?=\?|#)/, '');
fileName = this._parseSourceURL(this._source);
}
var file = path.join(this._tempDir, fileName);
var reqHeaders = {};
var that = this;
@@ -121,7 +131,7 @@ UrlResolver.prototype._download = function () {
// Download the file
return download(this._source, file, {
proxy: this._remote.protocol === 'https:' ? this._config.httpsProxy : this._config.proxy,
ca: this._config.ca.default,
strictSSL: this._config.strictSsl,
timeout: this._config.timeout,
headers: reqHeaders

View File

@@ -1,6 +1,6 @@
var Q = require('q');
var path = require('path');
var fs = require('fs');
var fs = require('../../util/fs');
var object = require('mout/object');
var semver = require('../../util/semver');
@@ -52,7 +52,7 @@ function pluginResolverFactory(resolverFactory, bower) {
return this._decEndpoint.target || '*';
};
PluginResolver.prototype.getName = function() {
PluginResolver.prototype.getName = function () {
if (!this._decEndpoint.name && typeof resolver.getName === 'function') {
return resolver.getName.call(resolver, this.getSource());
} else if (!this._decEndpoint.name) {
@@ -70,7 +70,7 @@ function pluginResolverFactory(resolverFactory, bower) {
// Plugin Resolver is always considered potentially cacheable
// The "resolve" method decides whether to use cached or fetch new version.
PluginResolver.prototype.isCacheable = function() {
PluginResolver.prototype.isCacheable = function () {
return true;
};
@@ -95,11 +95,11 @@ function pluginResolverFactory(resolverFactory, bower) {
var that = this;
return this.resolvePromise = Q.fcall(function() {
return this.resolvePromise = Q.fcall(function () {
var target = that.getTarget();
// It means that we can accept ranges as targets
if(that.constructor.isTargetable()) {
if (that.constructor.isTargetable()) {
that._release = target;
if (semver.validRange(target)) {
@@ -109,7 +109,7 @@ function pluginResolverFactory(resolverFactory, bower) {
throw createError('Resolver did not provide releases of package.');
}
var releases = this._releases = result;
var releases = that._releases = result;
var versions = releases.filter(function (target) {
return semver.clean(target.version);
@@ -191,7 +191,8 @@ function pluginResolverFactory(resolverFactory, bower) {
var that = this;
return readJson(dir, {
assume: { name: that.getName() }
assume: { name: that.getName() },
logger: bower.logger
})
.spread(function (json, deprecated) {
if (deprecated) {
@@ -275,7 +276,7 @@ function pluginResolverFactory(resolverFactory, bower) {
});
};
PluginResolver.isTargetable = function() {
PluginResolver.isTargetable = function () {
// If resolver doesn't define versions function, it's not targetable..
return typeof resolver.releases === 'function';
};

View File

@@ -78,17 +78,18 @@ var run = function (cmdString, action, logger, config) {
var hook = function (action, ordered, config, logger, packages, installed, json) {
if (mout.object.keys(packages).length === 0 || !config.scripts || !config.scripts[action]) {
/*jshint newcap: false */
return Q();
}
var orderedPackages = ordered ? orderByDependencies(packages, installed, json) : mout.object.keys(packages);
var cmdString = mout.string.replace(config.scripts[action], '%', orderedPackages.join(' '));
var placeholder = new RegExp('%', 'g');
var cmdString = mout.string.replace(config.scripts[action], placeholder, orderedPackages.join(' '));
return run(cmdString, action, logger, config);
};
module.exports = {
preuninstall: mout.function.partial(hook, 'preuninstall', false),
postuninstall: mout.function.partial(hook, 'postuninstall', false),
preinstall: mout.function.partial(hook, 'preinstall', true),
postinstall: mout.function.partial(hook, 'postinstall', true),
//only exposed for test

View File

@@ -1,30 +1,6 @@
var abbrev = require('abbrev');
var mout = require('mout');
var commands = require('./commands');
var pkg = require('../package.json');
var abbreviations = abbrev(expandNames(commands));
abbreviations.i = 'install';
abbreviations.rm = 'uninstall';
abbreviations.unlink = 'uninstall';
abbreviations.ls = 'list';
function expandNames(obj, prefix, stack) {
prefix = prefix || '';
stack = stack || [];
mout.object.forOwn(obj, function (value, name) {
name = prefix + name;
stack.push(name);
if (typeof value === 'object' && !value.line) {
expandNames(value, name + ' ', stack);
}
});
return stack;
}
var version = require('./version');
var abbreviations = require('./util/abbreviations')(commands);
function clearRuntimeCache() {
// Note that in edge cases, some architecture components instance's
@@ -35,7 +11,7 @@ function clearRuntimeCache() {
}
module.exports = {
version: pkg.version,
version: version,
commands: commands,
config: require('./config')(),
abbreviations: abbreviations,

View File

@@ -31,10 +31,8 @@ JsonRenderer.prototype.error = function (err) {
err.message = message;
// Stack
/*jshint camelcase:false*/
stack = err.fstream_stack || err.stack || 'N/A';
err.stacktrace = (Array.isArray(stack) ? stack.join('\n') : stack);
/*jshint camelcase:true*/
this.log(err);
this.end();

View File

@@ -5,7 +5,8 @@ var archy = require('archy');
var Q = require('q');
var stringifyObject = require('stringify-object');
var os = require('os');
var pkg = require(path.join(__dirname, '../..', 'package.json'));
var semverUtils = require('semver-utils');
var version = require('../version');
var template = require('../util/template');
function StandardRenderer(command, config) {
@@ -71,19 +72,17 @@ StandardRenderer.prototype.error = function (err) {
// Print trace if verbose, the error has no code
// or if the error is a node error
if (this._config.verbose || !err.code || err.errno) {
/*jshint camelcase:false*/
stack = err.fstream_stack || err.stack || 'N/A';
str = chalk.yellow('\nStack trace:\n');
str += (Array.isArray(stack) ? stack.join('\n') : stack) + '\n';
str += chalk.yellow('\nConsole trace:\n');
/*jshint camelcase:true*/
this._write(process.stderr, str);
this._write(process.stderr, new Error().stack);
// Print bower version, node version and system info.
this._write(process.stderr, chalk.yellow('\nSystem info:\n'));
this._write(process.stderr, 'Bower version: ' + pkg.version + '\n');
this._write(process.stderr, 'Bower version: ' + version + '\n');
this._write(process.stderr, 'Node version: ' + process.versions.node + '\n');
this._write(process.stderr, 'OS: ' + os.type() + ' ' + os.release() + ' ' + os.arch() + '\n');
}
@@ -209,6 +208,19 @@ StandardRenderer.prototype._info = function (data) {
// Render the versions at the end
if (includeVersions) {
data.hidePreReleases = false;
data.numPreReleases = 0;
// If output isn't verbose, hide prereleases
if (!this._config.verbose) {
data.versions = mout.array.filter(data.versions, function (version) {
version = semverUtils.parse(version);
if (!version.release && !version.build) {
return true;
}
data.numPreReleases++;
});
data.hidePreReleases = !!data.numPreReleases;
}
str += '\n' + template.render('std/info.std', data);
}

View File

@@ -3,10 +3,9 @@ var mout = require('mout');
function rpad(Handlebars) {
Handlebars.registerHelper('rpad', function (context) {
var hash = context.hash;
var length = parseInt(hash.length, 10);
var minLength = parseInt(hash.minLength, 10);
var chr = hash.char;
return mout.string.rpad(context.fn(this), length, chr);
return mout.string.rpad(context.fn(this), minLength, chr);
});
}

View File

@@ -11,6 +11,11 @@
"flag": "--force-latest",
"description": "Force latest version on conflict"
},
{
"shorthand": "-f",
"flag": "--force",
"description": "If dependencies are installed, it reinstalls all installed components. It also forces installation even when there are non-bower directories with the same name in the components directory. Also bypasses the cache and overwrites to the cache anyway."
},
{
"shorthand": "-h",
"flag": "--help",

View File

@@ -1,6 +1,6 @@
{
"command": "lookup",
"description": "Looks up a package URL by name.",
"description": "Look up a single package URL by name.",
"usage": [
"lookup <name> [<options>]"
],

View File

@@ -5,6 +5,11 @@
"register <name> <url> [<options>]"
],
"options": [
{
"shorthand": "-f",
"flag": "--force",
"description": "Bypasses confirmation. Bower login is still needed."
},
{
"shorthand": "-h",
"flag": "--help",

View File

@@ -1,8 +1,7 @@
{
"command": "search",
"description": "Finds all packages or a specific package.",
"description": "Search for packages by name.",
"usage": [
"search [<options>]",
"search <name> [<options>]"
],
"options": [

View File

@@ -5,6 +5,11 @@
"uninstall <name> [<name> ..] [<options>]"
],
"options": [
{
"shorthand": "-f",
"flag": "--force",
"description": "Continues uninstallation even after a dependency conflict"
},
{
"shorthand": "-h",
"flag": "--help",

View File

@@ -5,6 +5,11 @@
"unregister <name> [<options>]"
],
"options": [
{
"shorthand": "-f",
"flag": "--force",
"description": "Bypasses confirmation. Bower login is still needed."
},
{
"shorthand": "-h",
"flag": "--help",

View File

@@ -19,6 +19,16 @@
"shorthand": "-p",
"flag": "--production",
"description": "Do not install project devDependencies"
},
{
"shorthand": "-S",
"flag": "--save",
"description": "Update dependencies in bower.json"
},
{
"shorthand": "-D",
"flag": "--save-dev",
"description": "Update devDependencies in bower.json"
}
]
}

View File

@@ -0,0 +1,14 @@
{
"command": "version",
"description": "Creates an empty version commit and tag, and fail if the repo is not clean.\n\nThe <version> argument should be a valid semver string, or one of following:\nbuild, patch, minor, major.\n\nIf supplied with --message (shorthand: -m) config option, bower will use it\nas a commit message when creating a version commit. If the message config\ncontains %s then that will be replaced with the resulting version number.\n\nFor example:\n\n bower version patch -m \"Upgrade to %s for reasons\"",
"usage": [
"version [<version> | major | minor | patch]"
],
"options": [
{
"shorthand": "-m",
"flag": "--message",
"description": "Custom git commit and tag message"
}
]
}

View File

@@ -12,10 +12,10 @@
"link": "Symlink a package folder",
"list": "List local packages - and possible updates",
"login": "Authenticate with GitHub and store credentials",
"lookup": "Look up a package URL by name",
"lookup": "Look up a single package URL by name",
"prune": "Removes local extraneous packages",
"register": "Register a package",
"search": "Search for a package by name",
"search": "Search for packages by name",
"update": "Update a local package",
"uninstall": "Remove a local package",
"unregister": "Remove a package from the registry",
@@ -34,7 +34,7 @@
},
{
"shorthand": "-l",
"flag": "--log-level",
"flag": "--loglevel",
"description": "What level of logs to report"
},
{
@@ -69,6 +69,10 @@
{
"flag": "--no-color",
"description": "Disable colors"
},
{
"flag": "--config.interactive=false",
"description": "Disable prompts"
}
]
}

View File

@@ -1,4 +1,4 @@
{{#yellow}}Unable to find a suitable version for {{name}}, please choose one:{{/yellow}}
{{#yellow}}Unable to find a suitable version for {{name}}, please choose one by typing one of the numbers below:{{/yellow}}
{{#condense}}
{{#each picks}}
{{#magenta}}{{sum @index 1}}){{/magenta}} {{#cyan}}{{endpoint.name}}#{{endpoint.target}}{{/cyan}}{{#if pkgMeta._release}} which resolved to {{#green}}{{pkgMeta._release}}{{/green}}{{/if}}{{#if dependants}} and is required by {{#green}}{{dependants}}{{/green}}{{/if}}

View File

@@ -11,7 +11,7 @@ Commands:
{{#condense}}
{{#each commands}}
{{#rpad length="23"}}{{@key}}{{/rpad}} {{.}}
{{#rpad minLength="23"}}{{@key}}{{/rpad}} {{.}}
{{/each}}
{{/condense}}
{{#rpad minLength="23"}}{{/rpad}}

View File

@@ -7,11 +7,12 @@ Usage:
{{/each}}
{{/condense}}
Options:
{{#condense}}
{{#each options}}
{{#yellow}}{{#rpad length="23"}}{{#if shorthand}}{{shorthand}}, {{/if}}{{flag}}{{/rpad}}{{/yellow}} {{description}}
{{#yellow}}{{#rpad minLength="23"}}{{#if shorthand}}{{shorthand}}, {{/if}}{{flag}}{{/rpad}}{{/yellow}} {{description}}
{{/each}}
{{/condense}}

View File

@@ -11,7 +11,7 @@ Commands:
{{#condense}}
{{#each commands}}
{{#rpad length="23"}}{{@key}}{{/rpad}} {{.}}
{{#rpad minLength="23"}}{{@key}}{{/rpad}} {{.}}
{{/each}}
{{/condense}}
@@ -19,7 +19,7 @@ Options:
{{#condense}}
{{#each options}}
{{#yellow}}{{#rpad length="23"}}{{#if shorthand}}{{shorthand}}, {{/if}}{{flag}}{{/rpad}}{{/yellow}} {{description}}
{{#yellow}}{{#rpad minLength="23"}}{{#if shorthand}}{{shorthand}}, {{/if}}{{flag}}{{/rpad}}{{/yellow}} {{description}}
{{/each}}
{{/condense}}

View File

@@ -5,6 +5,10 @@
{{/versions}}
{{/condense}}
{{#if hidePreReleases}}
Show {{numPreReleases}} additional prereleases with bower info {{name}} --verbose
{{/if}}
You can request info for a specific version with 'bower info {{name}}#<version>'
{{else}}No versions available.
{{/if}}

30
lib/util/abbreviations.js Normal file
View File

@@ -0,0 +1,30 @@
var abbrev = require('abbrev');
var mout = require('mout');
function expandNames(obj, prefix, stack) {
prefix = prefix || '';
stack = stack || [];
mout.object.forOwn(obj, function (value, name) {
name = prefix + name;
stack.push(name);
if (typeof value === 'object' && !value.line) {
expandNames(value, name + ' ', stack);
}
});
return stack;
}
module.exports = function (commands) {
var abbreviations = abbrev(expandNames(commands));
abbreviations.i = 'install';
abbreviations.rm = 'uninstall';
abbreviations.unlink = 'uninstall';
abbreviations.ls = 'list';
return abbreviations;
};

View File

@@ -1,113 +0,0 @@
var Q = require('q');
var mout = require('mout');
var analytics = module.exports;
var insight;
var enableAnalytics = false;
// Insight takes long to load, and often causes problems
// in non-interactive environment, so we load it lazily
//
// Insight is used in two cases:
//
// 1. Read insight configuration (whether track user actions)
// 2. Track user actions (Tracker.track method)
//
// We don't want to instantiate Insight in non-interactive mode
// because it takes time to read config and configstore has concurrency issues:
//
// https://github.com/yeoman/configstore/issues/20
function ensureInsight () {
if (!insight) {
var Insight = require('insight');
insight = new Insight({
trackingCode: 'UA-43531210-1',
pkg: require('../../package.json')
});
}
}
// Initializes the application-wide insight singleton and asks for the
// permission on the CLI during the first run.
//
// This method is called only from bin/bower. Programmatic API skips it.
analytics.setup = function setup (config) {
var deferred = Q.defer();
// No need for asking if analytics is set in bower config
if (config.analytics === undefined) {
ensureInsight();
// For non-interactive call from bin/bower we disable analytics
if (config.interactive) {
if (insight.optOut !== undefined) {
deferred.resolve(!insight.optOut);
} else {
insight.askPermission(null, function(err, optIn) {
// optIn callback param was exactly opposite before 0.4.3
// so we force at least insight@0.4.3 in package.json
deferred.resolve(optIn);
});
}
} else {
// no specified value, no stored value, and can't prompt for one
// most likely CI environment; defaults to false to reduce data noise
deferred.resolve(false);
}
} else {
// use the specified value
deferred.resolve(config.analytics);
}
return deferred.promise.then(function (enabled) {
enableAnalytics = enabled;
return enabled;
});
};
var Tracker = analytics.Tracker = function Tracker(config) {
function analyticsEnabled () {
// Allow for overriding analytics default
if (config && config.analytics !== undefined) {
return config.analytics;
}
// TODO: let bower pass this variable from bin/bower instead closure
return enableAnalytics;
}
if (analyticsEnabled()) {
ensureInsight();
} else {
this.track = function noop () {};
this.trackDecomposedEndpoints = function noop () {};
this.trackPackages = function noop () {};
this.trackNames = function noop () {};
}
};
Tracker.prototype.track = function track() {
insight.track.apply(insight, arguments);
};
Tracker.prototype.trackDecomposedEndpoints = function trackDecomposedEndpoints(command, endpoints) {
endpoints.forEach(function (endpoint) {
this.track(command, endpoint.source, endpoint.target);
}.bind(this));
};
Tracker.prototype.trackPackages = function trackPackages(command, packages) {
mout.object.forOwn(packages, function (package) {
var meta = package.pkgMeta;
this.track(command, meta.name, meta.version);
}.bind(this));
};
Tracker.prototype.trackNames = function trackNames(command, names) {
names.forEach(function (name) {
this.track(command, name);
}.bind(this));
};

View File

@@ -1,6 +1,6 @@
var fstream = require('fstream');
var fstreamIgnore = require('fstream-ignore');
var fs = require('graceful-fs');
var fs = require('./fs');
var Q = require('q');
function copy(reader, writer) {

View File

@@ -1,4 +1,4 @@
var fs = require('graceful-fs');
var fs = require('./fs');
var path = require('path');
var Q = require('q');
var mkdirp = require('mkdirp');

View File

@@ -3,19 +3,20 @@ var request = require('request');
var Q = require('q');
var mout = require('mout');
var retry = require('retry');
var fs = require('graceful-fs');
var createError = require('./createError');
var createWriteStream = require('fs-write-stream-atomic');
var destroy = require('destroy');
var errorCodes = [
'EADDRINFO',
'ETIMEDOUT',
'ECONNRESET',
'ESOCKETTIMEDOUT'
'ESOCKETTIMEDOUT',
'ENOTFOUND'
];
function download(url, file, options) {
var operation;
var response;
var deferred = Q.defer();
var progressDelay = 8000;
@@ -24,46 +25,24 @@ function download(url, file, options) {
factor: 2,
minTimeout: 1000,
maxTimeout: 35000,
randomize: true
randomize: true,
progressDelay: progressDelay,
gzip: true
}, options || {});
// Retry on network errors
operation = retry.operation(options);
operation.attempt(function () {
var req;
var writeStream;
var contentLength;
var bytesDownloaded = 0;
req = progress(request(url, options), {
delay: progressDelay
Q.fcall(fetch, url, file, options)
.then(function (response) {
deferred.resolve(response);
})
.on('response', function (res) {
var status = res.statusCode;
if (status < 200 || status >= 300) {
return deferred.reject(createError('Status code of ' + status, 'EHTTP'));
}
response = res;
contentLength = Number(res.headers['content-length']);
.progress(function (status) {
deferred.notify(status);
})
.on('data', function (data) {
bytesDownloaded += data.length;
})
.on('progress', function (state) {
deferred.notify(state);
})
.on('end', function () {
// Check if the whole file was downloaded
// In some unstable connections the ACK/FIN packet might be sent in the
// middle of the download
// See: https://github.com/joyent/node/issues/6143
if (contentLength && bytesDownloaded < contentLength) {
req.emit('error', createError('Transfer closed with ' + (contentLength - bytesDownloaded) + ' bytes remaining to read', 'EINCOMPLETE'));
}
})
.on('error', function (error) {
.fail(function (error) {
// Save timeout before retrying to report
var timeout = operation._timeouts[0];
// Reject if error is not a network error
@@ -74,36 +53,91 @@ function download(url, file, options) {
// Next attempt will start reporting download progress immediately
progressDelay = 0;
// Check if there are more retries
// This will schedule next retry or return false
if (operation.retry(error)) {
// Ensure that there are no more events from this request
req.removeAllListeners();
req.on('error', function () {});
// Ensure that there are no more events from the write stream
writeStream.removeAllListeners();
writeStream.on('error', function () {});
return deferred.notify({
deferred.notify({
retry: true,
delay: timeout,
error: error
});
} else {
deferred.reject(error);
}
// No more retries, reject!
deferred.reject(error);
});
// Pipe read stream to write stream
writeStream = req
.pipe(fs.createWriteStream(file))
.on('error', deferred.reject)
.on('close', function () {
deferred.resolve(response);
});
});
return deferred.promise;
}
function fetch(url, file, options) {
var deferred = Q.defer();
var contentLength;
var bytesDownloaded = 0;
var reject = function (error) {
deferred.reject(error);
};
var req = progress(request(url, options), {
delay: options.progressDelay
})
.on('response', function (response) {
contentLength = Number(response.headers['content-length']);
var status = response.statusCode;
if (status < 200 || status >= 300) {
return deferred.reject(createError('Status code of ' + status, 'EHTTP'));
}
var writeStream = createWriteStream(file);
var errored = false;
// Change error listener so it cleans up writeStream before exiting
req.removeListener('error', reject);
req.on('error', function (error) {
errored = true;
destroy(req);
destroy(writeStream);
// Wait for writeStream to cleanup after itself...
// TODO: Maybe there's a better way?
setTimeout(function () {
deferred.reject(error);
}, 50);
});
writeStream.on('finish', function () {
if (!errored) {
destroy(req);
deferred.resolve(response);
}
});
req.pipe(writeStream);
})
.on('data', function (data) {
bytesDownloaded += data.length;
})
.on('progress', function (state) {
deferred.notify(state);
})
.on('error', reject)
.on('end', function () {
// Check if the whole file was downloaded
// In some unstable connections the ACK/FIN packet might be sent in the
// middle of the download
// See: https://github.com/joyent/node/issues/6143
if (contentLength && bytesDownloaded < contentLength) {
req.emit('error', createError(
'Transfer closed with ' + (contentLength - bytesDownloaded) + ' bytes remaining to read',
'EINCOMPLETE'
));
}
});
return deferred.promise;
}
module.exports = download;

View File

@@ -1,5 +1,5 @@
var path = require('path');
var fs = require('graceful-fs');
var fs = require('./fs');
var zlib = require('zlib');
var DecompressZip = require('decompress-zip');
var tar = require('tar-fs');
@@ -7,6 +7,9 @@ var Q = require('q');
var mout = require('mout');
var junk = require('junk');
var createError = require('./createError');
var createWriteStream = require('fs-write-stream-atomic');
var destroy = require('destroy');
var tmp = require('tmp');
// This forces the default chunk size to something small in an attempt
// to avoid issue #314
@@ -49,15 +52,24 @@ function extractZip(archive, dst) {
function extractTar(archive, dst) {
var deferred = Q.defer();
fs.createReadStream(archive)
.on('error', deferred.reject)
var stream = fs.createReadStream(archive);
var reject = function (error) {
destroy(stream);
deferred.reject(error);
};
stream.on('error', reject)
.pipe(tar.extract(dst, {
ignore: isSymlink, // Filter symlink files
dmode: 0555, // Ensure dirs are readable
fmode: 0444 // Ensure files are readable
}))
.on('error', deferred.reject)
.on('finish', deferred.resolve.bind(deferred, dst));
.on('error', reject)
.on('finish', function (result) {
destroy(stream);
deferred.resolve(dst);
});
return deferred.promise;
}
@@ -65,17 +77,26 @@ function extractTar(archive, dst) {
function extractTarGz(archive, dst) {
var deferred = Q.defer();
fs.createReadStream(archive)
.on('error', deferred.reject)
var stream = fs.createReadStream(archive);
var reject = function (error) {
destroy(stream);
deferred.reject(error);
};
stream.on('error', reject)
.pipe(zlib.createGunzip())
.on('error', deferred.reject)
.on('error', reject)
.pipe(tar.extract(dst, {
ignore: isSymlink, // Filter symlink files
dmode: 0555, // Ensure dirs are readable
fmode: 0444 // Ensure files are readable
}))
.on('error', deferred.reject)
.on('finish', deferred.resolve.bind(deferred, dst));
.on('error', reject)
.on('finish', function (result) {
destroy(stream);
deferred.resolve(dst);
});
return deferred.promise;
}
@@ -83,13 +104,21 @@ function extractTarGz(archive, dst) {
function extractGz(archive, dst) {
var deferred = Q.defer();
fs.createReadStream(archive)
.on('error', deferred.reject)
var stream = fs.createReadStream(archive);
var reject = function (error) {
destroy(stream);
deferred.reject(error);
};
stream.on('error', reject)
.pipe(zlib.createGunzip())
.on('error', deferred.reject)
.pipe(fs.createWriteStream(dst))
.on('error', deferred.reject)
.on('close', deferred.resolve.bind(deferred, dst));
.on('error', reject)
.pipe(createWriteStream(dst))
.on('error', reject)
.on('finish', function (result) {
destroy(stream);
deferred.resolve(dst);
});
return deferred.promise;
}
@@ -136,15 +165,11 @@ function isSingleDir(dir) {
});
}
function moveSingleDirContents(dir) {
var destDir = path.dirname(dir);
return Q.nfcall(fs.readdir, dir)
function moveDirectory(srcDir, destDir) {
return Q.nfcall(fs.readdir, srcDir)
.then(function (files) {
var promises;
promises = files.map(function (file) {
var src = path.join(dir, file);
var promises = files.map(function (file) {
var src = path.join(srcDir, file);
var dst = path.join(destDir, file);
return Q.nfcall(fs.rename, src, dst);
@@ -153,7 +178,7 @@ function moveSingleDirContents(dir) {
return Q.all(promises);
})
.then(function () {
return Q.nfcall(fs.rmdir, dir);
return Q.nfcall(fs.rmdir, srcDir);
});
}
@@ -187,44 +212,53 @@ function extract(src, dst, opts) {
return Q.reject(createError('File ' + src + ' is not a known archive', 'ENOTARCHIVE'));
}
// Check archive file size
promise = Q.nfcall(fs.stat, src)
.then(function (stat) {
if (stat.size <= 8) {
throw createError('File ' + src + ' is an invalid archive', 'ENOTARCHIVE');
// Extract to a temporary directory in case of file name clashes
return Q.nfcall(tmp.dir, {
template: dst + '-XXXXXX',
mode: 0777 & ~process.umask()
}).then(function (tempDir) {
// nfcall may return multiple callback arguments as an array
return Array.isArray(tempDir) ? tempDir[0] : tempDir;
}).then(function (tempDir) {
// Check archive file size
promise = Q.nfcall(fs.stat, src)
.then(function (stat) {
if (stat.size <= 8) {
throw createError('File ' + src + ' is an invalid archive', 'ENOTARCHIVE');
}
// Extract archive
return extractor(src, tempDir);
});
// Remove archive
if (!opts.keepArchive) {
promise = promise
.then(function () {
return Q.nfcall(fs.unlink, src);
});
}
// Extract archive
return extractor(src, dst);
});
// TODO: There's an issue here if the src and dst are the same and
// The zip name is the same as some of the zip file contents
// Maybe create a temp directory inside dst, unzip it there,
// unlink zip and then move contents
// Remove archive
if (!opts.keepArchive) {
// Move contents from the temporary directory
// If the contents are a single directory (and we're not preserving structure),
// move its contents directly instead.
promise = promise
.then(function () {
return Q.nfcall(fs.unlink, src);
});
}
// Move contents if a single directory was extracted
if (!opts.keepStructure) {
promise = promise
.then(function () {
return isSingleDir(dst);
return isSingleDir(tempDir);
})
.then(function (singleDir) {
return singleDir ? moveSingleDirContents(singleDir) : null;
if (singleDir && !opts.keepStructure) {
return moveDirectory(singleDir, dst);
} else {
return moveDirectory(tempDir, dst);
}
});
}
// Resolve promise to the dst dir
return promise.then(function () {
return dst;
// Resolve promise to the dst dir
return promise.then(function () {
return dst;
});
});
}

34
lib/util/fs.js Normal file
View File

@@ -0,0 +1,34 @@
var fs = require('graceful-fs');
var readdir = fs.readdir.bind(fs);
var readdirSync = fs.readdirSync.bind(fs);
module.exports = fs;
module.exports.readdir = function (dir, callback) {
fs.stat(dir, function (err, stats) {
if (err) return callback(err);
if (stats.isDirectory()) {
return readdir(dir, callback);
} else {
var error = new Error('ENOTDIR, not a directory \'' + dir + '\'');
error.code = 'ENOTDIR';
error.path = dir;
error.errono = -20;
return callback(error);
}
});
};
module.exports.readdirSync = function (dir) {
var stats = fs.statSync(dir);
if (stats.isDirectory()) {
return readdirSync(dir);
} else {
var error = new Error();
error.code = 'ENOTDIR';
throw error;
}
};

View File

@@ -0,0 +1,5 @@
function isPathAbsolute(filePath) {
return filePath.charAt(0) === '/';
}
module.exports = isPathAbsolute;

View File

@@ -17,6 +17,16 @@ function readJson(file, options) {
.spread(function (json, jsonFile) {
var deprecated;
if (options.logger) {
var issues = bowerJson.getIssues(json);
if (issues.warnings.length > 0) {
options.logger.warn('invalid-meta', 'for:' + jsonFile);
}
issues.warnings.forEach(function (warning) {
options.logger.warn('invalid-meta', warning);
});
}
jsonFile = path.basename(jsonFile);
deprecated = jsonFile === 'component.json' ? jsonFile : false;

View File

@@ -0,0 +1,14 @@
var path = require('path');
var isPathAbsolute = require('./isPathAbsolute');
function relativeToBaseDir(baseDir) {
return function (filePath) {
if (isPathAbsolute(filePath)) {
return path.resolve(filePath);
} else {
return path.resolve(baseDir, filePath);
}
};
}
module.exports = relativeToBaseDir;

View File

@@ -1,5 +1,5 @@
var path = require('path');
var rimraf = require('rimraf');
var rimraf = require('../util/rimraf');
var fstreamIgnore = require('fstream-ignore');
var mout = require('mout');
var Q = require('q');

22
lib/util/resolve.js Normal file
View File

@@ -0,0 +1,22 @@
var requireg = require('requireg');
var resolve = require('resolve');
function startsWith(string, searchString, position) {
position = position || 0;
return string.substr(position, searchString.length) === searchString;
};
module.exports = function (id, options) {
var resolvedPath;
var cwd = (options || {}).cwd || process.cwd();
try {
resolvedPath = resolve.sync(id, { basedir: cwd });
} catch (e) {
// Fallback to global require
resolvedPath = requireg.resolve(id);
}
return resolvedPath;
}

46
lib/util/rimraf.js Normal file
View File

@@ -0,0 +1,46 @@
var rimraf = require('rimraf');
var chmodr = require('chmodr');
var fs = require('./fs');
module.exports = function (dir, callback) {
var checkAndRetry = function (e) {
fs.lstat(dir, function (err, stats) {
if (err) {
if (err.code === 'ENOENT') return callback();
return callback(e);
}
chmodr(dir, 0777, function (err) {
if (err) return callback(e);
rimraf(dir, callback);
});
});
};
if (process.platform === 'win32') {
checkAndRetry();
} else {
rimraf(dir, checkAndRetry);
}
};
module.exports.sync = function (dir) {
var checkAndRetry = function () {
try {
fs.lstatSync(dir);
chmodr.sync(dir, 0777);
return rimraf.sync(dir);
} catch (e) {
if (e.code === 'ENOENT') return;
throw e;
}
};
try {
return rimraf.sync(dir);
} catch (e) {
return checkAndRetry();
} finally {
return checkAndRetry();
}
};

View File

@@ -1,4 +1,3 @@
/*jshint multistr:true*/
'use strict';
var isRoot = require('is-root');
var createError = require('./createError');
@@ -19,7 +18,7 @@ sudo, please spend a few minutes learning more about how your system should work
make any necessary repairs.\n\n\
http://www.joyent.com/blog/installing-node-and-npm\n\
https://gist.github.com/isaacs/579814\n\n\
You can however run a command with sudo using --allow-root option';
You can however run a command with sudo using "--allow-root" option';
if (isRoot()) {
var cli = require('./cli');

View File

@@ -1,10 +1,10 @@
var path = require('path');
var fs = require('graceful-fs');
var fs = require('./fs');
var Handlebars = require('handlebars');
var mout = require('mout');
var helpers = require('../../templates/helpers');
var helpers = require('../templates/helpers');
var templatesDir = path.resolve(__dirname, '../../templates');
var templatesDir = path.resolve(__dirname, '../templates');
var cache = {};
// Register helpers

3
lib/util/userAgent.js Normal file
View File

@@ -0,0 +1,3 @@
var version = require('../version');
module.exports = 'node/' + process.version + ' ' + process.platform + ' ' + process.arch + ' ' + ';Bower ' + version;

View File

@@ -1,5 +1,5 @@
var Q = require('q');
var fs = require('graceful-fs');
var fs = require('./fs');
function validLink(file) {
// Ensures that a file is a symlink that points

3
lib/version.js Normal file
View File

@@ -0,0 +1,3 @@
var findup = require('findup-sync');
module.exports = require(findup('package.json', { cwd: __dirname })).version;

Some files were not shown because too many files have changed in this diff Show More