/** * Generate a CSS rule, it reads the width and height attributes of the svg element or fallback to * viewBox attribute. * * @param id ID to use. * @param svg Svg element to convert. * @return A css rule. */ private CharSequence css(final String id, final Element svg) { Throwing.Function<String, Tuple<Tuple<Number, String>, Tuple<Number, String>>> viewBox = Throwing .<String, Tuple<Tuple<Number, String>, Tuple<Number, String>>>throwingFunction(name -> { String vbox = svg.attr(name); String[] dimension = vbox.split("\\s+"); return new Tuple(parse(dimension[2]), parse(dimension[_3])); }).memoized(); Tuple<Number, String> w = Optional.ofNullable(Strings.emptyToNull(svg.attr("width"))) .map(this::parse) .orElseGet(() -> viewBox.apply("viewBox")._1); Tuple<Number, String> h = Optional.ofNullable(Strings.emptyToNull(svg.attr("height"))) .map(this::parse) .orElseGet(() -> viewBox.apply("viewBox")._2); StringBuilder css = new StringBuilder(); css.append(get("css.prefix").toString()).append(".").append(id) .append(" {\n width: ").append(w._1).append(w._2).append(";\n") .append(" height: ").append(h._1).append(h._2).append(";\n}"); return css; }
@Override public void configure(final Env env, final Config conf, final Binder binder) throws Exception { boolean useFile = Stream.of(swaggerOptions, ramlOptions) .filter(Objects::nonNull) .filter(it -> it.file != null) .findFirst() .isPresent(); Throwing.Function<Set<Route.Definition>, List<RouteMethod>> provider = null; if (!useFile) { Path dir = Optional.ofNullable(basedir).orElse(Paths.get(conf.getString("user.dir"))); ApiParser parser = new ApiParser(dir, filter); customizer.forEach(parser::modify); provider = routes -> parser .parseFully(conf.getString("application.class"), new ArrayList<>(routes)); if (!env.name().equals("dev")) { provider = provider.memoized(); } binder.bind(ApiParser.class).toInstance(parser); } String contextPath = conf.getString("application.path"); if (swaggerOptions != null) { swagger(contextPath, env.router(), swaggerOptions, conf, swagger, provider); } if (ramlOptions != null) { raml(contextPath, env.router(), ramlOptions, raml, provider); } }
@Override public void configure(final Env env, final Config conf, final Binder binder) throws Exception { boolean useFile = Stream.of(swaggerOptions, ramlOptions) .filter(Objects::nonNull) .filter(it -> it.file != null) .findFirst() .isPresent(); Throwing.Function<Set<Route.Definition>, List<RouteMethod>> provider = null; if (!useFile) { Path dir = Optional.ofNullable(basedir).orElse(Paths.get(conf.getString("user.dir"))); ApiParser parser = new ApiParser(dir, filter); customizer.forEach(parser::modify); provider = routes -> parser .parseFully(conf.getString("application.class"), new ArrayList<>(routes)); if (!env.name().equals("dev")) { provider = provider.memoized(); } binder.bind(ApiParser.class).toInstance(parser); } String contextPath = conf.getString("application.path"); if (swaggerOptions != null) { swagger(contextPath, env.router(), swaggerOptions, conf, swagger, provider); } if (ramlOptions != null) { raml(contextPath, env.router(), ramlOptions, raml, provider); } }
public CassandraSessionStore(final com.datastax.driver.core.Session session, final int timeout) { this.session = requireNonNull(session, "Session required."); this.timeout = timeout; createTableIfNotExists(session, tableName, log); this.insertSQL = Throwing.<String, PreparedStatement>throwingFunction(table -> session.prepare(insertSQL(table, timeout)) ).memoized(); this.selectSQL = Throwing.<String, PreparedStatement>throwingFunction(table -> session.prepare(selectSQL(table)) ).memoized(); this.deleteSQL = Throwing.<String, PreparedStatement>throwingFunction(table -> session.prepare(deleteSQL(table)) ).memoized(); }
public ExecSchedulerHook(final Map<String, Executor> executors) { // we don't want eager initialization of Schedulers schedulers = Throwing.<String, Scheduler>throwingFunction( name -> Schedulers.from(executors.get(name))) .memoized(); }
public CassandraSessionStore(final com.datastax.driver.core.Session session, final int timeout) { this.session = requireNonNull(session, "Session required."); this.timeout = timeout; createTableIfNotExists(session, tableName, log); this.insertSQL = Throwing.<String, PreparedStatement>throwingFunction(table -> session.prepare(insertSQL(table, timeout)) ).memoized(); this.selectSQL = Throwing.<String, PreparedStatement>throwingFunction(table -> session.prepare(selectSQL(table)) ).memoized(); this.deleteSQL = Throwing.<String, PreparedStatement>throwingFunction(table -> session.prepare(deleteSQL(table)) ).memoized(); }
public ExecSchedulerHook(final Map<String, Executor> executors) { // we don't want eager initialization of Schedulers schedulers = Throwing.<String, Scheduler>throwingFunction( name -> Schedulers.from(executors.get(name))) .memoized(); }