redsnow 0.0.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +34 -0
- data/.gitmodules +3 -0
- data/.travis.yml +20 -0
- data/CHANGELOG.md +4 -0
- data/Gemfile +4 -0
- data/LICENSE +21 -0
- data/README.md +62 -0
- data/Rakefile +36 -0
- data/Vagrantfile +20 -0
- data/ext/snowcrash/Makefile +64 -0
- data/ext/snowcrash/Vagrantfile +20 -0
- data/ext/snowcrash/bin/snowcrash +0 -0
- data/ext/snowcrash/common.gypi +163 -0
- data/ext/snowcrash/config.gypi +10 -0
- data/ext/snowcrash/config.mk +5 -0
- data/ext/snowcrash/configure +213 -0
- data/ext/snowcrash/provisioning.sh +15 -0
- data/ext/snowcrash/snowcrash.gyp +141 -0
- data/ext/snowcrash/src/ActionParser.h +503 -0
- data/ext/snowcrash/src/AssetParser.h +215 -0
- data/ext/snowcrash/src/BlockUtility.h +186 -0
- data/ext/snowcrash/src/Blueprint.h +283 -0
- data/ext/snowcrash/src/BlueprintParser.h +347 -0
- data/ext/snowcrash/src/BlueprintParserCore.h +190 -0
- data/ext/snowcrash/src/BlueprintSection.h +140 -0
- data/ext/snowcrash/src/BlueprintUtility.h +126 -0
- data/ext/snowcrash/src/CBlueprint.cc +600 -0
- data/ext/snowcrash/src/CBlueprint.h +354 -0
- data/ext/snowcrash/src/CSourceAnnotation.cc +140 -0
- data/ext/snowcrash/src/CSourceAnnotation.h +106 -0
- data/ext/snowcrash/src/CodeBlockUtility.h +189 -0
- data/ext/snowcrash/src/DescriptionSectionUtility.h +156 -0
- data/ext/snowcrash/src/HTTP.cc +46 -0
- data/ext/snowcrash/src/HTTP.h +105 -0
- data/ext/snowcrash/src/HeaderParser.h +289 -0
- data/ext/snowcrash/src/ListBlockUtility.h +273 -0
- data/ext/snowcrash/src/ListUtility.h +95 -0
- data/ext/snowcrash/src/MarkdownBlock.cc +176 -0
- data/ext/snowcrash/src/MarkdownBlock.h +93 -0
- data/ext/snowcrash/src/MarkdownParser.cc +266 -0
- data/ext/snowcrash/src/MarkdownParser.h +88 -0
- data/ext/snowcrash/src/ParameterDefinitonParser.h +570 -0
- data/ext/snowcrash/src/ParametersParser.h +252 -0
- data/ext/snowcrash/src/Parser.cc +71 -0
- data/ext/snowcrash/src/Parser.h +29 -0
- data/ext/snowcrash/src/ParserCore.cc +120 -0
- data/ext/snowcrash/src/ParserCore.h +82 -0
- data/ext/snowcrash/src/PayloadParser.h +672 -0
- data/ext/snowcrash/src/Platform.h +54 -0
- data/ext/snowcrash/src/RegexMatch.h +32 -0
- data/ext/snowcrash/src/ResourceGroupParser.h +195 -0
- data/ext/snowcrash/src/ResourceParser.h +584 -0
- data/ext/snowcrash/src/SectionUtility.h +142 -0
- data/ext/snowcrash/src/Serialize.cc +52 -0
- data/ext/snowcrash/src/Serialize.h +69 -0
- data/ext/snowcrash/src/SerializeJSON.cc +601 -0
- data/ext/snowcrash/src/SerializeJSON.h +21 -0
- data/ext/snowcrash/src/SerializeYAML.cc +336 -0
- data/ext/snowcrash/src/SerializeYAML.h +21 -0
- data/ext/snowcrash/src/SourceAnnotation.h +177 -0
- data/ext/snowcrash/src/StringUtility.h +109 -0
- data/ext/snowcrash/src/SymbolTable.h +83 -0
- data/ext/snowcrash/src/UriTemplateParser.cc +195 -0
- data/ext/snowcrash/src/UriTemplateParser.h +243 -0
- data/ext/snowcrash/src/Version.h +39 -0
- data/ext/snowcrash/src/csnowcrash.cc +23 -0
- data/ext/snowcrash/src/csnowcrash.h +38 -0
- data/ext/snowcrash/src/posix/RegexMatch.cc +99 -0
- data/ext/snowcrash/src/snowcrash.cc +18 -0
- data/ext/snowcrash/src/snowcrash.h +41 -0
- data/ext/snowcrash/src/snowcrash/snowcrash.cc +170 -0
- data/ext/snowcrash/src/win/RegexMatch.cc +78 -0
- data/ext/snowcrash/sundown/CONTRIBUTING.md +10 -0
- data/ext/snowcrash/sundown/Makefile +83 -0
- data/ext/snowcrash/sundown/Makefile.win +33 -0
- data/ext/snowcrash/sundown/examples/smartypants.c +72 -0
- data/ext/snowcrash/sundown/examples/sundown.c +80 -0
- data/ext/snowcrash/sundown/html/houdini.h +37 -0
- data/ext/snowcrash/sundown/html/houdini_href_e.c +108 -0
- data/ext/snowcrash/sundown/html/houdini_html_e.c +84 -0
- data/ext/snowcrash/sundown/html/html.c +647 -0
- data/ext/snowcrash/sundown/html/html.h +77 -0
- data/ext/snowcrash/sundown/html/html_smartypants.c +389 -0
- data/ext/snowcrash/sundown/html_block_names.txt +25 -0
- data/ext/snowcrash/sundown/src/autolink.c +297 -0
- data/ext/snowcrash/sundown/src/autolink.h +51 -0
- data/ext/snowcrash/sundown/src/buffer.c +225 -0
- data/ext/snowcrash/sundown/src/buffer.h +96 -0
- data/ext/snowcrash/sundown/src/html_blocks.h +206 -0
- data/ext/snowcrash/sundown/src/markdown.c +2701 -0
- data/ext/snowcrash/sundown/src/markdown.h +147 -0
- data/ext/snowcrash/sundown/src/src_map.c +200 -0
- data/ext/snowcrash/sundown/src/src_map.h +58 -0
- data/ext/snowcrash/sundown/src/stack.c +81 -0
- data/ext/snowcrash/sundown/src/stack.h +29 -0
- data/ext/snowcrash/sundown/sundown.def +20 -0
- data/ext/snowcrash/tools/gyp/AUTHORS +11 -0
- data/ext/snowcrash/tools/gyp/DEPS +24 -0
- data/ext/snowcrash/tools/gyp/OWNERS +1 -0
- data/ext/snowcrash/tools/gyp/PRESUBMIT.py +120 -0
- data/ext/snowcrash/tools/gyp/buildbot/buildbot_run.py +190 -0
- data/ext/snowcrash/tools/gyp/codereview.settings +10 -0
- data/ext/snowcrash/tools/gyp/data/win/large-pdb-shim.cc +12 -0
- data/ext/snowcrash/tools/gyp/gyp +8 -0
- data/ext/snowcrash/tools/gyp/gyp.bat +5 -0
- data/ext/snowcrash/tools/gyp/gyp_main.py +18 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSNew.py +340 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSProject.py +208 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSSettings.py +1063 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSToolFile.py +58 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSUserFile.py +147 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSUtil.py +267 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/MSVSVersion.py +409 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/__init__.py +537 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/__init__.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/common.py +521 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/common.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/easy_xml.py +157 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/flock_tool.py +49 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/__init__.py +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/__init__.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/android.py +1069 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/cmake.py +1143 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/dump_dependency_json.py +81 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/eclipse.py +335 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/gypd.py +87 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/gypsh.py +56 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/make.py +2181 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/make.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/msvs.py +3335 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/ninja.py +2156 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/xcode.py +1224 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/generator/xcode.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/input.py +2809 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/input.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/mac_tool.py +510 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/msvs_emulation.py +972 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/ninja_syntax.py +160 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/ordered_dict.py +289 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/win_tool.py +292 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/xcode_emulation.py +1440 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/xcode_emulation.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/xcodeproj_file.py +2889 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/xcodeproj_file.pyc +0 -0
- data/ext/snowcrash/tools/gyp/pylib/gyp/xml_fix.py +69 -0
- data/ext/snowcrash/tools/gyp/pylintrc +307 -0
- data/ext/snowcrash/tools/gyp/samples/samples +81 -0
- data/ext/snowcrash/tools/gyp/samples/samples.bat +5 -0
- data/ext/snowcrash/tools/gyp/setup.py +19 -0
- data/ext/snowcrash/tools/gyp/tools/Xcode/Specifications/gyp.pbfilespec +27 -0
- data/ext/snowcrash/tools/gyp/tools/Xcode/Specifications/gyp.xclangspec +226 -0
- data/ext/snowcrash/tools/gyp/tools/emacs/gyp.el +252 -0
- data/ext/snowcrash/tools/gyp/tools/graphviz.py +100 -0
- data/ext/snowcrash/tools/gyp/tools/pretty_gyp.py +155 -0
- data/ext/snowcrash/tools/gyp/tools/pretty_sln.py +168 -0
- data/ext/snowcrash/tools/gyp/tools/pretty_vcproj.py +329 -0
- data/ext/snowcrash/tools/homebrew/snowcrash.rb +11 -0
- data/ext/snowcrash/vcbuild.bat +184 -0
- data/lib/redsnow.rb +31 -0
- data/lib/redsnow/binding.rb +132 -0
- data/lib/redsnow/blueprint.rb +365 -0
- data/lib/redsnow/object.rb +18 -0
- data/lib/redsnow/parseresult.rb +107 -0
- data/lib/redsnow/version.rb +4 -0
- data/provisioning.sh +20 -0
- data/redsnow.gemspec +35 -0
- data/test/_helper.rb +15 -0
- data/test/fixtures/sample-api-ast.json +97 -0
- data/test/fixtures/sample-api.apib +20 -0
- data/test/redsnow_binding_test.rb +35 -0
- data/test/redsnow_parseresult_test.rb +50 -0
- data/test/redsnow_test.rb +285 -0
- metadata +358 -0
@@ -0,0 +1,58 @@
|
|
1
|
+
# Copyright (c) 2012 Google Inc. All rights reserved.
|
2
|
+
# Use of this source code is governed by a BSD-style license that can be
|
3
|
+
# found in the LICENSE file.
|
4
|
+
|
5
|
+
"""Visual Studio project reader/writer."""
|
6
|
+
|
7
|
+
import gyp.common
|
8
|
+
import gyp.easy_xml as easy_xml
|
9
|
+
|
10
|
+
|
11
|
+
class Writer(object):
|
12
|
+
"""Visual Studio XML tool file writer."""
|
13
|
+
|
14
|
+
def __init__(self, tool_file_path, name):
|
15
|
+
"""Initializes the tool file.
|
16
|
+
|
17
|
+
Args:
|
18
|
+
tool_file_path: Path to the tool file.
|
19
|
+
name: Name of the tool file.
|
20
|
+
"""
|
21
|
+
self.tool_file_path = tool_file_path
|
22
|
+
self.name = name
|
23
|
+
self.rules_section = ['Rules']
|
24
|
+
|
25
|
+
def AddCustomBuildRule(self, name, cmd, description,
|
26
|
+
additional_dependencies,
|
27
|
+
outputs, extensions):
|
28
|
+
"""Adds a rule to the tool file.
|
29
|
+
|
30
|
+
Args:
|
31
|
+
name: Name of the rule.
|
32
|
+
description: Description of the rule.
|
33
|
+
cmd: Command line of the rule.
|
34
|
+
additional_dependencies: other files which may trigger the rule.
|
35
|
+
outputs: outputs of the rule.
|
36
|
+
extensions: extensions handled by the rule.
|
37
|
+
"""
|
38
|
+
rule = ['CustomBuildRule',
|
39
|
+
{'Name': name,
|
40
|
+
'ExecutionDescription': description,
|
41
|
+
'CommandLine': cmd,
|
42
|
+
'Outputs': ';'.join(outputs),
|
43
|
+
'FileExtensions': ';'.join(extensions),
|
44
|
+
'AdditionalDependencies':
|
45
|
+
';'.join(additional_dependencies)
|
46
|
+
}]
|
47
|
+
self.rules_section.append(rule)
|
48
|
+
|
49
|
+
def WriteIfChanged(self):
|
50
|
+
"""Writes the tool file."""
|
51
|
+
content = ['VisualStudioToolFile',
|
52
|
+
{'Version': '8.00',
|
53
|
+
'Name': self.name
|
54
|
+
},
|
55
|
+
self.rules_section
|
56
|
+
]
|
57
|
+
easy_xml.WriteXmlIfChanged(content, self.tool_file_path,
|
58
|
+
encoding="Windows-1252")
|
@@ -0,0 +1,147 @@
|
|
1
|
+
# Copyright (c) 2012 Google Inc. All rights reserved.
|
2
|
+
# Use of this source code is governed by a BSD-style license that can be
|
3
|
+
# found in the LICENSE file.
|
4
|
+
|
5
|
+
"""Visual Studio user preferences file writer."""
|
6
|
+
|
7
|
+
import os
|
8
|
+
import re
|
9
|
+
import socket # for gethostname
|
10
|
+
|
11
|
+
import gyp.common
|
12
|
+
import gyp.easy_xml as easy_xml
|
13
|
+
|
14
|
+
|
15
|
+
#------------------------------------------------------------------------------
|
16
|
+
|
17
|
+
def _FindCommandInPath(command):
|
18
|
+
"""If there are no slashes in the command given, this function
|
19
|
+
searches the PATH env to find the given command, and converts it
|
20
|
+
to an absolute path. We have to do this because MSVS is looking
|
21
|
+
for an actual file to launch a debugger on, not just a command
|
22
|
+
line. Note that this happens at GYP time, so anything needing to
|
23
|
+
be built needs to have a full path."""
|
24
|
+
if '/' in command or '\\' in command:
|
25
|
+
# If the command already has path elements (either relative or
|
26
|
+
# absolute), then assume it is constructed properly.
|
27
|
+
return command
|
28
|
+
else:
|
29
|
+
# Search through the path list and find an existing file that
|
30
|
+
# we can access.
|
31
|
+
paths = os.environ.get('PATH','').split(os.pathsep)
|
32
|
+
for path in paths:
|
33
|
+
item = os.path.join(path, command)
|
34
|
+
if os.path.isfile(item) and os.access(item, os.X_OK):
|
35
|
+
return item
|
36
|
+
return command
|
37
|
+
|
38
|
+
def _QuoteWin32CommandLineArgs(args):
|
39
|
+
new_args = []
|
40
|
+
for arg in args:
|
41
|
+
# Replace all double-quotes with double-double-quotes to escape
|
42
|
+
# them for cmd shell, and then quote the whole thing if there
|
43
|
+
# are any.
|
44
|
+
if arg.find('"') != -1:
|
45
|
+
arg = '""'.join(arg.split('"'))
|
46
|
+
arg = '"%s"' % arg
|
47
|
+
|
48
|
+
# Otherwise, if there are any spaces, quote the whole arg.
|
49
|
+
elif re.search(r'[ \t\n]', arg):
|
50
|
+
arg = '"%s"' % arg
|
51
|
+
new_args.append(arg)
|
52
|
+
return new_args
|
53
|
+
|
54
|
+
class Writer(object):
|
55
|
+
"""Visual Studio XML user user file writer."""
|
56
|
+
|
57
|
+
def __init__(self, user_file_path, version, name):
|
58
|
+
"""Initializes the user file.
|
59
|
+
|
60
|
+
Args:
|
61
|
+
user_file_path: Path to the user file.
|
62
|
+
version: Version info.
|
63
|
+
name: Name of the user file.
|
64
|
+
"""
|
65
|
+
self.user_file_path = user_file_path
|
66
|
+
self.version = version
|
67
|
+
self.name = name
|
68
|
+
self.configurations = {}
|
69
|
+
|
70
|
+
def AddConfig(self, name):
|
71
|
+
"""Adds a configuration to the project.
|
72
|
+
|
73
|
+
Args:
|
74
|
+
name: Configuration name.
|
75
|
+
"""
|
76
|
+
self.configurations[name] = ['Configuration', {'Name': name}]
|
77
|
+
|
78
|
+
def AddDebugSettings(self, config_name, command, environment = {},
|
79
|
+
working_directory=""):
|
80
|
+
"""Adds a DebugSettings node to the user file for a particular config.
|
81
|
+
|
82
|
+
Args:
|
83
|
+
command: command line to run. First element in the list is the
|
84
|
+
executable. All elements of the command will be quoted if
|
85
|
+
necessary.
|
86
|
+
working_directory: other files which may trigger the rule. (optional)
|
87
|
+
"""
|
88
|
+
command = _QuoteWin32CommandLineArgs(command)
|
89
|
+
|
90
|
+
abs_command = _FindCommandInPath(command[0])
|
91
|
+
|
92
|
+
if environment and isinstance(environment, dict):
|
93
|
+
env_list = ['%s="%s"' % (key, val)
|
94
|
+
for (key,val) in environment.iteritems()]
|
95
|
+
environment = ' '.join(env_list)
|
96
|
+
else:
|
97
|
+
environment = ''
|
98
|
+
|
99
|
+
n_cmd = ['DebugSettings',
|
100
|
+
{'Command': abs_command,
|
101
|
+
'WorkingDirectory': working_directory,
|
102
|
+
'CommandArguments': " ".join(command[1:]),
|
103
|
+
'RemoteMachine': socket.gethostname(),
|
104
|
+
'Environment': environment,
|
105
|
+
'EnvironmentMerge': 'true',
|
106
|
+
# Currently these are all "dummy" values that we're just setting
|
107
|
+
# in the default manner that MSVS does it. We could use some of
|
108
|
+
# these to add additional capabilities, I suppose, but they might
|
109
|
+
# not have parity with other platforms then.
|
110
|
+
'Attach': 'false',
|
111
|
+
'DebuggerType': '3', # 'auto' debugger
|
112
|
+
'Remote': '1',
|
113
|
+
'RemoteCommand': '',
|
114
|
+
'HttpUrl': '',
|
115
|
+
'PDBPath': '',
|
116
|
+
'SQLDebugging': '',
|
117
|
+
'DebuggerFlavor': '0',
|
118
|
+
'MPIRunCommand': '',
|
119
|
+
'MPIRunArguments': '',
|
120
|
+
'MPIRunWorkingDirectory': '',
|
121
|
+
'ApplicationCommand': '',
|
122
|
+
'ApplicationArguments': '',
|
123
|
+
'ShimCommand': '',
|
124
|
+
'MPIAcceptMode': '',
|
125
|
+
'MPIAcceptFilter': ''
|
126
|
+
}]
|
127
|
+
|
128
|
+
# Find the config, and add it if it doesn't exist.
|
129
|
+
if config_name not in self.configurations:
|
130
|
+
self.AddConfig(config_name)
|
131
|
+
|
132
|
+
# Add the DebugSettings onto the appropriate config.
|
133
|
+
self.configurations[config_name].append(n_cmd)
|
134
|
+
|
135
|
+
def WriteIfChanged(self):
|
136
|
+
"""Writes the user file."""
|
137
|
+
configs = ['Configurations']
|
138
|
+
for config, spec in sorted(self.configurations.iteritems()):
|
139
|
+
configs.append(spec)
|
140
|
+
|
141
|
+
content = ['VisualStudioUserFile',
|
142
|
+
{'Version': self.version.ProjectVersion(),
|
143
|
+
'Name': self.name
|
144
|
+
},
|
145
|
+
configs]
|
146
|
+
easy_xml.WriteXmlIfChanged(content, self.user_file_path,
|
147
|
+
encoding="Windows-1252")
|
@@ -0,0 +1,267 @@
|
|
1
|
+
# Copyright (c) 2013 Google Inc. All rights reserved.
|
2
|
+
# Use of this source code is governed by a BSD-style license that can be
|
3
|
+
# found in the LICENSE file.
|
4
|
+
|
5
|
+
"""Utility functions shared amongst the Windows generators."""
|
6
|
+
|
7
|
+
import copy
|
8
|
+
import os
|
9
|
+
|
10
|
+
|
11
|
+
_TARGET_TYPE_EXT = {
|
12
|
+
'executable': '.exe',
|
13
|
+
'loadable_module': '.dll',
|
14
|
+
'shared_library': '.dll',
|
15
|
+
}
|
16
|
+
|
17
|
+
|
18
|
+
def _GetLargePdbShimCcPath():
|
19
|
+
"""Returns the path of the large_pdb_shim.cc file."""
|
20
|
+
this_dir = os.path.abspath(os.path.dirname(__file__))
|
21
|
+
src_dir = os.path.abspath(os.path.join(this_dir, '..', '..'))
|
22
|
+
win_data_dir = os.path.join(src_dir, 'data', 'win')
|
23
|
+
large_pdb_shim_cc = os.path.join(win_data_dir, 'large-pdb-shim.cc')
|
24
|
+
return large_pdb_shim_cc
|
25
|
+
|
26
|
+
|
27
|
+
def _DeepCopySomeKeys(in_dict, keys):
|
28
|
+
"""Performs a partial deep-copy on |in_dict|, only copying the keys in |keys|.
|
29
|
+
|
30
|
+
Arguments:
|
31
|
+
in_dict: The dictionary to copy.
|
32
|
+
keys: The keys to be copied. If a key is in this list and doesn't exist in
|
33
|
+
|in_dict| this is not an error.
|
34
|
+
Returns:
|
35
|
+
The partially deep-copied dictionary.
|
36
|
+
"""
|
37
|
+
d = {}
|
38
|
+
for key in keys:
|
39
|
+
if key not in in_dict:
|
40
|
+
continue
|
41
|
+
d[key] = copy.deepcopy(in_dict[key])
|
42
|
+
return d
|
43
|
+
|
44
|
+
|
45
|
+
def _SuffixName(name, suffix):
|
46
|
+
"""Add a suffix to the end of a target.
|
47
|
+
|
48
|
+
Arguments:
|
49
|
+
name: name of the target (foo#target)
|
50
|
+
suffix: the suffix to be added
|
51
|
+
Returns:
|
52
|
+
Target name with suffix added (foo_suffix#target)
|
53
|
+
"""
|
54
|
+
parts = name.rsplit('#', 1)
|
55
|
+
parts[0] = '%s_%s' % (parts[0], suffix)
|
56
|
+
return '#'.join(parts)
|
57
|
+
|
58
|
+
|
59
|
+
def _ShardName(name, number):
|
60
|
+
"""Add a shard number to the end of a target.
|
61
|
+
|
62
|
+
Arguments:
|
63
|
+
name: name of the target (foo#target)
|
64
|
+
number: shard number
|
65
|
+
Returns:
|
66
|
+
Target name with shard added (foo_1#target)
|
67
|
+
"""
|
68
|
+
return _SuffixName(name, str(number))
|
69
|
+
|
70
|
+
|
71
|
+
def ShardTargets(target_list, target_dicts):
|
72
|
+
"""Shard some targets apart to work around the linkers limits.
|
73
|
+
|
74
|
+
Arguments:
|
75
|
+
target_list: List of target pairs: 'base/base.gyp:base'.
|
76
|
+
target_dicts: Dict of target properties keyed on target pair.
|
77
|
+
Returns:
|
78
|
+
Tuple of the new sharded versions of the inputs.
|
79
|
+
"""
|
80
|
+
# Gather the targets to shard, and how many pieces.
|
81
|
+
targets_to_shard = {}
|
82
|
+
for t in target_dicts:
|
83
|
+
shards = int(target_dicts[t].get('msvs_shard', 0))
|
84
|
+
if shards:
|
85
|
+
targets_to_shard[t] = shards
|
86
|
+
# Shard target_list.
|
87
|
+
new_target_list = []
|
88
|
+
for t in target_list:
|
89
|
+
if t in targets_to_shard:
|
90
|
+
for i in range(targets_to_shard[t]):
|
91
|
+
new_target_list.append(_ShardName(t, i))
|
92
|
+
else:
|
93
|
+
new_target_list.append(t)
|
94
|
+
# Shard target_dict.
|
95
|
+
new_target_dicts = {}
|
96
|
+
for t in target_dicts:
|
97
|
+
if t in targets_to_shard:
|
98
|
+
for i in range(targets_to_shard[t]):
|
99
|
+
name = _ShardName(t, i)
|
100
|
+
new_target_dicts[name] = copy.copy(target_dicts[t])
|
101
|
+
new_target_dicts[name]['target_name'] = _ShardName(
|
102
|
+
new_target_dicts[name]['target_name'], i)
|
103
|
+
sources = new_target_dicts[name].get('sources', [])
|
104
|
+
new_sources = []
|
105
|
+
for pos in range(i, len(sources), targets_to_shard[t]):
|
106
|
+
new_sources.append(sources[pos])
|
107
|
+
new_target_dicts[name]['sources'] = new_sources
|
108
|
+
else:
|
109
|
+
new_target_dicts[t] = target_dicts[t]
|
110
|
+
# Shard dependencies.
|
111
|
+
for t in new_target_dicts:
|
112
|
+
dependencies = copy.copy(new_target_dicts[t].get('dependencies', []))
|
113
|
+
new_dependencies = []
|
114
|
+
for d in dependencies:
|
115
|
+
if d in targets_to_shard:
|
116
|
+
for i in range(targets_to_shard[d]):
|
117
|
+
new_dependencies.append(_ShardName(d, i))
|
118
|
+
else:
|
119
|
+
new_dependencies.append(d)
|
120
|
+
new_target_dicts[t]['dependencies'] = new_dependencies
|
121
|
+
|
122
|
+
return (new_target_list, new_target_dicts)
|
123
|
+
|
124
|
+
|
125
|
+
def _GetPdbPath(target_dict, config_name, vars):
|
126
|
+
"""Returns the path to the PDB file that will be generated by a given
|
127
|
+
configuration.
|
128
|
+
|
129
|
+
The lookup proceeds as follows:
|
130
|
+
- Look for an explicit path in the VCLinkerTool configuration block.
|
131
|
+
- Look for an 'msvs_large_pdb_path' variable.
|
132
|
+
- Use '<(PRODUCT_DIR)/<(product_name).(exe|dll).pdb' if 'product_name' is
|
133
|
+
specified.
|
134
|
+
- Use '<(PRODUCT_DIR)/<(target_name).(exe|dll).pdb'.
|
135
|
+
|
136
|
+
Arguments:
|
137
|
+
target_dict: The target dictionary to be searched.
|
138
|
+
config_name: The name of the configuration of interest.
|
139
|
+
vars: A dictionary of common GYP variables with generator-specific values.
|
140
|
+
Returns:
|
141
|
+
The path of the corresponding PDB file.
|
142
|
+
"""
|
143
|
+
config = target_dict['configurations'][config_name]
|
144
|
+
msvs = config.setdefault('msvs_settings', {})
|
145
|
+
|
146
|
+
linker = msvs.get('VCLinkerTool', {})
|
147
|
+
|
148
|
+
pdb_path = linker.get('ProgramDatabaseFile')
|
149
|
+
if pdb_path:
|
150
|
+
return pdb_path
|
151
|
+
|
152
|
+
variables = target_dict.get('variables', {})
|
153
|
+
pdb_path = variables.get('msvs_large_pdb_path', None)
|
154
|
+
if pdb_path:
|
155
|
+
return pdb_path
|
156
|
+
|
157
|
+
|
158
|
+
pdb_base = target_dict.get('product_name', target_dict['target_name'])
|
159
|
+
pdb_base = '%s%s.pdb' % (pdb_base, _TARGET_TYPE_EXT[target_dict['type']])
|
160
|
+
pdb_path = vars['PRODUCT_DIR'] + '/' + pdb_base
|
161
|
+
|
162
|
+
return pdb_path
|
163
|
+
|
164
|
+
|
165
|
+
def InsertLargePdbShims(target_list, target_dicts, vars):
|
166
|
+
"""Insert a shim target that forces the linker to use 4KB pagesize PDBs.
|
167
|
+
|
168
|
+
This is a workaround for targets with PDBs greater than 1GB in size, the
|
169
|
+
limit for the 1KB pagesize PDBs created by the linker by default.
|
170
|
+
|
171
|
+
Arguments:
|
172
|
+
target_list: List of target pairs: 'base/base.gyp:base'.
|
173
|
+
target_dicts: Dict of target properties keyed on target pair.
|
174
|
+
vars: A dictionary of common GYP variables with generator-specific values.
|
175
|
+
Returns:
|
176
|
+
Tuple of the shimmed version of the inputs.
|
177
|
+
"""
|
178
|
+
# Determine which targets need shimming.
|
179
|
+
targets_to_shim = []
|
180
|
+
for t in target_dicts:
|
181
|
+
target_dict = target_dicts[t]
|
182
|
+
|
183
|
+
# We only want to shim targets that have msvs_large_pdb enabled.
|
184
|
+
if not int(target_dict.get('msvs_large_pdb', 0)):
|
185
|
+
continue
|
186
|
+
# This is intended for executable, shared_library and loadable_module
|
187
|
+
# targets where every configuration is set up to produce a PDB output.
|
188
|
+
# If any of these conditions is not true then the shim logic will fail
|
189
|
+
# below.
|
190
|
+
targets_to_shim.append(t)
|
191
|
+
|
192
|
+
large_pdb_shim_cc = _GetLargePdbShimCcPath()
|
193
|
+
|
194
|
+
for t in targets_to_shim:
|
195
|
+
target_dict = target_dicts[t]
|
196
|
+
target_name = target_dict.get('target_name')
|
197
|
+
|
198
|
+
base_dict = _DeepCopySomeKeys(target_dict,
|
199
|
+
['configurations', 'default_configuration', 'toolset'])
|
200
|
+
|
201
|
+
# This is the dict for copying the source file (part of the GYP tree)
|
202
|
+
# to the intermediate directory of the project. This is necessary because
|
203
|
+
# we can't always build a relative path to the shim source file (on Windows
|
204
|
+
# GYP and the project may be on different drives), and Ninja hates absolute
|
205
|
+
# paths (it ends up generating the .obj and .obj.d alongside the source
|
206
|
+
# file, polluting GYPs tree).
|
207
|
+
copy_suffix = 'large_pdb_copy'
|
208
|
+
copy_target_name = target_name + '_' + copy_suffix
|
209
|
+
full_copy_target_name = _SuffixName(t, copy_suffix)
|
210
|
+
shim_cc_basename = os.path.basename(large_pdb_shim_cc)
|
211
|
+
shim_cc_dir = vars['SHARED_INTERMEDIATE_DIR'] + '/' + copy_target_name
|
212
|
+
shim_cc_path = shim_cc_dir + '/' + shim_cc_basename
|
213
|
+
copy_dict = copy.deepcopy(base_dict)
|
214
|
+
copy_dict['target_name'] = copy_target_name
|
215
|
+
copy_dict['type'] = 'none'
|
216
|
+
copy_dict['sources'] = [ large_pdb_shim_cc ]
|
217
|
+
copy_dict['copies'] = [{
|
218
|
+
'destination': shim_cc_dir,
|
219
|
+
'files': [ large_pdb_shim_cc ]
|
220
|
+
}]
|
221
|
+
|
222
|
+
# This is the dict for the PDB generating shim target. It depends on the
|
223
|
+
# copy target.
|
224
|
+
shim_suffix = 'large_pdb_shim'
|
225
|
+
shim_target_name = target_name + '_' + shim_suffix
|
226
|
+
full_shim_target_name = _SuffixName(t, shim_suffix)
|
227
|
+
shim_dict = copy.deepcopy(base_dict)
|
228
|
+
shim_dict['target_name'] = shim_target_name
|
229
|
+
shim_dict['type'] = 'static_library'
|
230
|
+
shim_dict['sources'] = [ shim_cc_path ]
|
231
|
+
shim_dict['dependencies'] = [ full_copy_target_name ]
|
232
|
+
|
233
|
+
# Set up the shim to output its PDB to the same location as the final linker
|
234
|
+
# target.
|
235
|
+
for config_name, config in shim_dict.get('configurations').iteritems():
|
236
|
+
pdb_path = _GetPdbPath(target_dict, config_name, vars)
|
237
|
+
|
238
|
+
# A few keys that we don't want to propagate.
|
239
|
+
for key in ['msvs_precompiled_header', 'msvs_precompiled_source', 'test']:
|
240
|
+
config.pop(key, None)
|
241
|
+
|
242
|
+
msvs = config.setdefault('msvs_settings', {})
|
243
|
+
|
244
|
+
# Update the compiler directives in the shim target.
|
245
|
+
compiler = msvs.setdefault('VCCLCompilerTool', {})
|
246
|
+
compiler['DebugInformationFormat'] = '3'
|
247
|
+
compiler['ProgramDataBaseFileName'] = pdb_path
|
248
|
+
|
249
|
+
# Set the explicit PDB path in the appropriate configuration of the
|
250
|
+
# original target.
|
251
|
+
config = target_dict['configurations'][config_name]
|
252
|
+
msvs = config.setdefault('msvs_settings', {})
|
253
|
+
linker = msvs.setdefault('VCLinkerTool', {})
|
254
|
+
linker['GenerateDebugInformation'] = 'true'
|
255
|
+
linker['ProgramDatabaseFile'] = pdb_path
|
256
|
+
|
257
|
+
# Add the new targets. They must go to the beginning of the list so that
|
258
|
+
# the dependency generation works as expected in ninja.
|
259
|
+
target_list.insert(0, full_copy_target_name)
|
260
|
+
target_list.insert(0, full_shim_target_name)
|
261
|
+
target_dicts[full_copy_target_name] = copy_dict
|
262
|
+
target_dicts[full_shim_target_name] = shim_dict
|
263
|
+
|
264
|
+
# Update the original target to depend on the shim target.
|
265
|
+
target_dict.setdefault('dependencies', []).append(full_shim_target_name)
|
266
|
+
|
267
|
+
return (target_list, target_dicts)
|