From f4879e7b414c07c9263ac5ade499b33c488e3fff Mon Sep 17 00:00:00 2001
From: Laurent Modolo <laurent@modolo.fr>
Date: Wed, 27 Nov 2019 14:10:15 +0100
Subject: [PATCH] add session 4 slides

---
 session_4/img/transform-logical.png | Bin 0 -> 71917 bytes
 session_4/slides.Rmd                | 315 ++++++++++++++
 web/4_b                             |   7 +
 web/4_c                             |   7 +
 web/4_d                             |   2 +
 web/slides_4.html                   | 650 ++++++++++++++++++++++++++++
 6 files changed, 981 insertions(+)
 create mode 100644 session_4/img/transform-logical.png
 create mode 100644 session_4/slides.Rmd
 create mode 100644 web/4_b
 create mode 100644 web/4_c
 create mode 100644 web/4_d
 create mode 100644 web/slides_4.html

diff --git a/session_4/img/transform-logical.png b/session_4/img/transform-logical.png
new file mode 100644
index 0000000000000000000000000000000000000000..43462e6394b8bb292c7ccf6c38ce142ded767059
GIT binary patch
literal 71917
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

literal 0
HcmV?d00001

diff --git a/session_4/slides.Rmd b/session_4/slides.Rmd
new file mode 100644
index 0000000..f8de0a4
--- /dev/null
+++ b/session_4/slides.Rmd
@@ -0,0 +1,315 @@
+---
+title: "R#4: data transformation"
+author: "Laurent Modolo [laurent.modolo@ens-lyon.fr](mailto:laurent.modolo@ens-lyon.fr)"
+date: "08 Nov 2019"
+output:
+  slidy_presentation:
+    highlight: tango
+  beamer_presentation:
+    theme: metropolis
+    slide_level: 3
+    fig_caption: no
+    df_print: tibble
+    highlight: tango
+    latex_engine: xelatex
+---
+```{r setup, include=FALSE, cache=TRUE}
+knitr::opts_chunk$set(echo = FALSE)
+library(tidyverse)
+```
+
+## R#4: data transformation
+The goal of this practical is to practices data transformation with `tidyverse`.
+The objectives of this session will be to:
+
+- Filter rows with `filter()`
+- Arrange rows with `arrange()`
+- Select columns with `select()`
+- Add new variables with `mutate()`
+- Combining multiple operations with the pipe `%>%`
+
+## **nycflights13**
+
+`nycflights13::flights`contains all 336,776 flights that departed from New York City in 2013. The data comes from the US Bureau of Transportation Statistics, and is documented in `?flights`
+
+```{r load_data, eval=T, message=FALSE, cache=T}
+library(nycflights13)
+library(tidyverse)
+```
+
+
+
+## **nycflights13**
+
+```{r display_data, eval=F, message=FALSE, cache=T}
+flights
+```
+
+- **int** stands for integers.
+- **dbl** stands for doubles, or real numbers.
+- **chr** stands for character vectors, or strings.
+- **dttm** stands for date-times (a date + a time).
+- **lgl** stands for logical, vectors that contain only TRUE or FALSE.
+- **fctr** stands for factors, which R uses to represent categorical variables with fixed possible values.
+- **date** stands for dates.
+
+## Filter rows with `filter()`
+
+`filter()` allows you to subset observations based on their values. 
+
+```{r filter_month_day, eval=T, message=T, cache=T}
+filter(flights, month == 1, day == 1)
+```
+
+## Filter rows with `filter()`
+
+`dplyr` functions never modify their inputs, so if you want to save the result, you’ll need to use the assignment operator, `<-`
+
+```{r filter_month_day_sav, eval=T, message=F, cache=T}
+jan1 <- filter(flights, month == 1, day == 1)
+```
+
+R either prints out the results, or saves them to a variable.
+
+```{r filter_month_day_sav_display, eval=T, message=F, cache=T}
+(dec25 <- filter(flights, month == 12, day == 25))
+```
+
+## Logical operators
+
+Multiple arguments to `filter()` are combined with “and”: every expression must be true in order for a row to be included in the output.
+
+```{r logical_operator, echo=FALSE, out.width='100%'}
+knitr::include_graphics('img/transform-logical.png')
+```
+
+## Logical operators
+
+Test the following operations:
+
+```{r filter_logical_operators, eval=T, message=F, cache=T}
+filter(flights, month == 11 | month == 12)
+filter(flights, month %in% c(11, 12))
+filter(flights, !(arr_delay > 120 | dep_delay > 120))
+filter(flights, arr_delay <= 120, dep_delay <= 120)
+```
+
+## Missing values
+
+One important feature of R that can make comparison tricky are missing values, or `NA`s (“not availables”). 
+
+```{r filter_logical_operators_NA, eval=T, message=T, cache=T}
+NA > 5
+10 == NA
+NA + 10
+NA / 2
+```
+
+## Missing values
+
+```{r filter_logical_operators_test_NA, eval=T, message=T, cache=T}
+NA == NA
+is.na(NA)
+```
+
+## Filter challenges
+
+Find all flights that:
+
+- Had an arrival delay of two or more hours
+- Were operated by United, American, or Delta
+- Departed between midnight and 6am (inclusive)
+
+Another useful dplyr filtering helper is `between()`. What does it do? Can you use it to simplify the code needed to answer the previous challenges?
+
+How many flights have a missing `dep_time`? What other variables are missing? What might these rows represent?
+
+Why is `NA ^ 0` not `NA`? Why is `NA | TRUE` not `NA`? Why is `FALSE & NA` not `NA`? Can you figure out the general rule? (`NA * 0` is a tricky counter-example!)
+
+
+## Arrange rows with `arrange()`
+
+`arrange()` works similarly to `filter()` except that instead of selecting rows, it changes their order.
+
+```{r arrange_ymd, eval=F, message=F, cache=T}
+arrange(flights, year, month, day)
+```
+
+Use `desc()` to re-order by a column in descending order:
+
+```{r arrange_desc, eval=F, message=F, cache=T}
+arrange(flights, desc(dep_delay))
+```
+
+Missing values are always sorted at the end:
+
+```{r arrange_NA, eval=F, message=F, cache=T}
+arrange(tibble(x = c(5, 2, NA)), x)
+arrange(tibble(x = c(5, 2, NA)), desc(x))
+```
+
+## Arrange challenges
+
+- Sort flights to find the most delayed flights. Find the flights that left earliest.
+- Sort flights to find the fastest flights.
+- Which flights traveled the longest? Which traveled the shortest?
+
+## Select columns with `select()`
+
+`select()` allows you to rapidly zoom in on a useful subset using operations based on the names of the variables.
+
+```{r select_ymd, eval=F, message=F, cache=T}
+select(flights, year, month, day)
+select(flights, year:day)
+select(flights, -(year:day))
+```
+
+## Select columns with `select()`
+
+here are a number of helper functions you can use within `select()`:
+
+- `starts_with("abc")`: matches names that begin with “abc”.
+- `ends_with("xyz")`: matches names that end with “xyz”.
+- `contains("ijk")`: matches names that contain “ijk”.
+- `matches("(.)\\1")`: selects variables that match a regular expression. This one matches any variables that contain repeated characters. You’ll learn more about regular expressions in strings.
+- `num_range("x", 1:3)`: matches `x1`, `x2` and `x3`.
+
+See `?select` for more details.
+
+## Select challenges
+
+- Brainstorm as many ways as possible to select `dep_time`, `dep_delay`, `arr_time`, and `arr_delay` from `flights`.
+- What does the `one_of()` function do? Why might it be helpful in conjunction with this vector?
+```{r select_one_of, eval=F, message=F, cache=T}
+vars <- c("year", "month", "day", "dep_delay", "arr_delay")
+```
+- Does the result of running the following code surprise you? How do the select helpers deal with case by default? How can you change that default?
+```{r select_contains, eval=F, message=F, cache=T}
+select(flights, contains("TIME"))
+```
+
+## Add new variables with `mutate()`
+
+It’s often useful to add new columns that are functions of existing columns. That’s the job of `mutate()`.
+
+```{r mutate, eval=F, message=F, cache=T}
+flights_sml <- select(flights, 
+  year:day, 
+  ends_with("delay"), 
+  distance, 
+  air_time
+)
+mutate(flights_sml,
+  gain = dep_delay - arr_delay,
+  speed = distance / air_time * 60
+)
+```
+
+**4_a**
+
+## Add new variables with `mutate()`
+
+You can refer to columns that you’ve just created:
+
+```{r mutate_reuse, eval=F, message=F, cache=T}
+mutate(flights,
+  gain = dep_delay - arr_delay,
+  hours = air_time / 60,
+  gain_per_hour = gain / hours
+)
+```
+
+## Useful creation functions
+
+- Offsets: `lead()` and `lag()` allow you to refer to leading or lagging values. This allows you to compute running differences (e.g. `x - lag(x)`) or find when values change (`x != lag(x)`).
+- Cumulative and rolling aggregates: R provides functions for running sums, products, mins and maxes: `cumsum()`, `cumprod()`, `cummin()`, `cummax()`; and dplyr provides `cummean()` for cumulative means. 
+- Logical comparisons, `<`, `<=`, `>`, `>=`, `!=`, and `==`
+- Ranking: there are a number of ranking functions, but you should start with `min_rank()`. There is also `row_number()`, `dense_rank()`, `percent_rank()`, `cume_dist()`, `ntile()`
+
+## Mutate challenges
+
+- Currently `dep_time` and `sched_dep_time` are convenient to look at, but hard to compute with because they’re not really continuous numbers. Convert them to a more convenient representation of number of minutes since midnight.
+
+\pause
+
+```{r mutate_challenges_a, eval=F, message=F, cache=T}
+mutate(
+  flights,
+  dep_time = (dep_time %/% 100) * 60 +
+    dep_time %% 100,
+  sched_dep_time = (sched_dep_time %/% 100) * 60 +
+    sched_dep_time %% 100
+)
+```
+
+**4_b**
+
+## Mutate challenges
+
+- Compare `dep_time`, `sched_dep_time`, and `dep_delay`. How would you expect those three numbers to be related?
+
+\pause
+
+```{r mutate_challenge_b, eval=F, message=F, cache=T}
+mutate(
+  flights,
+  dep_time = (dep_time %/% 100) * 60 + 
+    dep_time %% 100,
+  sched_dep_time = (sched_dep_time %/% 100) * 60 +
+    sched_dep_time %% 100
+)
+```
+
+**4_c**
+
+## Mutate challenges
+
+- Find the 10 most delayed flights using a ranking function. How do you want to handle ties? Carefully read the documentation for `min_rank()`
+
+\pause
+
+```{r mutate_challenge_c, eval=F, message=F, cache=T}
+flights_md <- mutate(flights, most_delay = min_rank(desc(dep_delay)))
+filter(flights_md, most_delay < 10)
+```
+
+**4_d**
+
+## Combining multiple operations with the pipe
+
+We don't want to create useless intermediate variables so we can use the pipe opperator: `%>%`
+(`ctrl + shift + M`).
+
+```{r pipe_example_a, eval=F, message=F, cache=T}
+flights_md <- mutate(flights,
+                     most_delay = min_rank(desc(dep_delay)))
+flights_md <- filter(flights_md, most_delay < 10)
+flights_md <- arrange(flights_md, most_delay)
+```
+
+## Combining multiple operations with the pipe
+
+We don't want to create useless intermediate variables so we can use the pipe opperator: `%>%`
+(`ctrl + shift + M`).
+
+```{r pipe_example_b, eval=F, message=F, cache=T}
+flights %>%
+  mutate(most_delay = min_rank(desc(dep_delay))) %>% 
+  filter(most_delay < 10) %>% 
+  arrange(most_delay)
+```
+
+## Combining multiple operations with the pipe
+
+Behind the scenes, `x %>% f(y)` turns into `f(x, y)`, and `x %>% f(y) %>% g(z)` turns into `g(f(x, y), z)` and so on. You can use the pipe to rewrite multiple operations in a way that you can read left-to-right, top-to-bottom. 
+
+You can access the transmited variables with `.`
+
+```{r pipe_example_c, eval=F, message=F, cache=T}
+flights %>%
+  mutate(most_delay = min_rank(desc(dep_delay))) %>% 
+  filter(., most_delay < 10) %>% 
+  arrange(., most_delay)
+```
+
+Working with the pipe is one of the key criteria for belonging to the `tidyverse`. The only exception is `ggplot2`: it was written before the pipe was discovered. Unfortunately, the next iteration of `ggplot2`, `ggvis`, which does use the pipe, isn’t quite ready for prime time yet.
\ No newline at end of file
diff --git a/web/4_b b/web/4_b
new file mode 100644
index 0000000..be9d2de
--- /dev/null
+++ b/web/4_b
@@ -0,0 +1,7 @@
+mutate(
+  flights,
+  dep_time = (dep_time %/% 100) * 60 +
+    dep_time %% 100,
+  sched_dep_time = (sched_dep_time %/% 100) * 60 +
+    sched_dep_time %% 100
+)
\ No newline at end of file
diff --git a/web/4_c b/web/4_c
new file mode 100644
index 0000000..17749a3
--- /dev/null
+++ b/web/4_c
@@ -0,0 +1,7 @@
+mutate(
+  flights,
+  dep_time = (dep_time %/% 100) * 60 + 
+    dep_time %% 100,
+  sched_dep_time = (sched_dep_time %/% 100) * 60 +
+    sched_dep_time %% 100
+)
\ No newline at end of file
diff --git a/web/4_d b/web/4_d
new file mode 100644
index 0000000..0a3bef6
--- /dev/null
+++ b/web/4_d
@@ -0,0 +1,2 @@
+flights_md <- mutate(flights, most_delay = min_rank(desc(dep_delay)))
+filter(flights_md, most_delay < 10)
\ No newline at end of file
diff --git a/web/slides_4.html b/web/slides_4.html
new file mode 100644
index 0000000..a255f13
--- /dev/null
+++ b/web/slides_4.html
@@ -0,0 +1,650 @@
+<?xml version="1.0" encoding="utf-8" ?>
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+  <meta http-equiv="Content-Style-Type" content="text/css" />
+  <meta name="generator" content="pandoc" />
+  <meta name="author" content="Laurent Modolo laurent.modolo@ens-lyon.fr" />
+  <meta name="date" content="2019-11-08" />
+  <title>R#4: data transformation</title>
+  <style type="text/css">code{white-space: pre;}</style>
+  <style type="text/css">
+body
+{
+margin: 0 0 0 0;
+padding: 0 0 0 0;
+width: 100%;
+height: 100%;
+color: black;
+background-color: white;
+font-family: "Gill Sans MT", "Gill Sans", GillSans, sans-serif;
+font-size: 14pt;
+}
+div.toolbar {
+position: fixed; z-index: 200;
+top: auto; bottom: 0; left: 0; right: 0;
+height: 1.2em; text-align: right;
+padding-left: 1em;
+padding-right: 1em; font-size: 60%;
+color: DimGray;
+background-color: rgb(240,240,240);
+border-top: solid 1px rgb(180,180,180);
+}
+div.toolbar span.copyright {
+color: DimGray;
+margin-left: 0.5em;
+}
+div.initial_prompt {
+position: absolute;
+z-index: 1000;
+bottom: 1.2em;
+width: 100%;
+background-color: rgb(200,200,200);
+opacity: 0.35;
+background-color: rgb(200,200,200, 0.35);
+cursor: pointer;
+}
+div.initial_prompt p.help {
+text-align: center;
+}
+div.initial_prompt p.close {
+text-align: right;
+font-style: italic;
+}
+div.slidy_toc {
+position: absolute;
+z-index: 300;
+width: 60%;
+max-width: 30em;
+height: 30em;
+overflow: auto;
+top: auto;
+right: auto;
+left: 4em;
+bottom: 4em;
+padding: 1em;
+background: rgb(240,240,240);
+border-style: solid;
+border-width: 2px;
+font-size: 60%;
+}
+div.slidy_toc .toc_heading {
+text-align: center;
+width: 100%;
+margin: 0;
+margin-bottom: 1em;
+border-bottom-style: solid;
+border-bottom-color: rgb(180,180,180);
+border-bottom-width: 1px;
+}
+div.slide {
+z-index: 20;
+margin: 0 0 0 0;
+padding-top: 0;
+padding-bottom: 0;
+padding-left: 20px;
+padding-right: 20px;
+border-width: 0;
+clear: both;
+top: 0;
+bottom: 0;
+left: 0;
+right: 0;
+line-height: 120%;
+background-color: transparent;
+}
+div.background {
+display: none;
+}
+div.handout {
+margin-left: 20px;
+margin-right: 20px;
+}
+div.slide.titlepage {
+text-align: center;
+}
+div.slide.titlepage h1 {
+padding-top: 10%;
+margin-right: 0;
+}
+div.slide h1 {
+padding-left: 0;
+padding-right: 20pt;
+padding-top: 4pt;
+padding-bottom: 4pt;
+margin-top: 0;
+margin-left: 0;
+margin-right: 60pt;
+margin-bottom: 0.5em;
+display: block; font-size: 160%;
+line-height: 1.2em;
+background: transparent;
+}
+@media screen and (max-device-width: 1024px)
+{
+div.slide { font-size: 100%; }
+}
+@media screen and (max-device-width: 800px)
+{
+div.slide { font-size: 200%; }
+div.slidy_toc {
+top: 1em;
+left: 1em;
+right: auto;
+width: 80%;
+font-size: 180%;
+}
+}
+div.toc-heading {
+width: 100%;
+border-bottom: solid 1px rgb(180,180,180);
+margin-bottom: 1em;
+text-align: center;
+}
+img {
+image-rendering: optimize-quality;
+}
+pre {
+font-size: 80%;
+font-weight: bold;
+line-height: 120%;
+padding-top: 0.2em;
+padding-bottom: 0.2em;
+padding-left: 1em;
+padding-right: 1em;
+border-style: solid;
+border-left-width: 1em;
+border-top-width: thin;
+border-right-width: thin;
+border-bottom-width: thin;
+border-color: #95ABD0;
+color: #00428C;
+background-color: #E4E5E7;
+}
+li pre { margin-left: 0; }
+blockquote { font-style: italic }
+img { background-color: transparent }
+p.copyright { font-size: smaller }
+.center { text-align: center }
+.footnote { font-size: smaller; margin-left: 2em; }
+a img { border-width: 0; border-style: none }
+a:visited { color: navy }
+a:link { color: navy }
+a:hover { color: red; text-decoration: underline }
+a:active { color: red; text-decoration: underline }
+a {text-decoration: none}
+.toolbar a:link {color: blue}
+.toolbar a:visited {color: blue}
+.toolbar a:active {color: red}
+.toolbar a:hover {color: red}
+ul { list-style-type: square; }
+ul ul { list-style-type: disc; }
+ul ul ul { list-style-type: circle; }
+ul ul ul ul { list-style-type: disc; }
+li { margin-left: 0.5em; margin-top: 0.5em; }
+li li { font-size: 85%; font-style: italic }
+li li li { font-size: 85%; font-style: normal }
+div dt
+{
+margin-left: 0;
+margin-top: 1em;
+margin-bottom: 0.5em;
+font-weight: bold;
+}
+div dd
+{
+margin-left: 2em;
+margin-bottom: 0.5em;
+}
+p,pre,ul,ol,blockquote,h2,h3,h4,h5,h6,dl,table {
+margin-left: 1em;
+margin-right: 1em;
+}
+p.subhead { font-weight: bold; margin-top: 2em; }
+.smaller { font-size: smaller }
+.bigger { font-size: 130% }
+td,th { padding: 0.2em }
+ul {
+margin: 0.5em 1.5em 0.5em 1.5em;
+padding: 0;
+}
+ol {
+margin: 0.5em 1.5em 0.5em 1.5em;
+padding: 0;
+}
+ul { list-style-type: square; }
+ul ul { list-style-type: disc; }
+ul ul ul { list-style-type: circle; }
+ul ul ul ul { list-style-type: disc; }
+ul li { list-style: square;
+margin: 0.1em 0em 0.6em 0;
+padding: 0 0 0 0;
+line-height: 140%;
+}
+ol li { margin: 0.1em 0em 0.6em 1.5em;
+padding: 0 0 0 0px;
+line-height: 140%;
+list-style-type: decimal;
+}
+li ul li { font-size: 85%; font-style: italic;
+list-style-type: disc;
+background: transparent;
+padding: 0 0 0 0;
+}
+li li ul li { font-size: 85%; font-style: normal;
+list-style-type: circle;
+background: transparent;
+padding: 0 0 0 0;
+}
+li li li ul li {
+list-style-type: disc;
+background: transparent;
+padding: 0 0 0 0;
+}
+li ol li {
+list-style-type: decimal;
+}
+li li ol li {
+list-style-type: decimal;
+}
+
+ol.outline li:hover { cursor: pointer }
+ol.outline li.nofold:hover { cursor: default }
+ul.outline li:hover { cursor: pointer }
+ul.outline li.nofold:hover { cursor: default }
+ol.outline { list-style:decimal; }
+ol.outline ol { list-style-type:lower-alpha }
+ol.outline li.nofold {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ol.outline li.unfolded {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ol.outline li.folded {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ol.outline li.unfolded:hover {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ol.outline li.folded:hover {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ul.outline li.nofold {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ul.outline li.unfolded {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ul.outline li.folded {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ul.outline li.unfolded:hover {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+ul.outline li.folded:hover {
+padding: 0 0 0 20px;
+background: transparent url() no-repeat 0px 0.5em;
+}
+
+a.titleslide { font-weight: bold; font-style: italic }
+
+img.hidden { display: none; visibility: hidden }
+div.initial_prompt { display: none; visibility: hidden }
+div.slide {
+visibility: visible;
+position: inherit;
+}
+div.handout {
+border-top-style: solid;
+border-top-width: thin;
+border-top-color: black;
+}
+@media screen {
+.hidden { display: none; visibility: visible }
+div.slide.hidden { display: block; visibility: visible }
+div.handout.hidden { display: block; visibility: visible }
+div.background { display: none; visibility: hidden }
+body.single_slide div.initial_prompt { display: block; visibility: visible }
+body.single_slide div.background { display: block; visibility: visible }
+body.single_slide div.background.hidden { display: none; visibility: hidden }
+body.single_slide .invisible { visibility: hidden }
+body.single_slide .hidden { display: none; visibility: hidden }
+body.single_slide div.slide { position: absolute }
+body.single_slide div.handout { display: none; visibility: hidden }
+}
+@media print {
+.hidden { display: block; visibility: visible }
+div.slide pre { font-size: 60%; padding-left: 0.5em; }
+div.toolbar { display: none; visibility: hidden; }
+div.slidy_toc { display: none; visibility: hidden; }
+div.background { display: none; visibility: hidden; }
+div.slide { page-break-before: always }
+
+div.slide.first-slide { page-break-before: avoid }
+}
+
+
+.jslider table {
+margin-left: 0em;
+margin-right: 0em;
+}
+
+table.dataTable, .shiny-datatable-output div {
+font-size: 14pt;
+}
+
+.dataTables_info, .dataTables_paginate {
+font-size: 19px;
+}
+
+pre.sourceCode, code.sourceCode {
+font-size: 80%;
+}
+
+label, button, input, select, textarea {
+font-size: 14pt;
+}
+
+ul.nav, ul.nav li {
+list-style-type: none;
+}
+</style>
+  <script src="data:application/javascript;base64,Lyogc2xpZHkuanMKCiAgIENvcHlyaWdodCAoYykgMjAwNS0yMDEzIFczQyAoTUlULCBFUkNJTSwgS2VpbyksIEFsbCBSaWdodHMgUmVzZXJ2ZWQuCiAgIFczQyBsaWFiaWxpdHksIHRyYWRlbWFyaywgZG9jdW1lbnQgdXNlIGFuZCBzb2Z0d2FyZSBsaWNlbnNpbmcKICAgcnVsZXMgYXBwbHksIHNlZToKCiAgIGh0dHA6Ly93d3cudzMub3JnL0NvbnNvcnRpdW0vTGVnYWwvY29weXJpZ2h0LWRvY3VtZW50cwogICBodHRwOi8vd3d3LnczLm9yZy9Db25zb3J0aXVtL0xlZ2FsL2NvcHlyaWdodC1zb2Z0d2FyZQoKICAgRGVmaW5lcyBzaW5nbGUgbmFtZSAidzNjX3NsaWR5IiBpbiBnbG9iYWwgbmFtZXNwYWNlCiAgIEFkZHMgZXZlbnQgaGFuZGxlcnMgd2l0aG91dCB0cmFtcGxpbmcgb24gYW55IG90aGVycwoqLwoKLy8gdGhlIHNsaWR5IG9iamVjdCBpbXBsZW1lbnRhdGlvbgp2YXIgdzNjX3NsaWR5ID0gewogIC8vIGNsYXNzaWZ5IHdoaWNoIGtpbmQgb2YgYnJvd3NlciB3ZSdyZSBydW5uaW5nIHVuZGVyCiAgbnNfcG9zOiAodHlwZW9mIHdpbmRvdy5wYWdlWU9mZnNldCE9J3VuZGVmaW5lZCcpLAogIGtodG1sOiAoKG5hdmlnYXRvci51c2VyQWdlbnQpLmluZGV4T2YoIktIVE1MIikgPj0gMCA/IHRydWUgOiBmYWxzZSksCiAgb3BlcmE6ICgobmF2aWdhdG9yLnVzZXJBZ2VudCkuaW5kZXhPZigiT3BlcmEiKSA+PSAwID8gdHJ1ZSA6IGZhbHNlKSwKICBpcGFkOiAoKG5hdmlnYXRvci51c2VyQWdlbnQpLmluZGV4T2YoImlQYWQiKSA+PSAwID8gdHJ1ZSA6IGZhbHNlKSwKICBpcGhvbmU6ICgobmF2aWdhdG9yLnVzZXJBZ2VudCkuaW5kZXhPZigiaVBob25lIikgPj0gMCA/IHRydWUgOiBmYWxzZSksCiAgYW5kcm9pZDogKChuYXZpZ2F0b3IudXNlckFnZW50KS5pbmRleE9mKCJBbmRyb2lkIikgPj0gMCA/IHRydWUgOiBmYWxzZSksCiAgaWU6ICh0eXBlb2YgZG9jdW1lbnQuYWxsICE9ICJ1bmRlZmluZWQiICYmICF0aGlzLm9wZXJhKSwKICBpZTY6ICghdGhpcy5uc19wb3MgJiYgbmF2aWdhdG9yLnVzZXJBZ2VudC5pbmRleE9mKCJNU0lFIDYiKSAhPSAtMSksCiAgaWU3OiAoIXRoaXMubnNfcG9zICYmIG5hdmlnYXRvci51c2VyQWdlbnQuaW5kZXhPZigiTVNJRSA3IikgIT0gLTEpLAogIGllODogKCF0aGlzLm5zX3BvcyAmJiBuYXZpZ2F0b3IudXNlckFnZW50LmluZGV4T2YoIk1TSUUgOCIpICE9IC0xKSwKICBpZTk6ICghdGhpcy5uc19wb3MgJiYgbmF2aWdhdG9yLnVzZXJBZ2VudC5pbmRleE9mKCJNU0lFIDkiKSAhPSAtMSksCgogIC8vIGRhdGEgZm9yIHN3aXBlIGFuZCBkb3VibGUgdGFwIGRldGVjdGlvbiBvbiB0b3VjaCBzY3JlZW5zCiAgbGFzdF90YXA6IDAsCiAgcHJldl90YXA6IDAsCiAgc3RhcnRfeDogMCwKICBzdGFydF95OiAwLAogIGRlbHRhX3g6IDAsCiAgZGVsdGFfeTogMCwKCiAgLy8gYXJlIHdlIHJ1bm5pbmcgYXMgWEhUTUw/IChkb2Vzbid0IHdvcmsgb24gT3BlcmEpCiAgaXNfeGh0bWw6IC94bWwvLnRlc3QoZG9jdW1lbnQuY29udGVudFR5cGUpLAoKICBzbGlkZV9udW1iZXI6IDAsIC8vIGludGVnZXIgc2xpZGUgY291bnQ6IDAsIDEsIDIsIC4uLgogIHNsaWRlX251bWJlcl9lbGVtZW50OiBudWxsLCAvLyBlbGVtZW50IGNvbnRhaW5pbmcgc2xpZGUgbnVtYmVyCiAgc2xpZGVzOiBbXSwgLy8gc2V0IHRvIGFycmF5IG9mIHNsaWRlIGRpdidzCiAgbm90ZXM6IFtdLCAvLyBzZXQgdG8gYXJyYXkgb2YgaGFuZG91dCBkaXYncwogIGJhY2tncm91bmRzOiBbXSwgLy8gc2V0IHRvIGFycmF5IG9mIGJhY2tncm91bmQgZGl2J3MKICBvYnNlcnZlcnM6IFtdLCAvLyBsaXN0IG9mIG9ic2VydmVyIGZ1bmN0aW9ucwogIHRvb2xiYXI6IG51bGwsIC8vIGVsZW1lbnQgY29udGFpbmluZyB0b29sYmFyCiAgdGl0bGU6IG51bGwsIC8vIGRvY3VtZW50IHRpdGxlCiAgbGFzdF9zaG93bjogbnVsbCwgLy8gbGFzdCBpbmNyZW1lbnRhbGx5IHNob3duIGl0ZW0KICBlb3M6IG51bGwsICAvLyBzcGFuIGVsZW1lbnQgZm9yIGVuZCBvZiBzbGlkZSBpbmRpY2F0b3IKICB0b2M6IG51bGwsIC8vIHRhYmxlIG9mIGNvbnRlbnRzCiAgb3V0bGluZTogbnVsbCwgLy8gb3V0bGluZSBlbGVtZW50IHdpdGggdGhlIGZvY3VzCiAgc2VsZWN0ZWRfdGV4dF9sZW46IDAsIC8vIGxlbmd0aCBvZiBkcmFnIHNlbGVjdGlvbiBvbiBkb2N1bWVudAogIHZpZXdfYWxsOiAwLCAgLy8gMSB0byB2aWV3IGFsbCBzbGlkZXMgKyBoYW5kb3V0cwogIHdhbnRfdG9vbGJhcjogdHJ1ZSwgIC8vIHVzZXIgcHJlZmVyZW5jZSB0byBzaG93L2hpZGUgdG9vbGJhcgogIG1vdXNlX2NsaWNrX2VuYWJsZWQ6IHRydWUsIC8vIGVuYWJsZXMgbGVmdCBjbGljayBmb3IgbmV4dCBzbGlkZQogIHNjcm9sbF9oYWNrOiAwLCAvLyBJRSB3b3JrIGFyb3VuZCBmb3IgcG9zaXRpb246IGZpeGVkCiAgZGlzYWJsZV9zbGlkZV9jbGljazogZmFsc2UsICAvLyB1c2VkIGJ5IGNsaWNrZWQgYW5jaG9ycwoKICBsYW5nOiAiZW4iLCAvLyB1cGRhdGVkIHRvIGxhbmd1YWdlIHNwZWNpZmllZCBieSBodG1sIGZpbGUKCiAgaGVscF9hbmNob3I6IG51bGwsIC8vIHVzZWQgZm9yIGtleWJvYXJkIGZvY3VzIGhhY2sgaW4gc2hvd1Rvb2xiYXIoKQogIGhlbHBfcGFnZTogImh0dHA6Ly93d3cudzMub3JnL1RhbGtzL1Rvb2xzL1NsaWR5Mi9oZWxwL2hlbHAuaHRtbCIsCiAgaGVscF90ZXh0OiAiTmF2aWdhdGUgd2l0aCBtb3VzZSBjbGljaywgc3BhY2UgYmFyLCBDdXJzb3IgTGVmdC9SaWdodCwgIiArCiAgICAgICAgICAgICAib3IgUGcgVXAgYW5kIFBnIERuLiBVc2UgUyBhbmQgQiB0byBjaGFuZ2UgZm9udCBzaXplLiIsCgogIHNpemVfaW5kZXg6IDAsCiAgc2l6ZV9hZGp1c3RtZW50OiAwLAogIHNpemVzOiAgbmV3IEFycmF5KCIxMHB0IiwgIjEycHQiLCAiMTRwdCIsICIxNnB0IiwgIjE4cHQiLCAiMjBwdCIsCiAgICAgICAgICAgICAgICAgICAgIjIycHQiLCAiMjRwdCIsICIyNnB0IiwgIjI4cHQiLCAiMzBwdCIsICIzMnB0IiksCgogIC8vIG5lZWRlZCBmb3IgZWZmaWNpZW50IHJlc2l6aW5nCiAgbGFzdF93aWR0aDogMCwKICBsYXN0X2hlaWdodDogMCwKCgogIC8vIE5lZWRlZCBmb3IgY3Jvc3MgYnJvd3NlciBzdXBwb3J0IGZvciByZWxhdGl2ZSB3aWR0aC9oZWlnaHQgb24KICAvLyBvYmplY3QgZWxlbWVudHMuIFRoZSB3b3JrIGFyb3VuZCBpcyB0byBzYXZlIHdpZHRoL2hlaWdodCBhdHRyaWJ1dGVzCiAgLy8gYW5kIHRoZW4gdG8gcmVjb21wdXRlIGFic29sdXRlIHdpZHRoL2hlaWdodCBkaW1lbnNpb25zIG9uIHJlc2l6aW5nCiAgIG9iamVjdHM6IFtdLAoKICAvLyBhdHRhY2ggaW5pdGlhbGlhdGlvbiBldmVudCBoYW5kbGVycwogIHNldF91cDogZnVuY3Rpb24gKCkgewogICAgdmFyIGluaXQgPSBmdW5jdGlvbigpIHsgdzNjX3NsaWR5LmluaXQoKTsgfTsKICAgIGlmICh0eXBlb2Ygd2luZG93LmFkZEV2ZW50TGlzdGVuZXIgIT0gInVuZGVmaW5lZCIpCiAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCJsb2FkIiwgaW5pdCwgZmFsc2UpOwogICAgZWxzZQogICAgICB3aW5kb3cuYXR0YWNoRXZlbnQoIm9ubG9hZCIsIGluaXQpOwogIH0sCgogIGhpZGVfc2xpZGVzOiBmdW5jdGlvbiAoKSB7CiAgICBpZiAoZG9jdW1lbnQuYm9keSAmJiAhdzNjX3NsaWR5LmluaXRpYWxpemVkKQogICAgICBkb2N1bWVudC5ib2R5LnN0eWxlLnZpc2liaWxpdHkgPSAiaGlkZGVuIjsKICAgIGVsc2UKICAgICAgc2V0VGltZW91dCh3M2Nfc2xpZHkuaGlkZV9zbGlkZXMsIDUwKTsKICB9LAoKICAvLyBoYWNrIHRvIHBlcnN1YWRlIElFIHRvIGNvbXB1dGUgY29ycmVjdCBkb2N1bWVudCBoZWlnaHQKICAvLyBhcyBuZWVkZWQgZm9yIHNpbXVsYXRpbmcgZml4ZWQgcG9zaXRpb25pbmcgb2YgdG9vbGJhcgogIGllX2hhY2s6IGZ1bmN0aW9uICgpIHsKICAgIHdpbmRvdy5yZXNpemVCeSgwLC0xKTsKICAgIHdpbmRvdy5yZXNpemVCeSgwLCAxKTsKICB9LAoKICBpbml0OiBmdW5jdGlvbiAoKSB7CiAgICAvL2FsZXJ0KCJzbGlkeSBzdGFydGluZyB0ZXN0IDEwIik7CiAgICBkb2N1bWVudC5ib2R5LnN0eWxlLnZpc2liaWxpdHkgPSAidmlzaWJsZSI7CiAgICB0aGlzLmluaXRfbG9jYWxpemF0aW9uKCk7CiAgICB0aGlzLmFkZF90b29sYmFyKCk7CiAgICB0aGlzLndyYXBfaW1wbGljaXRfc2xpZGVzKCk7CiAgICB0aGlzLmNvbGxlY3Rfc2xpZGVzKCk7CiAgICB0aGlzLmNvbGxlY3Rfbm90ZXMoKTsKICAgIHRoaXMuY29sbGVjdF9iYWNrZ3JvdW5kcygpOwogICAgdGhpcy5vYmplY3RzID0gZG9jdW1lbnQuYm9keS5nZXRFbGVtZW50c0J5VGFnTmFtZSgib2JqZWN0Iik7CiAgICB0aGlzLnBhdGNoX2FuY2hvcnMoKTsKICAgIHRoaXMuc2xpZGVfbnVtYmVyID0gdGhpcy5maW5kX3NsaWRlX251bWJlcihsb2NhdGlvbi5ocmVmKTsKICAgIHdpbmRvdy5vZmZzY3JlZW5idWZmZXJpbmcgPSB0cnVlOwogICAgdGhpcy5zaXplX2FkanVzdG1lbnQgPSB0aGlzLmZpbmRfc2l6ZV9hZGp1c3QoKTsKICAgIHRoaXMudGltZV9sZWZ0ID0gdGhpcy5maW5kX2R1cmF0aW9uKCk7CiAgICB0aGlzLmhpZGVfaW1hZ2VfdG9vbGJhcigpOyAgLy8gc3VwcHJlc3MgSUUgaW1hZ2UgdG9vbGJhciBwb3B1cAogICAgdGhpcy5pbml0X291dGxpbmVyKCk7ICAvLyBhY3RpdmF0ZSBmb2xkL3VuZm9sZCBzdXBwb3J0CiAgICB0aGlzLnRpdGxlID0gZG9jdW1lbnQudGl0bGU7CiAgICB0aGlzLmtleWJvYXJkbGVzcyA9ICh0aGlzLmlwYWR8fHRoaXMuaXBob25lfHx0aGlzLmFuZHJvaWQpOwoKICAgIGlmICh0aGlzLmtleWJvYXJkbGVzcykKICAgIHsKICAgICAgdzNjX3NsaWR5LnJlbW92ZV9jbGFzcyh3M2Nfc2xpZHkudG9vbGJhciwgImhpZGRlbiIpCiAgICAgIHRoaXMud2FudF90b29sYmFyID0gMDsKICAgIH0KCiAgICAvLyB3b3JrIGFyb3VuZCBmb3Igb3BlcmEgYnVnCiAgICB0aGlzLmlzX3hodG1sID0gKGRvY3VtZW50LmJvZHkudGFnTmFtZSA9PSAiQk9EWSIgPyBmYWxzZSA6IHRydWUpOwoKICAgIGlmICh0aGlzLnNsaWRlcy5sZW5ndGggPiAwKQogICAgewogICAgICB2YXIgc2xpZGUgPSB0aGlzLnNsaWRlc1t0aGlzLnNsaWRlX251bWJlcl07CiAgIAogICAgICBpZiAodGhpcy5zbGlkZV9udW1iZXIgPiAwKQogICAgICB7CiAgICAgICAgdGhpcy5zZXRfdmlzaWJpbGl0eV9hbGxfaW5jcmVtZW50YWwoInZpc2libGUiKTsKICAgICAgICB0aGlzLmxhc3Rfc2hvd24gPSB0aGlzLnByZXZpb3VzX2luY3JlbWVudGFsX2l0ZW0obnVsbCk7CiAgICAgICAgdGhpcy5zZXRfZW9zX3N0YXR1cyh0cnVlKTsKICAgICAgfQogICAgICBlbHNlCiAgICAgIHsKICAgICAgICB0aGlzLmxhc3Rfc2hvd24gPSBudWxsOwogICAgICAgIHRoaXMuc2V0X3Zpc2liaWxpdHlfYWxsX2luY3JlbWVudGFsKCJoaWRkZW4iKTsKICAgICAgICB0aGlzLnNldF9lb3Nfc3RhdHVzKCF0aGlzLm5leHRfaW5jcmVtZW50YWxfaXRlbSh0aGlzLmxhc3Rfc2hvd24pKTsKICAgICAgfQoKICAgICAgdGhpcy5zZXRfbG9jYXRpb24oKTsKICAgICAgdGhpcy5hZGRfY2xhc3ModGhpcy5zbGlkZXNbMF0sICJmaXJzdC1zbGlkZSIpOwogICAgICB3M2Nfc2xpZHkuc2hvd19zbGlkZShzbGlkZSk7CiAgICB9CgogICAgdGhpcy50b2MgPSB0aGlzLnRhYmxlX29mX2NvbnRlbnRzKCk7CgogICAgdGhpcy5hZGRfaW5pdGlhbF9wcm9tcHQoKTsKCiAgICAvLyBiaW5kIGV2ZW50IGhhbmRsZXJzIHdpdGhvdXQgaW50ZXJmZXJpbmcgd2l0aCBjdXN0b20gcGFnZSBzY3JpcHRzCiAgICAvLyBUYXAgZXZlbnRzIGJlaGF2ZSB0b28gd2VpcmRseSB0byBzdXBwb3J0IGNsaWNrcyByZWxpYWJseSBvbgogICAgLy8gaVBob25lIGFuZCBpUGFkLCBzbyBleGNsdWRlIHRoZXNlIGZyb20gY2xpY2sgaGFuZGxlcgoKICAgIGlmICghdGhpcy5rZXlib2FyZGxlc3MpCiAgICB7CiAgICAgIHRoaXMuYWRkX2xpc3RlbmVyKGRvY3VtZW50LmJvZHksICJjbGljayIsIHRoaXMubW91c2VfYnV0dG9uX2NsaWNrKTsKICAgICAgdGhpcy5hZGRfbGlzdGVuZXIoZG9jdW1lbnQuYm9keSwgIm1vdXNlZG93biIsIHRoaXMubW91c2VfYnV0dG9uX2Rvd24pOwogICAgfQoKICAgIHRoaXMuYWRkX2xpc3RlbmVyKGRvY3VtZW50LCAia2V5ZG93biIsIHRoaXMua2V5X2Rvd24pOwogICAgdGhpcy5hZGRfbGlzdGVuZXIoZG9jdW1lbnQsICJrZXlwcmVzcyIsIHRoaXMua2V5X3ByZXNzKTsKICAgIHRoaXMuYWRkX2xpc3RlbmVyKHdpbmRvdywgInJlc2l6ZSIsIHRoaXMucmVzaXplZCk7CiAgICB0aGlzLmFkZF9saXN0ZW5lcih3aW5kb3csICJzY3JvbGwiLCB0aGlzLnNjcm9sbGVkKTsKICAgIHRoaXMuYWRkX2xpc3RlbmVyKHdpbmRvdywgInVubG9hZCIsIHRoaXMudW5sb2FkZWQpOwoKICAgIHRoaXMuYWRkX2xpc3RlbmVyKGRvY3VtZW50LCAiZ2VzdHVyZWNoYW5nZSIsIGZ1bmN0aW9uICgpCiAgICB7CiAgICAgIHJldHVybiBmYWxzZTsKICAgIH0pOwoKICAgIHRoaXMuYXR0YWNoX3RvdWNoX2hhbmRlcnModGhpcy5zbGlkZXMpOwoKICAgIC8vIHRoaXMgc2VlbXMgdG8gYmUgYSBkZWJ1Z2dpbmcgaGFjawogICAgLy9pZiAoIWRvY3VtZW50LmJvZHkub25jbGljaykKICAgIC8vICBkb2N1bWVudC5ib2R5Lm9uY2xpY2sgPSBmdW5jdGlvbiAoKSB7IH07CgogICAgdGhpcy5zaW5nbGVfc2xpZGVfdmlldygpOwoKICAgIC8vdGhpcy5zZXRfbG9jYXRpb24oKTsKCiAgICB0aGlzLnJlc2l6ZWQoKTsKCiAgICBpZiAodGhpcy5pZTcpCiAgICAgIHNldFRpbWVvdXQodzNjX3NsaWR5LmllX2hhY2ssIDEwMCk7CgogICAgdGhpcy5zaG93X3Rvb2xiYXIoKTsKCiAgICAvLyBmb3IgYmFjayBidXR0b24gZGV0ZWN0aW9uCiAgICBzZXRJbnRlcnZhbChmdW5jdGlvbiAoKSB7IHczY19zbGlkeS5jaGVja19sb2NhdGlvbigpOyB9LCAyMDApOwogICAgdzNjX3NsaWR5LmluaXRpYWxpemVkID0gdHJ1ZTsKICB9LAoKICAvLyBjcmVhdGUgZGl2IGVsZW1lbnQgd2l0aCBsaW5rcyB0byBlYWNoIHNsaWRlCiAgdGFibGVfb2ZfY29udGVudHM6IGZ1bmN0aW9uICgpIHsKICAgIHZhciB0b2MgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJkaXYiKTsKICAgIHRoaXMuYWRkX2NsYXNzKHRvYywgInNsaWR5X3RvYyBoaWRkZW4iKTsKICAgIC8vdG9jLnNldEF0dHJpYnV0ZSgidGFiaW5kZXgiLCAiMCIpOwoKICAgIHZhciBoZWFkaW5nID0gdGhpcy5jcmVhdGVfZWxlbWVudCgiZGl2Iik7CiAgICB0aGlzLmFkZF9jbGFzcyhoZWFkaW5nLCAidG9jLWhlYWRpbmciKTsKICAgIGhlYWRpbmcuaW5uZXJIVE1MID0gdGhpcy5sb2NhbGl6ZSgiVGFibGUgb2YgQ29udGVudHMiKTsKCiAgICB0b2MuYXBwZW5kQ2hpbGQoaGVhZGluZyk7CiAgICB2YXIgcHJldmlvdXMgPSBudWxsOwoKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgdGhpcy5zbGlkZXMubGVuZ3RoOyArK2kpCiAgICB7CiAgICAgIHZhciB0aXRsZSA9IHRoaXMuaGFzX2NsYXNzKHRoaXMuc2xpZGVzW2ldLCAidGl0bGUiKTsKICAgICAgdmFyIG51bSA9IGRvY3VtZW50LmNyZWF0ZVRleHROb2RlKChpICsgMSkgKyAiLiAiKTsKCiAgICAgIHRvYy5hcHBlbmRDaGlsZChudW0pOwoKICAgICAgdmFyIGEgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJhIik7CiAgICAgIGEuc2V0QXR0cmlidXRlKCJocmVmIiwgIiMoIiArIChpKzEpICsgIikiKTsKCiAgICAgIGlmICh0aXRsZSkKICAgICAgICB0aGlzLmFkZF9jbGFzcyhhLCAidGl0bGVzbGlkZSIpOwoKICAgICAgdmFyIG5hbWUgPSBkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZSh0aGlzLnNsaWRlX25hbWUoaSkpOwogICAgICBhLmFwcGVuZENoaWxkKG5hbWUpOwogICAgICBhLm9uY2xpY2sgPSB3M2Nfc2xpZHkudG9jX2NsaWNrOwogICAgICBhLm9ua2V5ZG93biA9IHczY19zbGlkeS50b2Nfa2V5X2Rvd247CiAgICAgIGEucHJldmlvdXMgPSBwcmV2aW91czsKCiAgICAgIGlmIChwcmV2aW91cykKICAgICAgICBwcmV2aW91cy5uZXh0ID0gYTsKCiAgICAgIHRvYy5hcHBlbmRDaGlsZChhKTsKCiAgICAgIGlmIChpID09IDApCiAgICAgICAgdG9jLmZpcnN0ID0gYTsKCiAgICAgIGlmIChpIDwgdGhpcy5zbGlkZXMubGVuZ3RoIC0gMSkKICAgICAgewogICAgICAgIHZhciBiciA9IHRoaXMuY3JlYXRlX2VsZW1lbnQoImJyIik7CiAgICAgICAgdG9jLmFwcGVuZENoaWxkKGJyKTsKICAgICAgfQoKICAgICAgcHJldmlvdXMgPSBhOwogICAgfQoKICAgIHRvYy5mb2N1cyA9IGZ1bmN0aW9uICgpIHsKICAgICAgaWYgKHRoaXMuZmlyc3QpCiAgICAgICAgdGhpcy5maXJzdC5mb2N1cygpOwogICAgfQoKICAgIHRvYy5vbm1vdXNldXAgPSB3M2Nfc2xpZHkubW91c2VfYnV0dG9uX3VwOwoKICAgIHRvYy5vbmNsaWNrID0gZnVuY3Rpb24gKGUpIHsKICAgICAgZXx8KGU9d2luZG93LmV2ZW50KTsKCiAgICAgIGlmICh3M2Nfc2xpZHkuc2VsZWN0ZWRfdGV4dF9sZW4gPD0gMCkKICAgICAgICAgdzNjX3NsaWR5LmhpZGVfdGFibGVfb2ZfY29udGVudHModHJ1ZSk7CgogICAgICB3M2Nfc2xpZHkuc3RvcF9wcm9wYWdhdGlvbihlKTsKICAgIAogICAgICBpZiAoZS5jYW5jZWwgIT0gdW5kZWZpbmVkKQogICAgICAgIGUuY2FuY2VsID0gdHJ1ZTsKICAgICAgCiAgICAgIGlmIChlLnJldHVyblZhbHVlICE9IHVuZGVmaW5lZCkKICAgICAgICBlLnJldHVyblZhbHVlID0gZmFsc2U7CiAgICAgIAogICAgICByZXR1cm4gZmFsc2U7CiAgICB9OwoKICAgIGRvY3VtZW50LmJvZHkuaW5zZXJ0QmVmb3JlKHRvYywgZG9jdW1lbnQuYm9keS5maXJzdENoaWxkKTsKICAgIHJldHVybiB0b2M7CiAgfSwKCiAgaXNfc2hvd25fdG9jOiBmdW5jdGlvbiAoKSB7CiAgICByZXR1cm4gIXczY19zbGlkeS5oYXNfY2xhc3ModzNjX3NsaWR5LnRvYywgImhpZGRlbiIpOwogIH0sCgogIHNob3dfdGFibGVfb2ZfY29udGVudHM6IGZ1bmN0aW9uICgpIHsKICAgIHczY19zbGlkeS5yZW1vdmVfY2xhc3ModzNjX3NsaWR5LnRvYywgImhpZGRlbiIpOwogICAgdmFyIHRvYyA9IHczY19zbGlkeS50b2M7CiAgICB0b2MuZm9jdXMoKTsKCiAgICBpZiAodzNjX3NsaWR5LmllNyAmJiB3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyID09IDApCiAgICAgIHNldFRpbWVvdXQodzNjX3NsaWR5LmllX2hhY2ssIDEwMCk7CiAgfSwKCiAgaGlkZV90YWJsZV9vZl9jb250ZW50czogZnVuY3Rpb24gKGZvY3VzKSB7CiAgICB3M2Nfc2xpZHkuYWRkX2NsYXNzKHczY19zbGlkeS50b2MsICJoaWRkZW4iKTsKCiAgICBpZiAoZm9jdXMgJiYgIXczY19zbGlkeS5vcGVyYSAmJgogICAgICAgICF3M2Nfc2xpZHkuaGFzX2NsYXNzKHczY19zbGlkeS50b2MsICJoaWRkZW4iKSkKICAgICAgdzNjX3NsaWR5LnNldF9mb2N1cygpOwogIH0sCgogIHRvZ2dsZV90YWJsZV9vZl9jb250ZW50czogZnVuY3Rpb24gKCkgewogICAgaWYgKHczY19zbGlkeS5pc19zaG93bl90b2MoKSkKICAgICAgdzNjX3NsaWR5LmhpZGVfdGFibGVfb2ZfY29udGVudHModHJ1ZSk7CiAgICBlbHNlCiAgICAgIHczY19zbGlkeS5zaG93X3RhYmxlX29mX2NvbnRlbnRzKCk7CiAgfSwKCiAgLy8gY2FsbGVkIG9uIGNsaWNraW5nIHRvYyBlbnRyeQogIHRvY19jbGljazogZnVuY3Rpb24gKGUpIHsKICAgIGlmICghZSkKICAgICAgZSA9IHdpbmRvdy5ldmVudDsKCiAgICB2YXIgdGFyZ2V0ID0gdzNjX3NsaWR5LmdldF90YXJnZXQoZSk7CgogICAgaWYgKHRhcmdldCAmJiB0YXJnZXQubm9kZVR5cGUgPT0gMSkKICAgIHsKICAgICAgdmFyIHVyaSA9IHRhcmdldC5nZXRBdHRyaWJ1dGUoImhyZWYiKTsKCiAgICAgIGlmICh1cmkpCiAgICAgIHsKICAgICAgICAvL2FsZXJ0KCJnb2luZyB0byAiICsgdXJpKTsKICAgICAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgICAgIHczY19zbGlkeS5oaWRlX3NsaWRlKHNsaWRlKTsKICAgICAgICB3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyID0gdzNjX3NsaWR5LmZpbmRfc2xpZGVfbnVtYmVyKHVyaSk7CiAgICAgICAgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgICAgIHczY19zbGlkeS5sYXN0X3Nob3duID0gbnVsbDsKICAgICAgICB3M2Nfc2xpZHkuc2V0X2xvY2F0aW9uKCk7CiAgICAgICAgdzNjX3NsaWR5LnNldF92aXNpYmlsaXR5X2FsbF9pbmNyZW1lbnRhbCgiaGlkZGVuIik7CiAgICAgICAgdzNjX3NsaWR5LnNldF9lb3Nfc3RhdHVzKCF3M2Nfc2xpZHkubmV4dF9pbmNyZW1lbnRhbF9pdGVtKHczY19zbGlkeS5sYXN0X3Nob3duKSk7CiAgICAgICAgdzNjX3NsaWR5LnNob3dfc2xpZGUoc2xpZGUpOwogICAgICAgIC8vdGFyZ2V0LmZvY3VzKCk7CgogICAgICAgIHRyeQogICAgICAgIHsKICAgICAgICAgIGlmICghdzNjX3NsaWR5Lm9wZXJhKQogICAgICAgICAgICB3M2Nfc2xpZHkuc2V0X2ZvY3VzKCk7CiAgICAgICAgfQogICAgICAgIGNhdGNoIChlKQogICAgICAgIHsKICAgICAgICB9CiAgICAgIH0KICAgIH0KCiAgICB3M2Nfc2xpZHkuaGlkZV90YWJsZV9vZl9jb250ZW50cyh0cnVlKTsKICAgIGlmICh3M2Nfc2xpZHkuaWU3KSB3M2Nfc2xpZHkuaWVfaGFjaygpOwogICAgdzNjX3NsaWR5LnN0b3BfcHJvcGFnYXRpb24oZSk7CiAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChlKTsKICB9LAoKICAvLyBjYWxsZWQgb25rZXlkb3duIGZvciB0b2MgZW50cnkKICB0b2Nfa2V5X2Rvd246IGZ1bmN0aW9uIChldmVudCkgewogICAgdmFyIGtleTsKCiAgICBpZiAoIWV2ZW50KQogICAgICB2YXIgZXZlbnQgPSB3aW5kb3cuZXZlbnQ7CgogICAgLy8ga2x1ZGdlIGFyb3VuZCBOUy9JRSBkaWZmZXJlbmNlcyAKICAgIGlmICh3aW5kb3cuZXZlbnQpCiAgICAgIGtleSA9IHdpbmRvdy5ldmVudC5rZXlDb2RlOwogICAgZWxzZSBpZiAoZXZlbnQud2hpY2gpCiAgICAgIGtleSA9IGV2ZW50LndoaWNoOwogICAgZWxzZQogICAgICByZXR1cm4gdHJ1ZTsgLy8gWWlrZXMhIHVua25vd24gYnJvd3NlcgoKICAgIC8vIGlnbm9yZSBldmVudCBpZiBrZXkgdmFsdWUgaXMgemVybwogICAgLy8gYXMgZm9yIGFsdCBvbiBPcGVyYSBhbmQgS29ucXVlcm9yCiAgICBpZiAoIWtleSkKICAgICAgcmV0dXJuIHRydWU7CgogICAgLy8gY2hlY2sgZm9yIGNvbmN1cnJlbnQgY29udHJvbC9jb21tYW5kL2FsdCBrZXkKICAgIC8vIGJ1dCBhcmUgdGhlc2Ugb25seSBwcmVzZW50IG9uIG1vdXNlIGV2ZW50cz8KCiAgICBpZiAoZXZlbnQuY3RybEtleSB8fCBldmVudC5hbHRLZXkpCiAgICAgIHJldHVybiB0cnVlOwoKICAgIGlmIChrZXkgPT0gMTMpCiAgICB7CiAgICAgIHZhciB1cmkgPSB0aGlzLmdldEF0dHJpYnV0ZSgiaHJlZiIpOwoKICAgICAgaWYgKHVyaSkKICAgICAgewogICAgICAgIC8vYWxlcnQoImdvaW5nIHRvICIgKyB1cmkpOwogICAgICAgdmFyIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICB3M2Nfc2xpZHkuaGlkZV9zbGlkZShzbGlkZSk7CiAgICAgICAgdzNjX3NsaWR5LnNsaWRlX251bWJlciA9IHczY19zbGlkeS5maW5kX3NsaWRlX251bWJlcih1cmkpOwogICAgICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICB3M2Nfc2xpZHkubGFzdF9zaG93biA9IG51bGw7CiAgICAgICAgdzNjX3NsaWR5LnNldF9sb2NhdGlvbigpOwogICAgICAgIHczY19zbGlkeS5zZXRfdmlzaWJpbGl0eV9hbGxfaW5jcmVtZW50YWwoImhpZGRlbiIpOwogICAgICAgIHczY19zbGlkeS5zZXRfZW9zX3N0YXR1cyghdzNjX3NsaWR5Lm5leHRfaW5jcmVtZW50YWxfaXRlbSh3M2Nfc2xpZHkubGFzdF9zaG93bikpOwogICAgICAgIHczY19zbGlkeS5zaG93X3NsaWRlKHNsaWRlKTsKICAgICAgICAvL3RhcmdldC5mb2N1cygpOwoKICAgICAgICB0cnkKICAgICAgICB7CiAgICAgICAgICBpZiAoIXczY19zbGlkeS5vcGVyYSkKICAgICAgICAgICAgdzNjX3NsaWR5LnNldF9mb2N1cygpOwogICAgICAgIH0KICAgICAgICBjYXRjaCAoZSkKICAgICAgICB7CiAgICAgICAgfQogICAgICB9CgogICAgICB3M2Nfc2xpZHkuaGlkZV90YWJsZV9vZl9jb250ZW50cyh0cnVlKTsKCiAgICAgIGlmIChzZWxmLmllNykKICAgICAgIHczY19zbGlkeS5pZV9oYWNrKCk7CgogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CgogICAgaWYgKGtleSA9PSA0MCAmJiB0aGlzLm5leHQpCiAgICB7CiAgICAgIHRoaXMubmV4dC5mb2N1cygpOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CgogICAgaWYgKGtleSA9PSAzOCAmJiB0aGlzLnByZXZpb3VzKQogICAgewogICAgICB0aGlzLnByZXZpb3VzLmZvY3VzKCk7CiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KCiAgICByZXR1cm4gdHJ1ZTsKICB9LAoKICB0b3VjaHN0YXJ0OiBmdW5jdGlvbiAoZSkKICB7CiAgICAvLyBhIGRvdWJsZSB0b3VjaCBvZnRlbiBzdGFydHMgd2l0aCBhCiAgICAvLyBzaW5nbGUgdG91Y2ggZHVlIHRvIGZpbmdlcnMgdG91Y2hpbmcKICAgIC8vIGRvd24gYXQgc2xpZ2h0bHkgZGlmZmVyZW50IHRpbWVzCiAgICAvLyB0aHVzIGF2b2lkIGNhbGxpbmcgcHJldmVudERlZmF1bHQgaGVyZQogICAgdGhpcy5wcmV2X3RhcCA9IHRoaXMubGFzdF90YXA7CiAgICB0aGlzLmxhc3RfdGFwID0gKG5ldyBEYXRlKS5nZXRUaW1lKCk7CgogICAgdmFyIHRhcF9kZWxheSA9IHRoaXMubGFzdF90YXAgLSB0aGlzLnByZXZfdGFwOwoKICAgIGlmICh0YXBfZGVsYXkgPD0gMjAwKQogICAgewogICAgICAvLyBkb3VibGUgdGFwCiAgICB9CgogICAgdmFyIHRvdWNoID0gZS50b3VjaGVzWzBdOwoKICAgIHRoaXMucGFnZVggPSB0b3VjaC5wYWdlWDsKICAgIHRoaXMucGFnZVkgPSB0b3VjaC5wYWdlWTsKICAgIHRoaXMuc2NyZWVuWCA9IHRvdWNoLnNjcmVlblg7CiAgICB0aGlzLnNjcmVlblkgPSB0b3VjaC5zY3JlZW5ZOwogICAgdGhpcy5jbGllbnRYID0gdG91Y2guY2xpZW50WDsKICAgIHRoaXMuY2xpZW50WSA9IHRvdWNoLmNsaWVudFk7CgogICAgdGhpcy5kZWx0YV94ID0gdGhpcy5kZWx0YV95ID0gMDsKICB9LAoKICB0b3VjaG1vdmU6IGZ1bmN0aW9uIChlKQogIHsKICAgIC8vIG92ZXJyaWRlIG5hdGl2ZSBnZXN0dXJlcyBmb3Igc2luZ2xlIHRvdWNoCiAgICBpZiAoZS50b3VjaGVzLmxlbmd0aCA+IDEpCiAgICAgIHJldHVybjsKCiAgICBlLnByZXZlbnREZWZhdWx0KCk7CiAgICB2YXIgdG91Y2ggPSBlLnRvdWNoZXNbMF07CiAgICB0aGlzLmRlbHRhX3ggPSB0b3VjaC5wYWdlWCAtIHRoaXMucGFnZVg7CiAgICB0aGlzLmRlbHRhX3kgPSB0b3VjaC5wYWdlWSAtIHRoaXMucGFnZVk7CiAgfSwKCiAgdG91Y2hlbmQ6IGZ1bmN0aW9uIChlKQogIHsKICAgIC8vIGRlZmF1bHQgYmVoYXZpb3IgZm9yIG11bHRpLXRvdWNoCiAgICBpZiAoZS50b3VjaGVzLmxlbmd0aCA+IDEpCiAgICAgIHJldHVybjsKCiAgICB2YXIgZGVsYXkgPSAobmV3IERhdGUpLmdldFRpbWUoKSAtIHRoaXMubGFzdF90YXA7CiAgICB2YXIgZHggPSB0aGlzLmRlbHRhX3g7CiAgICB2YXIgZHkgPSB0aGlzLmRlbHRhX3k7CiAgICB2YXIgYWJzX2R4ID0gTWF0aC5hYnMoZHgpOwogICAgdmFyIGFic19keSA9IE1hdGguYWJzKGR5KTsKCiAgICBpZiAoZGVsYXkgPCA1MDAgJiYgKGFic19keCA+IDEwMCB8fCBhYnNfZHkgPiAxMDApKQogICAgewogICAgICBpZiAoYWJzX2R4ID4gMC41ICogYWJzX2R5KQogICAgICB7CiAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpOwoKICAgICAgICBpZiAoZHggPCAwKQogICAgICAgICAgdzNjX3NsaWR5Lm5leHRfc2xpZGUodHJ1ZSk7CiAgICAgICAgZWxzZQogICAgICAgICAgdzNjX3NsaWR5LnByZXZpb3VzX3NsaWRlKHRydWUpOwogICAgICB9CiAgICAgIGVsc2UgaWYgKGFic19keSA+IDIgKiBhYnNfZHgpCiAgICAgIHsKICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7CiAgICAgICAgdzNjX3NsaWR5LnRvZ2dsZV90YWJsZV9vZl9jb250ZW50cygpOwogICAgICB9CiAgICB9CiAgfSwKCiAgLy8gIyMjIE9CU09MRVRFICMjIwogIGJlZm9yZV9wcmludDogZnVuY3Rpb24gKCkgewogICAgdGhpcy5zaG93X2FsbF9zbGlkZXMoKTsKICAgIHRoaXMuaGlkZV90b29sYmFyKCk7CiAgICBhbGVydCgiYmVmb3JlIHByaW50Iik7CiAgfSwKCiAgLy8gIyMjIE9CU09MRVRFICMjIwogIGFmdGVyX3ByaW50OiBmdW5jdGlvbiAoKSB7CiAgICBpZiAoIXRoaXMudmlld19hbGwpCiAgICB7CiAgICAgIHRoaXMuc2luZ2xlX3NsaWRlX3ZpZXcoKTsKICAgICAgdGhpcy5zaG93X3Rvb2xiYXIoKTsKICAgIH0KICAgIGFsZXJ0KCJhZnRlciBwcmludCIpOwogIH0sCgogIC8vICMjIyBPQlNPTEVURSAjIyMKICBwcmludF9zbGlkZXM6IGZ1bmN0aW9uICgpIHsKICAgIHRoaXMuYmVmb3JlX3ByaW50KCk7CiAgICB3aW5kb3cucHJpbnQoKTsKICAgIHRoaXMuYWZ0ZXJfcHJpbnQoKTsKICB9LAoKICAvLyAjIyMgT0JTT0xFVEUgPz8gIyMjCiAgdG9nZ2xlX3ZpZXc6IGZ1bmN0aW9uICgpIHsKICAgIGlmICh0aGlzLnZpZXdfYWxsKQogICAgewogICAgICB0aGlzLnNpbmdsZV9zbGlkZV92aWV3KCk7CiAgICAgIHRoaXMuc2hvd190b29sYmFyKCk7CiAgICAgIHRoaXMudmlld19hbGwgPSAwOwogICAgfQogICAgZWxzZQogICAgewogICAgICB0aGlzLnNob3dfYWxsX3NsaWRlcygpOwogICAgICB0aGlzLmhpZGVfdG9vbGJhcigpOwogICAgICB0aGlzLnZpZXdfYWxsID0gMTsKICAgIH0KICB9LAoKICAvLyBwcmVwYXJlIGZvciBwcmludGluZyAgIyMjIE9CU09MRVRFICMjIwogIHNob3dfYWxsX3NsaWRlczogZnVuY3Rpb24gKCkgewogICAgdGhpcy5yZW1vdmVfY2xhc3MoZG9jdW1lbnQuYm9keSwgInNpbmdsZV9zbGlkZSIpOwogICAgdGhpcy5zZXRfdmlzaWJpbGl0eV9hbGxfaW5jcmVtZW50YWwoInZpc2libGUiKTsKICB9LAoKICAvLyByZXN0b3JlIGFmdGVyIHByaW50aW5nICAjIyMgT0JTT0xFVEUgIyMjCiAgc2luZ2xlX3NsaWRlX3ZpZXc6IGZ1bmN0aW9uICgpIHsKICAgIHRoaXMuYWRkX2NsYXNzKGRvY3VtZW50LmJvZHksICJzaW5nbGVfc2xpZGUiKTsKICAgIHRoaXMuc2V0X3Zpc2liaWxpdHlfYWxsX2luY3JlbWVudGFsKCJ2aXNpYmxlIik7CiAgICB0aGlzLmxhc3Rfc2hvd24gPSB0aGlzLnByZXZpb3VzX2luY3JlbWVudGFsX2l0ZW0obnVsbCk7CiAgfSwKCiAgLy8gc3VwcHJlc3MgSUUncyBpbWFnZSB0b29sYmFyIHBvcCB1cAogIGhpZGVfaW1hZ2VfdG9vbGJhcjogZnVuY3Rpb24gKCkgewogICAgaWYgKCF0aGlzLm5zX3BvcykKICAgIHsKICAgICAgdmFyIGltYWdlcyA9IGRvY3VtZW50LmdldEVsZW1lbnRzQnlUYWdOYW1lKCJJTUciKTsKCiAgICAgIGZvciAodmFyIGkgPSAwOyBpIDwgaW1hZ2VzLmxlbmd0aDsgKytpKQogICAgICAgIGltYWdlc1tpXS5zZXRBdHRyaWJ1dGUoImdhbGxlcnlpbWciLCAibm8iKTsKICAgIH0KICB9LAoKICB1bmxvYWRlZDogZnVuY3Rpb24gKGUpIHsKICAgIC8vYWxlcnQoInVubG9hZGVkIik7CiAgfSwKCiAgLy8gU2FmYXJpIGFuZCBLb25xdWVyb3IgZG9uJ3QgeWV0IHN1cHBvcnQgZ2V0Q29tcHV0ZWRTdHlsZSgpCiAgLy8gYW5kIHRoZXkgYWx3YXlzIHJlbG9hZCBwYWdlIHdoZW4gbG9jYXRpb24uaHJlZiBpcyB1cGRhdGVkCiAgaXNfS0hUTUw6IGZ1bmN0aW9uICgpIHsKICAgIHZhciBhZ2VudCA9IG5hdmlnYXRvci51c2VyQWdlbnQ7CiAgICByZXR1cm4gKGFnZW50LmluZGV4T2YoIktIVE1MIikgPj0gMCA/IHRydWUgOiBmYWxzZSk7CiAgfSwKCiAgLy8gZmluZCBzbGlkZSBuYW1lIGZyb20gZmlyc3QgaDEgZWxlbWVudAogIC8vIGRlZmF1bHQgdG8gZG9jdW1lbnQgdGl0bGUgKyBzbGlkZSBudW1iZXIKICBzbGlkZV9uYW1lOiBmdW5jdGlvbiAoaW5kZXgpIHsKICAgIHZhciBuYW1lID0gbnVsbDsKICAgIHZhciBzbGlkZSA9IHRoaXMuc2xpZGVzW2luZGV4XTsKCiAgICB2YXIgaGVhZGluZyA9IHRoaXMuZmluZF9oZWFkaW5nKHNsaWRlKTsKCiAgICBpZiAoaGVhZGluZykKICAgICAgbmFtZSA9IHRoaXMuZXh0cmFjdF90ZXh0KGhlYWRpbmcpOwoKICAgIGlmICghbmFtZSkKICAgICAgbmFtZSA9IHRoaXMudGl0bGUgKyAiKCIgKyAoaW5kZXggKyAxKSArICIpIjsKCiAgICBuYW1lLnJlcGxhY2UoL1wmL2csICImYW1wOyIpOwogICAgbmFtZS5yZXBsYWNlKC9cPC9nLCAiJmx0OyIpOwogICAgbmFtZS5yZXBsYWNlKC9cPi9nLCAiJmd0OyIpOwoKICAgIHJldHVybiBuYW1lOwogIH0sCgogIC8vIGZpbmQgZmlyc3QgaDEgZWxlbWVudCBpbiBET00gdHJlZQogIGZpbmRfaGVhZGluZzogZnVuY3Rpb24gKG5vZGUpIHsKICAgIGlmICghbm9kZSB8fCBub2RlLm5vZGVUeXBlICE9IDEpCiAgICAgIHJldHVybiBudWxsOwoKICAgIGlmIChub2RlLm5vZGVOYW1lID09ICJIMSIgfHwgbm9kZS5ub2RlTmFtZSA9PSAiaDEiKQogICAgICByZXR1cm4gbm9kZTsKCiAgICB2YXIgY2hpbGQgPSBub2RlLmZpcnN0Q2hpbGQ7CgogICAgd2hpbGUgKGNoaWxkKQogICAgewogICAgICBub2RlID0gdGhpcy5maW5kX2hlYWRpbmcoY2hpbGQpOwoKICAgICAgaWYgKG5vZGUpCiAgICAgICAgcmV0dXJuIG5vZGU7CgogICAgICBjaGlsZCA9IGNoaWxkLm5leHRTaWJsaW5nOwogICAgfQoKICAgIHJldHVybiBudWxsOwogIH0sCgogIC8vIHJlY3Vyc2l2ZWx5IGV4dHJhY3QgdGV4dCBmcm9tIERPTSB0cmVlCiAgZXh0cmFjdF90ZXh0OiBmdW5jdGlvbiAobm9kZSkgewogICAgaWYgKCFub2RlKQogICAgICByZXR1cm4gIiI7CgogICAgLy8gdGV4dCBub2RlcwogICAgaWYgKG5vZGUubm9kZVR5cGUgPT0gMykKICAgICAgcmV0dXJuIG5vZGUubm9kZVZhbHVlOwoKICAgIC8vIGVsZW1lbnRzCiAgICBpZiAobm9kZS5ub2RlVHlwZSA9PSAxKQogICAgewogICAgICBub2RlID0gbm9kZS5maXJzdENoaWxkOwogICAgICB2YXIgdGV4dCA9ICIiOwoKICAgICAgd2hpbGUgKG5vZGUpCiAgICAgIHsKICAgICAgICB0ZXh0ID0gdGV4dCArIHRoaXMuZXh0cmFjdF90ZXh0KG5vZGUpOwogICAgICAgIG5vZGUgPSBub2RlLm5leHRTaWJsaW5nOwogICAgICB9CgogICAgICByZXR1cm4gdGV4dDsKICAgIH0KCiAgICByZXR1cm4gIiI7CiAgfSwKCiAgLy8gZmluZCBjb3B5cmlnaHQgdGV4dCBmcm9tIG1ldGEgZWxlbWVudAogIGZpbmRfY29weXJpZ2h0OiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgbmFtZSwgY29udGVudDsKICAgIHZhciBtZXRhID0gZG9jdW1lbnQuZ2V0RWxlbWVudHNCeVRhZ05hbWUoIm1ldGEiKTsKCiAgICBmb3IgKHZhciBpID0gMDsgaSA8IG1ldGEubGVuZ3RoOyArK2kpCiAgICB7CiAgICAgIG5hbWUgPSBtZXRhW2ldLmdldEF0dHJpYnV0ZSgibmFtZSIpOwogICAgICBjb250ZW50ID0gbWV0YVtpXS5nZXRBdHRyaWJ1dGUoImNvbnRlbnQiKTsKCiAgICAgIGlmIChuYW1lID09ICJjb3B5cmlnaHQiKQogICAgICAgIHJldHVybiBjb250ZW50OwogICAgfQoKICAgIHJldHVybiBudWxsOwogIH0sCgogIGZpbmRfc2l6ZV9hZGp1c3Q6IGZ1bmN0aW9uICgpIHsKICAgIHZhciBuYW1lLCBjb250ZW50LCBvZmZzZXQ7CiAgICB2YXIgbWV0YSA9IGRvY3VtZW50LmdldEVsZW1lbnRzQnlUYWdOYW1lKCJtZXRhIik7CgogICAgZm9yICh2YXIgaSA9IDA7IGkgPCBtZXRhLmxlbmd0aDsgKytpKQogICAgewogICAgICBuYW1lID0gbWV0YVtpXS5nZXRBdHRyaWJ1dGUoIm5hbWUiKTsKICAgICAgY29udGVudCA9IG1ldGFbaV0uZ2V0QXR0cmlidXRlKCJjb250ZW50Iik7CgogICAgICBpZiAobmFtZSA9PSAiZm9udC1zaXplLWFkanVzdG1lbnQiKQogICAgICAgIHJldHVybiAxICogY29udGVudDsKICAgIH0KCiAgICByZXR1cm4gMTsKICB9LAoKICAvLyA8bWV0YSBuYW1lPSJkdXJhdGlvbiIgY29udGVudD0iMjAiIC8+ICBmb3IgMjAgbWludXRlcwogIGZpbmRfZHVyYXRpb246IGZ1bmN0aW9uICgpIHsKICAgIHZhciBuYW1lLCBjb250ZW50LCBvZmZzZXQ7CiAgICB2YXIgbWV0YSA9IGRvY3VtZW50LmdldEVsZW1lbnRzQnlUYWdOYW1lKCJtZXRhIik7CgogICAgZm9yICh2YXIgaSA9IDA7IGkgPCBtZXRhLmxlbmd0aDsgKytpKQogICAgewogICAgICBuYW1lID0gbWV0YVtpXS5nZXRBdHRyaWJ1dGUoIm5hbWUiKTsKICAgICAgY29udGVudCA9IG1ldGFbaV0uZ2V0QXR0cmlidXRlKCJjb250ZW50Iik7CgogICAgICBpZiAobmFtZSA9PSAiZHVyYXRpb24iKQogICAgICAgIHJldHVybiA2MDAwMCAqIGNvbnRlbnQ7CiAgICB9CgogICAgcmV0dXJuIG51bGw7CiAgfSwKCiAgcmVwbGFjZV9ieV9ub25fYnJlYWtpbmdfc3BhY2U6IGZ1bmN0aW9uIChzdHIpIHsKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgc3RyLmxlbmd0aDsgKytpKQogICAgICBzdHJbaV0gPSAxNjA7CiAgfSwKCiAgLy8gIyMjIENIRUNLIE1FICMjIyBpcyB1c2Ugb2YgImxpIiBva2F5IGZvciB0ZXh0L2h0bWw/CiAgLy8gZm9yIFhIVE1MIGRvIHdlIGFsc28gbmVlZCB0byBzcGVjaWZ5IG5hbWVzcGFjZT8KICBpbml0X291dGxpbmVyOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgaXRlbXMgPSBkb2N1bWVudC5nZXRFbGVtZW50c0J5VGFnTmFtZSgibGkiKTsKCiAgICBmb3IgKHZhciBpID0gMDsgaSA8IGl0ZW1zLmxlbmd0aDsgKytpKQogICAgewogICAgICB2YXIgdGFyZ2V0ID0gaXRlbXNbaV07CgogICAgICBpZiAoIXRoaXMuaGFzX2NsYXNzKHRhcmdldC5wYXJlbnROb2RlLCAib3V0bGluZSIpKQogICAgICAgIGNvbnRpbnVlOwoKICAgICAgdGFyZ2V0Lm9uY2xpY2sgPSB0aGlzLm91dGxpbmVfY2xpY2s7Ci8qICMjIyBtb3JlIHdvcmsgbmVlZGVkIGZvciBJRTYKICAgICAgaWYgKCF0aGlzLm5zX3BvcykKICAgICAgewogICAgICAgIHRhcmdldC5vbm1vdXNlb3ZlciA9IHRoaXMuaG92ZXJfb3V0bGluZTsKICAgICAgICB0YXJnZXQub25tb3VzZW91dCA9IHRoaXMudW5ob3Zlcl9vdXRsaW5lOwogICAgICB9CiovCiAgICAgIGlmICh0aGlzLmZvbGRhYmxlKHRhcmdldCkpCiAgICAgIHsKICAgICAgICB0YXJnZXQuZm9sZGFibGUgPSB0cnVlOwogICAgICAgIHRhcmdldC5vbmZvY3VzID0gZnVuY3Rpb24gKCkge3czY19zbGlkeS5vdXRsaW5lID0gdGhpczt9OwogICAgICAgIHRhcmdldC5vbmJsdXIgPSBmdW5jdGlvbiAoKSB7dzNjX3NsaWR5Lm91dGxpbmUgPSBudWxsO307CgogICAgICAgIGlmICghdGFyZ2V0LmdldEF0dHJpYnV0ZSgidGFiaW5kZXgiKSkKICAgICAgICAgIHRhcmdldC5zZXRBdHRyaWJ1dGUoInRhYmluZGV4IiwgIjAiKTsKCiAgICAgICAgaWYgKHRoaXMuaGFzX2NsYXNzKHRhcmdldCwgImV4cGFuZCIpKQogICAgICAgICAgdGhpcy51bmZvbGQodGFyZ2V0KTsKICAgICAgICBlbHNlCiAgICAgICAgICB0aGlzLmZvbGQodGFyZ2V0KTsKICAgICAgfQogICAgICBlbHNlCiAgICAgIHsKICAgICAgICB0aGlzLmFkZF9jbGFzcyh0YXJnZXQsICJub2ZvbGQiKTsKICAgICAgICB0YXJnZXQudmlzaWJsZSA9IHRydWU7CiAgICAgICAgdGFyZ2V0LmZvbGRhYmxlID0gZmFsc2U7CiAgICAgIH0KICAgIH0KICB9LAoKICBmb2xkYWJsZTogZnVuY3Rpb24gKGl0ZW0pIHsKICAgIGlmICghaXRlbSB8fCBpdGVtLm5vZGVUeXBlICE9IDEpCiAgICAgIHJldHVybiBmYWxzZTsKCiAgICB2YXIgbm9kZSA9IGl0ZW0uZmlyc3RDaGlsZDsKCiAgICB3aGlsZSAobm9kZSkKICAgIHsKICAgICAgaWYgKG5vZGUubm9kZVR5cGUgPT0gMSAmJiB0aGlzLmlzX2Jsb2NrKG5vZGUpKQogICAgICAgIHJldHVybiB0cnVlOwoKICAgICAgbm9kZSA9IG5vZGUubmV4dFNpYmxpbmc7CiAgICB9CgogICAgcmV0dXJuIGZhbHNlOwogIH0sCgogIC8vICMjIyBDSEVDSyBNRSAjIyMgc3dpdGNoIHRvIGFkZC9yZW1vdmUgImhpZGRlbiIgY2xhc3MKICBmb2xkOiBmdW5jdGlvbiAoaXRlbSkgewogICAgaWYgKGl0ZW0pCiAgICB7CiAgICAgIHRoaXMucmVtb3ZlX2NsYXNzKGl0ZW0sICJ1bmZvbGRlZCIpOwogICAgICB0aGlzLmFkZF9jbGFzcyhpdGVtLCAiZm9sZGVkIik7CiAgICB9CgogICAgdmFyIG5vZGUgPSBpdGVtID8gaXRlbS5maXJzdENoaWxkIDogbnVsbDsKCiAgICB3aGlsZSAobm9kZSkKICAgIHsKICAgICAgaWYgKG5vZGUubm9kZVR5cGUgPT0gMSAmJiB0aGlzLmlzX2Jsb2NrKG5vZGUpKSAvLyBlbGVtZW50CiAgICAgIHsKICAgICAgICAgdzNjX3NsaWR5LmFkZF9jbGFzcyhub2RlLCAiaGlkZGVuIik7CiAgICAgIH0KCiAgICAgIG5vZGUgPSBub2RlLm5leHRTaWJsaW5nOwogICAgfQoKICAgIGl0ZW0udmlzaWJsZSA9IGZhbHNlOwogIH0sCgogIC8vICMjIyBDSEVDSyBNRSAjIyMgc3dpdGNoIHRvIGFkZC9yZW1vdmUgImhpZGRlbiIgY2xhc3MKICB1bmZvbGQ6IGZ1bmN0aW9uIChpdGVtKSB7CiAgICBpZiAoaXRlbSkKICAgIHsKICAgICAgdGhpcy5hZGRfY2xhc3MoaXRlbSwgInVuZm9sZGVkIik7CiAgICAgIHRoaXMucmVtb3ZlX2NsYXNzKGl0ZW0sICJmb2xkZWQiKTsKICAgIH0KCiAgICB2YXIgbm9kZSA9IGl0ZW0gPyBpdGVtLmZpcnN0Q2hpbGQgOiBudWxsOwoKICAgIHdoaWxlIChub2RlKQogICAgewogICAgICBpZiAobm9kZS5ub2RlVHlwZSA9PSAxICYmIHRoaXMuaXNfYmxvY2sobm9kZSkpIC8vIGVsZW1lbnQKICAgICAgewogICAgICAgIHczY19zbGlkeS5yZW1vdmVfY2xhc3Mobm9kZSwgImhpZGRlbiIpOwogICAgICB9CgogICAgICBub2RlID0gbm9kZS5uZXh0U2libGluZzsKICAgIH0KCiAgICBpdGVtLnZpc2libGUgPSB0cnVlOwogIH0sCgogIG91dGxpbmVfY2xpY2s6IGZ1bmN0aW9uIChlKSB7CiAgICBpZiAoIWUpCiAgICAgIGUgPSB3aW5kb3cuZXZlbnQ7CgogICAgdmFyIHJpZ2h0Y2xpY2sgPSBmYWxzZTsKICAgIHZhciB0YXJnZXQgPSB3M2Nfc2xpZHkuZ2V0X3RhcmdldChlKTsKCiAgICB3aGlsZSAodGFyZ2V0ICYmIHRhcmdldC52aXNpYmxlID09IHVuZGVmaW5lZCkKICAgICAgdGFyZ2V0ID0gdGFyZ2V0LnBhcmVudE5vZGU7CgogICAgaWYgKCF0YXJnZXQpCiAgICAgIHJldHVybiB0cnVlOwoKICAgIGlmIChlLndoaWNoKQogICAgICByaWdodGNsaWNrID0gKGUud2hpY2ggPT0gMyk7CiAgICBlbHNlIGlmIChlLmJ1dHRvbikKICAgICAgcmlnaHRjbGljayA9IChlLmJ1dHRvbiA9PSAyKTsKCiAgICBpZiAoIXJpZ2h0Y2xpY2sgJiYgdGFyZ2V0LnZpc2libGUgIT0gdW5kZWZpbmVkKQogICAgewogICAgICBpZiAodGFyZ2V0LmZvbGRhYmxlKQogICAgICB7CiAgICAgICAgaWYgKHRhcmdldC52aXNpYmxlKQogICAgICAgICAgdzNjX3NsaWR5LmZvbGQodGFyZ2V0KTsKICAgICAgICBlbHNlCiAgICAgICAgICB3M2Nfc2xpZHkudW5mb2xkKHRhcmdldCk7CiAgICAgIH0KCiAgICAgIHczY19zbGlkeS5zdG9wX3Byb3BhZ2F0aW9uKGUpOwogICAgICBlLmNhbmNlbCA9IHRydWU7CiAgICAgIGUucmV0dXJuVmFsdWUgPSBmYWxzZTsKICAgIH0KCiAgICByZXR1cm4gZmFsc2U7CiAgfSwKCiAgYWRkX2luaXRpYWxfcHJvbXB0OiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgcHJvbXB0ID0gdGhpcy5jcmVhdGVfZWxlbWVudCgiZGl2Iik7CiAgICBwcm9tcHQuc2V0QXR0cmlidXRlKCJjbGFzcyIsICJpbml0aWFsX3Byb21wdCIpOwoKICAgIHZhciBwMSA9IHRoaXMuY3JlYXRlX2VsZW1lbnQoInAiKTsKICAgIHByb21wdC5hcHBlbmRDaGlsZChwMSk7CiAgICBwMS5zZXRBdHRyaWJ1dGUoImNsYXNzIiwgImhlbHAiKTsKCiAgICBpZiAodGhpcy5rZXlib2FyZGxlc3MpCiAgICAgIHAxLmlubmVySFRNTCA9ICJzd2lwZSBsZWZ0IHRvIG1vdmUgdG8gbmV4dCBzbGlkZSI7CiAgICBlbHNlCiAgICAgIHAxLmlubmVySFRNTCA9ICJTcGFjZSwgUmlnaHQgQXJyb3cgb3Igc3dpcGUgbGVmdCB0byBtb3ZlIHRvICIgKwogICAgICAgICAgICAgICAgICAgICAibmV4dCBzbGlkZSwgY2xpY2sgaGVscCBiZWxvdyBmb3IgbW9yZSBkZXRhaWxzIjsKCiAgICB0aGlzLmFkZF9saXN0ZW5lcihwcm9tcHQsICJjbGljayIsIGZ1bmN0aW9uIChlKSB7CiAgICAgIGRvY3VtZW50LmJvZHkucmVtb3ZlQ2hpbGQocHJvbXB0KTsKICAgICAgdzNjX3NsaWR5LnN0b3BfcHJvcGFnYXRpb24oZSk7CiAgICAKICAgICAgaWYgKGUuY2FuY2VsICE9IHVuZGVmaW5lZCkKICAgICAgICBlLmNhbmNlbCA9IHRydWU7CiAgICAgIAogICAgICBpZiAoZS5yZXR1cm5WYWx1ZSAhPSB1bmRlZmluZWQpCiAgICAgICAgZS5yZXR1cm5WYWx1ZSA9IGZhbHNlOwogICAgICAKICAgICAgcmV0dXJuIGZhbHNlOwogICAgfSk7CgogICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChwcm9tcHQpOwogICAgdGhpcy5pbml0aWFsX3Byb21wdCA9IHByb21wdDsKICAgIHNldFRpbWVvdXQoZnVuY3Rpb24oKSB7ZG9jdW1lbnQuYm9keS5yZW1vdmVDaGlsZChwcm9tcHQpO30sIDUwMDApOwogIH0sCgogIGFkZF90b29sYmFyOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgY291bnRlciwgcGFnZTsKCiAgICAgdGhpcy50b29sYmFyID0gdGhpcy5jcmVhdGVfZWxlbWVudCgiZGl2Iik7CiAgICAgdGhpcy50b29sYmFyLnNldEF0dHJpYnV0ZSgiY2xhc3MiLCAidG9vbGJhciIpOwoKICAgICAvLyBhIHJlYXNvbmFibHkgYmVoYXZlZCBicm93c2VyCiAgICAgaWYgKHRoaXMubnNfcG9zIHx8ICF0aGlzLmllNikKICAgICB7CiAgICAgICB2YXIgcmlnaHQgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJkaXYiKTsKICAgICAgIHJpZ2h0LnNldEF0dHJpYnV0ZSgic3R5bGUiLCAiZmxvYXQ6IHJpZ2h0OyB0ZXh0LWFsaWduOiByaWdodCIpOwoKICAgICAgIGNvdW50ZXIgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJzcGFuIikKICAgICAgIGNvdW50ZXIuaW5uZXJIVE1MID0gdGhpcy5sb2NhbGl6ZSgic2xpZGUiKSArICIgbi9tIjsKICAgICAgIHJpZ2h0LmFwcGVuZENoaWxkKGNvdW50ZXIpOwogICAgICAgdGhpcy50b29sYmFyLmFwcGVuZENoaWxkKHJpZ2h0KTsKCiAgICAgICB2YXIgbGVmdCA9IHRoaXMuY3JlYXRlX2VsZW1lbnQoImRpdiIpOwogICAgICAgbGVmdC5zZXRBdHRyaWJ1dGUoInN0eWxlIiwgInRleHQtYWxpZ246IGxlZnQiKTsKCiAgICAgICAvLyBnbG9iYWwgZW5kIG9mIHNsaWRlIGluZGljYXRvcgogICAgICAgdGhpcy5lb3MgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJzcGFuIik7CiAgICAgICB0aGlzLmVvcy5pbm5lckhUTUwgPSAiKiAiOwogICAgICAgbGVmdC5hcHBlbmRDaGlsZCh0aGlzLmVvcyk7CgogICAgICAgdmFyIGhlbHAgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJhIik7CiAgICAgICBoZWxwLnNldEF0dHJpYnV0ZSgiaHJlZiIsIHRoaXMuaGVscF9wYWdlKTsKICAgICAgIGhlbHAuc2V0QXR0cmlidXRlKCJ0aXRsZSIsIHRoaXMubG9jYWxpemUodGhpcy5oZWxwX3RleHQpKTsKICAgICAgIGhlbHAuaW5uZXJIVE1MID0gdGhpcy5sb2NhbGl6ZSgiaGVscD8iKTsKICAgICAgIGxlZnQuYXBwZW5kQ2hpbGQoaGVscCk7CiAgICAgICBoZWxwLnN0eWxlLmRpc3BsYXk9Im5vbmUiOyAKICAgICAgIHRoaXMuaGVscF9hbmNob3IgPSBoZWxwOyAgLy8gc2F2ZSBmb3IgZm9jdXMgaGFjawoKICAgICAgIHZhciBnYXAxID0gZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoIiAiKTsKICAgICAgIGxlZnQuYXBwZW5kQ2hpbGQoZ2FwMSk7CgogICAgICAgdmFyIGNvbnRlbnRzID0gdGhpcy5jcmVhdGVfZWxlbWVudCgiYSIpOwogICAgICAgY29udGVudHMuc2V0QXR0cmlidXRlKCJocmVmIiwgImphdmFzY3JpcHQ6dzNjX3NsaWR5LnRvZ2dsZV90YWJsZV9vZl9jb250ZW50cygpIik7CiAgICAgICBjb250ZW50cy5zZXRBdHRyaWJ1dGUoInRpdGxlIiwgdGhpcy5sb2NhbGl6ZSgidGFibGUgb2YgY29udGVudHMiKSk7CiAgICAgICBjb250ZW50cy5pbm5lckhUTUwgPSB0aGlzLmxvY2FsaXplKCJDb250ZW50cyIpOwogICAgICAgbGVmdC5hcHBlbmRDaGlsZChjb250ZW50cyk7CgogICAgICAgdmFyIGdhcDIgPSBkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZSgiICIpOwogICAgICAgbGVmdC5hcHBlbmRDaGlsZChnYXAyKTsKCiAgICAgICB2YXIgY29weXJpZ2h0ID0gdGhpcy5maW5kX2NvcHlyaWdodCgpOwoKICAgICAgIGlmIChjb3B5cmlnaHQpCiAgICAgICB7CiAgICAgICAgIHZhciBzcGFuID0gdGhpcy5jcmVhdGVfZWxlbWVudCgic3BhbiIpOwogICAgICAgICBzcGFuLmNsYXNzTmFtZSA9ICJjb3B5cmlnaHQiOwogICAgICAgICBzcGFuLmlubmVySFRNTCA9IGNvcHlyaWdodDsKICAgICAgICAgbGVmdC5hcHBlbmRDaGlsZChzcGFuKTsKICAgICAgIH0KCiAgICAgICB0aGlzLnRvb2xiYXIuc2V0QXR0cmlidXRlKCJ0YWJpbmRleCIsICIwIik7CiAgICAgICB0aGlzLnRvb2xiYXIuYXBwZW5kQ2hpbGQobGVmdCk7CiAgICAgfQogICAgIGVsc2UgLy8gSUU2IHNvIG5lZWQgdG8gd29yayBhcm91bmQgaXRzIHBvb3IgQ1NTIHN1cHBvcnQKICAgICB7CiAgICAgICB0aGlzLnRvb2xiYXIuc3R5bGUucG9zaXRpb24gPSAodGhpcy5pZTcgPyAiZml4ZWQiIDogImFic29sdXRlIik7CiAgICAgICB0aGlzLnRvb2xiYXIuc3R5bGUuekluZGV4ID0gIjIwMCI7CiAgICAgICB0aGlzLnRvb2xiYXIuc3R5bGUud2lkdGggPSAiOTkuOSUiOwogICAgICAgdGhpcy50b29sYmFyLnN0eWxlLmhlaWdodCA9ICIxLjJlbSI7CiAgICAgICB0aGlzLnRvb2xiYXIuc3R5bGUudG9wID0gImF1dG8iOwogICAgICAgdGhpcy50b29sYmFyLnN0eWxlLmJvdHRvbSA9ICIwIjsKICAgICAgIHRoaXMudG9vbGJhci5zdHlsZS5sZWZ0ID0gIjAiOwogICAgICAgdGhpcy50b29sYmFyLnN0eWxlLnJpZ2h0ID0gIjAiOwogICAgICAgdGhpcy50b29sYmFyLnN0eWxlLnRleHRBbGlnbiA9ICJsZWZ0IjsKICAgICAgIHRoaXMudG9vbGJhci5zdHlsZS5mb250U2l6ZSA9ICI2MCUiOwogICAgICAgdGhpcy50b29sYmFyLnN0eWxlLmNvbG9yID0gInJlZCI7CiAgICAgICB0aGlzLnRvb2xiYXIuYm9yZGVyV2lkdGggPSAwOwogICAgICAgdGhpcy50b29sYmFyLmNsYXNzTmFtZSA9ICJ0b29sYmFyIjsKICAgICAgIHRoaXMudG9vbGJhci5zdHlsZS5iYWNrZ3JvdW5kID0gInJnYigyNDAsMjQwLDI0MCkiOwoKICAgICAgIC8vIHdvdWxkIGxpa2UgdG8gaGF2ZSBoZWxwIHRleHQgbGVmdCBhbGlnbmVkCiAgICAgICAvLyBhbmQgcGFnZSBjb3VudGVyIHJpZ2h0IGFsaWduZWQsIGZsb2F0aW5nCiAgICAgICAvLyBkaXYncyBkb24ndCB3b3JrLCBzbyBpbnN0ZWFkIHVzZSBuZXN0ZWQKICAgICAgIC8vIGFic29sdXRlbHkgcG9zaXRpb25lZCBkaXYncy4KCiAgICAgICB2YXIgc3AgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJzcGFuIik7CiAgICAgICBzcC5pbm5lckhUTUwgPSAiJm5ic3A7Jm5ic3A7KiZuYnNwOyI7CiAgICAgICB0aGlzLnRvb2xiYXIuYXBwZW5kQ2hpbGQoc3ApOwogICAgICAgdGhpcy5lb3MgPSBzcDsgIC8vIGVuZCBvZiBzbGlkZSBpbmRpY2F0b3IKCiAgICAgICB2YXIgaGVscCA9IHRoaXMuY3JlYXRlX2VsZW1lbnQoImEiKTsKICAgICAgIGhlbHAuc2V0QXR0cmlidXRlKCJocmVmIiwgdGhpcy5oZWxwX3BhZ2UpOwogICAgICAgaGVscC5zZXRBdHRyaWJ1dGUoInRpdGxlIiwgdGhpcy5sb2NhbGl6ZSh0aGlzLmhlbHBfdGV4dCkpOwogICAgICAgaGVscC5pbm5lckhUTUwgPSB0aGlzLmxvY2FsaXplKCJoZWxwPyIpOwogICAgICAgdGhpcy50b29sYmFyLmFwcGVuZENoaWxkKGhlbHApOwogICAgICAgdGhpcy5oZWxwX2FuY2hvciA9IGhlbHA7ICAvLyBzYXZlIGZvciBmb2N1cyBoYWNrCgogICAgICAgdmFyIGdhcDEgPSBkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZSgiICIpOwogICAgICAgdGhpcy50b29sYmFyLmFwcGVuZENoaWxkKGdhcDEpOwoKICAgICAgIHZhciBjb250ZW50cyA9IHRoaXMuY3JlYXRlX2VsZW1lbnQoImEiKTsKICAgICAgIGNvbnRlbnRzLnNldEF0dHJpYnV0ZSgiaHJlZiIsICJqYXZhc2NyaXB0OnRvZ2dsZVRhYmxlT2ZDb250ZW50cygpIik7CiAgICAgICBjb250ZW50cy5zZXRBdHRyaWJ1dGUoInRpdGxlIiwgdGhpcy5sb2NhbGl6ZSgidGFibGUgb2YgY29udGVudHMiLmxvY2FsaXplKSk7CiAgICAgICBjb250ZW50cy5pbm5lckhUTUwgPSB0aGlzLmxvY2FsaXplKCJjb250ZW50cz8iKTsKICAgICAgIHRoaXMudG9vbGJhci5hcHBlbmRDaGlsZChjb250ZW50cyk7CgogICAgICAgdmFyIGdhcDIgPSBkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZSgiICIpOwogICAgICAgdGhpcy50b29sYmFyLmFwcGVuZENoaWxkKGdhcDIpOwoKICAgICAgIHZhciBjb3B5cmlnaHQgPSB0aGlzLmZpbmRfY29weXJpZ2h0KCk7CgogICAgICAgaWYgKGNvcHlyaWdodCkKICAgICAgIHsKICAgICAgICAgdmFyIHNwYW4gPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJzcGFuIik7CiAgICAgICAgIHNwYW4uaW5uZXJIVE1MID0gY29weXJpZ2h0OwogICAgICAgICBzcGFuLnN0eWxlLmNvbG9yID0gImJsYWNrIjsKICAgICAgICAgc3Bhbi5zdHlsZS5tYXJnaW5MZWZ0ID0gIjAuNWVtIjsKICAgICAgICAgdGhpcy50b29sYmFyLmFwcGVuZENoaWxkKHNwYW4pOwogICAgICAgfQoKICAgICAgIGNvdW50ZXIgPSB0aGlzLmNyZWF0ZV9lbGVtZW50KCJkaXYiKQogICAgICAgY291bnRlci5zdHlsZS5wb3NpdGlvbiA9ICJhYnNvbHV0ZSI7CiAgICAgICBjb3VudGVyLnN0eWxlLndpZHRoID0gImF1dG8iOyAvLyIyMCUiOwogICAgICAgY291bnRlci5zdHlsZS5oZWlnaHQgPSAiMS4yZW0iOwogICAgICAgY291bnRlci5zdHlsZS50b3AgPSAiYXV0byI7CiAgICAgICBjb3VudGVyLnN0eWxlLmJvdHRvbSA9IDA7CiAgICAgICBjb3VudGVyLnN0eWxlLnJpZ2h0ID0gIjAiOwogICAgICAgY291bnRlci5zdHlsZS50ZXh0QWxpZ24gPSAicmlnaHQiOwogICAgICAgY291bnRlci5zdHlsZS5jb2xvciA9ICJyZWQiOwogICAgICAgY291bnRlci5zdHlsZS5iYWNrZ3JvdW5kID0gInJnYigyNDAsMjQwLDI0MCkiOwoKICAgICAgIGNvdW50ZXIuaW5uZXJIVE1MID0gdGhpcy5sb2NhbGl6ZSgic2xpZGUiKSArICIgbi9tIjsKICAgICAgIHRoaXMudG9vbGJhci5hcHBlbmRDaGlsZChjb3VudGVyKTsKICAgICB9CgogICAgIC8vIGVuc3VyZSB0aGF0IGNsaWNrIGlzbid0IHBhc3NlZCB0aHJvdWdoIHRvIHRoZSBwYWdlCiAgICAgdGhpcy50b29sYmFyLm9uY2xpY2sgPQogICAgICAgICBmdW5jdGlvbiAoZSkgewogICAgICAgICAgIGlmICghZSkKICAgICAgICAgICAgIGUgPSB3aW5kb3cuZXZlbnQ7CgogICAgICAgICAgIHZhciB0YXJnZXQgPSBlLnRhcmdldDsKCiAgICAgICAgICAgaWYgKCF0YXJnZXQgJiYgZS5zcmNFbGVtZW50KQogICAgICAgICAgICAgdGFyZ2V0ID0gZS5zcmNFbGVtZW50OwoKICAgICAgICAgICAvLyB3b3JrIGFyb3VuZCBTYWZhcmkgYnVnCiAgICAgICAgICAgaWYgKHRhcmdldCAmJiB0YXJnZXQubm9kZVR5cGUgPT0gMykKICAgICAgICAgICAgIHRhcmdldCA9IHRhcmdldC5wYXJlbnROb2RlOwoKICAgICAgICAgICB3M2Nfc2xpZHkuc3RvcF9wcm9wYWdhdGlvbihlKTsKCiAgICAgICAgICAgaWYgKHRhcmdldCAmJiB0YXJnZXQubm9kZU5hbWUudG9Mb3dlckNhc2UoKSAhPSAiYSIpCiAgICAgICAgICAgICB3M2Nfc2xpZHkubW91c2VfYnV0dG9uX2NsaWNrKGUpOwogICAgICAgICB9OwoKICAgICB0aGlzLnNsaWRlX251bWJlcl9lbGVtZW50ID0gY291bnRlcjsKICAgICB0aGlzLnNldF9lb3Nfc3RhdHVzKGZhbHNlKTsKICAgICBkb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKHRoaXMudG9vbGJhcik7CiAgfSwKCiAgLy8gd3lzaXd5ZyBlZGl0b3JzIG1ha2UgaXQgaGFyZCB0byB1c2UgZGl2IGVsZW1lbnRzCiAgLy8gZS5nLiBhbWF5YSBsb3NlcyB0aGUgZGl2IHdoZW4geW91IGNvcHkgYW5kIHBhc3RlCiAgLy8gdGhpcyBmdW5jdGlvbiB3cmFwcyBkaXYgZWxlbWVudHMgYXJvdW5kIGltcGxpY2l0CiAgLy8gc2xpZGVzIHdoaWNoIHN0YXJ0IHdpdGggYW4gaDEgZWxlbWVudCBhbmQgY29udGludWUKICAvLyB1cCB0byB0aGUgbmV4dCBoZWFkaW5nIG9yIGRpdiBlbGVtZW50CiAgd3JhcF9pbXBsaWNpdF9zbGlkZXM6IGZ1bmN0aW9uICgpIHsKICAgIHZhciBpLCBoZWFkaW5nLCBub2RlLCBuZXh0LCBkaXY7CiAgICB2YXIgaGVhZGluZ3MgPSBkb2N1bWVudC5nZXRFbGVtZW50c0J5VGFnTmFtZSgiaDEiKTsKCiAgICBpZiAoIWhlYWRpbmdzKQogICAgICByZXR1cm47CgogICAgZm9yIChpID0gMDsgaSA8IGhlYWRpbmdzLmxlbmd0aDsgKytpKQogICAgewogICAgICBoZWFkaW5nID0gaGVhZGluZ3NbaV07CgogICAgICBpZiAoaGVhZGluZy5wYXJlbnROb2RlICE9IGRvY3VtZW50LmJvZHkpCiAgICAgICAgY29udGludWU7CgogICAgICBub2RlID0gaGVhZGluZy5uZXh0U2libGluZzsKCiAgICAgIGRpdiA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoImRpdiIpOwogICAgICB0aGlzLmFkZF9jbGFzcyhkaXYsICJzbGlkZSIpOwogICAgICBkb2N1bWVudC5ib2R5LnJlcGxhY2VDaGlsZChkaXYsIGhlYWRpbmcpOwogICAgICBkaXYuYXBwZW5kQ2hpbGQoaGVhZGluZyk7CgogICAgICB3aGlsZSAobm9kZSkKICAgICAgewogICAgICAgIGlmIChub2RlLm5vZGVUeXBlID09IDEpIC8vIGFuIGVsZW1lbnQKICAgICAgICB7CiAgICAgICAgICAgaWYgKG5vZGUubm9kZU5hbWUgPT0gIkgxIiB8fCBub2RlLm5vZGVOYW1lID09ICJoMSIpCiAgICAgICAgICAgICBicmVhazsKCiAgICAgICAgICAgaWYgKG5vZGUubm9kZU5hbWUgPT0gIkRJViIgfHwgbm9kZS5ub2RlTmFtZSA9PSAiZGl2IikKICAgICAgICAgICB7CiAgICAgICAgICAgICBpZiAodGhpcy5oYXNfY2xhc3Mobm9kZSwgInNsaWRlIikpCiAgICAgICAgICAgICAgIGJyZWFrOwoKICAgICAgICAgICAgIGlmICh0aGlzLmhhc19jbGFzcyhub2RlLCAiaGFuZG91dCIpKQogICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICB9CiAgICAgICAgfQoKICAgICAgICBuZXh0ID0gbm9kZS5uZXh0U2libGluZzsKICAgICAgICBub2RlID0gZG9jdW1lbnQuYm9keS5yZW1vdmVDaGlsZChub2RlKTsKICAgICAgICBkaXYuYXBwZW5kQ2hpbGQobm9kZSk7CiAgICAgICAgbm9kZSA9IG5leHQ7CiAgICAgIH0gCiAgICB9CiAgfSwKCiAgYXR0YWNoX3RvdWNoX2hhbmRlcnM6IGZ1bmN0aW9uKHNsaWRlcykKICB7CiAgICB2YXIgaSwgc2xpZGU7CgogICAgZm9yIChpID0gMDsgaSA8IHNsaWRlcy5sZW5ndGg7ICsraSkKICAgIHsKICAgICAgc2xpZGUgPSBzbGlkZXNbaV07CiAgICAgIHRoaXMuYWRkX2xpc3RlbmVyKHNsaWRlLCAidG91Y2hzdGFydCIsIHRoaXMudG91Y2hzdGFydCk7CiAgICAgIHRoaXMuYWRkX2xpc3RlbmVyKHNsaWRlLCAidG91Y2htb3ZlIiwgdGhpcy50b3VjaG1vdmUpOwogICAgICB0aGlzLmFkZF9saXN0ZW5lcihzbGlkZSwgInRvdWNoZW5kIiwgdGhpcy50b3VjaGVuZCk7CiAgICB9CiAgfSwKCi8vIHJldHVybiBuZXcgYXJyYXkgb2YgYWxsIHNsaWRlcwogIGNvbGxlY3Rfc2xpZGVzOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgc2xpZGVzID0gbmV3IEFycmF5KCk7CiAgICB2YXIgZGl2cyA9IGRvY3VtZW50LmJvZHkuZ2V0RWxlbWVudHNCeVRhZ05hbWUoImRpdiIpOwoKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgZGl2cy5sZW5ndGg7ICsraSkKICAgIHsKICAgICAgZGl2ID0gZGl2cy5pdGVtKGkpOwoKICAgICAgaWYgKHRoaXMuaGFzX2NsYXNzKGRpdiwgInNsaWRlIikpCiAgICAgIHsKICAgICAgICAvLyBhZGQgc2xpZGUgdG8gY29sbGVjdGlvbgogICAgICAgIHNsaWRlc1tzbGlkZXMubGVuZ3RoXSA9IGRpdjsKCiAgICAgICAgLy8gaGlkZSBlYWNoIHNsaWRlIGFzIGl0IGlzIGZvdW5kCiAgICAgICAgdGhpcy5hZGRfY2xhc3MoZGl2LCAiaGlkZGVuIik7CgogICAgICAgIC8vIGFkZCBkdW1teSA8YnIvPiBhdCBlbmQgZm9yIHNjcm9sbGluZyBoYWNrCiAgICAgICAgdmFyIG5vZGUxID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgiYnIiKTsKICAgICAgICBkaXYuYXBwZW5kQ2hpbGQobm9kZTEpOwogICAgICAgIHZhciBub2RlMiA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoImJyIik7CiAgICAgICAgZGl2LmFwcGVuZENoaWxkKG5vZGUyKTsKICAgICAgfQogICAgICBlbHNlIGlmICh0aGlzLmhhc19jbGFzcyhkaXYsICJiYWNrZ3JvdW5kIikpCiAgICAgIHsgIC8vIHdvcmsgYXJvdW5kIGZvciBGaXJlZm94IFNWRyByZWxvYWQgYnVnCiAgICAgICAgLy8gd2hpY2ggb3RoZXJ3aXNlIHJlcGxhY2VzIDFzdCBTVkcgZ3JhcGhpYyB3aXRoIDJuZAogICAgICAgIGRpdi5zdHlsZS5kaXNwbGF5ID0gImJsb2NrIjsKICAgICAgfQogICAgfQoKICAgIHRoaXMuc2xpZGVzID0gc2xpZGVzOwogIH0sCgogIC8vIHJldHVybiBuZXcgYXJyYXkgb2YgYWxsIDxkaXYgY2xhc3M9ImhhbmRvdXQiPgogIGNvbGxlY3Rfbm90ZXM6IGZ1bmN0aW9uICgpIHsKICAgIHZhciBub3RlcyA9IG5ldyBBcnJheSgpOwogICAgdmFyIGRpdnMgPSBkb2N1bWVudC5ib2R5LmdldEVsZW1lbnRzQnlUYWdOYW1lKCJkaXYiKTsKCiAgICBmb3IgKHZhciBpID0gMDsgaSA8IGRpdnMubGVuZ3RoOyArK2kpCiAgICB7CiAgICAgIGRpdiA9IGRpdnMuaXRlbShpKTsKCiAgICAgIGlmICh0aGlzLmhhc19jbGFzcyhkaXYsICJoYW5kb3V0IikpCiAgICAgIHsKICAgICAgICAvLyBhZGQgbm90ZSB0byBjb2xsZWN0aW9uCiAgICAgICAgbm90ZXNbbm90ZXMubGVuZ3RoXSA9IGRpdjsKCiAgICAgICAgLy8gYW5kIGhpZGUgaXQKICAgICAgICB0aGlzLmFkZF9jbGFzcyhkaXYsICJoaWRkZW4iKTsKICAgICAgfQogICAgfQoKICAgIHRoaXMubm90ZXMgPSBub3RlczsKICB9LAoKICAvLyByZXR1cm4gbmV3IGFycmF5IG9mIGFsbCA8ZGl2IGNsYXNzPSJiYWNrZ3JvdW5kIj4KICAvLyBpbmNsdWRpbmcgbmFtZWQgYmFja2dyb3VuZHMgZS5nLiBjbGFzcz0iYmFja2dyb3VuZCB0aXRsZXBhZ2UiCiAgY29sbGVjdF9iYWNrZ3JvdW5kczogZnVuY3Rpb24gKCkgewogICAgdmFyIGJhY2tncm91bmRzID0gbmV3IEFycmF5KCk7CiAgICB2YXIgZGl2cyA9IGRvY3VtZW50LmJvZHkuZ2V0RWxlbWVudHNCeVRhZ05hbWUoImRpdiIpOwoKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgZGl2cy5sZW5ndGg7ICsraSkKICAgIHsKICAgICAgZGl2ID0gZGl2cy5pdGVtKGkpOwoKICAgICAgaWYgKHRoaXMuaGFzX2NsYXNzKGRpdiwgImJhY2tncm91bmQiKSkKICAgICAgewogICAgICAgIC8vIGFkZCBiYWNrZ3JvdW5kIHRvIGNvbGxlY3Rpb24KICAgICAgICBiYWNrZ3JvdW5kc1tiYWNrZ3JvdW5kcy5sZW5ndGhdID0gZGl2OwoKICAgICAgICAvLyBhbmQgaGlkZSBpdAogICAgICAgIHRoaXMuYWRkX2NsYXNzKGRpdiwgImhpZGRlbiIpOwogICAgICB9CiAgICB9CgogICAgdGhpcy5iYWNrZ3JvdW5kcyA9IGJhY2tncm91bmRzOwogIH0sCgogIC8vIHNldCBjbGljayBoYW5kbGVycyBvbiBhbGwgYW5jaG9ycwogIHBhdGNoX2FuY2hvcnM6IGZ1bmN0aW9uICgpIHsKICAgIHZhciBzZWxmID0gdzNjX3NsaWR5OwogICAgdmFyIGhhbmRsZXIgPSBmdW5jdGlvbiAoZXZlbnQpIHsKICAgICAgLy8gY29tcGFyZSB0aGlzLmhyZWYgd2l0aCBsb2NhdGlvbi5ocmVmCiAgICAgIC8vIGZvciBsaW5rIHRvIGFub3RoZXIgc2xpZGUgaW4gdGhpcyBkb2MKCiAgICAgIGlmIChzZWxmLnBhZ2VfYWRkcmVzcyh0aGlzLmhyZWYpID09IHNlbGYucGFnZV9hZGRyZXNzKGxvY2F0aW9uLmhyZWYpKQogICAgICB7CiAgICAgICAgLy8geWVzLCBzbyBmaW5kIG5ldyBzbGlkZSBudW1iZXIKICAgICAgICB2YXIgbmV3c2xpZGVudW0gPSBzZWxmLmZpbmRfc2xpZGVfbnVtYmVyKHRoaXMuaHJlZik7CgogICAgICAgIGlmIChuZXdzbGlkZW51bSAhPSBzZWxmLnNsaWRlX251bWJlcikKICAgICAgICB7CiAgICAgICAgICB2YXIgc2xpZGUgPSBzZWxmLnNsaWRlc1tzZWxmLnNsaWRlX251bWJlcl07CiAgICAgICAgICBzZWxmLmhpZGVfc2xpZGUoc2xpZGUpOwogICAgICAgICAgc2VsZi5zbGlkZV9udW1iZXIgPSBuZXdzbGlkZW51bTsKICAgICAgICAgIHNsaWRlID0gc2VsZi5zbGlkZXNbc2VsZi5zbGlkZV9udW1iZXJdOwogICAgICAgICAgc2VsZi5zaG93X3NsaWRlKHNsaWRlKTsKICAgICAgICAgIHNlbGYuc2V0X2xvY2F0aW9uKCk7CiAgICAgICAgfQogICAgICB9CiAgICAgIGVsc2UKICAgICAgICB3M2Nfc2xpZHkuc3RvcF9wcm9wYWdhdGlvbihldmVudCk7CgovLyAgICAgIGVsc2UgaWYgKHRoaXMudGFyZ2V0ID09IG51bGwpCi8vICAgICAgICBsb2NhdGlvbi5ocmVmID0gdGhpcy5ocmVmOwoKICAgICAgdGhpcy5ibHVyKCk7CiAgICAgIHNlbGYuZGlzYWJsZV9zbGlkZV9jbGljayA9IHRydWU7CiAgICB9OwoKICAgIHZhciBhbmNob3JzID0gZG9jdW1lbnQuYm9keS5nZXRFbGVtZW50c0J5VGFnTmFtZSgiYSIpOwoKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgYW5jaG9ycy5sZW5ndGg7ICsraSkKICAgIHsKICAgICAgaWYgKHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKQogICAgICAgIGFuY2hvcnNbaV0uYWRkRXZlbnRMaXN0ZW5lcigiY2xpY2siLCBoYW5kbGVyLCBmYWxzZSk7CiAgICAgIGVsc2UKICAgICAgICBhbmNob3JzW2ldLmF0dGFjaEV2ZW50KCJvbmNsaWNrIiwgaGFuZGxlcik7CiAgICB9CiAgfSwKCiAgLy8gIyMjIENIRUNLIE1FICMjIyBzZWUgd2hpY2ggZnVuY3Rpb25zIGFyZSBpbnZva2VkIHZpYSBzZXRUaW1lb3V0CiAgLy8gZWl0aGVyIGRpcmVjdGx5IG9yIGluZGlyZWN0bHkgZm9yIHVzZSBvZiB3M2Nfc2xpZHkgdnMgdGhpcwogIHNob3dfc2xpZGVfbnVtYmVyOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgdGltZXIgPSB3M2Nfc2xpZHkuZ2V0X3RpbWVyKCk7CiAgICB3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyX2VsZW1lbnQuaW5uZXJIVE1MID0gdGltZXIgKyB3M2Nfc2xpZHkubG9jYWxpemUoInNsaWRlIikgKyAiICIgKwogICAgICAgICAgICh3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyICsgMSkgKyAiLyIgKyB3M2Nfc2xpZHkuc2xpZGVzLmxlbmd0aDsKICB9LAoKICAvLyBldmVyeSAyMDBtUyBjaGVjayBpZiB0aGUgbG9jYXRpb24gaGFzIGJlZW4gY2hhbmdlZCBhcyBhCiAgLy8gcmVzdWx0IG9mIHRoZSB1c2VyIGFjdGl2YXRpbmcgdGhlIEJhY2sgYnV0dG9uL21lbnUgaXRlbQogIC8vIGRvZXNuJ3Qgd29yayBmb3IgT3BlcmEgPCA5LjUKICBjaGVja19sb2NhdGlvbjogZnVuY3Rpb24gKCkgewogICAgdmFyIGhhc2ggPSBsb2NhdGlvbi5oYXNoOwoKICAgIGlmICh3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyID4gMCAmJiAoaGFzaCA9PSAiIiB8fCBoYXNoID09ICIjIikpCiAgICAgIHczY19zbGlkeS5nb3RvX3NsaWRlKDApOwogICAgZWxzZSBpZiAoaGFzaC5sZW5ndGggPiAyICYmIGhhc2ggIT0gIiMoIisodzNjX3NsaWR5LnNsaWRlX251bWJlcisxKSsiKSIpCiAgICB7CiAgICAgIHZhciBudW0gPSBwYXJzZUludChsb2NhdGlvbi5oYXNoLnN1YnN0cigyKSk7CgogICAgICBpZiAoIWlzTmFOKG51bSkpCiAgICAgICAgdzNjX3NsaWR5LmdvdG9fc2xpZGUobnVtLTEpOwogICAgfQoKICAgIGlmICh3M2Nfc2xpZHkudGltZV9sZWZ0ICYmIHczY19zbGlkeS5zbGlkZV9udW1iZXIgPiAwKQogICAgewogICAgICB3M2Nfc2xpZHkuc2hvd19zbGlkZV9udW1iZXIoKTsKCiAgICAgIGlmICh3M2Nfc2xpZHkudGltZV9sZWZ0ID4gMCkKICAgICAgICB3M2Nfc2xpZHkudGltZV9sZWZ0IC09IDIwMDsKICAgIH0gCiAgfSwKCiAgZ2V0X3RpbWVyOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgdGltZXIgPSAiIjsKICAgIGlmICh3M2Nfc2xpZHkudGltZV9sZWZ0KQogICAgewogICAgICB2YXIgbWlucywgc2VjczsKICAgICAgc2VjcyA9IE1hdGguZmxvb3IodzNjX3NsaWR5LnRpbWVfbGVmdC8xMDAwKTsKICAgICAgbWlucyA9IE1hdGguZmxvb3Ioc2VjcyAvIDYwKTsKICAgICAgc2VjcyA9IHNlY3MgJSA2MDsKICAgICAgdGltZXIgPSAobWlucyA/IG1pbnMrIm0iIDogIiIpICsgc2VjcyArICJzICI7CiAgICB9CgogICAgcmV0dXJuIHRpbWVyOwogIH0sCgogIC8vIHRoaXMgZG9lc24ndCBwdXNoIGxvY2F0aW9uIG9udG8gaGlzdG9yeSBzdGFjayBmb3IgSUUKICAvLyBmb3Igd2hpY2ggYSBoaWRkZW4gaWZyYW1lIGhhY2sgaXMgbmVlZGVkOiBsb2FkIHBhZ2UgaW50bwogIC8vIHRoZSBpZnJhbWUgd2l0aCBzY3JpcHQgdGhhdCBzZXQncyBwYXJlbnQncyBsb2NhdGlvbi5oYXNoCiAgLy8gYnV0IHRoYXQgd29uJ3Qgd29yayBmb3Igc3RhbmRhbG9uZSB1c2UgdW5sZXNzIHdlIGNhbgogIC8vIGNyZWF0ZSB0aGUgcGFnZSBkeW5hbWljYWxseSB2aWEgYSBqYXZhc2NyaXB0OiBVUkwKICAvLyAjIyMgdXNlIGhpc3RvcnkucHVzaFN0YXRlIGlmIGF2YWlsYWJsZQogIHNldF9sb2NhdGlvbjogZnVuY3Rpb24gKCkgewogICAgIHZhciB1cmkgPSB3M2Nfc2xpZHkucGFnZV9hZGRyZXNzKGxvY2F0aW9uLmhyZWYpOwogICAgIHZhciBoYXNoID0gIiMoIiArICh3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyKzEpICsgIikiOwoKICAgICBpZiAodzNjX3NsaWR5LnNsaWRlX251bWJlciA+PSAwKQogICAgICAgdXJpID0gdXJpICsgaGFzaDsKCiAgICAgaWYgKHR5cGVvZihoaXN0b3J5LnB1c2hTdGF0ZSkgIT0gInVuZGVmaW5lZCIgJiYgbG9jYXRpb24ucHJvdG9jb2wgIT09ICJmaWxlOiIpCiAgICAgewogICAgICAgZG9jdW1lbnQudGl0bGUgPSB3M2Nfc2xpZHkudGl0bGUgKyAiICgiICsgKHczY19zbGlkeS5zbGlkZV9udW1iZXIrMSkgKyAiKSI7CiAgICAgICBoaXN0b3J5LnB1c2hTdGF0ZSgwLCBkb2N1bWVudC50aXRsZSwgaGFzaCk7CiAgICAgICB3M2Nfc2xpZHkuc2hvd19zbGlkZV9udW1iZXIoKTsKICAgICAgIHczY19zbGlkeS5ub3RpZnlfb2JzZXJ2ZXJzKCk7CiAgICAgICByZXR1cm47CiAgICAgfQoKICAgICBpZiAodzNjX3NsaWR5LmllICYmICh3M2Nfc2xpZHkuaWU2IHx8IHczY19zbGlkeS5pZTcpKQogICAgICAgdzNjX3NsaWR5LnB1c2hfaGFzaChoYXNoKTsKCiAgICAgaWYgKHVyaSAhPSBsb2NhdGlvbi5ocmVmKSAvLyAmJiAha2h0bWwKICAgICAgICBsb2NhdGlvbi5ocmVmID0gdXJpOwoKICAgICBpZiAodGhpcy5raHRtbCkKICAgICAgICBoYXNoID0gIigiICsgKHczY19zbGlkeS5zbGlkZV9udW1iZXIrMSkgKyAiKSI7CgogICAgIGlmICghdGhpcy5pZSAmJiBsb2NhdGlvbi5oYXNoICE9IGhhc2ggJiYgbG9jYXRpb24uaGFzaCAhPSAiIikKICAgICAgIGxvY2F0aW9uLmhhc2ggPSBoYXNoOwoKICAgICBkb2N1bWVudC50aXRsZSA9IHczY19zbGlkeS50aXRsZSArICIgKCIgKyAodzNjX3NsaWR5LnNsaWRlX251bWJlcisxKSArICIpIjsKICAgICB3M2Nfc2xpZHkuc2hvd19zbGlkZV9udW1iZXIoKTsKICAgICB3M2Nfc2xpZHkubm90aWZ5X29ic2VydmVycygpOwogIH0sCgogIG5vdGlmeV9vYnNlcnZlcnM6IGZ1bmN0aW9uICgpCiAgewogICAgdmFyIHNsaWRlID0gdGhpcy5zbGlkZXNbdGhpcy5zbGlkZV9udW1iZXJdOwoKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgdGhpcy5vYnNlcnZlcnMubGVuZ3RoOyArK2kpCiAgICAgIHRoaXMub2JzZXJ2ZXJzW2ldKHRoaXMuc2xpZGVfbnVtYmVyKzEsIHRoaXMuZmluZF9oZWFkaW5nKHNsaWRlKS5pbm5lclRleHQsIGxvY2F0aW9uLmhyZWYpOwogIH0sCgogIGFkZF9vYnNlcnZlcjogZnVuY3Rpb24gKG9ic2VydmVyKQogIHsKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgdGhpcy5vYnNlcnZlcnMubGVuZ3RoOyArK2kpCiAgICB7CiAgICAgIGlmIChvYnNlcnZlciA9PSB0aGlzLm9ic2VydmVyc1tpXSkKICAgICAgICByZXR1cm47CiAgICB9CgogICAgdGhpcy5vYnNlcnZlcnMucHVzaChvYnNlcnZlcik7CiAgfSwKCiAgcmVtb3ZlX29ic2VydmVyOiBmdW5jdGlvbiAobykKICB7CiAgICBmb3IgKHZhciBpID0gMDsgaSA8IHRoaXMub2JzZXJ2ZXJzLmxlbmd0aDsgKytpKQogICAgewogICAgICBpZiAob2JzZXJ2ZXIgPT0gdGhpcy5vYnNlcnZlcnNbaV0pCiAgICAgIHsKICAgICAgICB0aGlzLm9ic2VydmVycy5zcGxpY2UoaSwxKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgfQogIH0sCgogIHBhZ2VfYWRkcmVzczogZnVuY3Rpb24gKHVyaSkgewogICAgdmFyIGkgPSB1cmkuaW5kZXhPZigiIyIpOwoKICAgIGlmIChpIDwgMCkKICAgICAgaSA9IHVyaS5pbmRleE9mKCIlMjMiKTsKCiAgICAvLyBjaGVjayBpZiBhbmNob3IgaXMgZW50aXJlIHBhZ2UKCiAgICBpZiAoaSA8IDApCiAgICAgIHJldHVybiB1cmk7ICAvLyB5ZXMKCiAgICByZXR1cm4gdXJpLnN1YnN0cigwLCBpKTsKICB9LAoKICAvLyBvbmx5IHVzZWQgZm9yIElFNiBhbmQgSUU3CiAgb25fZnJhbWVfbG9hZGVkOiBmdW5jdGlvbiAoaGFzaCkgewogICAgbG9jYXRpb24uaGFzaCA9IGhhc2g7CiAgICB2YXIgdXJpID0gdzNjX3NsaWR5LnBhZ2VfYWRkcmVzcyhsb2NhdGlvbi5ocmVmKTsKICAgIGxvY2F0aW9uLmhyZWYgPSB1cmkgKyBoYXNoOwogIH0sCgogIC8vIGhpc3RvcnkgaGFjayB3aXRoIHRoYW5rcyB0byBCZXJ0cmFuZCBMZSBSb3kKICBwdXNoX2hhc2g6IGZ1bmN0aW9uIChoYXNoKSB7CiAgICBpZiAoaGFzaCA9PSAiIikgaGFzaCA9ICIjKDEpIjsKICAgICAgd2luZG93LmxvY2F0aW9uLmhhc2ggPSBoYXNoOwoKICAgIHZhciBkb2MgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiaGlzdG9yeUZyYW1lIikuY29udGVudFdpbmRvdy5kb2N1bWVudDsKICAgIGRvYy5vcGVuKCJqYXZhc2NyaXB0Oic8aHRtbD48L2h0bWw+JyIpOwogICAgZG9jLndyaXRlKCI8aHRtbD48aGVhZD48c2NyaXB0IHR5cGU9XCJ0ZXh0L2phdmFzY3JpcHRcIj53aW5kb3cucGFyZW50LnczY19zbGlkeS5vbl9mcmFtZV9sb2FkZWQoJyIrCiAgICAgIChoYXNoKSArICInKTs8L3NjcmlwdD48L2hlYWQ+PGJvZHk+aGVsbG8gbXVtPC9ib2R5PjwvaHRtbD4iKTsKICAgICAgZG9jLmNsb3NlKCk7CiAgfSwKCiAgLy8gZmluZCBjdXJyZW50IHNsaWRlIGJhc2VkIHVwb24gbG9jYXRpb24KICAvLyBmaXJzdCBmaW5kIHRhcmdldCBhbmNob3IgYW5kIHRoZW4gbG9vawogIC8vIGZvciBhc3NvY2lhdGVkIGRpdiBlbGVtZW50IGVuY2xvc2luZyBpdAogIC8vIGZpbmFsbHkgbWFwIHRoYXQgdG8gc2xpZGUgbnVtYmVyCiAgZmluZF9zbGlkZV9udW1iZXI6IGZ1bmN0aW9uICh1cmkpIHsKICAgIC8vIGZpcnN0IGdldCBhbmNob3IgZnJvbSBwYWdlIGxvY2F0aW9uCgogICAgdmFyIGkgPSB1cmkuaW5kZXhPZigiIyIpOwoKICAgIC8vIGNoZWNrIGlmIGFuY2hvciBpcyBlbnRpcmUgcGFnZQogICAgaWYgKGkgPCAwKQogICAgICByZXR1cm4gMDsgIC8vIHllcwoKICAgIHZhciBhbmNob3IgPSB1bmVzY2FwZSh1cmkuc3Vic3RyKGkrMSkpOwoKICAgIC8vIG5vdyB1c2UgYW5jaG9yIGFzIFhNTCBJRCB0byBmaW5kIHRhcmdldAogICAgdmFyIHRhcmdldCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKGFuY2hvcik7CgogICAgaWYgKCF0YXJnZXQpCiAgICB7CiAgICAgIC8vIGRvZXMgYW5jaG9yIGxvb2sgbGlrZSAiKDIpIiBmb3Igc2xpZGUgMiA/PwogICAgICAvLyB3aGVyZSBmaXJzdCBzbGlkZSBpcyAoMSkKICAgICAgdmFyIHJlID0gL1woKFxkKStcKS87CgogICAgICBpZiAoYW5jaG9yLm1hdGNoKHJlKSkKICAgICAgewogICAgICAgIHZhciBudW0gPSBwYXJzZUludChhbmNob3Iuc3Vic3RyaW5nKDEsIGFuY2hvci5sZW5ndGgtMSkpOwoKICAgICAgICBpZiAobnVtID4gdGhpcy5zbGlkZXMubGVuZ3RoKQogICAgICAgICAgbnVtID0gMTsKCiAgICAgICAgaWYgKC0tbnVtIDwgMCkKICAgICAgICAgIG51bSA9IDA7CgogICAgICAgIHJldHVybiBudW07CiAgICAgIH0KCiAgICAgIC8vIGFjY2VwdCBbMl0gZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5CiAgICAgIHJlID0gL1xbKFxkKStcXS87CgogICAgICBpZiAoYW5jaG9yLm1hdGNoKHJlKSkKICAgICAgewogICAgICAgICB2YXIgbnVtID0gcGFyc2VJbnQoYW5jaG9yLnN1YnN0cmluZygxLCBhbmNob3IubGVuZ3RoLTEpKTsKCiAgICAgICAgIGlmIChudW0gPiB0aGlzLnNsaWRlcy5sZW5ndGgpCiAgICAgICAgICAgIG51bSA9IDE7CgogICAgICAgICBpZiAoLS1udW0gPCAwKQogICAgICAgICAgICBudW0gPSAwOwoKICAgICAgICAgcmV0dXJuIG51bTsKICAgICAgfQoKICAgICAgLy8gb2ggZGVhciB1bmtub3duIGFuY2hvcgogICAgICByZXR1cm4gMDsKICAgIH0KCiAgICAvLyBzZWFyY2ggZm9yIGVuY2xvc2luZyBzbGlkZQoKICAgIHdoaWxlICh0cnVlKQogICAgewogICAgICAvLyBicm93c2VyIGNvZXJjZXMgaHRtbCBlbGVtZW50cyB0byB1cHBlcmNhc2UhCiAgICAgIGlmICh0YXJnZXQubm9kZU5hbWUudG9Mb3dlckNhc2UoKSA9PSAiZGl2IiAmJgogICAgICAgICAgICB0aGlzLmhhc19jbGFzcyh0YXJnZXQsICJzbGlkZSIpKQogICAgICB7CiAgICAgICAgLy8gZm91bmQgdGhlIHNsaWRlIGVsZW1lbnQKICAgICAgICBicmVhazsKICAgICAgfQoKICAgICAgLy8gb3RoZXJ3aXNlIHRyeSBwYXJlbnQgZWxlbWVudCBpZiBhbnkKCiAgICAgIHRhcmdldCA9IHRhcmdldC5wYXJlbnROb2RlOwoKICAgICAgaWYgKCF0YXJnZXQpCiAgICAgIHsKICAgICAgICByZXR1cm4gMDsgICAvLyBubyBsdWNrIQogICAgICB9CiAgICB9OwoKICAgIGZvciAoaSA9IDA7IGkgPCBzbGlkZXMubGVuZ3RoOyArK2kpCiAgICB7CiAgICAgIGlmIChzbGlkZXNbaV0gPT0gdGFyZ2V0KQogICAgICAgIHJldHVybiBpOyAgLy8gc3VjY2VzcwogICAgfQoKICAgIC8vIG9oIGRlYXIgc3RpbGwgbm8gbHVjawogICAgcmV0dXJuIDA7CiAgfSwKCiAgcHJldmlvdXNfc2xpZGU6IGZ1bmN0aW9uIChpbmNyZW1lbnRhbCkgewogICAgaWYgKCF3M2Nfc2xpZHkudmlld19hbGwpCiAgICB7CiAgICAgIHZhciBzbGlkZTsKCiAgICAgIGlmICgoaW5jcmVtZW50YWwgfHwgdzNjX3NsaWR5LnNsaWRlX251bWJlciA9PSAwKSAmJiB3M2Nfc2xpZHkubGFzdF9zaG93biAhPSBudWxsKQogICAgICB7CiAgICAgICAgdzNjX3NsaWR5Lmxhc3Rfc2hvd24gPSB3M2Nfc2xpZHkuaGlkZV9wcmV2aW91c19pdGVtKHczY19zbGlkeS5sYXN0X3Nob3duKTsKICAgICAgICB3M2Nfc2xpZHkuc2V0X2Vvc19zdGF0dXMoZmFsc2UpOwogICAgICB9CiAgICAgIGVsc2UgaWYgKHczY19zbGlkeS5zbGlkZV9udW1iZXIgPiAwKQogICAgICB7CiAgICAgICAgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgICAgIHczY19zbGlkeS5oaWRlX3NsaWRlKHNsaWRlKTsKCiAgICAgICAgdzNjX3NsaWR5LnNsaWRlX251bWJlciA9IHczY19zbGlkeS5zbGlkZV9udW1iZXIgLSAxOwogICAgICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICB3M2Nfc2xpZHkuc2V0X3Zpc2liaWxpdHlfYWxsX2luY3JlbWVudGFsKCJ2aXNpYmxlIik7CiAgICAgICAgdzNjX3NsaWR5Lmxhc3Rfc2hvd24gPSB3M2Nfc2xpZHkucHJldmlvdXNfaW5jcmVtZW50YWxfaXRlbShudWxsKTsKICAgICAgICB3M2Nfc2xpZHkuc2V0X2Vvc19zdGF0dXModHJ1ZSk7CiAgICAgICAgdzNjX3NsaWR5LnNob3dfc2xpZGUoc2xpZGUpOwogICAgICB9CgogICAgICB3M2Nfc2xpZHkuc2V0X2xvY2F0aW9uKCk7CgogICAgICBpZiAoIXczY19zbGlkeS5uc19wb3MpCiAgICAgICAgdzNjX3NsaWR5LnJlZnJlc2hfdG9vbGJhcigyMDApOwogICAgfQogIH0sCgogIG5leHRfc2xpZGU6IGZ1bmN0aW9uIChpbmNyZW1lbnRhbCkgewogICAgaWYgKCF3M2Nfc2xpZHkudmlld19hbGwpCiAgICB7CiAgICAgIHZhciBzbGlkZSwgbGFzdCA9IHczY19zbGlkeS5sYXN0X3Nob3duOwoKICAgICAgaWYgKGluY3JlbWVudGFsIHx8IHczY19zbGlkeS5zbGlkZV9udW1iZXIgPT0gdzNjX3NsaWR5LnNsaWRlcy5sZW5ndGggLSAxKQogICAgICAgICB3M2Nfc2xpZHkubGFzdF9zaG93biA9IHczY19zbGlkeS5yZXZlYWxfbmV4dF9pdGVtKHczY19zbGlkeS5sYXN0X3Nob3duKTsKCiAgICAgIGlmICgoIWluY3JlbWVudGFsIHx8IHczY19zbGlkeS5sYXN0X3Nob3duID09IG51bGwpICYmCiAgICAgICAgICAgICB3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyIDwgdzNjX3NsaWR5LnNsaWRlcy5sZW5ndGggLSAxKQogICAgICB7CiAgICAgICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICAgdzNjX3NsaWR5LmhpZGVfc2xpZGUoc2xpZGUpOwoKICAgICAgICAgdzNjX3NsaWR5LnNsaWRlX251bWJlciA9IHczY19zbGlkeS5zbGlkZV9udW1iZXIgKyAxOwogICAgICAgICBzbGlkZSA9IHczY19zbGlkeS5zbGlkZXNbdzNjX3NsaWR5LnNsaWRlX251bWJlcl07CiAgICAgICAgIHczY19zbGlkeS5sYXN0X3Nob3duID0gbnVsbDsKICAgICAgICAgdzNjX3NsaWR5LnNldF92aXNpYmlsaXR5X2FsbF9pbmNyZW1lbnRhbCgiaGlkZGVuIik7CiAgICAgICAgIHczY19zbGlkeS5zaG93X3NsaWRlKHNsaWRlKTsKICAgICAgfQogICAgICBlbHNlIGlmICghdzNjX3NsaWR5Lmxhc3Rfc2hvd24pCiAgICAgIHsKICAgICAgICAgaWYgKGxhc3QgJiYgaW5jcmVtZW50YWwpCiAgICAgICAgICAgdzNjX3NsaWR5Lmxhc3Rfc2hvd24gPSBsYXN0OwogICAgICB9CgogICAgICB3M2Nfc2xpZHkuc2V0X2xvY2F0aW9uKCk7CgogICAgICB3M2Nfc2xpZHkuc2V0X2Vvc19zdGF0dXMoIXczY19zbGlkeS5uZXh0X2luY3JlbWVudGFsX2l0ZW0odzNjX3NsaWR5Lmxhc3Rfc2hvd24pKTsKCiAgICAgIGlmICghdzNjX3NsaWR5Lm5zX3BvcykKICAgICAgICAgdzNjX3NsaWR5LnJlZnJlc2hfdG9vbGJhcigyMDApOwogICAgIH0KICB9LAoKICAvLyB0byBmaXJzdCBzbGlkZSB3aXRoIG5vdGhpbmcgcmV2ZWFsZWQKICAvLyBpLmUuIHN0YXRlIGF0IHN0YXJ0IG9mIHByZXNlbnRhdGlvbgogIGZpcnN0X3NsaWRlOiBmdW5jdGlvbiAoKSB7CiAgICAgaWYgKCF3M2Nfc2xpZHkudmlld19hbGwpCiAgICAgewogICAgICAgdmFyIHNsaWRlOwoKICAgICAgIGlmICh3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyICE9IDApCiAgICAgICB7CiAgICAgICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICAgdzNjX3NsaWR5LmhpZGVfc2xpZGUoc2xpZGUpOwoKICAgICAgICAgdzNjX3NsaWR5LnNsaWRlX251bWJlciA9IDA7CiAgICAgICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICAgdzNjX3NsaWR5Lmxhc3Rfc2hvd24gPSBudWxsOwogICAgICAgICB3M2Nfc2xpZHkuc2V0X3Zpc2liaWxpdHlfYWxsX2luY3JlbWVudGFsKCJoaWRkZW4iKTsKICAgICAgICAgdzNjX3NsaWR5LnNob3dfc2xpZGUoc2xpZGUpOwogICAgICAgfQoKICAgICAgIHczY19zbGlkeS5zZXRfZW9zX3N0YXR1cygKICAgICAgICAgIXczY19zbGlkeS5uZXh0X2luY3JlbWVudGFsX2l0ZW0odzNjX3NsaWR5Lmxhc3Rfc2hvd24pKTsKICAgICAgIHczY19zbGlkeS5zZXRfbG9jYXRpb24oKTsKICAgICB9CiAgfSwKCiAgLy8gZ290byBsYXN0IHNsaWRlIHdpdGggZXZlcnl0aGluZyByZXZlYWxlZAogIC8vIGkuZS4gc3RhdGUgYXQgZW5kIG9mIHByZXNlbnRhdGlvbgogIGxhc3Rfc2xpZGU6IGZ1bmN0aW9uICgpIHsKICAgIGlmICghdzNjX3NsaWR5LnZpZXdfYWxsKQogICAgewogICAgICB2YXIgc2xpZGU7CgogICAgICB3M2Nfc2xpZHkubGFzdF9zaG93biA9IG51bGw7IC8vcmV2ZWFsTmV4dEl0ZW0obGFzdFNob3duKTsKCiAgICAgIGlmICh3M2Nfc2xpZHkubGFzdF9zaG93biA9PSBudWxsICYmCiAgICAgICAgICB3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyIDwgdzNjX3NsaWR5LnNsaWRlcy5sZW5ndGggLSAxKQogICAgICB7CiAgICAgICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgICAgICAgdzNjX3NsaWR5LmhpZGVfc2xpZGUoc2xpZGUpOwogICAgICAgICB3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyID0gdzNjX3NsaWR5LnNsaWRlcy5sZW5ndGggLSAxOwogICAgICAgICBzbGlkZSA9IHczY19zbGlkeS5zbGlkZXNbdzNjX3NsaWR5LnNsaWRlX251bWJlcl07CiAgICAgICAgIHczY19zbGlkeS5zZXRfdmlzaWJpbGl0eV9hbGxfaW5jcmVtZW50YWwoInZpc2libGUiKTsKICAgICAgICAgdzNjX3NsaWR5Lmxhc3Rfc2hvd24gPSB3M2Nfc2xpZHkucHJldmlvdXNfaW5jcmVtZW50YWxfaXRlbShudWxsKTsKCiAgICAgICAgIHczY19zbGlkeS5zaG93X3NsaWRlKHNsaWRlKTsKICAgICAgfQogICAgICBlbHNlCiAgICAgIHsKICAgICAgICAgdzNjX3NsaWR5LnNldF92aXNpYmlsaXR5X2FsbF9pbmNyZW1lbnRhbCgidmlzaWJsZSIpOwogICAgICAgICB3M2Nfc2xpZHkubGFzdF9zaG93biA9IHczY19zbGlkeS5wcmV2aW91c19pbmNyZW1lbnRhbF9pdGVtKG51bGwpOwogICAgICB9CgogICAgICB3M2Nfc2xpZHkuc2V0X2Vvc19zdGF0dXModHJ1ZSk7CiAgICAgIHczY19zbGlkeS5zZXRfbG9jYXRpb24oKTsKICAgIH0KICB9LAoKCiAgLy8gIyMjIGNoZWNrIHRoaXMgYW5kIGNvbnNpZGVyIGFkZC9yZW1vdmUgY2xhc3MKICBzZXRfZW9zX3N0YXR1czogZnVuY3Rpb24gKHN0YXRlKSB7CiAgICBpZiAodGhpcy5lb3MpCiAgICAgIHRoaXMuZW9zLnN0eWxlLmNvbG9yID0gKHN0YXRlID8gInJnYigyNDAsMjQwLDI0MCkiIDogInJlZCIpOwogIH0sCgogIC8vIGZpcnN0IHNsaWRlIGlzIDAKICBnb3RvX3NsaWRlOiBmdW5jdGlvbiAobnVtKSB7CiAgICAvL2FsZXJ0KCJnb2luZyB0byBzbGlkZSAiICsgKG51bSsxKSk7CiAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgdzNjX3NsaWR5LmhpZGVfc2xpZGUoc2xpZGUpOwogICAgdzNjX3NsaWR5LnNsaWRlX251bWJlciA9IG51bTsKICAgIHNsaWRlID0gdzNjX3NsaWR5LnNsaWRlc1t3M2Nfc2xpZHkuc2xpZGVfbnVtYmVyXTsKICAgIHczY19zbGlkeS5sYXN0X3Nob3duID0gbnVsbDsKICAgIHczY19zbGlkeS5zZXRfdmlzaWJpbGl0eV9hbGxfaW5jcmVtZW50YWwoImhpZGRlbiIpOwogICAgdzNjX3NsaWR5LnNldF9lb3Nfc3RhdHVzKCF3M2Nfc2xpZHkubmV4dF9pbmNyZW1lbnRhbF9pdGVtKHczY19zbGlkeS5sYXN0X3Nob3duKSk7CiAgICBkb2N1bWVudC50aXRsZSA9IHczY19zbGlkeS50aXRsZSArICIgKCIgKyAodzNjX3NsaWR5LnNsaWRlX251bWJlcisxKSArICIpIjsKICAgIHczY19zbGlkeS5zaG93X3NsaWRlKHNsaWRlKTsKICAgIHczY19zbGlkeS5zaG93X3NsaWRlX251bWJlcigpOwogIH0sCgoKICBzaG93X3NsaWRlOiBmdW5jdGlvbiAoc2xpZGUpIHsKICAgIHRoaXMuc3luY19iYWNrZ3JvdW5kKHNsaWRlKTsKICAgIHRoaXMucmVtb3ZlX2NsYXNzKHNsaWRlLCAiaGlkZGVuIik7CgogICAgLy8gd29yayBhcm91bmQgSUU5IG9iamVjdCByZW5kZXJpbmcgYnVnCiAgICBzZXRUaW1lb3V0KCJ3aW5kb3cuc2Nyb2xsVG8oMCwwKTsiLCAxKTsKICB9LAoKICBoaWRlX3NsaWRlOiBmdW5jdGlvbiAoc2xpZGUpIHsKICAgIHRoaXMuYWRkX2NsYXNzKHNsaWRlLCAiaGlkZGVuIik7CiAgfSwKCiAgc2V0X2ZvY3VzOiBmdW5jdGlvbiAoZWxlbWVudCkKICB7CiAgICBpZiAoZWxlbWVudCkKICAgICAgZWxlbWVudC5mb2N1cygpOwogICAgZWxzZQogICAgewogICAgICB3M2Nfc2xpZHkuaGVscF9hbmNob3IuZm9jdXMoKTsKCiAgICAgIHNldFRpbWVvdXQoZnVuY3Rpb24oKSB7CiAgICAgICAgdzNjX3NsaWR5LmhlbHBfYW5jaG9yLmJsdXIoKTsKICAgICAgfSwgMSk7CiAgICB9CiAgfSwKCiAgLy8gc2hvdyBqdXN0IHRoZSBiYWNrZ3JvdW5kcyBwZXJ0aW5lbnQgdG8gdGhpcyBzbGlkZQogIC8vIHdoZW4gc2xpZGUgYmFja2dyb3VuZC1jb2xvciBpcyB0cmFuc3BhcmVudAogIC8vIHRoaXMgc2hvdWxkIG5vdyB3b3JrIHdpdGggcmdiYSBjb2xvciB2YWx1ZXMKICBzeW5jX2JhY2tncm91bmQ6IGZ1bmN0aW9uIChzbGlkZSkgewogICAgdmFyIGJhY2tncm91bmQ7CiAgICB2YXIgYmdDb2xvcjsKCiAgICBpZiAoc2xpZGUuY3VycmVudFN0eWxlKQogICAgICBiZ0NvbG9yID0gc2xpZGUuY3VycmVudFN0eWxlWyJiYWNrZ3JvdW5kQ29sb3IiXTsKICAgIGVsc2UgaWYgKGRvY3VtZW50LmRlZmF1bHRWaWV3KQogICAgewogICAgICB2YXIgc3R5bGVzID0gZG9jdW1lbnQuZGVmYXVsdFZpZXcuZ2V0Q29tcHV0ZWRTdHlsZShzbGlkZSxudWxsKTsKCiAgICAgIGlmIChzdHlsZXMpCiAgICAgICAgYmdDb2xvciA9IHN0eWxlcy5nZXRQcm9wZXJ0eVZhbHVlKCJiYWNrZ3JvdW5kLWNvbG9yIik7CiAgICAgIGVsc2UgLy8gYnJva2VuIGltcGxlbWVudGF0aW9uIHByb2JhYmx5IGR1ZSBTYWZhcmkgb3IgS29ucXVlcm9yCiAgICAgIHsKICAgICAgICAvL2FsZXJ0KCJkZWZlY3RpdmUgaW1wbGVtZW50YXRpb24gb2YgZ2V0Q29tcHV0ZWRTdHlsZSgpIik7CiAgICAgICAgYmdDb2xvciA9ICJ0cmFuc3BhcmVudCI7CiAgICAgIH0KICAgIH0KICAgIGVsc2UKICAgICAgYmdDb2xvciA9PSAidHJhbnNwYXJlbnQiOwoKICAgIGlmIChiZ0NvbG9yID09ICJ0cmFuc3BhcmVudCIgfHwKICAgICAgICBiZ0NvbG9yLmluZGV4T2YoInJnYmEiKSA+PSAwIHx8CiAgICAgICAgYmdDb2xvci5pbmRleE9mKCJvcGFjaXR5IikgPj0gMCkKICAgIHsKICAgICAgdmFyIHNsaWRlQ2xhc3MgPSB0aGlzLmdldF9jbGFzc19saXN0KHNsaWRlKTsKCiAgICAgIGZvciAodmFyIGkgPSAwOyBpIDwgdGhpcy5iYWNrZ3JvdW5kcy5sZW5ndGg7IGkrKykKICAgICAgewogICAgICAgIGJhY2tncm91bmQgPSB0aGlzLmJhY2tncm91bmRzW2ldOwoKICAgICAgICB2YXIgYmdDbGFzcyA9IHRoaXMuZ2V0X2NsYXNzX2xpc3QoYmFja2dyb3VuZCk7CgogICAgICAgIGlmICh0aGlzLm1hdGNoaW5nX2JhY2tncm91bmQoc2xpZGVDbGFzcywgYmdDbGFzcykpCiAgICAgICAgICB0aGlzLnJlbW92ZV9jbGFzcyhiYWNrZ3JvdW5kLCAiaGlkZGVuIik7CiAgICAgICAgZWxzZQogICAgICAgICAgdGhpcy5hZGRfY2xhc3MoYmFja2dyb3VuZCwgImhpZGRlbiIpOwogICAgICB9CiAgICB9CiAgICBlbHNlIC8vIGZvcmNpYmx5IGhpZGUgYWxsIGJhY2tncm91bmRzCiAgICAgIHRoaXMuaGlkZV9iYWNrZ3JvdW5kcygpOwogIH0sCgogIGhpZGVfYmFja2dyb3VuZHM6IGZ1bmN0aW9uICgpIHsKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgdGhpcy5iYWNrZ3JvdW5kcy5sZW5ndGg7IGkrKykKICAgIHsKICAgICAgYmFja2dyb3VuZCA9IHRoaXMuYmFja2dyb3VuZHNbaV07CiAgICAgIHRoaXMuYWRkX2NsYXNzKGJhY2tncm91bmQsICJoaWRkZW4iKTsKICAgIH0KICB9LAoKICAvLyBjb21wYXJlIGNsYXNzZXMgZm9yIHNsaWRlIGFuZCBiYWNrZ3JvdW5kCiAgbWF0Y2hpbmdfYmFja2dyb3VuZDogZnVuY3Rpb24gKHNsaWRlQ2xhc3MsIGJnQ2xhc3MpIHsKICAgIHZhciBpLCBjb3VudCwgcGF0dGVybiwgcmVzdWx0OwoKICAgIC8vIGRlZmluZSBwYXR0ZXJuIGFzIHJlZ3VsYXIgZXhwcmVzc2lvbgogICAgcGF0dGVybiA9IC9cdysvZzsKCiAgICAvLyBjaGVjayBiYWNrZ3JvdW5kIGNsYXNzIG5hbWVzCiAgICByZXN1bHQgPSBiZ0NsYXNzLm1hdGNoKHBhdHRlcm4pOwoKICAgIGZvciAoaSA9IGNvdW50ID0gMDsgaSA8IHJlc3VsdC5sZW5ndGg7IGkrKykKICAgIHsKICAgICAgaWYgKHJlc3VsdFtpXSA9PSAiaGlkZGVuIikKICAgICAgICBjb250aW51ZTsKCiAgICAgIGlmIChyZXN1bHRbaV0gPT0gImJhY2tncm91bmQiKQoJY29udGludWU7CgogICAgICArK2NvdW50OwogICAgfQoKICAgIGlmIChjb3VudCA9PSAwKSAgLy8gZGVmYXVsdCBtYXRjaAogICAgICByZXR1cm4gdHJ1ZTsKCiAgICAvLyBjaGVjayBmb3IgbWF0Y2hlcyBhbmQgcGxhY2UgcmVzdWx0IGluIGFycmF5CiAgICByZXN1bHQgPSBzbGlkZUNsYXNzLm1hdGNoKHBhdHRlcm4pOwoKICAgIC8vIG5vdyBjaGVjayBpZiBkZXNpcmVkIG5hbWUgaXMgcHJlc2VudCBmb3IgYmFja2dyb3VuZAogICAgZm9yIChpID0gY291bnQgPSAwOyBpIDwgcmVzdWx0Lmxlbmd0aDsgaSsrKQogICAgewogICAgICBpZiAocmVzdWx0W2ldID09ICJoaWRkZW4iKQogICAgICAgIGNvbnRpbnVlOwoKICAgICAgaWYgKHRoaXMuaGFzX3Rva2VuKGJnQ2xhc3MsIHJlc3VsdFtpXSkpCiAgICAgICAgcmV0dXJuIHRydWU7CiAgICB9CgogICAgcmV0dXJuIGZhbHNlOwogIH0sCgogIHJlc2l6ZWQ6IGZ1bmN0aW9uICgpIHsKICAgICB2YXIgd2lkdGggPSAwOwoKICAgICBpZiAoIHR5cGVvZiggd2luZG93LmlubmVyV2lkdGggKSA9PSAnbnVtYmVyJyApCiAgICAgICB3aWR0aCA9IHdpbmRvdy5pbm5lcldpZHRoOyAgLy8gTm9uIElFIGJyb3dzZXIKICAgICBlbHNlIGlmIChkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQgJiYgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmNsaWVudFdpZHRoKQogICAgICAgd2lkdGggPSBkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuY2xpZW50V2lkdGg7ICAvLyBJRTYKICAgICBlbHNlIGlmIChkb2N1bWVudC5ib2R5ICYmIGRvY3VtZW50LmJvZHkuY2xpZW50V2lkdGgpCiAgICAgICB3aWR0aCA9IGRvY3VtZW50LmJvZHkuY2xpZW50V2lkdGg7IC8vIElFNAoKICAgICB2YXIgaGVpZ2h0ID0gMDsKCiAgICAgaWYgKCB0eXBlb2YoIHdpbmRvdy5pbm5lckhlaWdodCApID09ICdudW1iZXInICkKICAgICAgIGhlaWdodCA9IHdpbmRvdy5pbm5lckhlaWdodDsgIC8vIE5vbiBJRSBicm93c2VyCiAgICAgZWxzZSBpZiAoZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50ICYmIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5jbGllbnRIZWlnaHQpCiAgICAgICBoZWlnaHQgPSBkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuY2xpZW50SGVpZ2h0OyAgLy8gSUU2CiAgICAgZWxzZSBpZiAoZG9jdW1lbnQuYm9keSAmJiBkb2N1bWVudC5ib2R5LmNsaWVudEhlaWdodCkKICAgICAgIGhlaWdodCA9IGRvY3VtZW50LmJvZHkuY2xpZW50SGVpZ2h0OyAvLyBJRTQKCiAgICAgaWYgKGhlaWdodCAmJiAod2lkdGgvaGVpZ2h0ID4gMS4wNSoxMDI0Lzc2OCkpCiAgICAgewogICAgICAgd2lkdGggPSBoZWlnaHQgKiAxMDI0LjAvNzY4OwogICAgIH0KCiAgICAgLy8gSUUgZmlyZXMgb25yZXNpemUgZXZlbiB3aGVuIG9ubHkgZm9udCBzaXplIGlzIGNoYW5nZWQhCiAgICAgLy8gc28gd2UgZG8gYSBjaGVjayB0byBhdm9pZCBibG9ja2luZyA8IGFuZCA+IGFjdGlvbnMKICAgICBpZiAod2lkdGggIT0gdzNjX3NsaWR5Lmxhc3Rfd2lkdGggfHwgaGVpZ2h0ICE9IHczY19zbGlkeS5sYXN0X2hlaWdodCkKICAgICB7CiAgICAgICBpZiAod2lkdGggPj0gMTEwMCkKICAgICAgICAgdzNjX3NsaWR5LnNpemVfaW5kZXggPSA1OyAgICAvLyA0CiAgICAgICBlbHNlIGlmICh3aWR0aCA+PSAxMDAwKQogICAgICAgICB3M2Nfc2xpZHkuc2l6ZV9pbmRleCA9IDQ7ICAgIC8vIDMKICAgICAgIGVsc2UgaWYgKHdpZHRoID49IDgwMCkKICAgICAgICAgdzNjX3NsaWR5LnNpemVfaW5kZXggPSAzOyAgICAvLyAyCiAgICAgICBlbHNlIGlmICh3aWR0aCA+PSA2MDApCiAgICAgICAgIHczY19zbGlkeS5zaXplX2luZGV4ID0gMjsgICAgLy8gMQogICAgICAgZWxzZSBpZiAod2lkdGgpCiAgICAgICAgIHczY19zbGlkeS5zaXplX2luZGV4ID0gMDsKCiAgICAgICAvLyBhZGQgaW4gZm9udCBzaXplIGFkanVzdG1lbnQgZnJvbSBtZXRhIGVsZW1lbnQgZS5nLgogICAgICAgLy8gPG1ldGEgbmFtZT0iZm9udC1zaXplLWFkanVzdG1lbnQiIGNvbnRlbnQ9Ii0yIiAvPgogICAgICAgLy8gdXNlZnVsIHdoZW4gc2xpZGVzIGhhdmUgdG9vIG11Y2ggY29udGVudCA7LSkKCiAgICAgICBpZiAoMCA8PSB3M2Nfc2xpZHkuc2l6ZV9pbmRleCArIHczY19zbGlkeS5zaXplX2FkanVzdG1lbnQgJiYKICAgICAgICAgICAgIHczY19zbGlkeS5zaXplX2luZGV4ICsgdzNjX3NsaWR5LnNpemVfYWRqdXN0bWVudCA8IHczY19zbGlkeS5zaXplcy5sZW5ndGgpCiAgICAgICAgIHczY19zbGlkeS5zaXplX2luZGV4ID0gdzNjX3NsaWR5LnNpemVfaW5kZXggKyB3M2Nfc2xpZHkuc2l6ZV9hZGp1c3RtZW50OwoKICAgICAgIC8vIGVuYWJsZXMgY3Jvc3MgYnJvd3NlciB1c2Ugb2YgcmVsYXRpdmUgd2lkdGgvaGVpZ2h0CiAgICAgICAvLyBvbiBvYmplY3QgZWxlbWVudHMgZm9yIHVzZSB3aXRoIFNWRyBhbmQgRmxhc2ggbWVkaWEKICAgICAgIHczY19zbGlkeS5hZGp1c3Rfb2JqZWN0X2RpbWVuc2lvbnMod2lkdGgsIGhlaWdodCk7CgogICAgICAgaWYgKGRvY3VtZW50LmJvZHkuc3R5bGUuZm9udFNpemUgIT0gdzNjX3NsaWR5LnNpemVzW3czY19zbGlkeS5zaXplX2luZGV4XSkKICAgICAgIHsKICAgICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5mb250U2l6ZSA9IHczY19zbGlkeS5zaXplc1t3M2Nfc2xpZHkuc2l6ZV9pbmRleF07CiAgICAgICB9CgogICAgICAgdzNjX3NsaWR5Lmxhc3Rfd2lkdGggPSB3aWR0aDsKICAgICAgIHczY19zbGlkeS5sYXN0X2hlaWdodCA9IGhlaWdodDsKCiAgICAgICAvLyBmb3JjZSByZWZsb3cgdG8gd29yayBhcm91bmQgTW96aWxsYSBidWcKICAgICAgIGlmICh3M2Nfc2xpZHkubnNfcG9zKQogICAgICAgewogICAgICAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgICAgICB3M2Nfc2xpZHkuaGlkZV9zbGlkZShzbGlkZSk7CiAgICAgICAgIHczY19zbGlkeS5zaG93X3NsaWRlKHNsaWRlKTsKICAgICAgIH0KCiAgICAgICAvLyBmb3JjZSBjb3JyZWN0IHBvc2l0aW9uaW5nIG9mIHRvb2xiYXIKICAgICAgIHczY19zbGlkeS5yZWZyZXNoX3Rvb2xiYXIoMjAwKTsKICAgICB9CiAgfSwKCiAgc2Nyb2xsZWQ6IGZ1bmN0aW9uICgpIHsKICAgIGlmICh3M2Nfc2xpZHkudG9vbGJhciAmJiAhdzNjX3NsaWR5Lm5zX3BvcyAmJiAhdzNjX3NsaWR5LmllNykKICAgIHsKICAgICAgdzNjX3NsaWR5LmhhY2tfb2Zmc2V0ID0gdzNjX3NsaWR5LnNjcm9sbF94X29mZnNldCgpOwogICAgICAvLyBoaWRlIHRvb2xiYXIKICAgICAgdzNjX3NsaWR5LnRvb2xiYXIuc3R5bGUuZGlzcGxheSA9ICJub25lIjsKCiAgICAgIC8vIG1ha2UgaXQgcmVhcHBlYXIgbGF0ZXIKICAgICAgaWYgKHczY19zbGlkeS5zY3JvbGxoYWNrID09IDAgJiYgIXczY19zbGlkeS52aWV3X2FsbCkKICAgICAgewogICAgICAgIHNldFRpbWVvdXQoZnVuY3Rpb24gKCkge3czY19zbGlkeS5zaG93X3Rvb2xiYXIoKTsgfSwgMTAwMCk7CiAgICAgICAgdzNjX3NsaWR5LnNjcm9sbGhhY2sgPSAxOwogICAgICB9CiAgICB9CiAgfSwKCiAgaGlkZV90b29sYmFyOiBmdW5jdGlvbiAoKSB7CiAgICB3M2Nfc2xpZHkuYWRkX2NsYXNzKHczY19zbGlkeS50b29sYmFyLCAiaGlkZGVuIik7CiAgICB3aW5kb3cuZm9jdXMoKTsKICB9LAoKICAvLyB1c2VkIHRvIGVuc3VyZSBJRSByZWZyZXNoZXMgdG9vbGJhciBpbiBjb3JyZWN0IHBvc2l0aW9uCiAgcmVmcmVzaF90b29sYmFyOiBmdW5jdGlvbiAoaW50ZXJ2YWwpIHsKICAgIGlmICghdzNjX3NsaWR5Lm5zX3BvcyAmJiAhdzNjX3NsaWR5LmllNykKICAgIHsKICAgICAgdzNjX3NsaWR5LmhpZGVfdG9vbGJhcigpOwogICAgICBzZXRUaW1lb3V0KGZ1bmN0aW9uICgpIHt3M2Nfc2xpZHkuc2hvd190b29sYmFyKCk7fSwgaW50ZXJ2YWwpOwogICAgfQogIH0sCgogIC8vIHJlc3RvcmVzIHRvb2xiYXIgYWZ0ZXIgc2hvcnQgZGVsYXkKICBzaG93X3Rvb2xiYXI6IGZ1bmN0aW9uICgpIHsKICAgIGlmICh3M2Nfc2xpZHkud2FudF90b29sYmFyKQogICAgewogICAgICB3M2Nfc2xpZHkudG9vbGJhci5zdHlsZS5kaXNwbGF5ID0gImJsb2NrIjsKCiAgICAgIGlmICghdzNjX3NsaWR5Lm5zX3BvcykKICAgICAgewogICAgICAgIC8vIGFkanVzdCBwb3NpdGlvbiB0byBhbGxvdyBmb3Igc2Nyb2xsaW5nCiAgICAgICAgdmFyIHhvZmZzZXQgPSB3M2Nfc2xpZHkuc2Nyb2xsX3hfb2Zmc2V0KCk7CiAgICAgICAgdzNjX3NsaWR5LnRvb2xiYXIuc3R5bGUubGVmdCA9IHhvZmZzZXQ7CiAgICAgICAgdzNjX3NsaWR5LnRvb2xiYXIuc3R5bGUucmlnaHQgPSB4b2Zmc2V0OwoKICAgICAgICAvLyBkZXRlcm1pbmUgdmVydGljYWwgc2Nyb2xsIG9mZnNldAogICAgICAgIC8vdmFyIHlvZmZzZXQgPSBzY3JvbGxZT2Zmc2V0KCk7CgogICAgICAgIC8vIGJvdHRvbSBpcyBkb2MgaGVpZ2h0IC0gd2luZG93IGhlaWdodCAtIHNjcm9sbCBvZmZzZXQKICAgICAgICAvL3ZhciBib3R0b20gPSBkb2N1bWVudEhlaWdodCgpIC0gbGFzdEhlaWdodCAtIHlvZmZzZXQKCiAgICAgICAgLy9pZiAoeW9mZnNldCA+IDAgfHwgZG9jdW1lbnRIZWlnaHQoKSA+IGxhc3RIZWlnaHQpCiAgICAgICAgLy8gICBib3R0b20gKz0gMTY7ICAvLyBhbGxvdyBmb3IgaGVpZ2h0IG9mIHNjcm9sbGJhcgoKICAgICAgICB3M2Nfc2xpZHkudG9vbGJhci5zdHlsZS5ib3R0b20gPSAwOyAvL2JvdHRvbTsKICAgICAgfQoKICAgICAgdzNjX3NsaWR5LnJlbW92ZV9jbGFzcyh3M2Nfc2xpZHkudG9vbGJhciwgImhpZGRlbiIpOwogICAgfQoKICAgIHczY19zbGlkeS5zY3JvbGxoYWNrID0gMDsKCgogICAgLy8gc2V0IHRoZSBrZXlib2FyZCBmb2N1cyB0byB0aGUgaGVscCBsaW5rIG9uIHRoZQogICAgLy8gdG9vbGJhciB0byBlbnN1cmUgdGhhdCBkb2N1bWVudCBoYXMgdGhlIGZvY3VzCiAgICAvLyBJRSBkb2Vzbid0IGFsd2F5cyB3b3JrIHdpdGggd2luZG93LmZvY3VzKCkKICAgIC8vIGFuZCB0aGlzIGhhY2sgaGFzIGJlbmVmaXQgb2YgRW50ZXIgZm9yIGhlbHAKCiAgICB0cnkKICAgIHsKICAgICAgaWYgKCF3M2Nfc2xpZHkub3BlcmEpCiAgICAgICAgdzNjX3NsaWR5LnNldF9mb2N1cygpOwogICAgfQogICAgY2F0Y2ggKGUpCiAgICB7CiAgICB9CiAgfSwKCi8vIGludm9rZWQgdmlhIEYga2V5CiAgdG9nZ2xlX3Rvb2xiYXI6IGZ1bmN0aW9uICgpIHsKICAgIGlmICghdzNjX3NsaWR5LnZpZXdfYWxsKQogICAgewogICAgICBpZiAodzNjX3NsaWR5Lmhhc19jbGFzcyh3M2Nfc2xpZHkudG9vbGJhciwgImhpZGRlbiIpKQogICAgICB7CiAgICAgICAgdzNjX3NsaWR5LnJlbW92ZV9jbGFzcyh3M2Nfc2xpZHkudG9vbGJhciwgImhpZGRlbiIpCiAgICAgICAgdzNjX3NsaWR5LndhbnRfdG9vbGJhciA9IDE7CiAgICAgIH0KICAgICAgZWxzZQogICAgICB7CiAgICAgICAgdzNjX3NsaWR5LmFkZF9jbGFzcyh3M2Nfc2xpZHkudG9vbGJhciwgImhpZGRlbiIpCiAgICAgICAgdzNjX3NsaWR5LndhbnRfdG9vbGJhciA9IDA7CiAgICAgIH0KICAgIH0KICB9LAoKICBzY3JvbGxfeF9vZmZzZXQ6IGZ1bmN0aW9uICgpIHsKICAgIGlmICh3aW5kb3cucGFnZVhPZmZzZXQpCiAgICAgIHJldHVybiBzZWxmLnBhZ2VYT2Zmc2V0OwoKICAgIGlmIChkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQgJiYgCiAgICAgICAgICAgICBkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuc2Nyb2xsTGVmdCkKICAgICAgcmV0dXJuIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zY3JvbGxMZWZ0OwoKICAgIGlmIChkb2N1bWVudC5ib2R5KQogICAgICByZXR1cm4gZG9jdW1lbnQuYm9keS5zY3JvbGxMZWZ0OwoKICAgIHJldHVybiAwOwogIH0sCgogIHNjcm9sbF95X29mZnNldDogZnVuY3Rpb24gKCkgewogICAgaWYgKHdpbmRvdy5wYWdlWU9mZnNldCkKICAgICAgcmV0dXJuIHNlbGYucGFnZVlPZmZzZXQ7CgogICAgaWYgKGRvY3VtZW50LmRvY3VtZW50RWxlbWVudCAmJiAKICAgICAgICAgICAgIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zY3JvbGxUb3ApCiAgICAgIHJldHVybiBkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuc2Nyb2xsVG9wOwoKICAgIGlmIChkb2N1bWVudC5ib2R5KQogICAgICByZXR1cm4gZG9jdW1lbnQuYm9keS5zY3JvbGxUb3A7CgogICAgcmV0dXJuIDA7CiAgfSwKCiAgLy8gbG9va2luZyBmb3IgYSB3YXkgdG8gZGV0ZXJtaW5lIGhlaWdodCBvZiBzbGlkZSBjb250ZW50CiAgLy8gdGhlIHNsaWRlIGl0c2VsZiBpcyBzZXQgdG8gdGhlIGhlaWdodCBvZiB0aGUgd2luZG93CiAgb3B0aW1pemVfZm9udF9zaXplOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwoKICAgIC8vdmFyIGRoID0gZG9jdW1lbnRIZWlnaHQoKTsgLy9nZXREb2NIZWlnaHQoZG9jdW1lbnQpOwogICAgdmFyIGRoID0gc2xpZGUuc2Nyb2xsSGVpZ2h0OwogICAgdmFyIHdoID0gZ2V0V2luZG93SGVpZ2h0KCk7CiAgICB2YXIgdSA9IDEwMCAqIGRoIC8gd2g7CgogICAgYWxlcnQoIndpbmRvdyB1dGlsaXphdGlvbiA9ICIgKyB1ICsgIiUgKGRvYyAiCiAgICAgICsgZGggKyAiIHdpbiAiICsgd2ggKyAiKSIpOwogIH0sCgogIC8vIGZyb20gZG9jdW1lbnQgb2JqZWN0CiAgZ2V0X2RvY19oZWlnaHQ6IGZ1bmN0aW9uIChkb2MpIHsKICAgIGlmICghZG9jKQogICAgICBkb2MgPSBkb2N1bWVudDsKCiAgICBpZiAoZG9jICYmIGRvYy5ib2R5ICYmIGRvYy5ib2R5Lm9mZnNldEhlaWdodCkKICAgICAgcmV0dXJuIGRvYy5ib2R5Lm9mZnNldEhlaWdodDsgIC8vIG5zL2dlY2tvIHN5bnRheAoKICAgIGlmIChkb2MgJiYgZG9jLmJvZHkgJiYgZG9jLmJvZHkuc2Nyb2xsSGVpZ2h0KQogICAgICByZXR1cm4gZG9jLmJvZHkuc2Nyb2xsSGVpZ2h0OwoKICAgIGFsZXJ0KCJjb3VsZG4ndCBkZXRlcm1pbmUgZG9jdW1lbnQgaGVpZ2h0Iik7CiAgfSwKCiAgZ2V0X3dpbmRvd19oZWlnaHQ6IGZ1bmN0aW9uICgpIHsKICAgIGlmICggdHlwZW9mKCB3aW5kb3cuaW5uZXJIZWlnaHQgKSA9PSAnbnVtYmVyJyApCiAgICAgIHJldHVybiB3aW5kb3cuaW5uZXJIZWlnaHQ7ICAvLyBOb24gSUUgYnJvd3NlcgoKICAgIGlmIChkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQgJiYgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmNsaWVudEhlaWdodCkKICAgICAgcmV0dXJuIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5jbGllbnRIZWlnaHQ7ICAvLyBJRTYKCiAgICBpZiAoZG9jdW1lbnQuYm9keSAmJiBkb2N1bWVudC5ib2R5LmNsaWVudEhlaWdodCkKICAgICAgcmV0dXJuIGRvY3VtZW50LmJvZHkuY2xpZW50SGVpZ2h0OyAvLyBJRTQKICB9LAoKICBkb2N1bWVudF9oZWlnaHQ6IGZ1bmN0aW9uICgpIHsKICAgIHZhciBzaCwgb2g7CgogICAgc2ggPSBkb2N1bWVudC5ib2R5LnNjcm9sbEhlaWdodDsKICAgIG9oID0gZG9jdW1lbnQuYm9keS5vZmZzZXRIZWlnaHQ7CgogICAgaWYgKHNoICYmIG9oKQogICAgewogICAgICByZXR1cm4gKHNoID4gb2ggPyBzaCA6IG9oKTsKICAgIH0KCiAgICAvLyBubyBpZGVhIQogICAgcmV0dXJuIDA7CiAgfSwKCiAgc21hbGxlcjogZnVuY3Rpb24gKCkgewogICAgaWYgKHczY19zbGlkeS5zaXplX2luZGV4ID4gMCkKICAgIHsKICAgICAgLS13M2Nfc2xpZHkuc2l6ZV9pbmRleDsKICAgIH0KCiAgICB3M2Nfc2xpZHkudG9vbGJhci5zdHlsZS5kaXNwbGF5ID0gIm5vbmUiOwogICAgZG9jdW1lbnQuYm9keS5zdHlsZS5mb250U2l6ZSA9IHczY19zbGlkeS5zaXplc1t3M2Nfc2xpZHkuc2l6ZV9pbmRleF07CiAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgdzNjX3NsaWR5LmhpZGVfc2xpZGUoc2xpZGUpOwogICAgdzNjX3NsaWR5LnNob3dfc2xpZGUoc2xpZGUpOwogICAgc2V0VGltZW91dChmdW5jdGlvbiAoKSB7dzNjX3NsaWR5LnNob3dfdG9vbGJhcigpOyB9LCA1MCk7CiAgfSwKCiAgYmlnZ2VyOiBmdW5jdGlvbiAoKSB7CiAgICBpZiAodzNjX3NsaWR5LnNpemVfaW5kZXggPCB3M2Nfc2xpZHkuc2l6ZXMubGVuZ3RoIC0gMSkKICAgIHsKICAgICAgKyt3M2Nfc2xpZHkuc2l6ZV9pbmRleDsKICAgIH0KCiAgICB3M2Nfc2xpZHkudG9vbGJhci5zdHlsZS5kaXNwbGF5ID0gIm5vbmUiOwogICAgZG9jdW1lbnQuYm9keS5zdHlsZS5mb250U2l6ZSA9IHczY19zbGlkeS5zaXplc1t3M2Nfc2xpZHkuc2l6ZV9pbmRleF07CiAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwogICAgdzNjX3NsaWR5LmhpZGVfc2xpZGUoc2xpZGUpOwogICAgdzNjX3NsaWR5LnNob3dfc2xpZGUoc2xpZGUpOwogICAgc2V0VGltZW91dChmdW5jdGlvbiAoKSB7dzNjX3NsaWR5LnNob3dfdG9vbGJhcigpOyB9LCA1MCk7CiAgfSwKCiAgLy8gZW5hYmxlcyBjcm9zcyBicm93c2VyIHVzZSBvZiByZWxhdGl2ZSB3aWR0aC9oZWlnaHQKICAvLyBvbiBvYmplY3QgZWxlbWVudHMgZm9yIHVzZSB3aXRoIFNWRyBhbmQgRmxhc2ggbWVkaWEKICAvLyB3aXRoIHRoYW5rcyB0byBJdmFuIEhlcm1hbiBmb3IgdGhlIHN1Z2dlc3Rpb24KICBhZGp1c3Rfb2JqZWN0X2RpbWVuc2lvbnM6IGZ1bmN0aW9uICh3aWR0aCwgaGVpZ2h0KSB7CiAgICBmb3IoIHZhciBpID0gMDsgaSA8IHczY19zbGlkeS5vYmplY3RzLmxlbmd0aDsgaSsrICkKICAgIHsKICAgICAgdmFyIG9iaiA9IHRoaXMub2JqZWN0c1tpXTsKICAgICAgdmFyIG1pbWVUeXBlID0gb2JqLmdldEF0dHJpYnV0ZSgidHlwZSIpOwoKICAgICAgaWYgKG1pbWVUeXBlID09ICJpbWFnZS9zdmcreG1sIiB8fCBtaW1lVHlwZSA9PSAiYXBwbGljYXRpb24veC1zaG9ja3dhdmUtZmxhc2giKQogICAgICB7CiAgICAgICAgaWYgKCAhb2JqLmluaXRpYWxXaWR0aCApIAogICAgICAgICAgb2JqLmluaXRpYWxXaWR0aCA9IG9iai5nZXRBdHRyaWJ1dGUoIndpZHRoIik7CgogICAgICAgIGlmICggIW9iai5pbml0aWFsSGVpZ2h0ICkgCiAgICAgICAgICBvYmouaW5pdGlhbEhlaWdodCA9IG9iai5nZXRBdHRyaWJ1dGUoImhlaWdodCIpOwoKICAgICAgICBpZiAoIG9iai5pbml0aWFsV2lkdGggJiYgb2JqLmluaXRpYWxXaWR0aC5jaGFyQXQob2JqLmluaXRpYWxXaWR0aC5sZW5ndGgtMSkgPT0gIiUiICkKICAgICAgICB7CiAgICAgICAgICB2YXIgdyA9IHBhcnNlSW50KG9iai5pbml0aWFsV2lkdGguc2xpY2UoMCwgb2JqLmluaXRpYWxXaWR0aC5sZW5ndGgtMSkpOwogICAgICAgICAgdmFyIG5ld1cgPSB3aWR0aCAqICh3LzEwMC4wKTsKICAgICAgICAgIG9iai5zZXRBdHRyaWJ1dGUoIndpZHRoIixuZXdXKTsKICAgICAgICB9CgogICAgICAgIGlmICggb2JqLmluaXRpYWxIZWlnaHQgJiYKICAgICAgICAgICAgIG9iai5pbml0aWFsSGVpZ2h0LmNoYXJBdChvYmouaW5pdGlhbEhlaWdodC5sZW5ndGgtMSkgPT0gIiUiICkKICAgICAgICB7CiAgICAgICAgICB2YXIgaCA9IHBhcnNlSW50KG9iai5pbml0aWFsSGVpZ2h0LnNsaWNlKDAsIG9iai5pbml0aWFsSGVpZ2h0Lmxlbmd0aC0xKSk7CiAgICAgICAgICB2YXIgbmV3SCA9IGhlaWdodCAqIChoLzEwMC4wKTsKICAgICAgICAgIG9iai5zZXRBdHRyaWJ1dGUoImhlaWdodCIsIG5ld0gpOwogICAgICAgIH0KICAgICAgfQogICAgfQogIH0sCgogIC8vIG5lZWRlZCBmb3IgT3BlcmEgdG8gaW5oaWJpdCBkZWZhdWx0IGJlaGF2aW9yCiAgLy8gc2luY2UgT3BlcmEgZGVsaXZlcnMga2V5UHJlc3MgZXZlbiBpZiBrZXlEb3duCiAgLy8gd2FzIGNhbmNlbGxlZAogIGtleV9wcmVzczogZnVuY3Rpb24gKGV2ZW50KSB7CiAgICBpZiAoIWV2ZW50KQogICAgICBldmVudCA9IHdpbmRvdy5ldmVudDsKCiAgICBpZiAoIXczY19zbGlkeS5rZXlfd2FudGVkKQogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CgogICAgcmV0dXJuIHRydWU7CiAgfSwKCiAgLy8gIFNlZSBlLmcuIGh0dHA6Ly93d3cucXVpcmtzbW9kZS5vcmcvanMvZXZlbnRzL2tleXMuaHRtbCBmb3Iga2V5Y29kZXMKICBrZXlfZG93bjogZnVuY3Rpb24gKGV2ZW50KSB7CiAgICB2YXIga2V5LCB0YXJnZXQsIHRhZzsKCiAgICB3M2Nfc2xpZHkua2V5X3dhbnRlZCA9IHRydWU7CgogICAgaWYgKCFldmVudCkKICAgICAgZXZlbnQgPSB3aW5kb3cuZXZlbnQ7CgogICAgLy8ga2x1ZGdlIGFyb3VuZCBOUy9JRSBkaWZmZXJlbmNlcyAKICAgIGlmICh3aW5kb3cuZXZlbnQpCiAgICB7CiAgICAgIGtleSA9IHdpbmRvdy5ldmVudC5rZXlDb2RlOwogICAgICB0YXJnZXQgPSB3aW5kb3cuZXZlbnQuc3JjRWxlbWVudDsKICAgIH0KICAgIGVsc2UgaWYgKGV2ZW50LndoaWNoKQogICAgewogICAgICBrZXkgPSBldmVudC53aGljaDsKICAgICAgdGFyZ2V0ID0gZXZlbnQudGFyZ2V0OwogICAgfQogICAgZWxzZQogICAgICByZXR1cm4gdHJ1ZTsgLy8gWWlrZXMhIHVua25vd24gYnJvd3NlcgoKICAgIC8vIGlnbm9yZSBldmVudCBpZiBrZXkgdmFsdWUgaXMgemVybwogICAgLy8gYXMgZm9yIGFsdCBvbiBPcGVyYSBhbmQgS29ucXVlcm9yCiAgICBpZiAoIWtleSkKICAgICAgIHJldHVybiB0cnVlOwoKICAgIC8vIGF2b2lkIGludGVyZmVyaW5nIHdpdGgga2V5c3Ryb2tlCiAgICAvLyBiZWhhdmlvciBmb3Igbm9uLXNsaWR5IGNocm9tZSBlbGVtZW50cwogICAgaWYgKCF3M2Nfc2xpZHkuc2xpZHlfY2hyb21lKHRhcmdldCkgJiYKICAgICAgICB3M2Nfc2xpZHkuc3BlY2lhbF9lbGVtZW50KHRhcmdldCkpCiAgICAgIHJldHVybiB0cnVlOwoKICAgIC8vIGNoZWNrIGZvciBjb25jdXJyZW50IGNvbnRyb2wvY29tbWFuZC9hbHQga2V5CiAgICAvLyBidXQgYXJlIHRoZXNlIG9ubHkgcHJlc2VudCBvbiBtb3VzZSBldmVudHM/CgogICAgaWYgKGV2ZW50LmN0cmxLZXkgfHwgZXZlbnQuYWx0S2V5IHx8IGV2ZW50Lm1ldGFLZXkpCiAgICAgICByZXR1cm4gdHJ1ZTsKCiAgICAvLyBkaXNtaXNzIHRhYmxlIG9mIGNvbnRlbnRzIGlmIHZpc2libGUKICAgIGlmICh3M2Nfc2xpZHkuaXNfc2hvd25fdG9jKCkgJiYga2V5ICE9IDkgJiYga2V5ICE9IDE2ICYmIGtleSAhPSAzOCAmJiBrZXkgIT0gNDApCiAgICB7CiAgICAgIHczY19zbGlkeS5oaWRlX3RhYmxlX29mX2NvbnRlbnRzKHRydWUpOwoKICAgICAgaWYgKGtleSA9PSAyNyB8fCBrZXkgPT0gODQgfHwga2V5ID09IDY3KQogICAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KCiAgICBpZiAoa2V5ID09IDM0KSAvLyBQYWdlIERvd24KICAgIHsKICAgICAgaWYgKHczY19zbGlkeS52aWV3X2FsbCkKICAgICAgICByZXR1cm4gdHJ1ZTsKCiAgICAgIHczY19zbGlkeS5uZXh0X3NsaWRlKGZhbHNlKTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDMzKSAvLyBQYWdlIFVwCiAgICB7CiAgICAgIGlmICh3M2Nfc2xpZHkudmlld19hbGwpCiAgICAgICAgcmV0dXJuIHRydWU7CgogICAgICB3M2Nfc2xpZHkucHJldmlvdXNfc2xpZGUoZmFsc2UpOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CiAgICBlbHNlIGlmIChrZXkgPT0gMzIpIC8vIHNwYWNlIGJhcgogICAgewogICAgICB3M2Nfc2xpZHkubmV4dF9zbGlkZSh0cnVlKTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDM3KSAvLyBMZWZ0IGFycm93CiAgICB7CiAgICAgIHczY19zbGlkeS5wcmV2aW91c19zbGlkZSghZXZlbnQuc2hpZnRLZXkpOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CiAgICBlbHNlIGlmIChrZXkgPT0gMzYpIC8vIEhvbWUKICAgIHsKICAgICAgdzNjX3NsaWR5LmZpcnN0X3NsaWRlKCk7CiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KICAgIGVsc2UgaWYgKGtleSA9PSAzNSkgLy8gRW5kCiAgICB7CiAgICAgIHczY19zbGlkeS5sYXN0X3NsaWRlKCk7CiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KICAgIGVsc2UgaWYgKGtleSA9PSAzOSkgLy8gUmlnaHQgYXJyb3cKICAgIHsKICAgICAgdzNjX3NsaWR5Lm5leHRfc2xpZGUoIWV2ZW50LnNoaWZ0S2V5KTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDEzKSAvLyBFbnRlcgogICAgewogICAgICBpZiAodzNjX3NsaWR5Lm91dGxpbmUpCiAgICAgIHsKICAgICAgICBpZiAodzNjX3NsaWR5Lm91dGxpbmUudmlzaWJsZSkKICAgICAgICAgIHczY19zbGlkeS5mb2xkKHczY19zbGlkeS5vdXRsaW5lKTsKICAgICAgICBlbHNlCiAgICAgICAgICB3M2Nfc2xpZHkudW5mb2xkKHczY19zbGlkeS5vdXRsaW5lKTsKICAgICAgICAgIAogICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgICB9CiAgICB9CiAgICBlbHNlIGlmIChrZXkgPT0gMTg4KSAgLy8gPCBmb3Igc21hbGxlciBmb250cwogICAgewogICAgICB3M2Nfc2xpZHkuc21hbGxlcigpOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CiAgICBlbHNlIGlmIChrZXkgPT0gMTkwKSAgLy8gPiBmb3IgbGFyZ2VyIGZvbnRzCiAgICB7CiAgICAgIHczY19zbGlkeS5iaWdnZXIoKTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDE4OSB8fCBrZXkgPT0gMTA5KSAgLy8gLSBmb3Igc21hbGxlciBmb250cwogICAgewogICAgICB3M2Nfc2xpZHkuc21hbGxlcigpOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CiAgICBlbHNlIGlmIChrZXkgPT0gMTg3IHx8IGtleSA9PSAxOTEgfHwga2V5ID09IDEwNykgIC8vID0gKyAgZm9yIGxhcmdlciBmb250cwogICAgewogICAgICB3M2Nfc2xpZHkuYmlnZ2VyKCk7CiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KICAgIGVsc2UgaWYgKGtleSA9PSA4MykgIC8vIFMgZm9yIHNtYWxsZXIgZm9udHMKICAgIHsKICAgICAgdzNjX3NsaWR5LnNtYWxsZXIoKTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDY2KSAgLy8gQiBmb3IgbGFyZ2VyIGZvbnRzCiAgICB7CiAgICAgIHczY19zbGlkeS5iaWdnZXIoKTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDkwKSAgLy8gWiBmb3IgbGFzdCBzbGlkZQogICAgewogICAgICB3M2Nfc2xpZHkubGFzdF9zbGlkZSgpOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CiAgICBlbHNlIGlmIChrZXkgPT0gNzApICAvLyBGIGZvciB0b2dnbGUgdG9vbGJhcgogICAgewogICAgICB3M2Nfc2xpZHkudG9nZ2xlX3Rvb2xiYXIoKTsKICAgICAgcmV0dXJuIHczY19zbGlkeS5jYW5jZWwoZXZlbnQpOwogICAgfQogICAgZWxzZSBpZiAoa2V5ID09IDY1KSAgLy8gQSBmb3IgdG9nZ2xlIHZpZXcgc2luZ2xlL2FsbCBzbGlkZXMKICAgIHsKICAgICAgdzNjX3NsaWR5LnRvZ2dsZV92aWV3KCk7CiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KICAgIGVsc2UgaWYgKGtleSA9PSA3NSkgIC8vIHRvZ2dsZSBhY3Rpb24gb2YgbGVmdCBjbGljayBmb3IgbmV4dCBwYWdlCiAgICB7CiAgICAgIHczY19zbGlkeS5tb3VzZV9jbGlja19lbmFibGVkID0gIXczY19zbGlkeS5tb3VzZV9jbGlja19lbmFibGVkOwogICAgICB2YXIgYWxlcnRfbXNnID0gKHczY19zbGlkeS5tb3VzZV9jbGlja19lbmFibGVkID8KICAgICAgICAgICAgICAgICJlbmFibGVkIiA6ICJkaXNhYmxlZCIpICsgICIgbW91c2UgY2xpY2sgYWR2YW5jZSI7CgogICAgICBhbGVydCh3M2Nfc2xpZHkubG9jYWxpemUoYWxlcnRfbXNnKSk7CiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KICAgIGVsc2UgaWYgKGtleSA9PSA4NCB8fCBrZXkgPT0gNjcpICAvLyBUIG9yIEMgZm9yIHRhYmxlIG9mIGNvbnRlbnRzCiAgICB7CiAgICAgIGlmICh3M2Nfc2xpZHkudG9jKQogICAgICAgIHczY19zbGlkeS50b2dnbGVfdGFibGVfb2ZfY29udGVudHMoKTsKCiAgICAgIHJldHVybiB3M2Nfc2xpZHkuY2FuY2VsKGV2ZW50KTsKICAgIH0KICAgIGVsc2UgaWYgKGtleSA9PSA3MikgLy8gSCBmb3IgaGVscAogICAgewogICAgICB3aW5kb3cubG9jYXRpb24gPSB3M2Nfc2xpZHkuaGVscF9wYWdlOwogICAgICByZXR1cm4gdzNjX3NsaWR5LmNhbmNlbChldmVudCk7CiAgICB9CiAgICAvL2Vsc2UgYWxlcnQoImtleSBjb2RlIGlzICIrIGtleSk7CgogICAgcmV0dXJuIHRydWU7CiAgfSwKCiAgLy8gc2FmZSBmb3IgYm90aCB0ZXh0L2h0bWwgYW5kIGFwcGxpY2F0aW9uL3hodG1sK3htbAogIGNyZWF0ZV9lbGVtZW50OiBmdW5jdGlvbiAobmFtZSkgewogICAgaWYgKHRoaXMueGh0bWwgJiYgKHR5cGVvZiBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMgIT0gJ3VuZGVmaW5lZCcpKQogICAgICByZXR1cm4gZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKCJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIiwgbmFtZSkKCiAgICByZXR1cm4gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChuYW1lKTsKICB9LAoKICBnZXRfZWxlbWVudF9zdHlsZTogZnVuY3Rpb24gKGVsZW0sIElFU3R5bGVQcm9wLCBDU1NTdHlsZVByb3ApIHsKICAgIGlmIChlbGVtLmN1cnJlbnRTdHlsZSkKICAgIHsKICAgICAgcmV0dXJuIGVsZW0uY3VycmVudFN0eWxlW0lFU3R5bGVQcm9wXTsKICAgIH0KICAgIGVsc2UgaWYgKHdpbmRvdy5nZXRDb21wdXRlZFN0eWxlKQogICAgewogICAgICB2YXIgY29tcFN0eWxlID0gd2luZG93LmdldENvbXB1dGVkU3R5bGUoZWxlbSwgIiIpOwogICAgICByZXR1cm4gY29tcFN0eWxlLmdldFByb3BlcnR5VmFsdWUoQ1NTU3R5bGVQcm9wKTsKICAgIH0KICAgIHJldHVybiAiIjsKICB9LAoKICAvLyB0aGUgc3RyaW5nIHN0ciBpcyBhIHdoaXRlc3BhY2Ugc2VwYXJhdGVkIGxpc3Qgb2YgdG9rZW5zCiAgLy8gdGVzdCBpZiBzdHIgY29udGFpbnMgYSBwYXJ0aWN1bGFyIHRva2VuLCBlLmcuICJzbGlkZSIKICBoYXNfdG9rZW46IGZ1bmN0aW9uIChzdHIsIHRva2VuKSB7CiAgICBpZiAoc3RyKQogICAgewogICAgICAvLyBkZWZpbmUgcGF0dGVybiBhcyByZWd1bGFyIGV4cHJlc3Npb24KICAgICAgdmFyIHBhdHRlcm4gPSAvXHcrL2c7CgogICAgICAvLyBjaGVjayBmb3IgbWF0Y2hlcwogICAgICAvLyBwbGFjZSByZXN1bHQgaW4gYXJyYXkKICAgICAgdmFyIHJlc3VsdCA9IHN0ci5tYXRjaChwYXR0ZXJuKTsKCiAgICAgIC8vIG5vdyBjaGVjayBpZiBkZXNpcmVkIHRva2VuIGlzIHByZXNlbnQKICAgICAgZm9yICh2YXIgaSA9IDA7IGkgPCByZXN1bHQubGVuZ3RoOyBpKyspCiAgICAgIHsKICAgICAgICBpZiAocmVzdWx0W2ldID09IHRva2VuKQogICAgICAgICAgcmV0dXJuIHRydWU7CiAgICAgIH0KICAgIH0KCiAgICByZXR1cm4gZmFsc2U7CiAgfSwKCiAgZ2V0X2NsYXNzX2xpc3Q6IGZ1bmN0aW9uIChlbGVtZW50KSB7CiAgICBpZiAodHlwZW9mIGVsZW1lbnQuY2xhc3NOYW1lICE9ICd1bmRlZmluZWQnKQogICAgICByZXR1cm4gZWxlbWVudC5jbGFzc05hbWU7CgogICAgcmV0dXJuIGVsZW1lbnQuZ2V0QXR0cmlidXRlKCJjbGFzcyIpOwogIH0sCgogIGhhc19jbGFzczogZnVuY3Rpb24gKGVsZW1lbnQsIG5hbWUpIHsKICAgIGlmIChlbGVtZW50Lm5vZGVUeXBlICE9IDEpCiAgICAgIHJldHVybiBmYWxzZTsKCiAgICB2YXIgcmVnZXhwID0gbmV3IFJlZ0V4cCgiKF58ICkiICsgbmFtZSArICJcVyoiKTsKCiAgICBpZiAodHlwZW9mIGVsZW1lbnQuY2xhc3NOYW1lICE9ICd1bmRlZmluZWQnKQogICAgICByZXR1cm4gcmVnZXhwLnRlc3QoZWxlbWVudC5jbGFzc05hbWUpOwoKICAgIHJldHVybiByZWdleHAudGVzdChlbGVtZW50LmdldEF0dHJpYnV0ZSgiY2xhc3MiKSk7CiAgfSwKCiAgcmVtb3ZlX2NsYXNzOiBmdW5jdGlvbiAoZWxlbWVudCwgbmFtZSkgewogICAgdmFyIHJlZ2V4cCA9IG5ldyBSZWdFeHAoIihefCApIiArIG5hbWUgKyAiXFcqIik7CiAgICB2YXIgY2xzdmFsID0gIiI7CgogICAgaWYgKHR5cGVvZiBlbGVtZW50LmNsYXNzTmFtZSAhPSAndW5kZWZpbmVkJykKICAgIHsKICAgICAgY2xzdmFsID0gZWxlbWVudC5jbGFzc05hbWU7CgogICAgICBpZiAoY2xzdmFsKQogICAgICB7CiAgICAgICAgY2xzdmFsID0gY2xzdmFsLnJlcGxhY2UocmVnZXhwLCAiIik7CiAgICAgICAgZWxlbWVudC5jbGFzc05hbWUgPSBjbHN2YWw7CiAgICAgIH0KICAgIH0KICAgIGVsc2UKICAgIHsKICAgICAgY2xzdmFsID0gZWxlbWVudC5nZXRBdHRyaWJ1dGUoImNsYXNzIik7CgogICAgICBpZiAoY2xzdmFsKQogICAgICB7CiAgICAgICAgY2xzdmFsID0gY2xzdmFsLnJlcGxhY2UocmVnZXhwLCAiIik7CiAgICAgICAgZWxlbWVudC5zZXRBdHRyaWJ1dGUoImNsYXNzIiwgY2xzdmFsKTsKICAgICAgfQogICAgfQogIH0sCgogIGFkZF9jbGFzczogZnVuY3Rpb24gKGVsZW1lbnQsIG5hbWUpIHsKICAgIGlmICghdGhpcy5oYXNfY2xhc3MoZWxlbWVudCwgbmFtZSkpCiAgICB7CiAgICAgIGlmICh0eXBlb2YgZWxlbWVudC5jbGFzc05hbWUgIT0gJ3VuZGVmaW5lZCcpCiAgICAgICAgZWxlbWVudC5jbGFzc05hbWUgKz0gIiAiICsgbmFtZTsKICAgICAgZWxzZQogICAgICB7CiAgICAgICAgdmFyIGNsc3ZhbCA9IGVsZW1lbnQuZ2V0QXR0cmlidXRlKCJjbGFzcyIpOwogICAgICAgIGNsc3ZhbCA9IGNsc3ZhbCA/IGNsc3ZhbCArICIgIiArIG5hbWUgOiBuYW1lOwogICAgICAgIGVsZW1lbnQuc2V0QXR0cmlidXRlKCJjbGFzcyIsIGNsc3ZhbCk7CiAgICAgIH0KICAgIH0KICB9LAoKICAvLyBIVE1MIGVsZW1lbnRzIHRoYXQgY2FuIGJlIHVzZWQgd2l0aCBjbGFzcz0iaW5jcmVtZW50YWwiCiAgLy8gbm90ZSB0aGF0IHlvdSBjYW4gYWxzbyBwdXQgdGhlIGNsYXNzIG9uIGNvbnRhaW5lcnMgbGlrZQogIC8vIHVwLCBvbCwgZGwsIGFuZCBkaXYgdG8gbWFrZSB0aGVpciBjb250ZW50cyBhcHBlYXIKICAvLyBpbmNyZW1lbnRhbGx5LiBVcHBlciBjYXNlIGlzIHVzZWQgc2luY2UgdGhpcyBpcyB3aGF0CiAgLy8gYnJvd3NlcnMgcmVwb3J0IGZvciBIVE1MIG5vZGUgbmFtZXMgKHRleHQvaHRtbCkuCiAgaW5jcmVtZW50YWxfZWxlbWVudHM6IG51bGwsCiAgb2theV9mb3JfaW5jcmVtZW50YWw6IGZ1bmN0aW9uIChuYW1lKSB7CiAgICBpZiAoIXRoaXMuaW5jcmVtZW50YWxfZWxlbWVudHMpCiAgICB7CiAgICAgIHZhciBpbmNsaXN0ID0gbmV3IEFycmF5KCk7CiAgICAgIGluY2xpc3RbInAiXSA9IHRydWU7CiAgICAgIGluY2xpc3RbInByZSJdID0gdHJ1ZTsKICAgICAgaW5jbGlzdFsibGkiXSA9IHRydWU7CiAgICAgIGluY2xpc3RbImJsb2NrcXVvdGUiXSA9IHRydWU7CiAgICAgIGluY2xpc3RbImR0Il0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJkZCJdID0gdHJ1ZTsKICAgICAgaW5jbGlzdFsiaDIiXSA9IHRydWU7CiAgICAgIGluY2xpc3RbImgzIl0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJoNCJdID0gdHJ1ZTsKICAgICAgaW5jbGlzdFsiaDUiXSA9IHRydWU7CiAgICAgIGluY2xpc3RbImg2Il0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJzcGFuIl0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJhZGRyZXNzIl0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJ0YWJsZSJdID0gdHJ1ZTsKICAgICAgaW5jbGlzdFsidHIiXSA9IHRydWU7CiAgICAgIGluY2xpc3RbInRoIl0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJ0ZCJdID0gdHJ1ZTsKICAgICAgaW5jbGlzdFsiaW1nIl0gPSB0cnVlOwogICAgICBpbmNsaXN0WyJvYmplY3QiXSA9IHRydWU7CiAgICAgIHRoaXMuaW5jcmVtZW50YWxfZWxlbWVudHMgPSBpbmNsaXN0OwogICAgfQogICAgcmV0dXJuIHRoaXMuaW5jcmVtZW50YWxfZWxlbWVudHNbbmFtZS50b0xvd2VyQ2FzZSgpXTsKICB9LAoKICBuZXh0X2luY3JlbWVudGFsX2l0ZW06IGZ1bmN0aW9uIChub2RlKSB7CiAgICB2YXIgYnIgPSB0aGlzLmlzX3hodG1sID8gImJyIiA6ICJCUiI7CiAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwoKICAgIGZvciAoOzspCiAgICB7CiAgICAgIG5vZGUgPSB3M2Nfc2xpZHkubmV4dF9ub2RlKHNsaWRlLCBub2RlKTsKCiAgICAgIGlmIChub2RlID09IG51bGwgfHwgbm9kZS5wYXJlbnROb2RlID09IG51bGwpCiAgICAgICAgYnJlYWs7CgogICAgICBpZiAobm9kZS5ub2RlVHlwZSA9PSAxKSAgLy8gRUxFTUVOVAogICAgICB7CiAgICAgICAgaWYgKG5vZGUubm9kZU5hbWUgPT0gYnIpCiAgICAgICAgICBjb250aW51ZTsKCiAgICAgICAgaWYgKHczY19zbGlkeS5oYXNfY2xhc3Mobm9kZSwgImluY3JlbWVudGFsIikKICAgICAgICAgICAgICYmIHczY19zbGlkeS5va2F5X2Zvcl9pbmNyZW1lbnRhbChub2RlLm5vZGVOYW1lKSkKICAgICAgICAgIHJldHVybiBub2RlOwoKICAgICAgICBpZiAodzNjX3NsaWR5Lmhhc19jbGFzcyhub2RlLnBhcmVudE5vZGUsICJpbmNyZW1lbnRhbCIpCiAgICAgICAgICAgICAmJiAhdzNjX3NsaWR5Lmhhc19jbGFzcyhub2RlLCAibm9uLWluY3JlbWVudGFsIikpCiAgICAgICAgICByZXR1cm4gbm9kZTsKICAgICAgfQogICAgfQoKICAgIHJldHVybiBub2RlOwogIH0sCgogIHByZXZpb3VzX2luY3JlbWVudGFsX2l0ZW06IGZ1bmN0aW9uIChub2RlKSB7CiAgICB2YXIgYnIgPSB0aGlzLmlzX3hodG1sID8gImJyIiA6ICJCUiI7CiAgICB2YXIgc2xpZGUgPSB3M2Nfc2xpZHkuc2xpZGVzW3czY19zbGlkeS5zbGlkZV9udW1iZXJdOwoKICAgIGZvciAoOzspCiAgICB7CiAgICAgIG5vZGUgPSB3M2Nfc2xpZHkucHJldmlvdXNfbm9kZShzbGlkZSwgbm9kZSk7CgogICAgICBpZiAobm9kZSA9PSBudWxsIHx8IG5vZGUucGFyZW50Tm9kZSA9PSBudWxsKQogICAgICAgIGJyZWFrOwoKICAgICAgaWYgKG5vZGUubm9kZVR5cGUgPT0gMSkKICAgICAgewogICAgICAgIGlmIChub2RlLm5vZGVOYW1lID09IGJyKQogICAgICAgICAgY29udGludWU7CgogICAgICAgIGlmICh3M2Nfc2xpZHkuaGFzX2NsYXNzKG5vZGUsICJpbmNyZW1lbnRhbCIpCiAgICAgICAgICAgICAmJiB3M2Nfc2xpZHkub2theV9mb3JfaW5jcmVtZW50YWwobm9kZS5ub2RlTmFtZSkpCiAgICAgICAgICByZXR1cm4gbm9kZTsKCiAgICAgICAgaWYgKHczY19zbGlkeS5oYXNfY2xhc3Mobm9kZS5wYXJlbnROb2RlLCAiaW5jcmVtZW50YWwiKQogICAgICAgICAgICAgJiYgIXczY19zbGlkeS5oYXNfY2xhc3Mobm9kZSwgIm5vbi1pbmNyZW1lbnRhbCIpKQogICAgICAgICAgcmV0dXJuIG5vZGU7CiAgICAgIH0KICAgIH0KCiAgICByZXR1cm4gbm9kZTsKICB9LAoKICAvLyBzZXQgdmlzaWJpbGl0eSBmb3IgYWxsIGVsZW1lbnRzIG9uIGN1cnJlbnQgc2xpZGUgd2l0aAogIC8vIGEgcGFyZW50IGVsZW1lbnQgd2l0aCBhdHRyaWJ1dGUgY2xhc3M9ImluY3JlbWVudGFsIgogIHNldF92aXNpYmlsaXR5X2FsbF9pbmNyZW1lbnRhbDogZnVuY3Rpb24gKHZhbHVlKSB7CiAgICB2YXIgbm9kZSA9IHRoaXMubmV4dF9pbmNyZW1lbnRhbF9pdGVtKG51bGwpOwoKICAgIGlmICh2YWx1ZSA9PSAiaGlkZGVuIikKICAgIHsKICAgICAgd2hpbGUgKG5vZGUpCiAgICAgIHsKICAgICAgICB3M2Nfc2xpZHkuYWRkX2NsYXNzKG5vZGUsICJpbnZpc2libGUiKTsKICAgICAgICBub2RlID0gdzNjX3NsaWR5Lm5leHRfaW5jcmVtZW50YWxfaXRlbShub2RlKTsKICAgICAgfQogICAgfQogICAgZWxzZSAvLyB2YWx1ZSA9PSAidmlzaWJsZSIKICAgIHsKICAgICAgd2hpbGUgKG5vZGUpCiAgICAgIHsKICAgICAgICB3M2Nfc2xpZHkucmVtb3ZlX2NsYXNzKG5vZGUsICJpbnZpc2libGUiKTsKICAgICAgICBub2RlID0gdzNjX3NsaWR5Lm5leHRfaW5jcmVtZW50YWxfaXRlbShub2RlKTsKICAgICAgfQogICAgfQogIH0sCgogIC8vIHJldmVhbCB0aGUgbmV4dCBoaWRkZW4gaXRlbSBvbiB0aGUgc2xpZGUKICAvLyBub2RlIGlzIG51bGwgb3IgdGhlIG5vZGUgdGhhdCB3YXMgbGFzdCByZXZlYWxlZAogIHJldmVhbF9uZXh0X2l0ZW06IGZ1bmN0aW9uIChub2RlKSB7CiAgICBub2RlID0gdzNjX3NsaWR5Lm5leHRfaW5jcmVtZW50YWxfaXRlbShub2RlKTsKCiAgICBpZiAobm9kZSAmJiBub2RlLm5vZGVUeXBlID09IDEpICAvLyBhbiBlbGVtZW50CiAgICAgIHczY19zbGlkeS5yZW1vdmVfY2xhc3Mobm9kZSwgImludmlzaWJsZSIpOwoKICAgIHJldHVybiBub2RlOwogIH0sCgogIC8vIGV4YWN0IGludmVyc2Ugb2YgcmV2ZWFsTmV4dEl0ZW0obm9kZSkKICBoaWRlX3ByZXZpb3VzX2l0ZW06IGZ1bmN0aW9uIChub2RlKSB7CiAgICBpZiAobm9kZSAmJiBub2RlLm5vZGVUeXBlID09IDEpICAvLyBhbiBlbGVtZW50CiAgICAgIHczY19zbGlkeS5hZGRfY2xhc3Mobm9kZSwgImludmlzaWJsZSIpOwoKICAgIHJldHVybiB0aGlzLnByZXZpb3VzX2luY3JlbWVudGFsX2l0ZW0obm9kZSk7CiAgfSwKCiAgLy8gbGVmdCB0byByaWdodCB0cmF2ZXJzYWwgb2Ygcm9vdCdzIGNvbnRlbnQKICBuZXh0X25vZGU6IGZ1bmN0aW9uIChyb290LCBub2RlKSB7CiAgICBpZiAobm9kZSA9PSBudWxsKQogICAgICByZXR1cm4gcm9vdC5maXJzdENoaWxkOwoKICAgIGlmIChub2RlLmZpcnN0Q2hpbGQpCiAgICAgIHJldHVybiBub2RlLmZpcnN0Q2hpbGQ7CgogICAgaWYgKG5vZGUubmV4dFNpYmxpbmcpCiAgICAgIHJldHVybiBub2RlLm5leHRTaWJsaW5nOwoKICAgIGZvciAoOzspCiAgICB7CiAgICAgIG5vZGUgPSBub2RlLnBhcmVudE5vZGU7CgogICAgICBpZiAoIW5vZGUgfHwgbm9kZSA9PSByb290KQogICAgICAgIGJyZWFrOwoKICAgICAgaWYgKG5vZGUgJiYgbm9kZS5uZXh0U2libGluZykKICAgICAgICByZXR1cm4gbm9kZS5uZXh0U2libGluZzsKICAgIH0KCiAgICByZXR1cm4gbnVsbDsKICB9LAoKICAvLyByaWdodCB0byBsZWZ0IHRyYXZlcnNhbCBvZiByb290J3MgY29udGVudAogIHByZXZpb3VzX25vZGU6IGZ1bmN0aW9uIChyb290LCBub2RlKSB7CiAgICBpZiAobm9kZSA9PSBudWxsKQogICAgewogICAgICBub2RlID0gcm9vdC5sYXN0Q2hpbGQ7CgogICAgICBpZiAobm9kZSkKICAgICAgewogICAgICAgIHdoaWxlIChub2RlLmxhc3RDaGlsZCkKICAgICAgICAgIG5vZGUgPSBub2RlLmxhc3RDaGlsZDsKICAgICAgfQoKICAgICAgcmV0dXJuIG5vZGU7CiAgICB9CgogICAgaWYgKG5vZGUucHJldmlvdXNTaWJsaW5nKQogICAgewogICAgICBub2RlID0gbm9kZS5wcmV2aW91c1NpYmxpbmc7CgogICAgICB3aGlsZSAobm9kZS5sYXN0Q2hpbGQpCiAgICAgICAgbm9kZSA9IG5vZGUubGFzdENoaWxkOwoKICAgICAgcmV0dXJuIG5vZGU7CiAgICB9CgogICAgaWYgKG5vZGUucGFyZW50Tm9kZSAhPSByb290KQogICAgICByZXR1cm4gbm9kZS5wYXJlbnROb2RlOwoKICAgIHJldHVybiBudWxsOwogIH0sCgogIHByZXZpb3VzX3NpYmxpbmdfZWxlbWVudDogZnVuY3Rpb24gKGVsKSB7CiAgICBlbCA9IGVsLnByZXZpb3VzU2libGluZzsKCiAgICB3aGlsZSAoZWwgJiYgZWwubm9kZVR5cGUgIT0gMSkKICAgICAgZWwgPSBlbC5wcmV2aW91c1NpYmxpbmc7CgogICAgcmV0dXJuIGVsOwogIH0sCgogIG5leHRfc2libGluZ19lbGVtZW50OiBmdW5jdGlvbiAoZWwpIHsKICAgIGVsID0gZWwubmV4dFNpYmxpbmc7CgogICAgd2hpbGUgKGVsICYmIGVsLm5vZGVUeXBlICE9IDEpCiAgICAgIGVsID0gZWwubmV4dFNpYmxpbmc7CgogICAgcmV0dXJuIGVsOwogIH0sCgogIGZpcnN0X2NoaWxkX2VsZW1lbnQ6IGZ1bmN0aW9uIChlbCkgewogICAgdmFyIG5vZGU7CgogICAgZm9yIChub2RlID0gZWwuZmlyc3RDaGlsZDsgbm9kZTsgbm9kZSA9IG5vZGUubmV4dFNpYmxpbmcpCiAgICB7CiAgICAgIGlmIChub2RlLm5vZGVUeXBlID09IDEpCiAgICAgICAgYnJlYWs7CiAgICB9CgogICAgcmV0dXJuIG5vZGU7CiAgfSwKCiAgZmlyc3RfdGFnOiBmdW5jdGlvbiAoZWxlbWVudCwgdGFnKSB7CiAgICB2YXIgbm9kZTsKCiAgICBpZiAoIXRoaXMuaXNfeGh0bWwpCiAgICAgIHRhZyA9IHRhZy50b1VwcGVyQ2FzZSgpOwoKICAgIGZvciAobm9kZSA9IGVsZW1lbnQuZmlyc3RDaGlsZDsgbm9kZTsgbm9kZSA9IG5vZGUubmV4dFNpYmxpbmcpCiAgICB7CiAgICAgIGlmIChub2RlLm5vZGVUeXBlID09IDEgJiYgbm9kZS5ub2RlTmFtZSA9PSB0YWcpCiAgICAgICAgYnJlYWs7CiAgICB9CgogICAgcmV0dXJuIG5vZGU7CiAgfSwKCiAgaGlkZV9zZWxlY3Rpb246IGZ1bmN0aW9uICgpIHsKICAgIGlmICh3aW5kb3cuZ2V0U2VsZWN0aW9uKSAvLyBGaXJlZm94LCBDaHJvbWl1bSwgU2FmYXJpLCBPcGVyYQogICAgewogICAgICB2YXIgc2VsZWN0aW9uID0gd2luZG93LmdldFNlbGVjdGlvbigpOwoKICAgICAgaWYgKHNlbGVjdGlvbi5yYW5nZUNvdW50ID4gMCkKICAgICAgewogICAgICAgIHZhciByYW5nZSA9IHNlbGVjdGlvbi5nZXRSYW5nZUF0KDApOwogICAgICAgIHJhbmdlLmNvbGxhcHNlIChmYWxzZSk7CiAgICAgIH0KICAgIH0KICAgIGVsc2UgLy8gSW50ZXJuZXQgRXhwbG9yZXIKICAgIHsKICAgICAgdmFyIHRleHRSYW5nZSA9IGRvY3VtZW50LnNlbGVjdGlvbi5jcmVhdGVSYW5nZSAoKTsKICAgICAgdGV4dFJhbmdlLmNvbGxhcHNlIChmYWxzZSk7CiAgICB9CiAgfSwKCiAgZ2V0X3NlbGVjdGVkX3RleHQ6IGZ1bmN0aW9uICgpIHsKICAgIHRyeQogICAgewogICAgICBpZiAod2luZG93LmdldFNlbGVjdGlvbikKICAgICAgICByZXR1cm4gd2luZG93LmdldFNlbGVjdGlvbigpLnRvU3RyaW5nKCk7CgogICAgICBpZiAoZG9jdW1lbnQuZ2V0U2VsZWN0aW9uKQogICAgICAgIHJldHVybiBkb2N1bWVudC5nZXRTZWxlY3Rpb24oKS50b1N0cmluZygpOwoKICAgICAgaWYgKGRvY3VtZW50LnNlbGVjdGlvbikKICAgICAgICByZXR1cm4gZG9jdW1lbnQuc2VsZWN0aW9uLmNyZWF0ZVJhbmdlKCkudGV4dDsKICAgIH0KICAgIGNhdGNoIChlKQogICAgewogICAgfQoKICAgIHJldHVybiAiIjsKICB9LAoKICAvLyBtYWtlIG5vdGUgb2YgbGVuZ3RoIG9mIHNlbGVjdGVkIHRleHQKICAvLyBhcyB0aGlzIGV2YWx1YXRlcyB0byB6ZXJvIGluIGNsaWNrIGV2ZW50CiAgbW91c2VfYnV0dG9uX3VwOiBmdW5jdGlvbiAoZSkgewogICAgdzNjX3NsaWR5LnNlbGVjdGVkX3RleHRfbGVuID0gdzNjX3NsaWR5LmdldF9zZWxlY3RlZF90ZXh0KCkubGVuZ3RoOwogIH0sCgogIG1vdXNlX2J1dHRvbl9kb3duOiBmdW5jdGlvbiAoZSkgewogICAgdzNjX3NsaWR5LnNlbGVjdGVkX3RleHRfbGVuID0gdzNjX3NsaWR5LmdldF9zZWxlY3RlZF90ZXh0KCkubGVuZ3RoOwogICAgdzNjX3NsaWR5Lm1vdXNlX3ggPSBlLmNsaWVudFg7CiAgICB3M2Nfc2xpZHkubW91c2VfeSA9IGUuY2xpZW50WTsKICB9LAoKICAvLyByaWdodCBtb3VzZSBidXR0b24gY2xpY2sgaXMgcmVzZXJ2ZWQgZm9yIGNvbnRleHQgbWVudXMKICAvLyBpdCBpcyBtb3JlIHJlbGlhYmxlIHRvIGRldGVjdCByaWdodGNsaWNrIHRoYW4gbGVmdGNsaWNrCiAgbW91c2VfYnV0dG9uX2NsaWNrOiBmdW5jdGlvbiAoZSkgewogICAgaWYgKCFlKQogICAgICB2YXIgZSA9IHdpbmRvdy5ldmVudDsKCiAgICBpZiAoTWF0aC5hYnMoZS5jbGllbnRYIC13M2Nfc2xpZHkubW91c2VfeCkgKwogICAgICAgIE1hdGguYWJzKGUuY2xpZW50WSAtdzNjX3NsaWR5Lm1vdXNlX3kpID4gMTApCiAgICAgIHJldHVybiB0cnVlOwoKICAgIGlmICh3M2Nfc2xpZHkuc2VsZWN0ZWRfdGV4dF9sZW4gPiAwKQogICAgICByZXR1cm4gdHJ1ZTsKCiAgICB2YXIgcmlnaHRjbGljayA9IGZhbHNlOwogICAgdmFyIGxlZnRjbGljayA9IGZhbHNlOwogICAgdmFyIG1pZGRsZWNsaWNrID0gZmFsc2U7CiAgICB2YXIgdGFyZ2V0OwoKICAgIGlmICghZSkKICAgICAgdmFyIGUgPSB3aW5kb3cuZXZlbnQ7CgogICAgaWYgKGUudGFyZ2V0KQogICAgICB0YXJnZXQgPSBlLnRhcmdldDsKICAgIGVsc2UgaWYgKGUuc3JjRWxlbWVudCkKICAgICAgdGFyZ2V0ID0gZS5zcmNFbGVtZW50OwoKICAgIC8vIHdvcmsgYXJvdW5kIFNhZmFyaSBidWcKICAgIGlmICh0YXJnZXQubm9kZVR5cGUgPT0gMykKICAgICAgdGFyZ2V0ID0gdGFyZ2V0LnBhcmVudE5vZGU7CgogICAgaWYgKGUud2hpY2gpIC8vIGFsbCBicm93c2VycyBleGNlcHQgSUUKICAgIHsKICAgICAgbGVmdGNsaWNrID0gKGUud2hpY2ggPT0gMSk7CiAgICAgIG1pZGRsZWNsaWNrID0gKGUud2hpY2ggPT0gMik7CiAgICAgIHJpZ2h0Y2xpY2sgPSAoZS53aGljaCA9PSAzKTsKICAgIH0KICAgIGVsc2UgaWYgKGUuYnV0dG9uKQogICAgewogICAgICAvLyBLb25xdWVyb3IgZ2l2ZXMgMSBmb3IgbGVmdCwgNCBmb3IgbWlkZGxlCiAgICAgIC8vIElFNiBnaXZlcyAwIGZvciBsZWZ0IGFuZCBub3QgMSBhcyBJIGV4cGVjdGVkCgogICAgICBpZiAoZS5idXR0b24gPT0gNCkKICAgICAgICBtaWRkbGVjbGljayA9IHRydWU7CgogICAgICAvLyBhbGwgYnJvd3NlcnMgYWdyZWUgb24gMiBmb3IgcmlnaHQgYnV0dG9uCiAgICAgIHJpZ2h0Y2xpY2sgPSAoZS5idXR0b24gPT0gMik7CiAgICB9CiAgICBlbHNlCiAgICAgIGxlZnRjbGljayA9IHRydWU7CgogICAgaWYgKHczY19zbGlkeS5zZWxlY3RlZF90ZXh0X2xlbiA+IDApCiAgICB7CiAgICAgIHczY19zbGlkeS5zdG9wX3Byb3BhZ2F0aW9uKGUpOwogICAgICBlLmNhbmNlbCA9IHRydWU7CiAgICAgIGUucmV0dXJuVmFsdWUgPSBmYWxzZTsKICAgICAgcmV0dXJuIGZhbHNlOwogICAgfQoKICAgIC8vIGRpc21pc3MgdGFibGUgb2YgY29udGVudHMKICAgIHczY19zbGlkeS5oaWRlX3RhYmxlX29mX2NvbnRlbnRzKGZhbHNlKTsKCiAgICAvLyBjaGVjayBpZiB0YXJnZXQgaXMgc29tZXRoaW5nIHRoYXQgcHJvYmFibHkgd2FudCdzIGNsaWNrcwogICAgLy8gZS5nLiBhLCBlbWJlZCwgb2JqZWN0LCBpbnB1dCwgdGV4dGFyZWEsIHNlbGVjdCwgb3B0aW9uCiAgICB2YXIgdGFnID0gdGFyZ2V0Lm5vZGVOYW1lLnRvTG93ZXJDYXNlKCk7CgogICAgaWYgKHczY19zbGlkeS5tb3VzZV9jbGlja19lbmFibGVkICYmIGxlZnRjbGljayAmJgogICAgICAgICF3M2Nfc2xpZHkuc3BlY2lhbF9lbGVtZW50KHRhcmdldCkgJiYKICAgICAgICAhdGFyZ2V0Lm9uY2xpY2spCiAgICB7CiAgICAgIHczY19zbGlkeS5uZXh0X3NsaWRlKHRydWUpOwogICAgICB3M2Nfc2xpZHkuc3RvcF9wcm9wYWdhdGlvbihlKTsKICAgICAgZS5jYW5jZWwgPSB0cnVlOwogICAgICBlLnJldHVyblZhbHVlID0gZmFsc2U7CiAgICAgIHJldHVybiBmYWxzZTsKICAgIH0KCiAgICByZXR1cm4gdHJ1ZTsKICB9LAoKICBzcGVjaWFsX2VsZW1lbnQ6IGZ1bmN0aW9uIChlbGVtZW50KSB7CiAgICBpZiAodGhpcy5oYXNfY2xhc3MoZWxlbWVudCwgIm5vbi1pbnRlcmFjdGl2ZSIpKQogICAgICByZXR1cm4gZmFsc2U7CgogICAgdmFyIHRhZyA9IGVsZW1lbnQubm9kZU5hbWUudG9Mb3dlckNhc2UoKTsKCiAgICByZXR1cm4gZWxlbWVudC5vbmtleWRvd24gfHwKICAgICAgZWxlbWVudC5vbmNsaWNrIHx8CiAgICAgIHRhZyA9PSAiYSIgfHwKICAgICAgdGFnID09ICJlbWJlZCIgfHwKICAgICAgdGFnID09ICJvYmplY3QiIHx8CiAgICAgIHRhZyA9PSAidmlkZW8iIHx8CiAgICAgIHRhZyA9PSAiYXVkaW8iIHx8CiAgICAgIHRhZyA9PSAic3ZnIiB8fAogICAgICB0YWcgPT0gImNhbnZhcyIgfHwKICAgICAgdGFnID09ICJpbnB1dCIgfHwKICAgICAgdGFnID09ICJ0ZXh0YXJlYSIgfHwKICAgICAgdGFnID09ICJzZWxlY3QiIHx8CiAgICAgIHRhZyA9PSAib3B0aW9uIjsKICB9LAoKICBzbGlkeV9jaHJvbWU6IGZ1bmN0aW9uIChlbCkgewogICAgd2hpbGUgKGVsKQogICAgewogICAgICBpZiAoZWwgPT0gdzNjX3NsaWR5LnRvYyB8fAogICAgICAgICAgZWwgPT0gdzNjX3NsaWR5LnRvb2xiYXIgfHwKICAgICAgICAgIHczY19zbGlkeS5oYXNfY2xhc3MoZWwsICJvdXRsaW5lIikpCiAgICAgICAgcmV0dXJuIHRydWU7CgogICAgICBlbCA9IGVsLnBhcmVudE5vZGU7CiAgICB9CgogICAgcmV0dXJuIGZhbHNlOwogIH0sCgogIGdldF9rZXk6IGZ1bmN0aW9uIChlKQogIHsKICAgIHZhciBrZXk7CgogICAgLy8ga2x1ZGdlIGFyb3VuZCBOUy9JRSBkaWZmZXJlbmNlcyAKICAgIGlmICh0eXBlb2Ygd2luZG93LmV2ZW50ICE9ICJ1bmRlZmluZWQiKQogICAgICBrZXkgPSB3aW5kb3cuZXZlbnQua2V5Q29kZTsKICAgIGVsc2UgaWYgKGUud2hpY2gpCiAgICAgIGtleSA9IGUud2hpY2g7CgogICAgcmV0dXJuIGtleTsKICB9LAoKICBnZXRfdGFyZ2V0OiBmdW5jdGlvbiAoZSkgewogICAgdmFyIHRhcmdldDsKCiAgICBpZiAoIWUpCiAgICAgIGUgPSB3aW5kb3cuZXZlbnQ7CgogICAgaWYgKGUudGFyZ2V0KQogICAgICB0YXJnZXQgPSBlLnRhcmdldDsKICAgIGVsc2UgaWYgKGUuc3JjRWxlbWVudCkKICAgICAgdGFyZ2V0ID0gZS5zcmNFbGVtZW50OwoKICAgIGlmICh0YXJnZXQubm9kZVR5cGUgIT0gMSkKICAgICAgdGFyZ2V0ID0gdGFyZ2V0LnBhcmVudE5vZGU7CgogICAgcmV0dXJuIHRhcmdldDsKICB9LAoKICAvLyBkb2VzIGRpc3BsYXkgcHJvcGVydHkgcHJvdmlkZSBjb3JyZWN0IGRlZmF1bHRzPwogIGlzX2Jsb2NrOiBmdW5jdGlvbiAoZWxlbSkgewogICAgdmFyIHRhZyA9IGVsZW0ubm9kZU5hbWUudG9Mb3dlckNhc2UoKTsKCiAgICByZXR1cm4gdGFnID09ICJvbCIgfHwgdGFnID09ICJ1bCIgfHwgdGFnID09ICJwIiB8fCB0YWcgPT0gImRsIiB8fAogICAgICAgICAgIHRhZyA9PSAibGkiIHx8IHRhZyA9PSAidGFibGUiIHx8IHRhZyA9PSAicHJlIiB8fAogICAgICAgICAgIHRhZyA9PSAiaDEiIHx8IHRhZyA9PSAiaDIiIHx8IHRhZyA9PSAiaDMiIHx8CiAgICAgICAgICAgdGFnID09ICJoNCIgfHwgdGFnID09ICJoNSIgfHwgdGFnID09ICJoNiIgfHwKICAgICAgICAgICB0YWcgPT0gImJsb2NrcXVvdGUiIHx8IHRhZyA9PSAiYWRkcmVzcyI7IAogIH0sCgogIGFkZF9saXN0ZW5lcjogZnVuY3Rpb24gKGVsZW1lbnQsIGV2ZW50LCBoYW5kbGVyKSB7CiAgICBpZiAod2luZG93LmFkZEV2ZW50TGlzdGVuZXIpCiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihldmVudCwgaGFuZGxlciwgZmFsc2UpOwogICAgZWxzZQogICAgICBlbGVtZW50LmF0dGFjaEV2ZW50KCJvbiIrZXZlbnQsIGhhbmRsZXIpOwogIH0sCgogIC8vIHVzZWQgdG8gcHJldmVudCBldmVudCBwcm9wYWdhdGlvbiBmcm9tIGZpZWxkIGNvbnRyb2xzCiAgc3RvcF9wcm9wYWdhdGlvbjogZnVuY3Rpb24gKGV2ZW50KSB7CiAgICBldmVudCA9IGV2ZW50ID8gZXZlbnQgOiB3aW5kb3cuZXZlbnQ7CiAgICBldmVudC5jYW5jZWxCdWJibGUgPSB0cnVlOyAgLy8gZm9yIElFCgogICAgaWYgKGV2ZW50LnN0b3BQcm9wYWdhdGlvbikKICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7CgogICAgcmV0dXJuIHRydWU7CiAgfSwKCiAgY2FuY2VsOiBmdW5jdGlvbiAoZXZlbnQpIHsKICAgIGlmIChldmVudCkKICAgIHsKICAgICAgIGV2ZW50LmNhbmNlbCA9IHRydWU7CiAgICAgICBldmVudC5yZXR1cm5WYWx1ZSA9IGZhbHNlOwoKICAgICAgaWYgKGV2ZW50LnByZXZlbnREZWZhdWx0KQogICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7CiAgICB9CgogICAgdzNjX3NsaWR5LmtleV93YW50ZWQgPSBmYWxzZTsKICAgIHJldHVybiBmYWxzZTsKICB9LAoKLy8gZm9yIGVhY2ggbGFuZ3VhZ2UgZGVmaW5lIGFuIGFzc29jaWF0aXZlIGFycmF5Ci8vIGFuZCBhbHNvIHRoZSBoZWxwIHRleHQgd2hpY2ggaXMgbG9uZ2VyCgogIHN0cmluZ3NfZXM6IHsKICAgICJzbGlkZSI6InDDoWcuIiwKICAgICJoZWxwPyI6IkF5dWRhIiwKICAgICJjb250ZW50cz8iOiLDjW5kaWNlIiwKICAgICJ0YWJsZSBvZiBjb250ZW50cyI6InRhYmxhIGRlIGNvbnRlbmlkb3MiLAogICAgIlRhYmxlIG9mIENvbnRlbnRzIjoiVGFibGEgZGUgQ29udGVuaWRvcyIsCiAgICAicmVzdGFydCBwcmVzZW50YXRpb24iOiJSZWluaWNpYXIgcHJlc2VudGFjacOzbiIsCiAgICAicmVzdGFydD8iOiJJbmljaW8iCiAgfSwKICBoZWxwX2VzOgogICAgIlV0aWxpY2UgZWwgcmF0w7NuLCBiYXJyYSBlc3BhY2lhZG9yYSwgdGVjbGFzIEl6ZGEvRGNoYSwgIiArCiAgICAibyBSZSBww6FnIHkgQXYgcMOhZy4gVXNlIFMgeSBCIHBhcmEgY2FtYmlhciBlbCB0YW1hw7FvIGRlIGZ1ZW50ZS4iLAoKICBzdHJpbmdzX2NhOiB7CiAgICAic2xpZGUiOiJww6BnLi4iLAogICAgImhlbHA/IjoiQWp1ZGEiLAogICAgImNvbnRlbnRzPyI6IsONbmRleCIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiJ0YXVsYSBkZSBjb250aW5ndXRzIiwKICAgICJUYWJsZSBvZiBDb250ZW50cyI6IlRhdWxhIGRlIENvbnRpbmd1dHMiLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoiUmVpbmljaWFyIHByZXNlbnRhY2nDsyIsCiAgICAicmVzdGFydD8iOiJJbmljaSIKICB9LAogIGhlbHBfY2E6CiAgICAiVXRpbGl0emkgZWwgcmF0b2zDrSwgYmFycmEgZXNwYWlhZG9yYSwgdGVjbGVzIEVzcS4vRHRhLiAiICsKICAgICJvIFJlIHDDoGcgeSBBdiBww6BnLiBVc2kgUyBpIEIgcGVyIGNhbnZpYXIgZ3JhbmTDoHJpYSBkZSBmb250LiIsCgogIHN0cmluZ3NfY3M6IHsKICAgICJzbGlkZSI6InNuw61tZWsiLAogICAgImhlbHA/IjoibsOhcG92xJtkYSIsCiAgICAiY29udGVudHM/Ijoib2JzYWgiLAogICAgInRhYmxlIG9mIGNvbnRlbnRzIjoib2JzYWggcHJlemVudGFjZSIsCiAgICAiVGFibGUgb2YgQ29udGVudHMiOiJPYnNhaCBwcmV6ZW50YWNlIiwKICAgICJyZXN0YXJ0IHByZXNlbnRhdGlvbiI6Inpub3Z1IHNwdXN0aXQgcHJlemVudGFjaSIsCiAgICAicmVzdGFydD8iOiJyZXN0YXJ0IgogIH0sCiAgaGVscF9jczoKICAgICJQcmV6ZW50YWNpIG3Fr8W+ZXRlIHByb2Now6F6ZXQgcG9tb2PDrSBrbGlrbnV0w60gbXnFoWksIG1lemVybsOta3UsICIgKwogICAgIsWhaXBlayB2bGV2byBhIHZwcmF2byBuZWJvIGtsw6F2ZXMgUGFnZVVwIGEgUGFnZURvd24uIFDDrXNtbyBzZSAiICsKICAgICJkw6EgenbEm3TFoWl0IGEgem1lbsWhaXQgcG9tb2PDrSBrbMOhdmVzIEIgYSBTLiIsCgogIHN0cmluZ3Nfbmw6IHsKICAgICJzbGlkZSI6InBhZ2luYSIsCiAgICAiaGVscD8iOiJIZWxwPyIsCiAgICAiY29udGVudHM/IjoiSW5ob3VkPyIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiJpbmhvdWRzb3BnYXZlIiwKICAgICJUYWJsZSBvZiBDb250ZW50cyI6IkluaG91ZHNvcGdhdmUiLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoiaGVyc3RhcnQgcHJlc2VudGF0aWUiLAogICAgInJlc3RhcnQ/IjoiSGVyc3RhcnQ/IgogIH0sCiAgaGVscF9ubDoKICAgICAiTmF2aWdlZXIgZC5tLnYuIGhldCBtdWlzLCBzcGF0aWViYXIsIExpbmtzL1JlY2h0cyB0b2V0c2VuLCAiICsKICAgICAib2YgUGdVcCBlbiBQZ0RuLiBHZWJydWlrIFMgZW4gQiBvbSBkZSBrYXJha3Rlcmdyb290dGUgdGUgdmVyYW5kZXJlbi4iLAoKICBzdHJpbmdzX2RlOiB7CiAgICAic2xpZGUiOiJTZWl0ZSIsCiAgICAiaGVscD8iOiJIaWxmZSIsCiAgICAiY29udGVudHM/Ijoiw5xiZXJzaWNodCIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiJJbmhhbHRzdmVyemVpY2huaXMiLAogICAgIlRhYmxlIG9mIENvbnRlbnRzIjoiSW5oYWx0c3ZlcnplaWNobmlzIiwKICAgICJyZXN0YXJ0IHByZXNlbnRhdGlvbiI6IlByw6RzZW50YXRpb24gbmV1IHN0YXJ0ZW4iLAogICAgInJlc3RhcnQ/IjoiTmV1c3RhcnQiCiAgfSwKICBoZWxwX2RlOgogICAgIkJlbnV0emVuIFNpZSBkaWUgTWF1cywgTGVlcnNjaGxhZywgZGllIEN1cnNvcnRhc3RlbiBsaW5rcy9yZWNodHMgb2RlciAiICsKICAgICJQYWdlIHVwL1BhZ2UgRG93biB6dW0gV2VjaHNlbG4gZGVyIFNlaXRlbiB1bmQgUyB1bmQgQiBmw7xyIGRpZSBTY2hyaWZ0Z3LDtnNzZS4iLAoKICBzdHJpbmdzX3BsOiB7CiAgICAic2xpZGUiOiJzbGFqZCIsCiAgICAiaGVscD8iOiJwb21vYz8iLAogICAgImNvbnRlbnRzPyI6InNwaXMgdHJlxZtjaT8iLAogICAgInRhYmxlIG9mIGNvbnRlbnRzIjoic3BpcyB0cmXFm2NpIiwKICAgICJUYWJsZSBvZiBDb250ZW50cyI6IlNwaXMgVHJlxZtjaSIsCiAgICAicmVzdGFydCBwcmVzZW50YXRpb24iOiJSZXN0YXJ0dWogcHJlemVudGFjasSZIiwKICAgICJyZXN0YXJ0PyI6InJlc3RhcnQ/IgogIH0sCiAgaGVscF9wbDoKICAgICJabWllbmlhaiBzbGFqZHkga2xpa2FqxIVjIG15c3rEhSwgbmFjaXNrYWrEhWMgc3BhY2rEmSwgc3RyemHFgmtpIGxld28vcHJhd28iICsKICAgICJsdWIgUGdVcCAvIFBnRG4uIFXFvHlqIGtsYXdpc3p5IFMgaSBCLCBhYnkgem1pZW5pxIcgcm96bWlhciBjemN6aW9ua2kuIiwKCiAgc3RyaW5nc19mcjogewogICAgInNsaWRlIjoicGFnZSIsCiAgICAiaGVscD8iOiJBaWRlIiwKICAgICJjb250ZW50cz8iOiJJbmRleCIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiJ0YWJsZSBkZXMgbWF0acOocmVzIiwKICAgICJUYWJsZSBvZiBDb250ZW50cyI6IlRhYmxlIGRlcyBtYXRpw6hyZXMiLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoiUmVjb21tZW5jZXIgbCdleHBvc8OpIiwKICAgICJyZXN0YXJ0PyI6IkTDqWJ1dCIKICB9LAogIGhlbHBfZnI6CiAgICAiTmF2aWd1ZXogYXZlYyBsYSBzb3VyaXMsIGxhIGJhcnJlIGQnZXNwYWNlLCBsZXMgZmzDqGNoZXMgIiArCiAgICAiZ2F1Y2hlL2Ryb2l0ZSBvdSBsZXMgdG91Y2hlcyBQZyBVcCwgUGcgRG4uIFV0aWxpc2V6ICIgKwogICAgImxlcyB0b3VjaGVzIFMgZXQgQiBwb3VyIG1vZGlmaWVyIGxhIHRhaWxsZSBkZSBsYSBwb2xpY2UuIiwKCiAgc3RyaW5nc19odTogewogICAgInNsaWRlIjoib2xkYWwiLAogICAgImhlbHA/Ijoic2Vnw610c8OpZyIsCiAgICAiY29udGVudHM/IjoidGFydGFsb20iLAogICAgInRhYmxlIG9mIGNvbnRlbnRzIjoidGFydGFsb21qZWd5esOpayIsCiAgICAiVGFibGUgb2YgQ29udGVudHMiOiJUYXJ0YWxvbWplZ3l6w6lrIiwKICAgICJyZXN0YXJ0IHByZXNlbnRhdGlvbiI6ImJlbXV0YXTDsyDDumpyYWluZMOtdMOhc2EiLAogICAgInJlc3RhcnQ/Ijoiw7pqcmFpbmTDrXTDoXMiCiAgfSwKICBoZWxwX2h1OgogICAgIkF6IG9sZGFsYWsga8O2enRpIGzDqXBrZWTDqXNoZXoga2F0dGludHNvbiBheiBlZ8OpcnJlbCwgdmFneSAiICsKICAgICJoYXN6bsOhbGphIGEgc3rDs2vDtnosIGEgYmFsLCB2YWd5IGEgam9iYiBuecOtbCwgaWxsZXR2ZSBhIFBhZ2UgRG93biwgIiArCiAgICAiUGFnZSBVcCBiaWxsZW50ecWxa2V0LiBBeiBTIMOpcyBhIEIgYmlsbGVudHnFsWtrZWwgdsOhbHRvenRhdGhhdGphICIgKwogICAgImEgc3rDtnZlZyBtw6lyZXTDqXQuIiwKCiAgc3RyaW5nc19pdDogewogICAgInNsaWRlIjoicGFnLiIsCiAgICAiaGVscD8iOiJBaXV0byIsCiAgICAiY29udGVudHM/IjoiSW5kaWNlIiwKICAgICJ0YWJsZSBvZiBjb250ZW50cyI6ImluZGljZSIsCiAgICAiVGFibGUgb2YgQ29udGVudHMiOiJJbmRpY2UiLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoiUmljb21pbmNpYXJlIGxhIHByZXNlbnRhemlvbmUiLAogICAgInJlc3RhcnQ/IjoiSW5pemlvIgogIH0sCiAgaGVscF9pdDoKICAgICJOYXZpZ2FyZSBjb24gbW91c2UsIGJhcnJhIHNwYXppbywgZnJlY2NlIHNpbmlzdHJhL2Rlc3RyYSBvICIgKwogICAgIlBnVXAgZSBQZ0RuLiBVc2FyZSBTIGUgQiBwZXIgY2FtYmlhcmUgbGEgZGltZW5zaW9uZSBkZWkgY2FyYXR0ZXJpLiIsCgogIHN0cmluZ3NfZWw6IHsKICAgICJzbGlkZSI6Is+DzrXOu86vzrTOsSIsCiAgICAiaGVscD8iOiLOss6/zq7OuM61zrnOsTsiLAogICAgImNvbnRlbnRzPyI6Is+AzrXPgc65zrXPh8+MzrzOtc69zrE7IiwKICAgICJ0YWJsZSBvZiBjb250ZW50cyI6Is+Azq/Ovc6xzrrOsc+CIM+AzrXPgc65zrXPh86/zrzOrc69z4nOvSIsCiAgICAiVGFibGUgb2YgQ29udGVudHMiOiLOoM6vzr3Osc66zrHPgiDOoM61z4HOuc61z4fOv868zq3Ovc+Jzr0iLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoizrXPgM6xzr3Otc66zrrOr869zrfPg863IM+AzrHPgc6/z4XPg86vzrHPg863z4IiLAogICAgInJlc3RhcnQ/IjoizrXPgM6xzr3Otc66zrrOr869zrfPg863OyIKICB9LAogIGhlbHBfZWw6CiAgICAizqDOu86/zrfOs863zrjOtc6vz4TOtSDOvM61IM+Ezr8gzrrOu86vzrogz4TOv8+FIM+Azr/Ovc+EzrnOus65zr/PjSwgz4TOvyBzcGFjZSwgz4TOsSDOss6tzrvOtyDOsc+BzrnPg8+EzrXPgc6sL860zrXOvs65zqwsICIgKwogICAgIs6uIFBhZ2UgVXAgzrrOsc65IFBhZ2UgRG93bi4gzqfPgc63z4POuc68zr/PgM6/zrnOrs+Dz4TOtSDPhM6xIM+AzrvOrs66z4TPgc6xIFMgzrrOsc65IEIgzrPOuc6xIM69zrEgzrHOu867zqzOvs61z4TOtSAiICsKICAgICLPhM6/IM68zq3Os861zrjOv8+CIM+EzrfPgiDOs8+BzrHOvM68zrHPhM6/z4POtc65z4HOrM+CLiIsCgogIHN0cmluZ3NfamE6IHsKICAgICJzbGlkZSI6IuOCueODqeOCpOODiSIsCiAgICAiaGVscD8iOiLjg5jjg6vjg5ciLAogICAgImNvbnRlbnRzPyI6IuebruasoSIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiLnm67mrKHjgpLooajnpLoiLAogICAgIlRhYmxlIG9mIENvbnRlbnRzIjoi55uu5qyhIiwKICAgICJyZXN0YXJ0IHByZXNlbnRhdGlvbiI6IuacgOWIneOBi+OCieWGjeeUnyIsCiAgICAicmVzdGFydD8iOiLmnIDliJ3jgYvjgokiCiAgfSwKICBoZWxwX2phOgogICAgICLjg57jgqbjgrnlt6bjgq/jg6rjg4Pjgq8g44O7IOOCueODmuODvOOCuSDjg7sg5bem5Y+z44Kt44O8ICIgKwogICAgICLjgb7jgZ/jga8gUGFnZSBVcCDjg7sgUGFnZSBEb3du44Gn5pON5L2c77yMIFMg44O7IELjgafjg5Xjgqnjg7Pjg4jjgrXjgqTjgrrlpInmm7QiLAoKICBzdHJpbmdzX3poOiB7CiAgICAic2xpZGUiOiLlubvnga/niYciLAogICAgImhlbHA/Ijoi5biu5YqpPyIsCiAgICAiY29udGVudHM/Ijoi5YaF5a65PyIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiLnm67lvZUiLAogICAgIlRhYmxlIG9mIENvbnRlbnRzIjoi55uu5b2VIiwKICAgICJyZXN0YXJ0IHByZXNlbnRhdGlvbiI6IumHjeaWsOWQr+WKqOWxleekuiIsCiAgICAicmVzdGFydD8iOiLph43mlrDlkK/liqg/IgogIH0sCiAgaGVscF96aDoKICAgICLnlKjpvKDmoIfngrnlh7ssIOepuuagvOadoSwg5bem5Y+z566t5aS0LCBQZyBVcCDlkowgUGcgRG4g5a+86IiqLiAiICsKICAgICLnlKggUywgQiDmlLnlj5jlrZfkvZPlpKflsI8uIiwKCiAgc3RyaW5nc19ydTogewogICAgInNsaWRlIjoi0YHQu9Cw0LnQtCIsCiAgICAiaGVscD8iOiLQv9C+0LzQvtGJ0Yw/IiwKICAgICJjb250ZW50cz8iOiLRgdC+0LTQtdGA0LbQsNC90LjQtT8iLAogICAgInRhYmxlIG9mIGNvbnRlbnRzIjoi0L7Qs9C70LDQstC70LXQvdC40LUiLAogICAgIlRhYmxlIG9mIENvbnRlbnRzIjoi0J7Qs9C70LDQstC70LXQvdC40LUiLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoi0L/QtdGA0LXQt9Cw0L/Rg9GB0YLQuNGC0Ywg0L/RgNC10LfQtdC90YLQsNGG0LjRjiIsCiAgICAicmVzdGFydD8iOiLQv9C10YDQtdC30LDQv9GD0YHQuj8iCiAgfSwKICBoZWxwX3J1OgogICAgItCf0LXRgNC10LzQtdGJ0LDQudGC0LXRgdGMINC60LvQuNC60LDRjyDQvNGL0YjQutC+0LksINC40YHQv9C+0LvRjNC30YPRjyDQutC70LDQstC40YjRgyDQv9GA0L7QsdC10LssINGB0YLRgNC10LvQutC4IiArCiAgICAi0LLQu9C10LLQvi/QstC/0YDQsNCy0L4g0LjQu9C4IFBnIFVwINC4IFBnIERuLiDQmtC70LDQstC40YjQuCBTINC4IEIg0LzQtdC90Y/RjtGCINGA0LDQt9C80LXRgCDRiNGA0LjRhNGC0LAuIiwKCiAgc3RyaW5nc19zdjogewogICAgInNsaWRlIjoic2lkYSIsCiAgICAiaGVscD8iOiJoasOkbHAiLAogICAgImNvbnRlbnRzPyI6ImlubmVow6VsbCIsCiAgICAidGFibGUgb2YgY29udGVudHMiOiJpbm5laMOlbGxzZsO2cnRlY2tuaW5nIiwKICAgICJUYWJsZSBvZiBDb250ZW50cyI6IklubmVow6VsbHNmw7ZydGVja25pbmciLAogICAgInJlc3RhcnQgcHJlc2VudGF0aW9uIjoidmlzYSBwcmVzZW50YXRpb25lbiBmcsOlbiBiw7ZyamFuIiwKICAgICJyZXN0YXJ0PyI6ImLDtnJqYSBvbSIKICB9LAogIGhlbHBfc3Y6CiAgICAiQmzDpGRkcmEgbWVkIGV0dCBrbGljayBtZWQgdsOkbnN0cmEgbXVza25hcHBlbiwgbWVsbGFuc2xhZ3N0YW5nZW50ZW4sICIgKwogICAgInbDpG5zdGVyLSBvY2ggaMO2Z2VycGlsdGFuZ2VudGVybmEgZWxsZXIgdGFuZ2VudGVybmEgUGcgVXAsIFBnIERuLiAiICsKICAgICJBbnbDpG5kIHRhbmdlbnRlcm5hIFMgb2NoIEIgZsO2ciBhdHQgw6RuZHJhIHRleHRlbnMgc3Rvcmxlay4iLAoKICBzdHJpbmdzOiB7IH0sCgogIGxvY2FsaXplOiBmdW5jdGlvbiAoc3JjKSB7CiAgICBpZiAoc3JjID09ICIiKQogICAgICByZXR1cm4gc3JjOwoKICAgICAvLyB0cnkgZnVsbCBsYW5ndWFnZSBjb2RlLCBlLmcuIGVuLVVTCiAgICAgdmFyIHMsIGxvb2t1cCA9IHczY19zbGlkeS5zdHJpbmdzW3czY19zbGlkeS5sYW5nXTsKCiAgICAgaWYgKGxvb2t1cCkKICAgICB7CiAgICAgICBzID0gbG9va3VwW3NyY107CgogICAgICAgaWYgKHMpCiAgICAgICAgcmV0dXJuIHM7CiAgICAgfQoKICAgICAvLyBzdHJpcCBjb3VudHJ5IGNvZGUgc3VmZml4LCBlLmcuCiAgICAgLy8gdHJ5IGVuIGlmIHVuZGVmaW5lZCBmb3IgZW4tVVMKICAgICB2YXIgbGcgPSB3M2Nfc2xpZHkubGFuZy5zcGxpdCgiLSIpOwoKICAgICBpZiAobGcubGVuZ3RoID4gMSkKICAgICB7CiAgICAgICBsb29rdXAgPSB3M2Nfc2xpZHkuc3RyaW5nc1tsZ1swXV07CgogICAgICAgaWYgKGxvb2t1cCkKICAgICAgIHsKICAgICAgICAgcyA9IGxvb2t1cFtzcmNdOwoKICAgICAgICAgaWYgKHMpCiAgICAgICAgICByZXR1cm4gczsKICAgICAgIH0KICAgICB9CgogICAgIC8vIG90aGVyd2lzZSBzdHJpbmcgYXMgaXMKICAgICByZXR1cm4gc3JjOwogIH0sCgogIGluaXRfbG9jYWxpemF0aW9uOiBmdW5jdGlvbiAoKSB7CiAgICB2YXIgaTE4biA9IHczY19zbGlkeTsKICAgIHZhciBoZWxwX3RleHQgPSB3M2Nfc2xpZHkuaGVscF90ZXh0OwoKICAgIC8vIGVhY2ggc3VjaCBsYW5ndWFnZSBhcnJheSBpcyBkZWNsYXJlZCBpbiB0aGUgbG9jYWxpemUgYXJyYXkKICAgIC8vIHRoaXMgaXMgdXNlZCBhcyBpbiAgdzNjX3NsaWR5LmxvY2FsaXplKCJmb28iKTsKICAgIHRoaXMuc3RyaW5ncyA9IHsKICAgICAgImVzIjp0aGlzLnN0cmluZ3NfZXMsCiAgICAgICJjYSI6dGhpcy5zdHJpbmdzX2NhLAogICAgICAiY3MiOnRoaXMuc3RyaW5nc19jcywKICAgICAgIm5sIjp0aGlzLnN0cmluZ3NfbmwsCiAgICAgICJkZSI6dGhpcy5zdHJpbmdzX2RlLAogICAgICAicGwiOnRoaXMuc3RyaW5nc19wbCwKICAgICAgImZyIjp0aGlzLnN0cmluZ3NfZnIsCiAgICAgICJodSI6dGhpcy5zdHJpbmdzX2h1LAogICAgICAiaXQiOnRoaXMuc3RyaW5nc19pdCwKICAgICAgImVsIjp0aGlzLnN0cmluZ3NfZWwsCiAgICAgICJqcCI6dGhpcy5zdHJpbmdzX2phLAogICAgICAiemgiOnRoaXMuc3RyaW5nc196aCwKICAgICAgInJ1Ijp0aGlzLnN0cmluZ3NfcnUsCiAgICAgICJzdiI6dGhpcy5zdHJpbmdzX3N2CiAgICB9LAoKICAgIGkxOG4uc3RyaW5nc19lc1toZWxwX3RleHRdID0gaTE4bi5oZWxwX2VzOwogICAgaTE4bi5zdHJpbmdzX2NhW2hlbHBfdGV4dF0gPSBpMThuLmhlbHBfY2E7CiAgICBpMThuLnN0cmluZ3NfY3NbaGVscF90ZXh0XSA9IGkxOG4uaGVscF9jczsKICAgIGkxOG4uc3RyaW5nc19ubFtoZWxwX3RleHRdID0gaTE4bi5oZWxwX25sOwogICAgaTE4bi5zdHJpbmdzX2RlW2hlbHBfdGV4dF0gPSBpMThuLmhlbHBfZGU7CiAgICBpMThuLnN0cmluZ3NfcGxbaGVscF90ZXh0XSA9IGkxOG4uaGVscF9wbDsKICAgIGkxOG4uc3RyaW5nc19mcltoZWxwX3RleHRdID0gaTE4bi5oZWxwX2ZyOwogICAgaTE4bi5zdHJpbmdzX2h1W2hlbHBfdGV4dF0gPSBpMThuLmhlbHBfaHU7CiAgICBpMThuLnN0cmluZ3NfaXRbaGVscF90ZXh0XSA9IGkxOG4uaGVscF9pdDsKICAgIGkxOG4uc3RyaW5nc19lbFtoZWxwX3RleHRdID0gaTE4bi5oZWxwX2VsOwogICAgaTE4bi5zdHJpbmdzX2phW2hlbHBfdGV4dF0gPSBpMThuLmhlbHBfamE7CiAgICBpMThuLnN0cmluZ3NfemhbaGVscF90ZXh0XSA9IGkxOG4uaGVscF96aDsKICAgIGkxOG4uc3RyaW5nc19ydVtoZWxwX3RleHRdID0gaTE4bi5oZWxwX3J1OwogICAgaTE4bi5zdHJpbmdzX3N2W2hlbHBfdGV4dF0gPSBpMThuLmhlbHBfc3Y7CgogICAgdzNjX3NsaWR5LmxhbmcgPSBkb2N1bWVudC5ib2R5LnBhcmVudE5vZGUuZ2V0QXR0cmlidXRlKCJsYW5nIik7CgogICAgaWYgKCF3M2Nfc2xpZHkubGFuZykKICAgICAgdzNjX3NsaWR5LmxhbmcgPSBkb2N1bWVudC5ib2R5LnBhcmVudE5vZGUuZ2V0QXR0cmlidXRlKCJ4bWw6bGFuZyIpOwoKICAgIGlmICghdzNjX3NsaWR5LmxhbmcpCiAgICAgIHczY19zbGlkeS5sYW5nID0gImVuIjsKICB9Cn07CgovLyBoYWNrIGZvciBiYWNrIGJ1dHRvbiBiZWhhdmlvcgppZiAodzNjX3NsaWR5LmllNiB8fCB3M2Nfc2xpZHkuaWU3KQp7CiAgZG9jdW1lbnQud3JpdGUoIjxpZnJhbWUgaWQ9J2hpc3RvcnlGcmFtZScgIiArCiAgInNyYz0namF2YXNjcmlwdDpcIjxodG1sIisiPjwvIisiaHRtbD5cIicgIiArCiAgImhlaWdodD0nMScgd2lkdGg9JzEnICIgKwogICJzdHlsZT0ncG9zaXRpb246YWJzb2x1dGU7bGVmdDotODAwcHgnPjwvaWZyYW1lPiIpOwp9CgovLyBhdHRhY2ggZXZlbnQgbGlzdGVuZXJzIGZvciBpbml0aWFsaXphdGlvbgp3M2Nfc2xpZHkuc2V0X3VwKCk7CgovLyBoaWRlIHRoZSBzbGlkZXMgYXMgc29vbiBhcyBib2R5IGVsZW1lbnQgaXMgYXZhaWxhYmxlCi8vIHRvIHJlZHVjZSBhbm5veWluZyBzY3JlZW4gbWVzcyBiZWZvcmUgdGhlIG9ubG9hZCBldmVudApzZXRUaW1lb3V0KHczY19zbGlkeS5oaWRlX3NsaWRlcywgNTApOwoK"></script>
+</head>
+<body>
+<div class="slide titlepage">
+  <h1 class="title">R#4: data transformation</h1>
+  <p class="author">
+Laurent Modolo <a href="mailto:laurent.modolo@ens-lyon.fr">laurent.modolo@ens-lyon.fr</a>
+  </p>
+  <p class="date">08 Nov 2019</p>
+</div>
+<div id="r4-data-transformation" class="slide section level2">
+<h1>R#4: data transformation</h1>
+<p>The goal of this practical is to practices data transformation with <code>tidyverse</code>. The objectives of this session will be to:</p>
+<ul>
+<li>Filter rows with <code>filter()</code></li>
+<li>Arrange rows with <code>arrange()</code></li>
+<li>Select columns with <code>select()</code></li>
+<li>Add new variables with <code>mutate()</code></li>
+<li>Combining multiple operations with the pipe <code>%&gt;%</code></li>
+</ul>
+</div>
+<div id="nycflights13" class="slide section level2">
+<h1><strong>nycflights13</strong></h1>
+<p><code>nycflights13::flights</code>contains all 336,776 flights that departed from New York City in 2013. The data comes from the US Bureau of Transportation Statistics, and is documented in <code>?flights</code></p>
+</div>
+<div id="nycflights13-1" class="slide section level2">
+<h1><strong>nycflights13</strong></h1>
+<ul>
+<li><strong>int</strong> stands for integers.</li>
+<li><strong>dbl</strong> stands for doubles, or real numbers.</li>
+<li><strong>chr</strong> stands for character vectors, or strings.</li>
+<li><strong>dttm</strong> stands for date-times (a date + a time).</li>
+<li><strong>lgl</strong> stands for logical, vectors that contain only TRUE or FALSE.</li>
+<li><strong>fctr</strong> stands for factors, which R uses to represent categorical variables with fixed possible values.</li>
+<li><strong>date</strong> stands for dates.</li>
+</ul>
+</div>
+<div id="filter-rows-with-filter" class="slide section level2">
+<h1>Filter rows with <code>filter()</code></h1>
+<p><code>filter()</code> allows you to subset observations based on their values.</p>
+<pre><code>## # A tibble: 842 x 19
+##     year month   day dep_time sched_dep_time dep_delay arr_time
+##    &lt;int&gt; &lt;int&gt; &lt;int&gt;    &lt;int&gt;          &lt;int&gt;     &lt;dbl&gt;    &lt;int&gt;
+##  1  2013     1     1      517            515         2      830
+##  2  2013     1     1      533            529         4      850
+##  3  2013     1     1      542            540         2      923
+##  4  2013     1     1      544            545        -1     1004
+##  5  2013     1     1      554            600        -6      812
+##  6  2013     1     1      554            558        -4      740
+##  7  2013     1     1      555            600        -5      913
+##  8  2013     1     1      557            600        -3      709
+##  9  2013     1     1      557            600        -3      838
+## 10  2013     1     1      558            600        -2      753
+## # … with 832 more rows, and 12 more variables: sched_arr_time &lt;int&gt;,
+## #   arr_delay &lt;dbl&gt;, carrier &lt;chr&gt;, flight &lt;int&gt;, tailnum &lt;chr&gt;,
+## #   origin &lt;chr&gt;, dest &lt;chr&gt;, air_time &lt;dbl&gt;, distance &lt;dbl&gt;, hour &lt;dbl&gt;,
+## #   minute &lt;dbl&gt;, time_hour &lt;dttm&gt;</code></pre>
+</div>
+<div id="filter-rows-with-filter-1" class="slide section level2">
+<h1>Filter rows with <code>filter()</code></h1>
+<p><code>dplyr</code> functions never modify their inputs, so if you want to save the result, you’ll need to use the assignment operator, <code>&lt;-</code></p>
+<p>R either prints out the results, or saves them to a variable.</p>
+<pre><code>## # A tibble: 719 x 19
+##     year month   day dep_time sched_dep_time dep_delay arr_time
+##    &lt;int&gt; &lt;int&gt; &lt;int&gt;    &lt;int&gt;          &lt;int&gt;     &lt;dbl&gt;    &lt;int&gt;
+##  1  2013    12    25      456            500        -4      649
+##  2  2013    12    25      524            515         9      805
+##  3  2013    12    25      542            540         2      832
+##  4  2013    12    25      546            550        -4     1022
+##  5  2013    12    25      556            600        -4      730
+##  6  2013    12    25      557            600        -3      743
+##  7  2013    12    25      557            600        -3      818
+##  8  2013    12    25      559            600        -1      855
+##  9  2013    12    25      559            600        -1      849
+## 10  2013    12    25      600            600         0      850
+## # … with 709 more rows, and 12 more variables: sched_arr_time &lt;int&gt;,
+## #   arr_delay &lt;dbl&gt;, carrier &lt;chr&gt;, flight &lt;int&gt;, tailnum &lt;chr&gt;,
+## #   origin &lt;chr&gt;, dest &lt;chr&gt;, air_time &lt;dbl&gt;, distance &lt;dbl&gt;, hour &lt;dbl&gt;,
+## #   minute &lt;dbl&gt;, time_hour &lt;dttm&gt;</code></pre>
+</div>
+<div id="logical-operators" class="slide section level2">
+<h1>Logical operators</h1>
+<p>Multiple arguments to <code>filter()</code> are combined with “and”: every expression must be true in order for a row to be included in the output.</p>
+<p><img src="" width="100%" /></p>
+</div>
+<div id="logical-operators-1" class="slide section level2">
+<h1>Logical operators</h1>
+<p>Test the following operations:</p>
+<pre><code>## # A tibble: 55,403 x 19
+##     year month   day dep_time sched_dep_time dep_delay arr_time
+##    &lt;int&gt; &lt;int&gt; &lt;int&gt;    &lt;int&gt;          &lt;int&gt;     &lt;dbl&gt;    &lt;int&gt;
+##  1  2013    11     1        5           2359         6      352
+##  2  2013    11     1       35           2250       105      123
+##  3  2013    11     1      455            500        -5      641
+##  4  2013    11     1      539            545        -6      856
+##  5  2013    11     1      542            545        -3      831
+##  6  2013    11     1      549            600       -11      912
+##  7  2013    11     1      550            600       -10      705
+##  8  2013    11     1      554            600        -6      659
+##  9  2013    11     1      554            600        -6      826
+## 10  2013    11     1      554            600        -6      749
+## # … with 55,393 more rows, and 12 more variables: sched_arr_time &lt;int&gt;,
+## #   arr_delay &lt;dbl&gt;, carrier &lt;chr&gt;, flight &lt;int&gt;, tailnum &lt;chr&gt;,
+## #   origin &lt;chr&gt;, dest &lt;chr&gt;, air_time &lt;dbl&gt;, distance &lt;dbl&gt;, hour &lt;dbl&gt;,
+## #   minute &lt;dbl&gt;, time_hour &lt;dttm&gt;</code></pre>
+<pre><code>## # A tibble: 55,403 x 19
+##     year month   day dep_time sched_dep_time dep_delay arr_time
+##    &lt;int&gt; &lt;int&gt; &lt;int&gt;    &lt;int&gt;          &lt;int&gt;     &lt;dbl&gt;    &lt;int&gt;
+##  1  2013    11     1        5           2359         6      352
+##  2  2013    11     1       35           2250       105      123
+##  3  2013    11     1      455            500        -5      641
+##  4  2013    11     1      539            545        -6      856
+##  5  2013    11     1      542            545        -3      831
+##  6  2013    11     1      549            600       -11      912
+##  7  2013    11     1      550            600       -10      705
+##  8  2013    11     1      554            600        -6      659
+##  9  2013    11     1      554            600        -6      826
+## 10  2013    11     1      554            600        -6      749
+## # … with 55,393 more rows, and 12 more variables: sched_arr_time &lt;int&gt;,
+## #   arr_delay &lt;dbl&gt;, carrier &lt;chr&gt;, flight &lt;int&gt;, tailnum &lt;chr&gt;,
+## #   origin &lt;chr&gt;, dest &lt;chr&gt;, air_time &lt;dbl&gt;, distance &lt;dbl&gt;, hour &lt;dbl&gt;,
+## #   minute &lt;dbl&gt;, time_hour &lt;dttm&gt;</code></pre>
+<pre><code>## # A tibble: 316,050 x 19
+##     year month   day dep_time sched_dep_time dep_delay arr_time
+##    &lt;int&gt; &lt;int&gt; &lt;int&gt;    &lt;int&gt;          &lt;int&gt;     &lt;dbl&gt;    &lt;int&gt;
+##  1  2013     1     1      517            515         2      830
+##  2  2013     1     1      533            529         4      850
+##  3  2013     1     1      542            540         2      923
+##  4  2013     1     1      544            545        -1     1004
+##  5  2013     1     1      554            600        -6      812
+##  6  2013     1     1      554            558        -4      740
+##  7  2013     1     1      555            600        -5      913
+##  8  2013     1     1      557            600        -3      709
+##  9  2013     1     1      557            600        -3      838
+## 10  2013     1     1      558            600        -2      753
+## # … with 316,040 more rows, and 12 more variables: sched_arr_time &lt;int&gt;,
+## #   arr_delay &lt;dbl&gt;, carrier &lt;chr&gt;, flight &lt;int&gt;, tailnum &lt;chr&gt;,
+## #   origin &lt;chr&gt;, dest &lt;chr&gt;, air_time &lt;dbl&gt;, distance &lt;dbl&gt;, hour &lt;dbl&gt;,
+## #   minute &lt;dbl&gt;, time_hour &lt;dttm&gt;</code></pre>
+<pre><code>## # A tibble: 316,050 x 19
+##     year month   day dep_time sched_dep_time dep_delay arr_time
+##    &lt;int&gt; &lt;int&gt; &lt;int&gt;    &lt;int&gt;          &lt;int&gt;     &lt;dbl&gt;    &lt;int&gt;
+##  1  2013     1     1      517            515         2      830
+##  2  2013     1     1      533            529         4      850
+##  3  2013     1     1      542            540         2      923
+##  4  2013     1     1      544            545        -1     1004
+##  5  2013     1     1      554            600        -6      812
+##  6  2013     1     1      554            558        -4      740
+##  7  2013     1     1      555            600        -5      913
+##  8  2013     1     1      557            600        -3      709
+##  9  2013     1     1      557            600        -3      838
+## 10  2013     1     1      558            600        -2      753
+## # … with 316,040 more rows, and 12 more variables: sched_arr_time &lt;int&gt;,
+## #   arr_delay &lt;dbl&gt;, carrier &lt;chr&gt;, flight &lt;int&gt;, tailnum &lt;chr&gt;,
+## #   origin &lt;chr&gt;, dest &lt;chr&gt;, air_time &lt;dbl&gt;, distance &lt;dbl&gt;, hour &lt;dbl&gt;,
+## #   minute &lt;dbl&gt;, time_hour &lt;dttm&gt;</code></pre>
+</div>
+<div id="missing-values" class="slide section level2">
+<h1>Missing values</h1>
+<p>One important feature of R that can make comparison tricky are missing values, or <code>NA</code>s (“not availables”).</p>
+<pre><code>## [1] NA</code></pre>
+<pre><code>## [1] NA</code></pre>
+<pre><code>## [1] NA</code></pre>
+<pre><code>## [1] NA</code></pre>
+</div>
+<div id="missing-values-1" class="slide section level2">
+<h1>Missing values</h1>
+<pre><code>## [1] NA</code></pre>
+<pre><code>## [1] TRUE</code></pre>
+</div>
+<div id="filter-challenges" class="slide section level2">
+<h1>Filter challenges</h1>
+<p>Find all flights that:</p>
+<ul>
+<li>Had an arrival delay of two or more hours</li>
+<li>Were operated by United, American, or Delta</li>
+<li>Departed between midnight and 6am (inclusive)</li>
+</ul>
+<p>Another useful dplyr filtering helper is <code>between()</code>. What does it do? Can you use it to simplify the code needed to answer the previous challenges?</p>
+<p>How many flights have a missing <code>dep_time</code>? What other variables are missing? What might these rows represent?</p>
+<p>Why is <code>NA ^ 0</code> not <code>NA</code>? Why is <code>NA | TRUE</code> not <code>NA</code>? Why is <code>FALSE &amp; NA</code> not <code>NA</code>? Can you figure out the general rule? (<code>NA * 0</code> is a tricky counter-example!)</p>
+</div>
+<div id="arrange-rows-with-arrange" class="slide section level2">
+<h1>Arrange rows with <code>arrange()</code></h1>
+<p><code>arrange()</code> works similarly to <code>filter()</code> except that instead of selecting rows, it changes their order.</p>
+<p>Use <code>desc()</code> to re-order by a column in descending order:</p>
+<p>Missing values are always sorted at the end:</p>
+</div>
+<div id="arrange-challenges" class="slide section level2">
+<h1>Arrange challenges</h1>
+<ul>
+<li>Sort flights to find the most delayed flights. Find the flights that left earliest.</li>
+<li>Sort flights to find the fastest flights.</li>
+<li>Which flights traveled the longest? Which traveled the shortest?</li>
+</ul>
+</div>
+<div id="select-columns-with-select" class="slide section level2">
+<h1>Select columns with <code>select()</code></h1>
+<p><code>select()</code> allows you to rapidly zoom in on a useful subset using operations based on the names of the variables.</p>
+</div>
+<div id="select-columns-with-select-1" class="slide section level2">
+<h1>Select columns with <code>select()</code></h1>
+<p>here are a number of helper functions you can use within <code>select()</code>:</p>
+<ul>
+<li><code>starts_with(&quot;abc&quot;)</code>: matches names that begin with “abc”.</li>
+<li><code>ends_with(&quot;xyz&quot;)</code>: matches names that end with “xyz”.</li>
+<li><code>contains(&quot;ijk&quot;)</code>: matches names that contain “ijk”.</li>
+<li><code>matches(&quot;(.)\\1&quot;)</code>: selects variables that match a regular expression. This one matches any variables that contain repeated characters. You’ll learn more about regular expressions in strings.</li>
+<li><code>num_range(&quot;x&quot;, 1:3)</code>: matches <code>x1</code>, <code>x2</code> and <code>x3</code>.</li>
+</ul>
+<p>See <code>?select</code> for more details.</p>
+</div>
+<div id="select-challenges" class="slide section level2">
+<h1>Select challenges</h1>
+<ul>
+<li><p>Brainstorm as many ways as possible to select <code>dep_time</code>, <code>dep_delay</code>, <code>arr_time</code>, and <code>arr_delay</code> from <code>flights</code>.</p></li>
+<li><p>What does the <code>one_of()</code> function do? Why might it be helpful in conjunction with this vector?</p></li>
+<li><p>Does the result of running the following code surprise you? How do the select helpers deal with case by default? How can you change that default?</p></li>
+</ul>
+</div>
+<div id="add-new-variables-with-mutate" class="slide section level2">
+<h1>Add new variables with <code>mutate()</code></h1>
+<p>It’s often useful to add new columns that are functions of existing columns. That’s the job of <code>mutate()</code>.</p>
+<p><strong>4_a</strong></p>
+</div>
+<div id="add-new-variables-with-mutate-1" class="slide section level2">
+<h1>Add new variables with <code>mutate()</code></h1>
+<p>You can refer to columns that you’ve just created:</p>
+</div>
+<div id="useful-creation-functions" class="slide section level2">
+<h1>Useful creation functions</h1>
+<ul>
+<li>Offsets: <code>lead()</code> and <code>lag()</code> allow you to refer to leading or lagging values. This allows you to compute running differences (e.g. <code>x - lag(x)</code>) or find when values change (<code>x != lag(x)</code>).</li>
+<li>Cumulative and rolling aggregates: R provides functions for running sums, products, mins and maxes: <code>cumsum()</code>, <code>cumprod()</code>, <code>cummin()</code>, <code>cummax()</code>; and dplyr provides <code>cummean()</code> for cumulative means.</li>
+<li>Logical comparisons, <code>&lt;</code>, <code>&lt;=</code>, <code>&gt;</code>, <code>&gt;=</code>, <code>!=</code>, and <code>==</code></li>
+<li>Ranking: there are a number of ranking functions, but you should start with <code>min_rank()</code>. There is also <code>row_number()</code>, <code>dense_rank()</code>, <code>percent_rank()</code>, <code>cume_dist()</code>, <code>ntile()</code></li>
+</ul>
+</div>
+<div id="mutate-challenges" class="slide section level2">
+<h1>Mutate challenges</h1>
+<ul>
+<li>Currently <code>dep_time</code> and <code>sched_dep_time</code> are convenient to look at, but hard to compute with because they’re not really continuous numbers. Convert them to a more convenient representation of number of minutes since midnight.</li>
+</ul>
+
+<p><strong>4_b</strong></p>
+</div>
+<div id="mutate-challenges-1" class="slide section level2">
+<h1>Mutate challenges</h1>
+<ul>
+<li>Compare <code>dep_time</code>, <code>sched_dep_time</code>, and <code>dep_delay</code>. How would you expect those three numbers to be related?</li>
+</ul>
+
+<p><strong>4_c</strong></p>
+</div>
+<div id="mutate-challenges-2" class="slide section level2">
+<h1>Mutate challenges</h1>
+<ul>
+<li>Find the 10 most delayed flights using a ranking function. How do you want to handle ties? Carefully read the documentation for <code>min_rank()</code></li>
+</ul>
+
+<p><strong>4_d</strong></p>
+</div>
+<div id="combining-multiple-operations-with-the-pipe" class="slide section level2">
+<h1>Combining multiple operations with the pipe</h1>
+<p>We don’t want to create useless intermediate variables so we can use the pipe opperator: <code>%&gt;%</code> (<code>ctrl + shift + M</code>).</p>
+</div>
+<div id="combining-multiple-operations-with-the-pipe-1" class="slide section level2">
+<h1>Combining multiple operations with the pipe</h1>
+<p>We don’t want to create useless intermediate variables so we can use the pipe opperator: <code>%&gt;%</code> (<code>ctrl + shift + M</code>).</p>
+</div>
+<div id="combining-multiple-operations-with-the-pipe-2" class="slide section level2">
+<h1>Combining multiple operations with the pipe</h1>
+<p>Behind the scenes, <code>x %&gt;% f(y)</code> turns into <code>f(x, y)</code>, and <code>x %&gt;% f(y) %&gt;% g(z)</code> turns into <code>g(f(x, y), z)</code> and so on. You can use the pipe to rewrite multiple operations in a way that you can read left-to-right, top-to-bottom.</p>
+<p>You can access the transmited variables with <code>.</code></p>
+<p>Working with the pipe is one of the key criteria for belonging to the <code>tidyverse</code>. The only exception is <code>ggplot2</code>: it was written before the pipe was discovered. Unfortunately, the next iteration of <code>ggplot2</code>, <code>ggvis</code>, which does use the pipe, isn’t quite ready for prime time yet.</p>
+</div>
+
+  <!-- dynamically load mathjax for compatibility with self-contained -->
+  <script>
+    (function () {
+      var script = document.createElement("script");
+      script.type = "text/javascript";
+      script.src  = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
+      document.getElementsByTagName("head")[0].appendChild(script);
+    })();
+  </script>
+
+</body>
+</html>
-- 
GitLab