1[
2  {
3    "cmd": [
4      "python",
5      "-u",
6      "\nimport sys, os\npath = sys.argv[1]\nmode = int(sys.argv[2])\nif not os.path.isdir(path):\n  if os.path.exists(path):\n    print \"%s exists but is not a dir\" % path\n    sys.exit(1)\n  os.makedirs(path, mode)\n",
7      "[CUSTOM_C:\\_B_WORK]",
8      "511"
9    ],
10    "infra_step": true,
11    "name": "makedirs checkout_path",
12    "~followup_annotations": [
13      "@@@STEP_LOG_LINE@python.inline@@@@",
14      "@@@STEP_LOG_LINE@python.inline@import sys, os@@@",
15      "@@@STEP_LOG_LINE@python.inline@path = sys.argv[1]@@@",
16      "@@@STEP_LOG_LINE@python.inline@mode = int(sys.argv[2])@@@",
17      "@@@STEP_LOG_LINE@python.inline@if not os.path.isdir(path):@@@",
18      "@@@STEP_LOG_LINE@python.inline@  if os.path.exists(path):@@@",
19      "@@@STEP_LOG_LINE@python.inline@    print \"%s exists but is not a dir\" % path@@@",
20      "@@@STEP_LOG_LINE@python.inline@    sys.exit(1)@@@",
21      "@@@STEP_LOG_LINE@python.inline@  os.makedirs(path, mode)@@@",
22      "@@@STEP_LOG_END@python.inline@@@"
23    ]
24  },
25  {
26    "cmd": [
27      "python",
28      "-u",
29      "RECIPE_MODULE[depot_tools::bot_update]\\resources\\bot_update.py",
30      "--spec",
31      "cache_dir = '[CUSTOM_C:\\\\_B_CACHE]'\nsolutions = [{'deps_file': '.DEPS.git', 'managed': False, 'name': 'skia', 'url': 'https://skia.googlesource.com/skia.git'}]",
32      "--patch_root",
33      "skia",
34      "--revision_mapping_file",
35      "{\"skia\": \"got_revision\"}",
36      "--git-cache-dir",
37      "[CUSTOM_C:\\_B_CACHE]",
38      "--issue",
39      "2147533002",
40      "--patchset",
41      "1",
42      "--rietveld_server",
43      "https://codereview.chromium.org",
44      "--output_json",
45      "/path/to/tmp/json",
46      "--revision",
47      "skia@abc123",
48      "--output_manifest"
49    ],
50    "cwd": "[CUSTOM_C:\\_B_WORK]",
51    "env": {
52      "GIT_HTTP_LOW_SPEED_LIMIT": "1000",
53      "GIT_HTTP_LOW_SPEED_TIME": "300",
54      "PATH": "%(PATH)s;RECIPE_PACKAGE_REPO[depot_tools]"
55    },
56    "infra_step": true,
57    "name": "bot_update",
58    "~followup_annotations": [
59      "@@@STEP_TEXT@Some step text@@@",
60      "@@@STEP_LOG_LINE@json.output@{@@@",
61      "@@@STEP_LOG_LINE@json.output@  \"did_run\": true, @@@",
62      "@@@STEP_LOG_LINE@json.output@  \"fixed_revisions\": {@@@",
63      "@@@STEP_LOG_LINE@json.output@    \"skia\": \"abc123\"@@@",
64      "@@@STEP_LOG_LINE@json.output@  }, @@@",
65      "@@@STEP_LOG_LINE@json.output@  \"manifest\": {@@@",
66      "@@@STEP_LOG_LINE@json.output@    \"skia\": {@@@",
67      "@@@STEP_LOG_LINE@json.output@      \"repository\": \"https://fake.org/skia.git\", @@@",
68      "@@@STEP_LOG_LINE@json.output@      \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@",
69      "@@@STEP_LOG_LINE@json.output@    }@@@",
70      "@@@STEP_LOG_LINE@json.output@  }, @@@",
71      "@@@STEP_LOG_LINE@json.output@  \"patch_failure\": false, @@@",
72      "@@@STEP_LOG_LINE@json.output@  \"patch_root\": \"skia\", @@@",
73      "@@@STEP_LOG_LINE@json.output@  \"properties\": {@@@",
74      "@@@STEP_LOG_LINE@json.output@    \"got_revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\", @@@",
75      "@@@STEP_LOG_LINE@json.output@    \"got_revision_cp\": \"refs/heads/master@{#164710}\"@@@",
76      "@@@STEP_LOG_LINE@json.output@  }, @@@",
77      "@@@STEP_LOG_LINE@json.output@  \"root\": \"skia\", @@@",
78      "@@@STEP_LOG_LINE@json.output@  \"step_text\": \"Some step text\"@@@",
79      "@@@STEP_LOG_LINE@json.output@}@@@",
80      "@@@STEP_LOG_END@json.output@@@",
81      "@@@SET_BUILD_PROPERTY@got_revision@\"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@",
82      "@@@SET_BUILD_PROPERTY@got_revision_cp@\"refs/heads/master@{#164710}\"@@@"
83    ]
84  },
85  {
86    "cmd": [
87      "python",
88      "-u",
89      "[CUSTOM_C:\\_B_WORK]\\skia\\bin\\fetch-gn"
90    ],
91    "cwd": "[CUSTOM_C:\\_B_WORK]\\skia",
92    "env": {
93      "BUILDTYPE": "Debug",
94      "CHROME_HEADLESS": "1",
95      "PATH": "%(PATH)s;RECIPE_PACKAGE_REPO[depot_tools]",
96      "SKIA_OUT": "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-MSVC-x86-Debug"
97    },
98    "infra_step": true,
99    "name": "fetch-gn"
100  },
101  {
102    "cmd": [
103      "[CUSTOM_C:\\_B_WORK]\\skia\\bin\\gn.exe",
104      "gen",
105      "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-MSVC-x86-Debug\\Debug",
106      "--args=target_cpu=\"x86\" windk=\"[START_DIR]\\t\\depot_tools\\win_toolchain\\vs_files\\d3cb0e37bdd120ad0ac4650b674b09e81be45616\""
107    ],
108    "cwd": "[CUSTOM_C:\\_B_WORK]\\skia",
109    "env": {
110      "BUILDTYPE": "Debug",
111      "CHROME_HEADLESS": "1",
112      "PATH": "%(PATH)s;RECIPE_PACKAGE_REPO[depot_tools]",
113      "SKIA_OUT": "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-MSVC-x86-Debug"
114    },
115    "name": "gn gen"
116  },
117  {
118    "cmd": [
119      "ninja.exe",
120      "-C",
121      "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-MSVC-x86-Debug\\Debug"
122    ],
123    "cwd": "[CUSTOM_C:\\_B_WORK]\\skia",
124    "env": {
125      "BUILDTYPE": "Debug",
126      "CHROME_HEADLESS": "1",
127      "PATH": "%(PATH)s;RECIPE_PACKAGE_REPO[depot_tools]",
128      "SKIA_OUT": "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-MSVC-x86-Debug"
129    },
130    "name": "ninja"
131  },
132  {
133    "cmd": [
134      "python",
135      "-u",
136      "import errno\nimport glob\nimport os\nimport shutil\nimport sys\n\nsrc = sys.argv[1]\ndst = sys.argv[2]\nbuild_products_whitelist = ['dm', 'dm.exe', 'get_images_from_skps', 'get_images_from_skps.exe', 'nanobench', 'nanobench.exe', 'skpbench', '*.so', '*.dll', '*.dylib', 'skia_launcher', 'lib/*.so', 'iOSShell.app', 'iOSShell.ipa', 'visualbench', 'visualbench.exe', 'vulkan-1.dll']\n\ntry:\n  os.makedirs(dst)\nexcept OSError as e:\n  if e.errno != errno.EEXIST:\n    raise\n\nfor pattern in build_products_whitelist:\n  path = os.path.join(src, pattern)\n  for f in glob.glob(path):\n    dst_path = os.path.join(dst, os.path.relpath(f, src))\n    if not os.path.isdir(os.path.dirname(dst_path)):\n      os.makedirs(os.path.dirname(dst_path))\n    print 'Copying build product %s to %s' % (f, dst_path)\n    shutil.move(f, dst_path)\n",
137      "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-MSVC-x86-Debug\\Debug",
138      "[CUSTOM_[SWARM_OUT_DIR]]\\out\\Debug"
139    ],
140    "infra_step": true,
141    "name": "copy build products",
142    "~followup_annotations": [
143      "@@@STEP_LOG_LINE@python.inline@import errno@@@",
144      "@@@STEP_LOG_LINE@python.inline@import glob@@@",
145      "@@@STEP_LOG_LINE@python.inline@import os@@@",
146      "@@@STEP_LOG_LINE@python.inline@import shutil@@@",
147      "@@@STEP_LOG_LINE@python.inline@import sys@@@",
148      "@@@STEP_LOG_LINE@python.inline@@@@",
149      "@@@STEP_LOG_LINE@python.inline@src = sys.argv[1]@@@",
150      "@@@STEP_LOG_LINE@python.inline@dst = sys.argv[2]@@@",
151      "@@@STEP_LOG_LINE@python.inline@build_products_whitelist = ['dm', 'dm.exe', 'get_images_from_skps', 'get_images_from_skps.exe', 'nanobench', 'nanobench.exe', 'skpbench', '*.so', '*.dll', '*.dylib', 'skia_launcher', 'lib/*.so', 'iOSShell.app', 'iOSShell.ipa', 'visualbench', 'visualbench.exe', 'vulkan-1.dll']@@@",
152      "@@@STEP_LOG_LINE@python.inline@@@@",
153      "@@@STEP_LOG_LINE@python.inline@try:@@@",
154      "@@@STEP_LOG_LINE@python.inline@  os.makedirs(dst)@@@",
155      "@@@STEP_LOG_LINE@python.inline@except OSError as e:@@@",
156      "@@@STEP_LOG_LINE@python.inline@  if e.errno != errno.EEXIST:@@@",
157      "@@@STEP_LOG_LINE@python.inline@    raise@@@",
158      "@@@STEP_LOG_LINE@python.inline@@@@",
159      "@@@STEP_LOG_LINE@python.inline@for pattern in build_products_whitelist:@@@",
160      "@@@STEP_LOG_LINE@python.inline@  path = os.path.join(src, pattern)@@@",
161      "@@@STEP_LOG_LINE@python.inline@  for f in glob.glob(path):@@@",
162      "@@@STEP_LOG_LINE@python.inline@    dst_path = os.path.join(dst, os.path.relpath(f, src))@@@",
163      "@@@STEP_LOG_LINE@python.inline@    if not os.path.isdir(os.path.dirname(dst_path)):@@@",
164      "@@@STEP_LOG_LINE@python.inline@      os.makedirs(os.path.dirname(dst_path))@@@",
165      "@@@STEP_LOG_LINE@python.inline@    print 'Copying build product %s to %s' % (f, dst_path)@@@",
166      "@@@STEP_LOG_LINE@python.inline@    shutil.move(f, dst_path)@@@",
167      "@@@STEP_LOG_END@python.inline@@@"
168    ]
169  },
170  {
171    "cmd": [
172      "python",
173      "-u",
174      "import psutil\nfor p in psutil.process_iter():\n  try:\n    if p.name in ('mspdbsrv.exe', 'vctip.exe', 'cl.exe', 'link.exe'):\n      p.kill()\n  except psutil._error.AccessDenied:\n    pass\n"
175    ],
176    "infra_step": true,
177    "name": "cleanup",
178    "~followup_annotations": [
179      "@@@STEP_LOG_LINE@python.inline@import psutil@@@",
180      "@@@STEP_LOG_LINE@python.inline@for p in psutil.process_iter():@@@",
181      "@@@STEP_LOG_LINE@python.inline@  try:@@@",
182      "@@@STEP_LOG_LINE@python.inline@    if p.name in ('mspdbsrv.exe', 'vctip.exe', 'cl.exe', 'link.exe'):@@@",
183      "@@@STEP_LOG_LINE@python.inline@      p.kill()@@@",
184      "@@@STEP_LOG_LINE@python.inline@  except psutil._error.AccessDenied:@@@",
185      "@@@STEP_LOG_LINE@python.inline@    pass@@@",
186      "@@@STEP_LOG_END@python.inline@@@"
187    ]
188  },
189  {
190    "name": "$result",
191    "recipe_result": null,
192    "status_code": 0
193  }
194]