diff options
Diffstat (limited to 'fun')
-rw-r--r-- | fun/dt/CMakeLists.txt | 16 | ||||
-rw-r--r-- | fun/dt/README.md | 11 | ||||
-rw-r--r-- | fun/dt/default.nix | 14 | ||||
-rw-r--r-- | fun/dt/dt.cc | 79 |
4 files changed, 0 insertions, 120 deletions
diff --git a/fun/dt/CMakeLists.txt b/fun/dt/CMakeLists.txt deleted file mode 100644 index 85b659fea862..000000000000 --- a/fun/dt/CMakeLists.txt +++ /dev/null @@ -1,16 +0,0 @@ -# -*- mode: cmake; -*- -cmake_minimum_required(VERSION 3.16) -project(dt) -add_executable(dt dt.cc) -find_package(absl REQUIRED) - -target_link_libraries(dt - absl::flags - absl::flags_parse - absl::hash - absl::time - absl::strings - farmhash -) - -install(TARGETS dt DESTINATION bin) diff --git a/fun/dt/README.md b/fun/dt/README.md deleted file mode 100644 index ee43d5606409..000000000000 --- a/fun/dt/README.md +++ /dev/null @@ -1,11 +0,0 @@ -dt -== - -It's got a purpose. - -## Usage: - -``` -nix-build -E '(import (builtins.fetchGit "https://git.tazj.in/") {}).fun.dt' -./result/bin/dt --one ... --two ... -``` diff --git a/fun/dt/default.nix b/fun/dt/default.nix deleted file mode 100644 index b6efa289948b..000000000000 --- a/fun/dt/default.nix +++ /dev/null @@ -1,14 +0,0 @@ -{ depot, pkgs, ... }: - -let - stdenv = with pkgs; overrideCC clangStdenv clang_10; - abseil_cpp = pkgs.abseil_cpp.override { inherit stdenv; }; -in stdenv.mkDerivation { - name = "dt"; - src = ./.; - nativeBuildInputs = [ pkgs.cmake ]; - buildInputs = with pkgs; [ - abseil_cpp - farmhash - ]; -} diff --git a/fun/dt/dt.cc b/fun/dt/dt.cc deleted file mode 100644 index 5c4c3da76853..000000000000 --- a/fun/dt/dt.cc +++ /dev/null @@ -1,79 +0,0 @@ -#include <iostream> -#include <vector> - -#include "absl/flags/flag.h" -#include "absl/flags/parse.h" -#include "absl/hash/hash.h" -#include "absl/strings/str_cat.h" -#include "absl/time/clock.h" -#include "absl/time/time.h" -#include "absl/types/optional.h" -#include "farmhash.h" - -ABSL_FLAG(std::vector<std::string>, words, {}, "words to use"); - -struct Result { - std::string a; - int ec; - absl::optional<std::string> p; -}; - -std::string which(const std::vector<std::string>& words) { - uint64_t fp; - std::string word; - - for (const auto& w : words) { - auto nfp = util::Fingerprint64(w); - if (nfp > fp) { - fp = nfp; - word = w; - } - } - - return word; -} - -Result decide(const std::vector<std::string>& words) { - auto input = absl::FormatTime("%Y%m%d", absl::Now(), absl::UTCTimeZone()); - for (const auto& w : words) { - input += w; - } - - auto base = util::Fingerprint64(input); - Result result = { "nope" }; - - if (base % 10 == 0) { - result.a = "ca"; - } else if (base % 8 == 0) { - result.a = "c1"; - result.p = which(words); - } else if (base % 6 == 0) { - result.a = "skip"; - } else if (base % 3 == 0) { - result.a = "e1"; - result.ec = base % 10; - result.p = which(words); - } else if (base % 2 == 0) { - result.a = "ea"; - result.ec = base % 10; - } - - return result; -} - -int main(int argc, char *argv[]) { - absl::ParseCommandLine(argc, argv); - - auto words = absl::GetFlag(FLAGS_words); - if (words.size() < 2) { - std::cerr << "needs at least two!" << std::endl; - return 1; - } - - auto result = decide(words); - std::cout << result.a - << (result.p.has_value() ? absl::StrCat(" ", "(", result.p.value(), ")") - : "") - << (result.ec > 0 ? absl::StrCat(": ", result.ec) : "") - << std::endl; -} |