An MCP server that enables AI assistants to write FLExTools scripts and directly manipulate FieldWorks lexicon data using natural language.
Developed for SIL Global by Matthew Lee in connection with the SIL's AI Integration Advisory Board and the FLExTrans team.
What it does: FLExTools MCP gives AI assistants (Claude, Copilot, Gemini) the knowledge to write FLExTools modules by providing indexed, searchable documentation of LibLCM and FlexLibs APIs.
** Videos **
The MCP Connection: Talking to your Dictinary
This podcast, for a linguistic audience, gives an overview of using the FLExTools MCP.
MCPs for FLEx and FLExTools: LangTech AI Software Engineering CoP
This presentation, given to an audience of programmers, discusses the background, architecture, and advantages of an MCP, and introduces the FLExTools MCP.
Three ways to use it:
- Generate legacy modules (FlexLibs stable)
- Generate modern modules (FlexLibs 2.0 with ~1,400 functions)
- Run operations directly on FieldWorks databases using natural language queries
Example: "Delete any sense with 'q' in the gloss" → AI generates, tests, and runs the operation automatically.
- What is an MCP Server? See WHY-MCP.md - explains the LibLCM complexity problem and why generic AI assistants fail
- When is AI useful? See WHY-AI.md - learning curve problems and when manual approaches are better
See SETUP.md for detailed installation steps.
Quick summary:
git clone https://github.com/MattGyverLee/FlexToolsMCP.git
cd FlexToolsMCP
pip install -r requirements.txt
# Install FlexLibs 2.0
cd ..
git clone https://github.com/MattGyverLee/flexlibs.git flexlibs2
pip install ./flexlibs2
# Test it works
cd FlexToolsMCP
python -c "from src.server import APIIndex, get_index_dir; i=APIIndex.load(get_index_dir()); print('Loaded', len(i.flexlibs2.get('entities', {})), 'FlexLibs2 entities')"See SETUP.md for Claude Code, Antigravity, and other tools.
Note: Each AI tool has different MCP configuration syntax. See SETUP.md for your specific tool.
See SETUP.md for how to pull new releases.
See USAGE.md for workflows, tool reference, and examples.
Admin & Config:
flextools_start- Initialize session, set project and API modeflextools_manage_config- Get/set/delete persistent configurationflextools_get_session_history- View operation history and undo stackflextools_undo_last_operation- Undo the most recent writeflextools_get_module_template- Get FLExTools module boilerplate
Discovery:
flextools_search_by_capability- Find APIs by natural language intentflextools_get_object_api- Get full API for an object/operations classflextools_get_navigation_path- Find traversal between object typesflextools_find_examples- Get code examples by operation typeflextools_resolve_property- Check casting requirements for properties
Catalog:
flextools_list_categories- List semantic domains (lexicon, grammar, etc.)flextools_list_entities_in_category- List entities in a domain
Module & Execution:
flextools_start_module- Interactive wizard for new moduleflextools_get_operation_logs- View logs and pattern recommendationsflextools_run_module- Execute code with dry-run and write modes
- LibLCM: 2,295 C# entities
- FlexLibs Stable: ~71 methods
- FlexLibs 2.0: ~1,400 methods (99% documented, 82% with examples)
"Remove 'el ' from the beginning of any Spanish gloss"
"Add an environment named 'pre-y' with the context '/_y'"
"Delete the entry with lexeme ɛʃːɛr"
"List entries with "ː" in the headword"
"Are there any duplicates by gloss (fuzzy match) and POS?"
- Discovery-first workflow - the AI assembles modules from indexed building blocks (signatures, navigation skeletons, examples, casting fixes) rather than inventing API calls from training memory. See USAGE.md.
- Automatic index refresh when you update FieldWorks or libraries
- Dry-run mode to test before writing data
- Semantic search with synonym expansion
- Pythonnet casting detection - warns when you need type conversions
- Code examples extracted from real-world usage
- Multiple library versions supported simultaneously
| Document | Purpose |
|---|---|
| HISTORY.md | Release notes and version history |
| SETUP.md | Installation and AI tool configuration |
| USAGE.md | How to use the MCP, workflows, examples |
| DEVELOPMENT.md | Project structure, architecture, contributing |
| docs/WHY-MCP.md | Why FieldWorks needs MCP servers |
| docs/WHY-AI.md | When AI is useful for FieldWorks work |
| docs/INNOVATIONS.md | Technical innovations in this MCP |
| docs/BACKGROUND.md | Project history |
- Always backup before write operations - the MCP defaults to dry-run mode
- Dry run shows what would happen before writing
- Requires explicit user permission for write operations
- Cannot control the FLEx GUI (filters, display, etc.)
- Only manipulates data, not UI state
- FlexLibs 2.0 still undergoing extensive testing
- Some Scripture module edge cases recently fixed
User Request -> AI Assistant -> MCP Server -> Indexed APIs
|
Generated FLExTools Script or Direct Execution
|
FLExTools (IronPython) or FlexLibs 2.0
|
LibLCM (C# data model)
|
FieldWorks Database
For technical details, see DEVELOPMENT.md.
MIT License - See LICENSE file for details
Contributions are welcome! Please submit issues and pull requests on GitHub.
For development info, see DEVELOPMENT.md.
- The FieldWorks developers (Jason, Ken, Hasso, and team)
- Craig, the developer of FLExTools and FlexLibs
- The SIL AI Implementation Advisory Board
- Ron, Beth and the FLExTrans team
- My mentors Doug, Jeff, and Jenni at SIL LangTech
