From e4e25935b71cb6b5e2525c05d2b310381e583da2 Mon Sep 17 00:00:00 2001
From: Sloane Perrault <sloane@perrault.email>
Date: Thu, 29 Jun 2023 15:20:23 -0400
Subject: [PATCH] `mix new`

---
 .formatter.exs        |  4 ++++
 .gitignore            | 26 ++++++++++++++++++++++++++
 .tool-versions        |  2 ++
 README.md             | 21 +++++++++++++++++++++
 lib/type_id.ex        | 18 ++++++++++++++++++
 mix.exs               | 28 ++++++++++++++++++++++++++++
 test/test_helper.exs  |  1 +
 test/type_id_test.exs |  8 ++++++++
 8 files changed, 108 insertions(+)
 create mode 100644 .formatter.exs
 create mode 100644 .gitignore
 create mode 100644 .tool-versions
 create mode 100644 README.md
 create mode 100644 lib/type_id.ex
 create mode 100644 mix.exs
 create mode 100644 test/test_helper.exs
 create mode 100644 test/type_id_test.exs

diff --git a/.formatter.exs b/.formatter.exs
new file mode 100644
index 0000000..d2cda26
--- /dev/null
+++ b/.formatter.exs
@@ -0,0 +1,4 @@
+# Used by "mix format"
+[
+  inputs: ["{mix,.formatter}.exs", "{config,lib,test}/**/*.{ex,exs}"]
+]
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..cb39c22
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,26 @@
+# The directory Mix will write compiled artifacts to.
+/_build/
+
+# If you run "mix test --cover", coverage assets end up here.
+/cover/
+
+# The directory Mix downloads your dependencies sources to.
+/deps/
+
+# Where third-party dependencies like ExDoc output generated docs.
+/doc/
+
+# Ignore .fetch files in case you like to edit your project deps locally.
+/.fetch
+
+# If the VM crashes, it generates a dump, let's ignore it too.
+erl_crash.dump
+
+# Also ignore archive artifacts (built via "mix archive.build").
+*.ez
+
+# Ignore package tarball (built via "mix hex.build").
+typeid-*.tar
+
+# Temporary files, for example, from tests.
+/tmp/
diff --git a/.tool-versions b/.tool-versions
new file mode 100644
index 0000000..0c37fc4
--- /dev/null
+++ b/.tool-versions
@@ -0,0 +1,2 @@
+elixir 1.15.0-otp-26
+erlang 26.0.2
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..eb4e193
--- /dev/null
+++ b/README.md
@@ -0,0 +1,21 @@
+# TypeID
+
+**TODO: Add description**
+
+## Installation
+
+If [available in Hex](https://hex.pm/docs/publish), the package can be installed
+by adding `typeid` to your list of dependencies in `mix.exs`:
+
+```elixir
+def deps do
+  [
+    {:typeid, "~> 0.1.0"}
+  ]
+end
+```
+
+Documentation can be generated with [ExDoc](https://github.com/elixir-lang/ex_doc)
+and published on [HexDocs](https://hexdocs.pm). Once published, the docs can
+be found at <https://hexdocs.pm/typeid>.
+
diff --git a/lib/type_id.ex b/lib/type_id.ex
new file mode 100644
index 0000000..23b051a
--- /dev/null
+++ b/lib/type_id.ex
@@ -0,0 +1,18 @@
+defmodule TypeID do
+  @moduledoc """
+  Documentation for `TypeID`.
+  """
+
+  @doc """
+  Hello world.
+
+  ## Examples
+
+      iex> TypeID.hello()
+      :world
+
+  """
+  def hello do
+    :world
+  end
+end
diff --git a/mix.exs b/mix.exs
new file mode 100644
index 0000000..369e9da
--- /dev/null
+++ b/mix.exs
@@ -0,0 +1,28 @@
+defmodule TypeID.MixProject do
+  use Mix.Project
+
+  def project do
+    [
+      app: :typeid,
+      version: "0.1.0",
+      elixir: "~> 1.15",
+      start_permanent: Mix.env() == :prod,
+      deps: deps()
+    ]
+  end
+
+  # Run "mix help compile.app" to learn about applications.
+  def application do
+    [
+      extra_applications: [:logger]
+    ]
+  end
+
+  # Run "mix help deps" to learn about dependencies.
+  defp deps do
+    [
+      # {:dep_from_hexpm, "~> 0.3.0"},
+      # {:dep_from_git, git: "https://github.com/elixir-lang/my_dep.git", tag: "0.1.0"}
+    ]
+  end
+end
diff --git a/test/test_helper.exs b/test/test_helper.exs
new file mode 100644
index 0000000..869559e
--- /dev/null
+++ b/test/test_helper.exs
@@ -0,0 +1 @@
+ExUnit.start()
diff --git a/test/type_id_test.exs b/test/type_id_test.exs
new file mode 100644
index 0000000..0404774
--- /dev/null
+++ b/test/type_id_test.exs
@@ -0,0 +1,8 @@
+defmodule TypeIDTest do
+  use ExUnit.Case
+  doctest TypeID
+
+  test "greets the world" do
+    assert TypeID.hello() == :world
+  end
+end