pdftract/templates/sdk-skeleton/dotnet
jedarden 11257e7706 feat(pdftract-l993m): complete per-language Tera template scaffolding
Complete the Tera template scaffolding for all 8 subprocess-based SDKs
under templates/sdk-skeleton/<lang>/: node, go, java, dotnet, ruby,
php, swift, python-subprocess.

Each template directory contains:
- Package metadata template (package.json, go.mod, pom.xml, etc.)
- Method stubs template (methods.ts, client.go, Methods.java, etc.)
- Error stubs template (errors.ts, errors.go, Errors.java, etc.)
- Conformance runner template (conformance.test.ts, etc.)
- README template with {{ version }} variable substitution
- GENERATED.tera marker file

New files for python-subprocess:
- pdftract_subprocess/codegen/errors.py.tera
- tests/codegen/conformance_test.py.tera
- README.md.tera
- GENERATED.tera

All 8 language template directories are now complete and ready for
consumption by the `pdftract sdk codegen` subcommand.

Co-Authored-By: Claude Code <noreply@anthropic.com>
2026-05-18 02:01:46 -04:00
..
src/Codegen feat(pdftract-l993m): complete per-language Tera template scaffolding 2026-05-18 02:01:46 -04:00
tests/Pdftract.Tests feat(pdftract-l993m): complete per-language Tera template scaffolding 2026-05-18 02:01:46 -04:00
GENERATED.tera feat(pdftract-l993m): complete per-language Tera template scaffolding 2026-05-18 02:01:46 -04:00
Pdftract.csproj.tera feat(pdftract-l993m): complete per-language Tera template scaffolding 2026-05-18 02:01:46 -04:00
README.md.tera feat(pdftract-l993m): complete per-language Tera template scaffolding 2026-05-18 02:01:46 -04:00

# Pdftract

.NET SDK for pdftract - PDF extraction and conformance testing.

## Installation

```bash
dotnet add package Pdftract --version {{ version }}
```

## Usage

### Basic extract

```csharp
using Pdftract;
using Pdftract.Codegen;

using var client = new Pdftract();
var doc = await client.ExtractAsync(new PathSource("document.pdf"));
Console.WriteLine($"Pages: {doc.Pages.Count}");
```

### Extract with OCR

```csharp
var options = new ExtractOptions
{
    OcrLanguage = "eng",
    OcrThreshold = 0.7
};

var doc = await client.ExtractAsync(new PathSource("scanned.pdf"), options);
```

### Search

```csharp
await foreach (var match in client.SearchAsync(new PathSource("document.pdf"), "invoice"))
{
    Console.WriteLine($"Found on page {match.Page}: {match.Text}");
}
```

### Stream extraction

```csharp
await foreach (var page in client.ExtractStreamAsync(new PathSource("large.pdf")))
{
    Console.WriteLine($"Page {page.Page}: {page.Blocks.Count} blocks");
}
```

## Binary version compatibility

This SDK requires pdftract {{ version }}. Download from:
https://github.com/jedarden/pdftract/releases/tag/v{{ version }}

## Troubleshooting

### Binary not found
Ensure `pdftract` is on your PATH. The SDK probes PATH for the executable.

### Version mismatch
The SDK will refuse to invoke mismatched binary versions. Install the correct version.

### Network failure
For remote URLs, check your network connection and TLS certificate chain.