From 626f3163905ab12e05fc598b765dc5ff37b960a5 Mon Sep 17 00:00:00 2001 From: Richie Caputo Date: Thu, 24 Apr 2025 18:02:49 -0400 Subject: [PATCH 1/3] Update docs --- README.md | 24 +++++++++++++++++------- build.sbt | 2 +- scripts/examples.scala | 2 +- scripts/quickstart.scala | 2 +- 4 files changed, 20 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index 95c486c..4ba5bc6 100644 --- a/README.md +++ b/README.md @@ -10,7 +10,7 @@ Features --- -## Installation (Coming Soon) +## Installation Add to your **`build.sbt`** (defaulting to **Scala 3.6.4**): @@ -24,7 +24,7 @@ libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.0" When hacking on *FastMCP‑Scala* itself, you can consume a local build in any project. -### 🔨 Publish to the Local Ivy Repository with `sbt` (Recommended) +### 🔨 Publish to the Local Ivy Repository with `sbt` ```bash # From the fast-mcp-scala root @@ -34,7 +34,7 @@ sbt publishLocal Then, in your consuming sbt project: ```scala -libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.0-SNAPSHOT" +libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.1-SNAPSHOT" ``` > `publishLocal` installs the artifact under `~/.ivy2/local` (or the Coursier cache when enabled). @@ -48,7 +48,7 @@ libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.0-SNAPSHOT" sbt package # Copy the JAR – adjust Scala version / name if you change them -cp target/scala-3.6.4/fast-mcp-scala_3-0.1.0-SNAPSHOT.jar \ +cp target/scala-3.6.4/fast-mcp-scala_3-0.1.1-SNAPSHOT.jar \ /path/to/other-project/lib/ ``` @@ -61,7 +61,7 @@ Unmanaged JARs placed in a project’s `lib/` folder are picked up automatically You can use `fast-mcp-scala` in another scala‑cli project: ```scala //> using scala 3.6.4 -//> using dep com.tjclp::fast-mcp-scala:0.1.0-SNAPSHOT +//> using dep com.tjclp::fast-mcp-scala:0.1.0 //> using options "-Xcheck-macros" "-experimental" ``` @@ -69,7 +69,7 @@ You can also point directly at the local JAR: ```scala //> using scala 3.6.4 -//> using lib "/absolute/path/to/fast-mcp-scala_3-0.1.0-SNAPSHOT.jar" +//> using lib "/absolute/path/to/fast-mcp-scala_3-0.1.0.jar" //> using options "-Xcheck-macros" "-experimental" ``` @@ -79,7 +79,7 @@ You can also point directly at the local JAR: ```scala //> using scala 3.6.4 -//> using dep com.tjclp::fast-mcp-scala:0.1.0-SNAPSHOT +//> using dep com.tjclp::fast-mcp-scala:0.1.0 //> using options "-Xcheck-macros" "-experimental" import com.tjclp.fastmcp.core.{Tool, ToolParam, Prompt, PromptParam, Resource} @@ -118,6 +118,16 @@ The above example can be run using `scala-cli scripts/quickstart.scala` from the npx @modelcontextprotocol/inspector scala-cli /scripts/quickstart.scala ``` +You can also run examples directly from the command line: +```bash +scala-cli run \ + --scala 3.6.4 \ + --dep com.tjclp::fast-mcp-scala:0.1.0 \ + --scala-opt "-Xcheck-macros" \ + --scala-opt "-experimental" \ + --main-class com.tjclp.fastmcp.examples.AnnotatedServer +``` + For additional examples and in‑depth docs, see **`docs/guide.md`**. --- diff --git a/build.sbt b/build.sbt index 7486c73..24d0f01 100644 --- a/build.sbt +++ b/build.sbt @@ -5,7 +5,7 @@ sonatypeTimeoutMillis := 60000 ThisBuild / sonatypeCredentialHost := sonatypeCentralHost -ThisBuild / version := "0.1.0" +ThisBuild / version := "0.1.1-SNAPSHOT" ThisBuild / scalaVersion := "3.6.4" // Using Scala 3 ThisBuild / versionScheme := Some("semver-spec") diff --git a/scripts/examples.scala b/scripts/examples.scala index 8e52b4b..215d486 100644 --- a/scripts/examples.scala +++ b/scripts/examples.scala @@ -1,5 +1,5 @@ //> using scala "3.6.4" -//> using dep com.tjclp::fast-mcp-scala:0.1.0-SNAPSHOT +//> using dep com.tjclp::fast-mcp-scala:0.1.0 //> using options "-Xcheck-macros" "-experimental" // Enable verbose macro processing // This is a launcher file for scala-cli diff --git a/scripts/quickstart.scala b/scripts/quickstart.scala index a9da27b..4b256ae 100644 --- a/scripts/quickstart.scala +++ b/scripts/quickstart.scala @@ -1,5 +1,5 @@ //> using scala 3.6.4 -//> using dep com.tjclp::fast-mcp-scala:0.1.0-SNAPSHOT +//> using dep com.tjclp::fast-mcp-scala:0.1.0 //> using options "-Xcheck-macros" "-experimental" import com.tjclp.fastmcp.core.{Tool, ToolParam, Prompt, PromptParam, Resource} From 0741f0c06bf7ea736c1a1baaa463fc4f9c74a303 Mon Sep 17 00:00:00 2001 From: Richie Caputo Date: Thu, 24 Apr 2025 19:00:40 -0400 Subject: [PATCH 2/3] Update README.md --- README.md | 38 ++++++++++++++++++++++++++++++-------- 1 file changed, 30 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 4ba5bc6..1ebfaa0 100644 --- a/README.md +++ b/README.md @@ -26,6 +26,11 @@ When hacking on *FastMCP‑Scala* itself, you can consume a local build in any p ### 🔨 Publish to the Local Ivy Repository with `sbt` +In your cloned repository, set a working version +```scala +ThisBuild / version := "0.1.1-SNAPSHOT" +``` + ```bash # From the fast-mcp-scala root sbt publishLocal @@ -56,7 +61,7 @@ Unmanaged JARs placed in a project’s `lib/` folder are picked up automatically --- -### 🚀 Using with **scala‑cli** +### 🚀 Using with `scala‑cli` You can use `fast-mcp-scala` in another scala‑cli project: ```scala @@ -75,7 +80,7 @@ You can also point directly at the local JAR: --- -## Quickstart (Annotation‑based) +## Quickstart ```scala //> using scala 3.6.4 @@ -113,21 +118,38 @@ object ExampleServer extends ZIOAppDefault: yield () ``` -The above example can be run using `scala-cli scripts/quickstart.scala` from the repo root (make sure to run `sbt publishLocal` first). You can run the server via the MCP inspector by running +The above example can be run using `scala-cli scripts/quickstart.scala` from the repo root. You can run the server via the MCP inspector by running ```bash npx @modelcontextprotocol/inspector scala-cli /scripts/quickstart.scala ``` You can also run examples directly from the command line: ```bash -scala-cli run \ - --scala 3.6.4 \ - --dep com.tjclp::fast-mcp-scala:0.1.0 \ - --scala-opt "-Xcheck-macros" \ - --scala-opt "-experimental" \ +scala-cli \ + -e '//> using dep com.tjclp::fast-mcp-scala:0.1.0' \ --main-class com.tjclp.fastmcp.examples.AnnotatedServer ``` +In Claude desktop, you can add the following to your `claude_desktop_config.json`: + +```json +{ + "mcpServers": { + "example-fast-mcp-server": { + "command": "scala-cli", + "args": [ + "-e", + "//> using dep com.tjclp::fast-mcp-scala:0.1.0", + "--main-class", + "com.tjclp.fastmcp.examples.AnnotatedServer" + ] + } + } +} +``` + +> Note: FastMCP-Scala example servers are for demo purposes only and don't do anything useful + For additional examples and in‑depth docs, see **`docs/guide.md`**. --- From 0752bd931577620e5c9d357aad7185cd8ea111b2 Mon Sep 17 00:00:00 2001 From: Richie Caputo Date: Thu, 24 Apr 2025 19:03:14 -0400 Subject: [PATCH 3/3] Update README.md - Re-org structure --- README.md | 133 ++++++++++++++++++++++++++---------------------------- 1 file changed, 65 insertions(+), 68 deletions(-) diff --git a/README.md b/README.md index 1ebfaa0..c301425 100644 --- a/README.md +++ b/README.md @@ -8,8 +8,6 @@ Features - Automatic JSON Schema & handler generation via Scala 3 macros - Seamless integration with the Java MCP SDK ---- - ## Installation Add to your **`build.sbt`** (defaulting to **Scala 3.6.4**): @@ -18,68 +16,6 @@ Add to your **`build.sbt`** (defaulting to **Scala 3.6.4**): libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.0" ``` ---- - -## Developing Locally - -When hacking on *FastMCP‑Scala* itself, you can consume a local build in any project. - -### 🔨 Publish to the Local Ivy Repository with `sbt` - -In your cloned repository, set a working version -```scala -ThisBuild / version := "0.1.1-SNAPSHOT" -``` - -```bash -# From the fast-mcp-scala root -sbt publishLocal -``` - -Then, in your consuming sbt project: - -```scala -libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.1-SNAPSHOT" -``` - -> `publishLocal` installs the artifact under `~/.ivy2/local` (or the Coursier cache when enabled). - ---- - -### 📦 Use the JAR Directly (Unmanaged Dependencies) - -```bash -# Package the library -sbt package - -# Copy the JAR – adjust Scala version / name if you change them -cp target/scala-3.6.4/fast-mcp-scala_3-0.1.1-SNAPSHOT.jar \ - /path/to/other-project/lib/ -``` - -Unmanaged JARs placed in a project’s `lib/` folder are picked up automatically by sbt. - ---- - -### 🚀 Using with `scala‑cli` - -You can use `fast-mcp-scala` in another scala‑cli project: -```scala -//> using scala 3.6.4 -//> using dep com.tjclp::fast-mcp-scala:0.1.0 -//> using options "-Xcheck-macros" "-experimental" -``` - -You can also point directly at the local JAR: - -```scala -//> using scala 3.6.4 -//> using lib "/absolute/path/to/fast-mcp-scala_3-0.1.0.jar" -//> using options "-Xcheck-macros" "-experimental" -``` - ---- - ## Quickstart ```scala @@ -118,9 +54,12 @@ object ExampleServer extends ZIOAppDefault: yield () ``` -The above example can be run using `scala-cli scripts/quickstart.scala` from the repo root. You can run the server via the MCP inspector by running +### Running Examples + +The above example can be run using `scala-cli scripts/quickstart.scala` from the repo root. You can run the server via the MCP inspector by running: + ```bash - npx @modelcontextprotocol/inspector scala-cli /scripts/quickstart.scala +npx @modelcontextprotocol/inspector scala-cli /scripts/quickstart.scala ``` You can also run examples directly from the command line: @@ -130,6 +69,8 @@ scala-cli \ --main-class com.tjclp.fastmcp.examples.AnnotatedServer ``` +### Integration with Claude Desktop + In Claude desktop, you can add the following to your `claude_desktop_config.json`: ```json @@ -152,8 +93,64 @@ In Claude desktop, you can add the following to your `claude_desktop_config.json For additional examples and in‑depth docs, see **`docs/guide.md`**. +## License + +[MIT](LICENSE) + --- -## License +## Development Documentation + +### Developing Locally + +When hacking on *FastMCP‑Scala* itself, you can consume a local build in any project. + +#### 🔨 Publish to the Local Ivy Repository with `sbt` + +In your cloned repository, set a working version +```scala +ThisBuild / version := "0.1.1-SNAPSHOT" +``` + +```bash +# From the fast-mcp-scala root +sbt publishLocal +``` + +Then, in your consuming sbt project: + +```scala +libraryDependencies += "com.tjclp" %% "fast-mcp-scala" % "0.1.1-SNAPSHOT" +``` + +> `publishLocal` installs the artifact under `~/.ivy2/local` (or the Coursier cache when enabled). + +#### 📦 Use the JAR Directly (Unmanaged Dependencies) + +```bash +# Package the library +sbt package + +# Copy the JAR – adjust Scala version / name if you change them +cp target/scala-3.6.4/fast-mcp-scala_3-0.1.1-SNAPSHOT.jar \ + /path/to/other-project/lib/ +``` + +Unmanaged JARs placed in a project's `lib/` folder are picked up automatically by sbt. -[MIT](LICENSE) \ No newline at end of file +#### 🚀 Using with `scala‑cli` + +You can use `fast-mcp-scala` in another scala‑cli project: +```scala +//> using scala 3.6.4 +//> using dep com.tjclp::fast-mcp-scala:0.1.0 +//> using options "-Xcheck-macros" "-experimental" +``` + +You can also point directly at the local JAR: + +```scala +//> using scala 3.6.4 +//> using lib "/absolute/path/to/fast-mcp-scala_3-0.1.0.jar" +//> using options "-Xcheck-macros" "-experimental" +``` \ No newline at end of file