docs/SYNTAX.md
QMD queries are structured documents with typed sub-queries. Each line specifies a search type and query text.
query = expand_query | query_document ;
expand_query = text | explicit_expand ;
explicit_expand= "expand:" text ;
query_document = [ intent_line ] { typed_line } ;
intent_line = "intent:" text newline ;
typed_line = type ":" text newline ;
type = "lex" | "vec" | "hyde" ;
text = quoted_phrase | plain_text ;
quoted_phrase = '"' { character } '"' ;
plain_text = { character } ;
newline = "\n" ;
| Type | Method | Description |
|---|---|---|
lex | BM25 | Keyword search with exact matching |
vec | Vector | Semantic similarity search |
hyde | Vector | Hypothetical document embedding |
A QMD query is either a single expand query or a multi-line query document. Any single-line query with no prefix is treated as an expand query and passed to the expansion model, which emits lex, vec, and hyde variants automatically.
# These are equivalent and cannot be combined with typed lines:
how does authentication work
expand: how does authentication work
Lex queries support special syntax for precise keyword matching:
lex_query = { lex_term } ;
lex_term = negation | phrase | word ;
negation = "-" ( phrase | word ) ;
phrase = '"' { character } '"' ;
word = { letter | digit | "'" } ;
| Syntax | Meaning | Example |
|---|---|---|
word | Prefix match | perf matches "performance" |
"phrase" | Exact phrase | "rate limiter" |
-word | Exclude term | -sports |
-"phrase" | Exclude phrase | -"test data" |
lex: CAP theorem consistency
lex: "machine learning" -"deep learning"
lex: auth -oauth -saml
Vec queries are natural language questions. No special syntax — just write what you're looking for.
vec: how does the rate limiter handle burst traffic
vec: what is the tradeoff between consistency and availability
Hyde queries are hypothetical answer passages (50-100 words). Write what you expect the answer to look like.
hyde: The rate limiter uses a sliding window algorithm with a 60-second window. When a client exceeds 100 requests per minute, subsequent requests return 429 Too Many Requests.
Combine multiple query types for best results. First query gets 2x weight in fusion.
lex: rate limiter algorithm
vec: how does rate limiting work in the API
hyde: The API implements rate limiting using a token bucket algorithm...
An expand query stands alone; it's not mixed with typed lines. You can either rely on the default untyped form or add the explicit expand: prefix:
expand: error handling best practices
# equivalent
error handling best practices
Both forms call the local query expansion model, which generates lex, vec, and hyde variations automatically.
An optional intent: line provides background context to disambiguate ambiguous queries. It steers query expansion, reranking, and snippet extraction but does not search on its own.
intent: line per query documentintent: cannot appear alone — at least one lex:, vec:, or hyde: line is required--intent CLI flag or MCP intent parameterintent: web page load times and Core Web Vitals
lex: performance
vec: how to improve performance
Without intent, "performance" is ambiguous (web-perf? team health? fitness?). With intent, the search pipeline preferentially selects and ranks web-performance content.
lex, vec, hyde, and intent typed lines (no expand: inside)lex syntax (-term, "phrase") only works in lex queriesintent: line per query document; cannot appear aloneThe query tool accepts a query document:
{
"q": "lex: CAP theorem\nvec: consistency vs availability",
"collections": ["docs"],
"limit": 10
}
Or structured format:
{
"searches": [
{ "type": "lex", "query": "CAP theorem" },
{ "type": "vec", "query": "consistency vs availability" }
]
}
With intent:
{
"searches": [
{ "type": "lex", "query": "performance" }
],
"intent": "web page load times and Core Web Vitals"
}
# Single line (implicit expand)
qmd query "how does auth work"
# Multi-line with types
qmd query $'lex: auth token\nvec: how does authentication work'
# Structured
qmd query $'lex: keywords\nvec: question\nhyde: hypothetical answer...'
# With intent (inline)
qmd query $'intent: web performance and latency\nlex: performance\nvec: how to improve performance'
# With intent (flag)
qmd query --intent "web performance and latency" "performance"