Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release proposal: v5.2.0 #4180

Closed
wants to merge 323 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
323 commits
Select commit Hold shift + click to select a range
b8cea49
test: fix heap-profiler link error LNK1194 on win
Oct 28, 2015
f236b3a
lib,doc: return boolean from child.send()
Trott Oct 25, 2015
b64ce59
tls: remove util and calls to util.format
Oct 20, 2015
384e6c2
2015-10-29, Version 5.0.0 (Stable)
rvagg Oct 21, 2015
4e54dbe
Working on v5.0.1
rvagg Oct 29, 2015
e888471
child_process: don't fork bomb ourselves from -e
bnoordhuis Oct 28, 2015
d72bb1e
Revert "src: fix stuck debugger process"
bnoordhuis Oct 29, 2015
1e98d90
test: add regression test for --debug-brk -e 0
bnoordhuis Oct 29, 2015
65cd03c
src: wrap source before doing syntax check
evanlucas Oct 29, 2015
90723af
doc: made code spans more visible in the API docs
phillipj Oct 28, 2015
d2b5dcb
lib: return boolean from child.send()
Trott Oct 25, 2015
3137e46
tools: update gyp to b3cef02
Oct 19, 2015
cbd358c
tools: fix gyp to work on MacOSX without XCode
Feb 10, 2015
efa19bd
doc: add final full stop in CONTRIBUTING.md
emilyaviva Oct 29, 2015
7d0b589
doc: fix crypto spkac function descriptions
jas- Oct 31, 2015
5667369
buffer: neuter external `nullptr` buffers
indutny Nov 2, 2015
e40d282
tools: update npm test tooling for 3.3.10+
iarna Oct 29, 2015
c96400c
gitignore: don't ignore 'debug' in deps/npm
iarna Oct 29, 2015
08e0de5
deps: upgrade npm to 3.3.10
iarna Oct 29, 2015
5977963
test: remove flaky designation from ls-no-sslv3
Trott Nov 1, 2015
7fd8f13
doc: add note about timeout delay > TIMEOUT_MAX
sitegui Oct 25, 2015
e302c33
test: mark http-pipeline-flood flaky
Trott Oct 31, 2015
935b977
test: add regression test for 512 bits DH key
bnoordhuis Nov 2, 2015
8152248
test: more regression tests for minDHSize option
bnoordhuis Nov 2, 2015
5073da0
repl: don't crash if cannot open history file
evanlucas Nov 2, 2015
6ef043a
2015-11-03, Version 4.2.2 "Argon" (LTS) Release
jasnell Oct 29, 2015
045e04e
doc: typo fix in readme.md
SPGB Nov 3, 2015
7caeb14
deps: update http-parser to 2.6.0
jasnell Oct 28, 2015
325c4c7
doc:fix function param order in assert doc
birnam Oct 26, 2015
f3594e7
test: fix test-net-persistent-keepalive for AIX
Nov 3, 2015
8018662
doc: fix wrong date and known issue in changelog.md
jasnell Nov 3, 2015
409f299
doc: rename iojs-* groups to nodejs-*
srl295 Nov 2, 2015
a0db5fb
doc: stdout/stderr can block when directed to file
bnoordhuis Oct 3, 2015
a7f28a0
http: remove unneeded cb check from setTimeout()
aks- Nov 5, 2015
7a84fa6
docs: fs - remove encoding list and link to buffer
Sep 10, 2015
73e40f0
docs: fs - change links to buffer encoding to Buffer class anchor
Oct 13, 2015
8f5a255
build: omit -gline-tables-only for --enable-asan
bnoordhuis Nov 5, 2015
89285db
module: remove unnecessary JSON.stringify
zertosh Oct 29, 2015
59cd281
Add missing va_end before return
usta Oct 28, 2015
44f779b
doc: add caveats of algs and key size in crypto
Jul 27, 2015
b14d9c5
doc: add method links in events.markdown
a0viedo Nov 6, 2015
9a45c21
util: use regexp instead of str.replace().join()
hellopao Nov 6, 2015
b48dbf9
deps: upgrade npm to 3.3.12
iarna Nov 3, 2015
d64a56c
cluster: remove handles when disconnecting worker
bnoordhuis Nov 3, 2015
5d34c81
async_wrap: allow some hooks to be optional
trevnorris Oct 20, 2015
eccbec9
async_wrap: new instances get uid
trevnorris Oct 19, 2015
b663d2b
async_wrap: call callback in destructor
trevnorris Oct 20, 2015
2498e29
src: Revert "nix stdin _readableState.reading"
silverwind Oct 26, 2015
9cdceac
test: use really invalid hostname
thefourtheye Nov 8, 2015
75dbafc
repl: To exit, press ^C again or type .exit.
hemanth Nov 7, 2015
a05a0b4
doc: add saghul as a collaborator
saghul Nov 9, 2015
e5b9109
doc: add thealphanerd to collaborators
Nov 9, 2015
8199784
test: fix test-module-loading-error for musl
hmalphettes Nov 10, 2015
5ed30da
console: use 'label' argument for time and timeEnd
silverwind Oct 29, 2015
1c8a7c6
test: enhance fs-watch-recursive test
thefourtheye Aug 28, 2015
ac9e4ff
dns: prevent undefined values in results
Nov 6, 2015
a32d9e3
doc: add romankl to collaborators
r-52 Nov 9, 2015
597f875
doc: add note on tls connection meta data methods
DaftMonk Nov 10, 2015
02e012e
src: force line buffering for stderr
Trott Nov 6, 2015
38bb0d8
tools: Use `throw new Error()` consistently
Trott Nov 8, 2015
d036b35
tools: enforce `throw new Error()` with lint rule
Trott Nov 8, 2015
9ef81ff
deps: update V8 to 4.6.85.31
targos Nov 6, 2015
47f3735
cluster: send suicide message on disconnect
cjihrig Nov 9, 2015
2aa6a6d
fs: return null error on readFile() success
zbinlin Nov 10, 2015
da911f1
doc: update lts description in the collaborator guide
jasnell Nov 5, 2015
bea3542
tools: add tap output to cpplint
jbergstroem Oct 20, 2015
59077ac
deps: cherry-pick 68e89fb from v8's upstream
indutny Nov 11, 2015
35fb9f9
doc: Describe FIPSDIR environment variable
stefanmb Nov 6, 2015
f2c2e53
doc: add note to util.isBuffer
evanlucas Nov 12, 2015
530bb91
docs: improve discoverability of Code of Conduct
ashleygwilliams Nov 11, 2015
2c9fb14
crypto: Improve error checking and reporting
stefanmb Nov 9, 2015
c7c05d8
doc: sort assert alphabetically
tflanagan Nov 4, 2015
fb6a09c
doc: sort buffer alphabetically
tflanagan Nov 4, 2015
5c30e5d
doc: sort child_process alphabetically
tflanagan Nov 4, 2015
05f1af7
doc: sort cluster alphabetically
tflanagan Nov 4, 2015
3e046ac
doc: sort console alphabetically
tflanagan Nov 4, 2015
4118fd5
doc: sort dns alphabetically
tflanagan Nov 4, 2015
e1c357e
doc: sort crypto alphabetically
tflanagan Nov 4, 2015
488326d
doc: sort dgram alphabetically
tflanagan Nov 4, 2015
63a7874
doc: sort errors alphabetically
tflanagan Nov 4, 2015
ce3ac8d
doc: sort events alphabetically
tflanagan Nov 4, 2015
c3f5ea7
doc: sort fs alphabetically
tflanagan Nov 4, 2015
4ba1848
doc: sort globals alphabetically
tflanagan Nov 4, 2015
22961e0
doc: sort os alphabetically
tflanagan Nov 4, 2015
bc63667
doc: sort path alphabetically
tflanagan Nov 4, 2015
1f56aba
doc: sort punycode alphabetically
tflanagan Nov 4, 2015
d357b30
doc: sort querystring alphabetically
tflanagan Nov 4, 2015
39b8259
doc: sort vm alphabetically
tflanagan Nov 4, 2015
d4dda77
doc: sort url alphabetically
tflanagan Nov 4, 2015
14b5a95
doc: sort tty alphabetically
tflanagan Nov 4, 2015
0d22628
doc: sort timers alphabetically
tflanagan Nov 4, 2015
d383d62
doc: sort string_decoder alphabetically
tflanagan Nov 4, 2015
389ead3
doc: sort repl alphabetically
tflanagan Nov 4, 2015
29054ff
doc: sort readline alphabetically
tflanagan Nov 4, 2015
18da02f
doc: sort modules alphabetically
tflanagan Nov 4, 2015
6e9d01c
doc: sort http alphabetically
tflanagan Nov 4, 2015
df07072
doc: sort https alphabetically
tflanagan Nov 4, 2015
0996b97
doc: sort util alphabetically
tflanagan Nov 5, 2015
e1a5126
doc: sort zlib alphabetically
tflanagan Nov 5, 2015
cfa8198
doc: sort process alphabetically
tflanagan Nov 5, 2015
cd931a8
doc: sort net alphabetically
tflanagan Nov 5, 2015
7e60b81
doc: sort stream alphabetically
tflanagan Nov 5, 2015
09e524d
doc: sort tls alphabetically
tflanagan Nov 5, 2015
84bb745
child_process: add safety checks on stdio access
cjihrig Nov 12, 2015
ae2d1ee
doc: repl: add defineComand and displayPrompt
bengl Nov 11, 2015
1ab59ab
test: fix flaky test test-http-pipeline-flood
dnakamura Sep 14, 2015
2e67db3
test: refactor test-http-pipeline-flood
Trott Nov 2, 2015
05f0549
tls: copy client CAs and cert store on CertCb
indutny Oct 26, 2015
fd3f0d8
querystring: Parse multiple separator characters
yosuke-furukawa Nov 12, 2015
583f58e
test: stronger crypto in test fixtures
stefanmb Nov 10, 2015
25c3807
doc: clarify duplicate header handling
bengl Nov 13, 2015
5d1faa2
doc: reword message.headers to indicate they are not read-only
tflanagan Nov 13, 2015
45ff31c
doc: added what buf.copy returns
baslr Oct 28, 2015
d137f0f
doc: add warning about Windows process groups
r-52 Nov 5, 2015
132297d
doc: Updated streams simplified constructor API
tomgco Oct 30, 2015
96f53c6
doc: add link to [customizing util.inspect colors].
jmm Nov 10, 2015
91248b1
test: run pipeline flood test in parallel
Trott Nov 13, 2015
252e810
test: Fix test-cluster-worker-exit.js for AIX
Nov 4, 2015
fd0253b
deps: backport bc2e393 from v8 upstream
Nov 12, 2015
7a290ab
crypto: DSA parameter validation in FIPS mode
stefanmb Nov 10, 2015
828b786
test: add test for invalid DSA key size
stefanmb Nov 13, 2015
de707f0
test: add hasFipsCrypto to test/common.js
stefanmb Nov 12, 2015
d70deab
zlib: pass kind to recursive calls to flush
Oct 26, 2015
33ffc62
zlib: only apply drain listener if given callback
CraigCav Oct 26, 2015
2ec5e17
test: add test-zlib-flush-drain
Nov 11, 2015
413ca53
test: increase crypto strength for FIPS standard
stefanmb Nov 10, 2015
2a69b68
build: fix --with-intl=system-icu for x-compile
srl295 Nov 13, 2015
1c1e708
test: fix path to module for repl test on Windows
mcornac Oct 30, 2015
d61cb90
util: use Object.create(null) for dictionary object
JungMinu Nov 15, 2015
2d0ca02
build: fix configuring with prebuilt libraries
zyxar Sep 30, 2015
4bb27ba
test: skip test if FreeBSD jail will break it
Trott Nov 15, 2015
c2393d1
doc: consistent reference-style links
bengl Nov 14, 2015
66dccaf
debugger: also exit when the repl emits 'exit'
fb55 Aug 13, 2015
7ecd542
doc: address use of profanity in code of conduct
jasnell Nov 14, 2015
19a36ff
test: fix flaky SmartOS test
Trott Nov 15, 2015
7bff013
buffer: let WriteFloatGeneric silently drop values
pmq20 Nov 16, 2015
047abbd
test: move test-specific function out of common
Trott Nov 17, 2015
df1fdba
doc: sort repl alphabetically
tflanagan Nov 16, 2015
5c54fa0
module: cache regular expressions
evanlucas Nov 17, 2015
60d3daa
doc: replace head of readme with updated text
rvagg Oct 22, 2015
ea67d87
doc: document release types in readme
rvagg Oct 22, 2015
2f16be2
tls: Use SHA1 for sessionIdContext in FIPS mode
stefanmb Nov 9, 2015
02fd81a
2015-11-17, Version 5.1.0 (Stable)
Fishrock123 Nov 10, 2015
3b69060
Working on v5.1.1
Fishrock123 Nov 10, 2015
533881f
deps: upgrade openssl sources to 1.0.2e
Dec 3, 2015
12e70fa
http: fix pipeline regression
indutny Oct 29, 2015
76a552c
deps: backport 6df9a1d from upstream v8
bnoordhuis Nov 13, 2015
678398f
deps: backport a7e50a5 from upstream v8
bnoordhuis Nov 18, 2015
1143312
2015-12-04, Version 5.1.1 (Stable)
rvagg Nov 30, 2015
51a5227
Working on v5.1.2
rvagg Dec 4, 2015
6c16c40
doc: clarify v5.1.1 notable items
rvagg Dec 4, 2015
ce423f3
debugger: introduce exec method for debugger
JacksonTian Apr 21, 2015
f99c636
test: module loading error fix solaris #3798
Nov 16, 2015
781f8c0
test: add OS X to module loading error test
evanlucas Nov 18, 2015
272732e
test: fix flaky test-child-process-spawnsync-input
Trott Nov 17, 2015
bc27379
test: avoid test timeouts on rpi
stefanmb Nov 18, 2015
0997178
doc: add reference for buffer.inspect()
cjihrig Nov 19, 2015
bbcb2a2
doc: clarify module loading behavior
cjihrig Nov 19, 2015
e129d83
test: skip/replace weak crypto tests in FIPS mode
stefanmb Nov 10, 2015
788541b
test: fix race condition in unrefd interval test
mcornac Oct 27, 2015
def681a
crypto: disable crypto.createCipher in FIPS mode
stefanmb Nov 9, 2015
54aafa1
test: http complete list of non-concat headers
bengl Nov 20, 2015
f90227b
doc: move fs.existsSync() deprecation message
martfors Nov 20, 2015
fcf0e8e
buffer: move checkFloat from lib into src
Nov 11, 2015
26eeae8
doc: fix broken references
gromnitsky Nov 20, 2015
13834ca
module: fix column offsets in errors
tflanagan Sep 14, 2015
12754c5
net: small code cleanup
jscissr Nov 20, 2015
d7a7d3e
tools: update certdata.txt
bnoordhuis Nov 21, 2015
b81b45d
crypto: update root certificates
bnoordhuis Nov 21, 2015
f29c5d6
configure: `v8_use_snapshot` should be `true`
indutny Nov 22, 2015
f4ca007
doc: clarify that fs streams expect blocking fd
XeCycle Nov 3, 2015
f9fe0ae
test: numeric flags to fs.open
XeCycle Nov 3, 2015
77251d9
doc: numeric flags to fs.open
XeCycle Nov 3, 2015
4849a54
doc: Adding best practises for crypto.pbkdf2
tomgco Oct 9, 2015
4602e01
doc: replace sane with reasonable
lewiscowper Nov 23, 2015
665a35d
test: address flaky test-http-client-timeout-event
Trott Nov 22, 2015
1fe4d30
test: retry on smartos if ECONNREFUSED
Trott Nov 20, 2015
7e18f2e
src: add BE support to StringBytes::Encode()
exinfinitum Oct 7, 2015
b1dfa8b
doc: fix typo in README
Trott Nov 24, 2015
dd0d15f
test: add TAP diagnostic message for retried tests
Trott Nov 21, 2015
f0a2e2c
doc: message.header duplication correction
bengl Nov 24, 2015
a863e8d
test: remove flaky status for cluster test
Trott Nov 23, 2015
c584c3e
util,src: allow lookup of hidden values
cjihrig Nov 23, 2015
baac81d
net: add local address/port for better errors
jscissr Nov 20, 2015
19ed33d
test: skip test if in FreeBSD jail
Trott Nov 24, 2015
99fd1ec
deps: backport 819b40a from V8 upstream
targos Nov 20, 2015
1f0e8dc
installer: install the tick processor
Sep 22, 2015
ed255ab
build,src: add Intel Vtune profiling support
cdai2 Oct 21, 2015
ab5b529
buffer: default to UTF8 in byteLength()
tomgco Nov 24, 2015
d0621c5
test: mark fork regression test flaky on windows
Trott Nov 25, 2015
054a216
test: mark cluster-net-send test flaky on windows
Trott Nov 24, 2015
e68ea16
util: add decorateErrorStack()
cjihrig Nov 25, 2015
aaab108
repl: attach location info to syntax errors
cjihrig Nov 25, 2015
00b839a
test: use platform-based timeout for reliability
Trott Nov 25, 2015
f3c50f5
doc: fix rare case of misaligned columns
silverwind Nov 21, 2015
d94a70e
test: fix test-domain-exit-dispose-again
Nov 23, 2015
69c95bb
test: move ArrayStream to common
cjihrig Nov 25, 2015
c500037
test: mark test flaky on FreeBSD
Trott Nov 25, 2015
a76d788
build: update signtool description, add url
rvagg Nov 24, 2015
a2b7596
doc: fix color of linked code blocks
Nov 29, 2015
8988e1e
module,repl: remove repl require() hack
bnoordhuis Nov 25, 2015
098a311
util: move .decorateErrorStack to internal/util
bnoordhuis Nov 25, 2015
aaeced9
doc: fix the exception description
yorkie Nov 4, 2015
c93e267
util: fix constructor/instanceof checks
mscdex Oct 15, 2015
22b0971
test: eliminate multicast test FreeBSD flakiness
Trott Nov 26, 2015
7793c36
child_process: flush consuming streams
Nov 30, 2015
c61237d
doc: fix internal link to child.send()
lpinca Dec 1, 2015
4302648
test: add test for repl.defineCommand()
bengl Nov 19, 2015
0e18e68
buffer: fix writeInt{B,L}E for some neg values
pabigot Nov 23, 2015
2b5b127
test: fix cluster-disconnect-handles flakiness
santigimeno Nov 24, 2015
0869ef3
repl: allow leading period in multiline input
Zirak Nov 15, 2015
95dd60c
doc: reword https.Agent example text
Nov 30, 2015
1279adc
timers: optimize callback call: bind -> arrow
bsnote Nov 26, 2015
1b434e0
util: determine object types in C++
cjihrig Dec 1, 2015
cb55c67
test: improve cluster-disconnect-handles test
mscdex Dec 1, 2015
1c1af81
streams: update .readable/.writable to false
mscdex Mar 20, 2015
e8e4e07
meta: remove use of profanity in source
Dec 2, 2015
cfc9764
crypto: fix native module compilation with FIPS
stefanmb Nov 25, 2015
f3417e2
doc: standardize references to node.js in docs
scottsb Dec 3, 2015
4b43bf0
test: fix flaky test-net-socket-local-address
Trott Dec 1, 2015
3169eed
doc: add links and backticks around names
Nov 27, 2015
f4164bd
doc: update links to use https where possible
Dec 2, 2015
85b6012
doc: add HTTP working group
jasnell Nov 19, 2015
424eb96
doc: add zkat to collaborators
zkat Dec 3, 2015
fa0cdf7
doc: add iarna to collaborators
iarna Dec 3, 2015
fd5ed68
doc: add JungMinu to collaborators
JungMinu Dec 3, 2015
458facd
src: define getpid() based on OS
cjihrig Dec 4, 2015
756ab9c
stream: be less eager with readable flag
mscdex Dec 3, 2015
be41eb7
test: refactor test-http-exit-delay
Trott Nov 28, 2015
0cd4a52
doc: improve child_process.markdown wording
yorkie Dec 3, 2015
d969c09
src: define Is* util functions with macros
cjihrig Dec 2, 2015
9d16729
test: skip instead of fail when mem constrained
mcornac Nov 6, 2015
6f957a7
doc: s/node.js/Node.js in readme
rvagg Nov 24, 2015
da6be4d
test: fix time resolution constraint
gireeshpunathil Nov 23, 2015
9e9346f
src: use GetCurrentProcessId() for process.pid
bnoordhuis Dec 4, 2015
e3a8e8b
buffer: Prevent Buffer constructor deopt
brycebaril Dec 4, 2015
b3f3b2e
test: fix cluster-worker-isdead
santigimeno Nov 21, 2015
634c5f1
doc: url.format - true slash postfix behaviour
Dec 2, 2015
4c8800c
fs,doc: use `target` instead of `destination`
yorkie Nov 25, 2015
e84aeec
test: mark test-cluster-shared-leak flaky
Trott Dec 5, 2015
8f845ba
stream_wrap: error if stream has StringDecoder
indutny Dec 5, 2015
8a60aa1
test: don't check the # of chunks in test-http-1.0
santigimeno Nov 21, 2015
12649f4
build: add "--partly-static" build options
medns Dec 4, 2015
0c2a0dc
test: skip long path tests on non-Windows
rsp Dec 2, 2015
da5ac55
crypto: simplify using pre-existing keys with ECDH
Nov 19, 2015
8a5e434
node: s/doNTCallbackX/nextTickCallbackWithXArgs/
rvagg Dec 6, 2015
08a3f29
buffer: fix range checking for slowToString
Dec 7, 2015
1d50819
test: check range fix for slowToString
thefourtheye Dec 7, 2015
da3137d
src: don't print garbage errors
cjihrig Dec 2, 2015
9f34df8
2015-12-08, Version 5.2.0 (Stable)
rvagg Dec 8, 2015
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
tools: update gyp to b3cef02
Includes two patches for AIX. Adds support for both 32-bit and 64-bit
files[0] and uses -RPf for cp instead of -af (which is unsupported)[1]

[0] https://codereview.chromium.org/1319663007
[1] https://codereview.chromium.org/1368133002

PR-URL: #3487
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Shigeki Ohtsu <ohtsu@iij.ad.jp>
  • Loading branch information
Imran Iqbal authored and rvagg committed Nov 6, 2015
commit 3137e46cb853523442fd340593d8d505efc9f348
9 changes: 4 additions & 5 deletions tools/gyp/PRESUBMIT.py
Original file line number Diff line number Diff line change
Expand Up @@ -125,14 +125,13 @@ def CheckChangeOnCommit(input_api, output_api):


TRYBOTS = [
'gyp-win32',
'gyp-win64',
'gyp-linux',
'gyp-mac',
'linux_try',
'mac_try',
'win_try',
]


def GetPreferredTryMasters(_, change):
return {
'tryserver.nacl': { t: set(['defaulttests']) for t in TRYBOTS },
'client.gyp': { t: set(['defaulttests']) for t in TRYBOTS },
}
12 changes: 5 additions & 7 deletions tools/gyp/gyp_main.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,13 @@
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

import os
import sys

# TODO(mark): sys.path manipulation is some temporary testing stuff.
try:
import gyp
except ImportError, e:
import os.path
sys.path.append(os.path.join(os.path.dirname(sys.argv[0]), 'pylib'))
import gyp
# Make sure we're using the version of pylib in this repo, not one installed
# elsewhere on the system.
sys.path.insert(0, os.path.join(os.path.dirname(sys.argv[0]), 'pylib'))
import gyp

if __name__ == '__main__':
sys.exit(gyp.script_main())
5 changes: 1 addition & 4 deletions tools/gyp/pylib/gyp/MSVSSettings.py
Original file line number Diff line number Diff line change
Expand Up @@ -708,10 +708,7 @@ def _ValidateSettings(validators, settings, stderr):
_MSBuildOnly(_compile, 'BuildingInIDE', _boolean)
_MSBuildOnly(_compile, 'CompileAsManaged',
_Enumeration([], new=['false',
'true', # /clr
'Pure', # /clr:pure
'Safe', # /clr:safe
'OldSyntax'])) # /clr:oldSyntax
'true'])) # /clr
_MSBuildOnly(_compile, 'CreateHotpatchableImage', _boolean) # /hotpatch
_MSBuildOnly(_compile, 'MultiProcessorCompilation', _boolean) # /MP
_MSBuildOnly(_compile, 'PreprocessOutputPath', _string) # /Fi
Expand Down
2 changes: 1 addition & 1 deletion tools/gyp/pylib/gyp/MSVSSettings_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -296,7 +296,7 @@ def testValidateMSBuildSettings_settings(self):
'BuildingInIDE': 'true',
'CallingConvention': 'Cdecl',
'CompileAs': 'CompileAsC',
'CompileAsManaged': 'Pure',
'CompileAsManaged': 'true',
'CreateHotpatchableImage': 'true',
'DebugInformationFormat': 'ProgramDatabase',
'DisableLanguageExtensions': 'true',
Expand Down
11 changes: 9 additions & 2 deletions tools/gyp/pylib/gyp/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -131,13 +131,20 @@ def QualifiedTarget(build_file, target, toolset):


@memoize
def RelativePath(path, relative_to):
def RelativePath(path, relative_to, follow_path_symlink=True):
# Assuming both |path| and |relative_to| are relative to the current
# directory, returns a relative path that identifies path relative to
# relative_to.
# If |follow_symlink_path| is true (default) and |path| is a symlink, then
# this method returns a path to the real file represented by |path|. If it is
# false, this method returns a path to the symlink. If |path| is not a
# symlink, this option has no effect.

# Convert to normalized (and therefore absolute paths).
path = os.path.realpath(path)
if follow_path_symlink:
path = os.path.realpath(path)
else:
path = os.path.abspath(path)
relative_to = os.path.realpath(relative_to)

# On Windows, we can't create a relative path to a different drive, so just
Expand Down
4 changes: 2 additions & 2 deletions tools/gyp/pylib/gyp/generator/analyzer.py
Original file line number Diff line number Diff line change
Expand Up @@ -338,7 +338,7 @@ def _GenerateTargets(data, target_list, target_dicts, toplevel_dir, files,
sources = _ExtractSources(target_name, target_dicts[target_name],
toplevel_dir)
for source in sources:
if source in files:
if _ToGypPath(os.path.normpath(source)) in files:
print 'target', target_name, 'matches', source
target.match_status = MATCH_STATUS_MATCHES
matching_targets.append(target)
Expand Down Expand Up @@ -498,7 +498,7 @@ def _WasGypIncludeFileModified(params, files):
files."""
if params['options'].includes:
for include in params['options'].includes:
if _ToGypPath(include) in files:
if _ToGypPath(os.path.normpath(include)) in files:
print 'Include file modified, assuming all changed', include
return True
return False
Expand Down
18 changes: 11 additions & 7 deletions tools/gyp/pylib/gyp/generator/make.py
Original file line number Diff line number Diff line change
Expand Up @@ -211,10 +211,10 @@ def CalculateGeneratorInputInfo(params):

LINK_COMMANDS_AIX = """\
quiet_cmd_alink = AR($(TOOLSET)) $@
cmd_alink = rm -f $@ && $(AR.$(TOOLSET)) crs $@ $(filter %.o,$^)
cmd_alink = rm -f $@ && $(AR.$(TOOLSET)) -X32_64 crs $@ $(filter %.o,$^)

quiet_cmd_alink_thin = AR($(TOOLSET)) $@
cmd_alink_thin = rm -f $@ && $(AR.$(TOOLSET)) crs $@ $(filter %.o,$^)
cmd_alink_thin = rm -f $@ && $(AR.$(TOOLSET)) -X32_64 crs $@ $(filter %.o,$^)

quiet_cmd_link = LINK($(TOOLSET)) $@
cmd_link = $(LINK.$(TOOLSET)) $(GYP_LDFLAGS) $(LDFLAGS.$(TOOLSET)) -o $@ $(LD_INPUTS) $(LIBS)
Expand Down Expand Up @@ -273,9 +273,9 @@ def CalculateGeneratorInputInfo(params):
%(make_global_settings)s

CC.target ?= %(CC.target)s
CFLAGS.target ?= $(CFLAGS)
CFLAGS.target ?= $(CPPFLAGS) $(CFLAGS)
CXX.target ?= %(CXX.target)s
CXXFLAGS.target ?= $(CXXFLAGS)
CXXFLAGS.target ?= $(CPPFLAGS) $(CXXFLAGS)
LINK.target ?= %(LINK.target)s
LDFLAGS.target ?= $(LDFLAGS)
AR.target ?= $(AR)
Expand All @@ -286,9 +286,9 @@ def CalculateGeneratorInputInfo(params):
# TODO(evan): move all cross-compilation logic to gyp-time so we don't need
# to replicate this environment fallback in make as well.
CC.host ?= %(CC.host)s
CFLAGS.host ?=
CFLAGS.host ?= $(CPPFLAGS_host) $(CFLAGS_host)
CXX.host ?= %(CXX.host)s
CXXFLAGS.host ?=
CXXFLAGS.host ?= $(CPPFLAGS_host) $(CXXFLAGS_host)
LINK.host ?= %(LINK.host)s
LDFLAGS.host ?=
AR.host ?= %(AR.host)s
Expand Down Expand Up @@ -365,7 +365,7 @@ def CalculateGeneratorInputInfo(params):

quiet_cmd_copy = COPY $@
# send stderr to /dev/null to ignore messages when linking directories.
cmd_copy = ln -f "$<" "$@" 2>/dev/null || (rm -rf "$@" && cp -af "$<" "$@")
cmd_copy = ln -f "$<" "$@" 2>/dev/null || (rm -rf "$@" && cp %(copy_archive_args)s "$<" "$@")

%(link_commands)s
"""
Expand Down Expand Up @@ -2010,6 +2010,7 @@ def CalculateMakefilePath(build_file, base_name):
srcdir_prefix = '$(srcdir)/'

flock_command= 'flock'
copy_archive_arguments = '-af'
header_params = {
'default_target': default_target,
'builddir': builddir_name,
Expand All @@ -2019,6 +2020,7 @@ def CalculateMakefilePath(build_file, base_name):
'link_commands': LINK_COMMANDS_LINUX,
'extra_commands': '',
'srcdir': srcdir,
'copy_archive_args': copy_archive_arguments,
}
if flavor == 'mac':
flock_command = './gyp-mac-tool flock'
Expand All @@ -2043,7 +2045,9 @@ def CalculateMakefilePath(build_file, base_name):
'flock': 'lockf',
})
elif flavor == 'aix':
copy_archive_arguments = '-pPRf'
header_params.update({
'copy_archive_args': copy_archive_arguments,
'link_commands': LINK_COMMANDS_AIX,
'flock': './gyp-flock-tool flock',
'flock_index': 2,
Expand Down
13 changes: 13 additions & 0 deletions tools/gyp/pylib/gyp/generator/msvs.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,8 @@ def _import_OrderedDict():
'msvs_requires_importlibrary',
'msvs_enable_winphone',
'msvs_application_type_revision',
'msvs_target_platform_version',
'msvs_target_platform_minversion',
]


Expand Down Expand Up @@ -2644,6 +2646,17 @@ def _GetMSBuildGlobalProperties(spec, guid, gyp_file_name):
else:
properties[0].append(['ApplicationTypeRevision', '8.1'])

if spec.get('msvs_target_platform_version'):
target_platform_version = spec.get('msvs_target_platform_version')
properties[0].append(['WindowsTargetPlatformVersion',
target_platform_version])
if spec.get('msvs_target_platform_minversion'):
target_platform_minversion = spec.get('msvs_target_platform_minversion')
properties[0].append(['WindowsTargetPlatformMinVersion',
target_platform_minversion])
else:
properties[0].append(['WindowsTargetPlatformMinVersion',
target_platform_version])
if spec.get('msvs_enable_winphone'):
properties[0].append(['ApplicationType', 'Windows Phone'])
else:
Expand Down
19 changes: 15 additions & 4 deletions tools/gyp/pylib/gyp/generator/ninja.py
Original file line number Diff line number Diff line change
Expand Up @@ -921,6 +921,11 @@ def WriteSourcesForArch(self, ninja_file, config_name, config, sources,
os.environ.get('CFLAGS', '').split() + cflags_c)
cflags_cc = (os.environ.get('CPPFLAGS', '').split() +
os.environ.get('CXXFLAGS', '').split() + cflags_cc)
elif self.toolset == 'host':
cflags_c = (os.environ.get('CPPFLAGS_host', '').split() +
os.environ.get('CFLAGS_host', '').split() + cflags_c)
cflags_cc = (os.environ.get('CPPFLAGS_host', '').split() +
os.environ.get('CXXFLAGS_host', '').split() + cflags_cc)

defines = config.get('defines', []) + extra_defines
self.WriteVariableList(ninja_file, 'defines',
Expand Down Expand Up @@ -1672,7 +1677,7 @@ def CommandWithWrapper(cmd, wrappers, prog):

def GetDefaultConcurrentLinks():
"""Returns a best-guess for a number of concurrent links."""
pool_size = int(os.getenv('GYP_LINK_CONCURRENCY', 0))
pool_size = int(os.environ.get('GYP_LINK_CONCURRENCY', 0))
if pool_size:
return pool_size

Expand All @@ -1696,8 +1701,10 @@ class MEMORYSTATUSEX(ctypes.Structure):
stat.dwLength = ctypes.sizeof(stat)
ctypes.windll.kernel32.GlobalMemoryStatusEx(ctypes.byref(stat))

mem_limit = max(1, stat.ullTotalPhys / (4 * (2 ** 30))) # total / 4GB
hard_cap = max(1, int(os.getenv('GYP_LINK_CONCURRENCY_MAX', 2**32)))
# VS 2015 uses 20% more working set than VS 2013 and can consume all RAM
# on a 64 GB machine.
mem_limit = max(1, stat.ullTotalPhys / (5 * (2 ** 30))) # total / 5GB
hard_cap = max(1, int(os.environ.get('GYP_LINK_CONCURRENCY_MAX', 2**32)))
return min(mem_limit, hard_cap)
elif sys.platform.startswith('linux'):
if os.path.exists("/proc/meminfo"):
Expand Down Expand Up @@ -2275,7 +2282,11 @@ def GenerateOutputForConfig(target_list, target_dicts, data, params,
if flavor == 'mac':
gyp.xcode_emulation.MergeGlobalXcodeSettingsToSpec(data[build_file], spec)

build_file = gyp.common.RelativePath(build_file, options.toplevel_dir)
# If build_file is a symlink, we must not follow it because there's a chance
# it could point to a path above toplevel_dir, and we cannot correctly deal
# with that case at the moment.
build_file = gyp.common.RelativePath(build_file, options.toplevel_dir,
False)

qualified_target_for_hash = gyp.common.QualifiedTarget(build_file, name,
toolset)
Expand Down
20 changes: 12 additions & 8 deletions tools/gyp/pylib/gyp/input.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ def IsPathSection(section):
# If section ends in one of the '=+?!' characters, it's applied to a section
# without the trailing characters. '/' is notably absent from this list,
# because there's no way for a regular expression to be treated as a path.
while section[-1:] in '=+?!':
while section and section[-1:] in '=+?!':
section = section[:-1]

if section in path_sections:
Expand Down Expand Up @@ -893,20 +893,24 @@ def ExpandVariables(input, phase, variables, build_file):
else:
# Fix up command with platform specific workarounds.
contents = FixupPlatformCommand(contents)
p = subprocess.Popen(contents, shell=use_shell,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
stdin=subprocess.PIPE,
cwd=build_file_dir)
try:
p = subprocess.Popen(contents, shell=use_shell,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
stdin=subprocess.PIPE,
cwd=build_file_dir)
except Exception, e:
raise GypError("%s while executing command '%s' in %s" %
(e, contents, build_file))

p_stdout, p_stderr = p.communicate('')

if p.wait() != 0 or p_stderr:
sys.stderr.write(p_stderr)
# Simulate check_call behavior, since check_call only exists
# in python 2.5 and later.
raise GypError("Call to '%s' returned exit status %d." %
(contents, p.returncode))
raise GypError("Call to '%s' returned exit status %d while in %s." %
(contents, p.returncode, build_file))
replacement = p_stdout.rstrip()

cached_command_results[cache_key] = replacement
Expand Down
10 changes: 10 additions & 0 deletions tools/gyp/pylib/gyp/msvs_emulation.py
Original file line number Diff line number Diff line change
Expand Up @@ -442,6 +442,7 @@ def GetCflags(self, config):
cl('FloatingPointModel',
map={'0': 'precise', '1': 'strict', '2': 'fast'}, prefix='/fp:',
default='0')
cl('CompileAsManaged', map={'false': '', 'true': '/clr'})
cl('WholeProgramOptimization', map={'true': '/GL'})
cl('WarningLevel', prefix='/W')
cl('WarnAsError', map={'true': '/WX'})
Expand Down Expand Up @@ -593,6 +594,15 @@ def GetLdflags(self, config, gyp_to_build_path, expand_special,
'2': 'WINDOWS%s' % minimum_required_version},
prefix='/SUBSYSTEM:')

stack_reserve_size = self._Setting(
('VCLinkerTool', 'StackReserveSize'), config, default='')
if stack_reserve_size:
stack_commit_size = self._Setting(
('VCLinkerTool', 'StackCommitSize'), config, default='')
if stack_commit_size:
stack_commit_size = ',' + stack_commit_size
ldflags.append('/STACK:%s%s' % (stack_reserve_size, stack_commit_size))

ld('TerminalServerAware', map={'1': ':NO', '2': ''}, prefix='/TSAWARE')
ld('LinkIncremental', map={'1': ':NO', '2': ''}, prefix='/INCREMENTAL')
ld('BaseAddress', prefix='/BASE:')
Expand Down
4 changes: 3 additions & 1 deletion tools/gyp/pylib/gyp/win_tool.py
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,9 @@ def ExecLinkWrapper(self, arch, use_separate_mspdbsrv, *args):
stderr=subprocess.STDOUT)
out, _ = link.communicate()
for line in out.splitlines():
if not line.startswith(' Creating library '):
if (not line.startswith(' Creating library ') and
not line.startswith('Generating code') and
not line.startswith('Finished generating code')):
print line
return link.returncode

Expand Down
20 changes: 17 additions & 3 deletions tools/gyp/pylib/gyp/xcode_emulation.py
Original file line number Diff line number Diff line change
Expand Up @@ -1032,7 +1032,23 @@ def _AdjustLibrary(self, library, config_name=None):
sdk_root = self._SdkPath(config_name)
if not sdk_root:
sdk_root = ''
return l.replace('$(SDKROOT)', sdk_root)
# Xcode 7 started shipping with ".tbd" (text based stubs) files instead of
# ".dylib" without providing a real support for them. What it does, for
# "/usr/lib" libraries, is do "-L/usr/lib -lname" which is dependent on the
# library order and cause collision when building Chrome.
#
# Instead substitude ".tbd" to ".dylib" in the generated project when the
# following conditions are both true:
# - library is referenced in the gyp file as "$(SDKROOT)/**/*.dylib",
# - the ".dylib" file does not exists but a ".tbd" file do.
library = l.replace('$(SDKROOT)', sdk_root)
if l.startswith('$(SDKROOT)'):
basename, ext = os.path.splitext(library)
if ext == '.dylib' and not os.path.exists(library):
tbd_library = basename + '.tbd'
if os.path.exists(tbd_library):
library = tbd_library
return library

def AdjustLibraries(self, libraries, config_name=None):
"""Transforms entries like 'Cocoa.framework' in libraries into entries like
Expand Down Expand Up @@ -1479,8 +1495,6 @@ def _GetXcodeEnv(xcode_settings, built_products_dir, srcroot, configuration,
sdk_root = xcode_settings._SdkRoot(configuration)
if not sdk_root:
sdk_root = xcode_settings._XcodeSdkPath('')
if sdk_root is None:
sdk_root = ''
env['SDKROOT'] = sdk_root

if not additional_settings:
Expand Down