8 "/sdcard/revenge_of_the_skiabot/resources"
10 "cwd": "[START_DIR]/skia",
12 "name": "mkdir /sdcard/revenge_of_the_skiabot/resources"
18 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n",
19 "[START_DIR]/skia/resources",
20 "/sdcard/revenge_of_the_skiabot/resources"
23 "name": "push [START_DIR]/skia/resources/* /sdcard/revenge_of_the_skiabot/resources",
24 "~followup_annotations": [
25 "@@@STEP_LOG_LINE@python.inline@@@@",
26 "@@@STEP_LOG_LINE@python.inline@import os@@@",
27 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@",
28 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
29 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@",
30 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@",
31 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@",
32 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@",
33 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@",
34 "@@@STEP_LOG_LINE@python.inline@ continue@@@",
35 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@",
36 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@",
37 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@",
38 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@",
39 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@",
40 "@@@STEP_LOG_END@python.inline@@@"
47 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
48 "[START_DIR]/skia/infra/bots/assets/skp/VERSION",
52 "name": "Get downloaded SKP VERSION"
58 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
60 "[START_DIR]/tmp/SKP_VERSION"
63 "name": "write SKP_VERSION"
70 "/sdcard/revenge_of_the_skiabot/SKP_VERSION"
72 "cwd": "[START_DIR]/skia",
74 "name": "read /sdcard/revenge_of_the_skiabot/SKP_VERSION",
75 "stdout": "/path/to/tmp/"
83 "/sdcard/revenge_of_the_skiabot/SKP_VERSION"
85 "cwd": "[START_DIR]/skia",
87 "name": "rm /sdcard/revenge_of_the_skiabot/SKP_VERSION"
95 "/sdcard/revenge_of_the_skiabot/skps"
97 "cwd": "[START_DIR]/skia",
99 "name": "rm /sdcard/revenge_of_the_skiabot/skps"
107 "/sdcard/revenge_of_the_skiabot/skps"
109 "cwd": "[START_DIR]/skia",
111 "name": "mkdir /sdcard/revenge_of_the_skiabot/skps"
117 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n",
119 "/sdcard/revenge_of_the_skiabot/skps"
122 "name": "push [START_DIR]/skp/* /sdcard/revenge_of_the_skiabot/skps",
123 "~followup_annotations": [
124 "@@@STEP_LOG_LINE@python.inline@@@@",
125 "@@@STEP_LOG_LINE@python.inline@import os@@@",
126 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@",
127 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
128 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@",
129 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@",
130 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@",
131 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@",
132 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@",
133 "@@@STEP_LOG_LINE@python.inline@ continue@@@",
134 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@",
135 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@",
136 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@",
137 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@",
138 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@",
139 "@@@STEP_LOG_END@python.inline@@@"
146 "[START_DIR]/tmp/SKP_VERSION",
147 "/sdcard/revenge_of_the_skiabot/SKP_VERSION"
149 "cwd": "[START_DIR]/skia",
151 "name": "push [START_DIR]/tmp/SKP_VERSION /sdcard/revenge_of_the_skiabot/SKP_VERSION"
157 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
158 "[START_DIR]/skia/infra/bots/assets/skimage/VERSION",
162 "name": "Get downloaded skimage VERSION"
168 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
170 "[START_DIR]/tmp/SK_IMAGE_VERSION"
173 "name": "write SK_IMAGE_VERSION"
180 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION"
182 "cwd": "[START_DIR]/skia",
184 "name": "read /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION",
185 "stdout": "/path/to/tmp/"
193 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION"
195 "cwd": "[START_DIR]/skia",
197 "name": "rm /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION"
205 "/sdcard/revenge_of_the_skiabot/images"
207 "cwd": "[START_DIR]/skia",
209 "name": "rm /sdcard/revenge_of_the_skiabot/images"
217 "/sdcard/revenge_of_the_skiabot/images"
219 "cwd": "[START_DIR]/skia",
221 "name": "mkdir /sdcard/revenge_of_the_skiabot/images"
227 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n",
228 "[START_DIR]/skimage",
229 "/sdcard/revenge_of_the_skiabot/images"
232 "name": "push [START_DIR]/skimage/* /sdcard/revenge_of_the_skiabot/images",
233 "~followup_annotations": [
234 "@@@STEP_LOG_LINE@python.inline@@@@",
235 "@@@STEP_LOG_LINE@python.inline@import os@@@",
236 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@",
237 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
238 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@",
239 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@",
240 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@",
241 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@",
242 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@",
243 "@@@STEP_LOG_LINE@python.inline@ continue@@@",
244 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@",
245 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@",
246 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@",
247 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@",
248 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@",
249 "@@@STEP_LOG_END@python.inline@@@"
256 "[START_DIR]/tmp/SK_IMAGE_VERSION",
257 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION"
259 "cwd": "[START_DIR]/skia",
261 "name": "push [START_DIR]/tmp/SK_IMAGE_VERSION /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION"
267 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
268 "[START_DIR]/skia/infra/bots/assets/svg/VERSION",
272 "name": "Get downloaded SVG VERSION"
278 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
280 "[START_DIR]/tmp/SVG_VERSION"
283 "name": "write SVG_VERSION"
290 "/sdcard/revenge_of_the_skiabot/SVG_VERSION"
292 "cwd": "[START_DIR]/skia",
294 "name": "read /sdcard/revenge_of_the_skiabot/SVG_VERSION",
295 "stdout": "/path/to/tmp/"
303 "/sdcard/revenge_of_the_skiabot/SVG_VERSION"
305 "cwd": "[START_DIR]/skia",
307 "name": "rm /sdcard/revenge_of_the_skiabot/SVG_VERSION"
315 "/sdcard/revenge_of_the_skiabot/svgs"
317 "cwd": "[START_DIR]/skia",
319 "name": "rm /sdcard/revenge_of_the_skiabot/svgs"
327 "/sdcard/revenge_of_the_skiabot/svgs"
329 "cwd": "[START_DIR]/skia",
331 "name": "mkdir /sdcard/revenge_of_the_skiabot/svgs"
337 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n",
339 "/sdcard/revenge_of_the_skiabot/svgs"
342 "name": "push [START_DIR]/svg/* /sdcard/revenge_of_the_skiabot/svgs",
343 "~followup_annotations": [
344 "@@@STEP_LOG_LINE@python.inline@@@@",
345 "@@@STEP_LOG_LINE@python.inline@import os@@@",
346 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@",
347 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
348 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@",
349 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@",
350 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@",
351 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@",
352 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@",
353 "@@@STEP_LOG_LINE@python.inline@ continue@@@",
354 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@",
355 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@",
356 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@",
357 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@",
358 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@",
359 "@@@STEP_LOG_END@python.inline@@@"
366 "[START_DIR]/tmp/SVG_VERSION",
367 "/sdcard/revenge_of_the_skiabot/SVG_VERSION"
369 "cwd": "[START_DIR]/skia",
371 "name": "push [START_DIR]/tmp/SVG_VERSION /sdcard/revenge_of_the_skiabot/SVG_VERSION"
377 "RECIPE_MODULE[build::file]/resources/fileutil.py",
379 "[CUSTOM_[SWARM_OUT_DIR]]/dm"
382 "PYTHONPATH": "[START_DIR]/skia/infra/bots/.recipe_deps/build/scripts"
391 "\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",
392 "[CUSTOM_[SWARM_OUT_DIR]]/dm",
396 "name": "makedirs dm",
397 "~followup_annotations": [
398 "@@@STEP_LOG_LINE@python.inline@@@@",
399 "@@@STEP_LOG_LINE@python.inline@import sys, os@@@",
400 "@@@STEP_LOG_LINE@python.inline@path = sys.argv[1]@@@",
401 "@@@STEP_LOG_LINE@python.inline@mode = int(sys.argv[2])@@@",
402 "@@@STEP_LOG_LINE@python.inline@if not os.path.isdir(path):@@@",
403 "@@@STEP_LOG_LINE@python.inline@ if os.path.exists(path):@@@",
404 "@@@STEP_LOG_LINE@python.inline@ print \"%s exists but is not a dir\" % path@@@",
405 "@@@STEP_LOG_LINE@python.inline@ sys.exit(1)@@@",
406 "@@@STEP_LOG_LINE@python.inline@ os.makedirs(path, mode)@@@",
407 "@@@STEP_LOG_END@python.inline@@@"
416 "/sdcard/revenge_of_the_skiabot/dm_out"
418 "cwd": "[START_DIR]/skia",
420 "name": "rm /sdcard/revenge_of_the_skiabot/dm_out"
428 "/sdcard/revenge_of_the_skiabot/dm_out"
430 "cwd": "[START_DIR]/skia",
432 "name": "mkdir /sdcard/revenge_of_the_skiabot/dm_out"
438 "\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",
443 "name": "makedirs tmp_dir",
444 "~followup_annotations": [
445 "@@@STEP_LOG_LINE@python.inline@@@@",
446 "@@@STEP_LOG_LINE@python.inline@import sys, os@@@",
447 "@@@STEP_LOG_LINE@python.inline@path = sys.argv[1]@@@",
448 "@@@STEP_LOG_LINE@python.inline@mode = int(sys.argv[2])@@@",
449 "@@@STEP_LOG_LINE@python.inline@if not os.path.isdir(path):@@@",
450 "@@@STEP_LOG_LINE@python.inline@ if os.path.exists(path):@@@",
451 "@@@STEP_LOG_LINE@python.inline@ print \"%s exists but is not a dir\" % path@@@",
452 "@@@STEP_LOG_LINE@python.inline@ sys.exit(1)@@@",
453 "@@@STEP_LOG_LINE@python.inline@ os.makedirs(path, mode)@@@",
454 "@@@STEP_LOG_END@python.inline@@@"
461 "\nimport contextlib\nimport math\nimport socket\nimport sys\nimport time\nimport urllib2\n\nHASHES_URL = 'https://gold.skia.org/_/hashes'\nRETRIES = 5\nTIMEOUT = 60\nWAIT_BASE = 15\n\nsocket.setdefaulttimeout(TIMEOUT)\nfor retry in range(RETRIES):\n try:\n with contextlib.closing(\n urllib2.urlopen(HASHES_URL, timeout=TIMEOUT)) as w:\n hashes = w.read()\n with open(sys.argv[1], 'w') as f:\n f.write(hashes)\n break\n except Exception as e:\n print 'Failed to get uninteresting hashes from %s:' % HASHES_URL\n print e\n if retry == RETRIES:\n raise\n waittime = WAIT_BASE * math.pow(2, retry)\n print 'Retry in %d seconds.' % waittime\n time.sleep(waittime)\n",
462 "[START_DIR]/tmp/uninteresting_hashes.txt"
465 "name": "get uninteresting hashes",
466 "~followup_annotations": [
467 "@@@STEP_LOG_LINE@python.inline@@@@",
468 "@@@STEP_LOG_LINE@python.inline@import contextlib@@@",
469 "@@@STEP_LOG_LINE@python.inline@import math@@@",
470 "@@@STEP_LOG_LINE@python.inline@import socket@@@",
471 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
472 "@@@STEP_LOG_LINE@python.inline@import time@@@",
473 "@@@STEP_LOG_LINE@python.inline@import urllib2@@@",
474 "@@@STEP_LOG_LINE@python.inline@@@@",
475 "@@@STEP_LOG_LINE@python.inline@HASHES_URL = 'https://gold.skia.org/_/hashes'@@@",
476 "@@@STEP_LOG_LINE@python.inline@RETRIES = 5@@@",
477 "@@@STEP_LOG_LINE@python.inline@TIMEOUT = 60@@@",
478 "@@@STEP_LOG_LINE@python.inline@WAIT_BASE = 15@@@",
479 "@@@STEP_LOG_LINE@python.inline@@@@",
480 "@@@STEP_LOG_LINE@python.inline@socket.setdefaulttimeout(TIMEOUT)@@@",
481 "@@@STEP_LOG_LINE@python.inline@for retry in range(RETRIES):@@@",
482 "@@@STEP_LOG_LINE@python.inline@ try:@@@",
483 "@@@STEP_LOG_LINE@python.inline@ with contextlib.closing(@@@",
484 "@@@STEP_LOG_LINE@python.inline@ urllib2.urlopen(HASHES_URL, timeout=TIMEOUT)) as w:@@@",
485 "@@@STEP_LOG_LINE@python.inline@ hashes = w.read()@@@",
486 "@@@STEP_LOG_LINE@python.inline@ with open(sys.argv[1], 'w') as f:@@@",
487 "@@@STEP_LOG_LINE@python.inline@ f.write(hashes)@@@",
488 "@@@STEP_LOG_LINE@python.inline@ break@@@",
489 "@@@STEP_LOG_LINE@python.inline@ except Exception as e:@@@",
490 "@@@STEP_LOG_LINE@python.inline@ print 'Failed to get uninteresting hashes from %s:' % HASHES_URL@@@",
491 "@@@STEP_LOG_LINE@python.inline@ print e@@@",
492 "@@@STEP_LOG_LINE@python.inline@ if retry == RETRIES:@@@",
493 "@@@STEP_LOG_LINE@python.inline@ raise@@@",
494 "@@@STEP_LOG_LINE@python.inline@ waittime = WAIT_BASE * math.pow(2, retry)@@@",
495 "@@@STEP_LOG_LINE@python.inline@ print 'Retry in %d seconds.' % waittime@@@",
496 "@@@STEP_LOG_LINE@python.inline@ time.sleep(waittime)@@@",
497 "@@@STEP_LOG_END@python.inline@@@"
504 "[START_DIR]/tmp/uninteresting_hashes.txt",
505 "/sdcard/revenge_of_the_skiabot/uninteresting_hashes.txt"
507 "cwd": "[START_DIR]/skia",
509 "name": "push [START_DIR]/tmp/uninteresting_hashes.txt /sdcard/revenge_of_the_skiabot/uninteresting_hashes.txt"
515 "[START_DIR]/out/Debug/dm",
518 "cwd": "[START_DIR]/skia",
526 "\nimport shutil\nimport sys\nshutil.copy(sys.argv[1], sys.argv[2])\n",
527 "set -x; /data/local/tmp/dm --undefok --resourcePath /sdcard/revenge_of_the_skiabot/resources --skps /sdcard/revenge_of_the_skiabot/skps --images /sdcard/revenge_of_the_skiabot/images/dm --colorImages /sdcard/revenge_of_the_skiabot/images/colorspace --nameByHash --properties gitHash abc123 master client.skia builder Test-Android-Clang-GalaxyS6-GPU-MaliT760-arm64-Debug-Android build_number 5 --svgs /sdcard/revenge_of_the_skiabot/svgs --key arch arm64 compiler Clang configuration Debug cpu_or_gpu GPU cpu_or_gpu_value MaliT760 extra_config Android model GalaxyS6 os Android --uninterestingHashesFile /sdcard/revenge_of_the_skiabot/uninteresting_hashes.txt --writePath /sdcard/revenge_of_the_skiabot/dm_out --nocpu --config 8888 srgb gles glesdft glessrgb glesmsaa4 serialize-8888 tiles_rt-8888 pic-8888 --src tests gm image colorImage svg --blacklist glessrgb image _ _ 8888 image _ _ _ test _ GrShape serialize-8888 gm _ bleed_image serialize-8888 gm _ c_gms serialize-8888 gm _ colortype serialize-8888 gm _ colortype_xfermodes serialize-8888 gm _ drawfilter serialize-8888 gm _ fontmgr_bounds_0.75_0 serialize-8888 gm _ fontmgr_bounds_1_-0.25 serialize-8888 gm _ fontmgr_bounds serialize-8888 gm _ fontmgr_match serialize-8888 gm _ fontmgr_iter serialize-8888 gm _ imagemasksubset serialize-8888 gm _ bitmapfilters serialize-8888 gm _ bitmapshaders serialize-8888 gm _ bleed serialize-8888 gm _ bleed_alpha_bmp serialize-8888 gm _ bleed_alpha_bmp_shader serialize-8888 gm _ convex_poly_clip serialize-8888 gm _ extractalpha serialize-8888 gm _ filterbitmap_checkerboard_32_32_g8 serialize-8888 gm _ filterbitmap_image_mandrill_64 serialize-8888 gm _ shadows serialize-8888 gm _ simpleaaclip_aaclip serialize-8888 gm _ composeshader_bitmap serialize-8888 gm _ scaled_tilemodes_npot serialize-8888 gm _ scaled_tilemodes serialize-8888 gm _ typefacerendering_pfaMac serialize-8888 gm _ parsedpaths serialize-8888 gm _ ImageGeneratorExternal_rect serialize-8888 gm _ ImageGeneratorExternal_shader serialize-8888 gm _ shadow_utils serialize-8888 gm _ bleed_alpha_image serialize-8888 gm _ bleed_alpha_image_shader serialize-8888 gm _ verylargebitmap serialize-8888 gm _ verylarge_picture_image pic-8888 gm _ drawfilter pic-8888 gm _ image-cacherator-from-picture serialize-8888 gm _ image-cacherator-from-picture pic-8888 gm _ image-cacherator-from-raster serialize-8888 gm _ image-cacherator-from-raster pic-8888 gm _ image-cacherator-from-ctable serialize-8888 gm _ image-cacherator-from-ctable pic-8888 gm _ gamut serialize-8888 gm _ gamut pic-8888 gm _ complexclip4_bw serialize-8888 gm _ complexclip4_bw pic-8888 gm _ complexclip4_aa serialize-8888 gm _ complexclip4_aa tiles_rt-8888 gm _ complexclip4_bw tiles_rt-8888 gm _ complexclip4_aa _ image _ interlaced1.png _ image _ interlaced2.png _ image _ interlaced3.png _ image _ .arw _ image _ .cr2 _ image _ .dng _ image _ .nef _ image _ .nrw _ image _ .orf _ image _ .raf _ image _ .rw2 _ image _ .pef _ image _ .srw _ image _ .ARW _ image _ .CR2 _ image _ .DNG _ image _ .NEF _ image _ .NRW _ image _ .ORF _ image _ .RAF _ image _ .RW2 _ image _ .PEF _ image _ .SRW --match ~SpecialImage; echo $? >/data/local/tmp/rc",
528 "[START_DIR]/tmp/dm.sh"
531 "name": "write dm.sh"
537 "[START_DIR]/tmp/dm.sh",
540 "cwd": "[START_DIR]/skia",
550 "cwd": "[START_DIR]/skia",
558 "\nimport subprocess\nimport sys\nbin_dir = sys.argv[1]\nsh = sys.argv[2]\nsubprocess.check_call(['adb', 'shell', 'sh', bin_dir + sh])\ntry:\n sys.exit(int(subprocess.check_output(['adb', 'shell', 'cat',\n bin_dir + 'rc'])))\nexcept ValueError:\n print \"Couldn't read the return code. Probably killed for OOM.\"\n sys.exit(1)\n",
563 "~followup_annotations": [
564 "@@@STEP_LOG_LINE@python.inline@@@@",
565 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@",
566 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
567 "@@@STEP_LOG_LINE@python.inline@bin_dir = sys.argv[1]@@@",
568 "@@@STEP_LOG_LINE@python.inline@sh = sys.argv[2]@@@",
569 "@@@STEP_LOG_LINE@python.inline@subprocess.check_call(['adb', 'shell', 'sh', bin_dir + sh])@@@",
570 "@@@STEP_LOG_LINE@python.inline@try:@@@",
571 "@@@STEP_LOG_LINE@python.inline@ sys.exit(int(subprocess.check_output(['adb', 'shell', 'cat',@@@",
572 "@@@STEP_LOG_LINE@python.inline@ bin_dir + 'rc'])))@@@",
573 "@@@STEP_LOG_LINE@python.inline@except ValueError:@@@",
574 "@@@STEP_LOG_LINE@python.inline@ print \"Couldn't read the return code. Probably killed for OOM.\"@@@",
575 "@@@STEP_LOG_LINE@python.inline@ sys.exit(1)@@@",
576 "@@@STEP_LOG_END@python.inline@@@"
583 "/sdcard/revenge_of_the_skiabot/dm_out",
584 "[CUSTOM_[SWARM_OUT_DIR]]/dm"
586 "cwd": "[START_DIR]/skia",
588 "name": "pull /sdcard/revenge_of_the_skiabot/dm_out [CUSTOM_[SWARM_OUT_DIR]]/dm"
594 "\nimport os\nimport subprocess\nimport sys\nout = sys.argv[1]\nlog = subprocess.check_output(['adb', 'logcat', '-d'])\nfor line in log.split('\\n'):\n tokens = line.split()\n if len(tokens) == 11 and tokens[-7] == 'F' and tokens[-3] == 'pc':\n addr, path = tokens[-2:]\n local = os.path.join(out, os.path.basename(path))\n if os.path.exists(local):\n sym = subprocess.check_output(['addr2line', '-Cfpe', local, addr])\n line = line.replace(addr, addr + ' ' + sym.strip())\n print line\n",
595 "[START_DIR]/out/Debug"
599 "~followup_annotations": [
600 "@@@STEP_LOG_LINE@python.inline@@@@",
601 "@@@STEP_LOG_LINE@python.inline@import os@@@",
602 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@",
603 "@@@STEP_LOG_LINE@python.inline@import sys@@@",
604 "@@@STEP_LOG_LINE@python.inline@out = sys.argv[1]@@@",
605 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output(['adb', 'logcat', '-d'])@@@",
606 "@@@STEP_LOG_LINE@python.inline@for line in log.split('\\n'):@@@",
607 "@@@STEP_LOG_LINE@python.inline@ tokens = line.split()@@@",
608 "@@@STEP_LOG_LINE@python.inline@ if len(tokens) == 11 and tokens[-7] == 'F' and tokens[-3] == 'pc':@@@",
609 "@@@STEP_LOG_LINE@python.inline@ addr, path = tokens[-2:]@@@",
610 "@@@STEP_LOG_LINE@python.inline@ local = os.path.join(out, os.path.basename(path))@@@",
611 "@@@STEP_LOG_LINE@python.inline@ if os.path.exists(local):@@@",
612 "@@@STEP_LOG_LINE@python.inline@ sym = subprocess.check_output(['addr2line', '-Cfpe', local, addr])@@@",
613 "@@@STEP_LOG_LINE@python.inline@ line = line.replace(addr, addr + ' ' + sym.strip())@@@",
614 "@@@STEP_LOG_LINE@python.inline@ print line@@@",
615 "@@@STEP_LOG_END@python.inline@@@"
623 "cwd": "[START_DIR]/skia",
625 "name": "kill adb server"
629 "recipe_result": null,