-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME-elpa
799 lines (648 loc) · 35.2 KB
/
README-elpa
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
[file:https://img.shields.io/badge/license-GPL_3-green.svg]
[file:https://melpa.org/packages/ellama-badge.svg]
[file:https://stable.melpa.org/packages/ellama-badge.svg]
[file:https://elpa.gnu.org/packages/ellama.svg]
Ellama is a tool for interacting with large language models from
Emacs. It allows you to ask questions and receive responses from the
LLMs. Ellama can perform various tasks such as translation, code review,
summarization, enhancing grammar/spelling or wording and more through
the Emacs interface. Ellama natively supports streaming output, making
it effortless to use with your preferred text editor.
The name "ellama" is derived from "Emacs Large LAnguage Model
Assistant". Previous sentence was written by Ellama itself.
<file:imgs/reasoning-models.gif>
[file:https://img.shields.io/badge/license-GPL_3-green.svg]
<http://www.gnu.org/licenses/gpl-3.0.txt>
[file:https://melpa.org/packages/ellama-badge.svg]
<https://melpa.org/#/ellama>
[file:https://stable.melpa.org/packages/ellama-badge.svg]
<https://stable.melpa.org/#/ellama>
[file:https://elpa.gnu.org/packages/ellama.svg]
<https://elpa.gnu.org/packages/ellama.html>
1 Installation
══════════════
Just `M-x' `package-install' Enter `ellama' Enter. By default it uses
[ollama] provider. If you ok with it, you need to install [ollama] and
pull [any ollama model] like this:
┌────
│ ollama pull qwen2.5:3b
└────
You can use `ellama' with other model or other llm provider. Without
any configuration, the first available ollama model will be used. You
can customize ellama configuration like this:
┌────
│ (use-package ellama
│ :ensure t
│ :bind ("C-c e" . ellama)
│ ;; send last message in chat buffer with C-c C-c
│ :hook (org-ctrl-c-ctrl-c-final . ellama-chat-send-last-message)
│ :init (setopt ellama-auto-scroll t)
│ :config
│ ;; show ellama context in header line in all buffers
│ (ellama-context-header-line-global-mode +1)
│ ;; show ellama session id in header line in all buffers
│ (ellama-session-header-line-global-mode +1))
└────
More sofisticated configuration example:
┌────
│ (use-package ellama
│ :ensure t
│ :bind ("C-c e" . ellama)
│ ;; send last message in chat buffer with C-c C-c
│ :hook (org-ctrl-c-ctrl-c-final . ellama-chat-send-last-message)
│ :init
│ ;; setup key bindings
│ ;; (setopt ellama-keymap-prefix "C-c e")
│ ;; language you want ellama to translate to
│ (setopt ellama-language "German")
│ ;; could be llm-openai for example
│ (require 'llm-ollama)
│ (setopt ellama-provider
│ (make-llm-ollama
│ ;; this model should be pulled to use it
│ ;; value should be the same as you print in terminal during pull
│ :chat-model "llama3:8b-instruct-q8_0"
│ :embedding-model "nomic-embed-text"
│ :default-chat-non-standard-params '(("num_ctx" . 8192))))
│ (setopt ellama-summarization-provider
│ (make-llm-ollama
│ :chat-model "qwen2.5:3b"
│ :embedding-model "nomic-embed-text"
│ :default-chat-non-standard-params '(("num_ctx" . 32768))))
│ (setopt ellama-coding-provider
│ (make-llm-ollama
│ :chat-model "qwen2.5-coder:3b"
│ :embedding-model "nomic-embed-text"
│ :default-chat-non-standard-params '(("num_ctx" . 32768))))
│ ;; Predefined llm providers for interactive switching.
│ ;; You shouldn't add ollama providers here - it can be selected interactively
│ ;; without it. It is just example.
│ (setopt ellama-providers
│ '(("zephyr" . (make-llm-ollama
│ :chat-model "zephyr:7b-beta-q6_K"
│ :embedding-model "zephyr:7b-beta-q6_K"))
│ ("mistral" . (make-llm-ollama
│ :chat-model "mistral:7b-instruct-v0.2-q6_K"
│ :embedding-model "mistral:7b-instruct-v0.2-q6_K"))
│ ("mixtral" . (make-llm-ollama
│ :chat-model "mixtral:8x7b-instruct-v0.1-q3_K_M-4k"
│ :embedding-model "mixtral:8x7b-instruct-v0.1-q3_K_M-4k"))))
│ ;; Naming new sessions with llm
│ (setopt ellama-naming-provider
│ (make-llm-ollama
│ :chat-model "llama3:8b-instruct-q8_0"
│ :embedding-model "nomic-embed-text"
│ :default-chat-non-standard-params '(("stop" . ("\n")))))
│ (setopt ellama-naming-scheme 'ellama-generate-name-by-llm)
│ ;; Translation llm provider
│ (setopt ellama-translation-provider
│ (make-llm-ollama
│ :chat-model "qwen2.5:3b"
│ :embedding-model "nomic-embed-text"
│ :default-chat-non-standard-params
│ '(("num_ctx" . 32768))))
│ (setopt ellama-extraction-provider (make-llm-ollama
│ :chat-model "qwen2.5-coder:7b-instruct-q8_0"
│ :embedding-model "nomic-embed-text"
│ :default-chat-non-standard-params
│ '(("num_ctx" . 32768))))
│ ;; customize display buffer behaviour
│ ;; see ~(info "(elisp) Buffer Display Action Functions")~
│ (setopt ellama-chat-display-action-function #'display-buffer-full-frame)
│ (setopt ellama-instant-display-action-function #'display-buffer-at-bottom)
│ :config
│ ;; show ellama context in header line in all buffers
│ (ellama-context-header-line-global-mode +1)
│ ;; show ellama session id in header line in all buffers
│ (ellama-session-header-line-global-mode +1)
│ ;; handle scrolling events
│ (advice-add 'pixel-scroll-precision :before #'ellama-disable-scroll)
│ (advice-add 'end-of-buffer :after #'ellama-enable-scroll))
└────
[ollama] <https://github.com/jmorganca/ollama>
[any ollama model] <https://ollama.com/models>
2 Commands
══════════
• `ellama': This is the entry point for Ellama. It displays the main
transient menu, allowing you to access all other Ellama commands
from here.
• `ellama-chat': Ask Ellama about something by entering a prompt in an
interactive buffer and continue conversation. If called with
universal argument (`C-u') will start new session with llm model
interactive selection.
• `ellama-write': This command allows you to generate text using an
LLM. When called interactively, it prompts for an instruction that
is then used to generate text based on the context. If a region is
active, the selected text is added to the context before generating
the response.
• `ellama-chat-send-last-message': Send last user message extracted
from current ellama chat buffer.
• `ellama-ask-about': Ask Ellama about a selected region or the
current buffer.
• `ellama-ask-selection': Send selected region or current buffer to
ellama chat.
• `ellama-ask-line': Send current line to ellama chat.
• `ellama-complete': Complete text in current buffer with ellama.
• `ellama-translate': Ask Ellama to translate a selected region or
word at the point.
• `ellama-translate-buffer': Translate current buffer.
• `ellama-define-word': Find the definition of the current word using
Ellama.
• `ellama-summarize': Summarize a selected region or the current
buffer using Ellama.
• `ellama-summarize-killring': Summarize text from the kill ring.
• `ellama-code-review': Review code in a selected region or the
current buffer using Ellama.
• `ellama-change': Change text in a selected region or the current
buffer according to a provided change.
• `ellama-make-list': Create a markdown list from the active region or
the current buffer using Ellama.
• `ellama-make-table': Create a markdown table from the active region
or the current buffer using Ellama.
• `ellama-summarize-webpage': Summarize a webpage fetched from a URL
using Ellama.
• `ellama-provider-select': Select ellama provider.
• `ellama-code-complete': Complete selected code or code in the
current buffer according to a provided change using Ellama.
• `ellama-code-add': Generate and insert new code based on
description. This function prompts the user to describe the code
they want to generate. If a region is active, it includes the
selected text as context for code generation.
• `ellama-code-edit': Change selected code or code in the current
buffer according to a provided change using Ellama.
• `ellama-code-improve': Change selected code or code in the current
buffer according to a provided change using Ellama.
• `ellama-generate-commit-message': Generate commit message based on
diff.
• `ellama-proofread': Proofread selected text.
• `ellama-improve-wording': Enhance the wording in the currently
selected region or buffer using Ellama.
• `ellama-improve-grammar': Enhance the grammar and spelling in the
currently selected region or buffer using Ellama.
• `ellama-improve-conciseness': Make the text of the currently
selected region or buffer concise and simple using Ellama.
• `ellama-make-format': Render the currently selected text or the text
in the current buffer as a specified format using Ellama.
• `ellama-load-session': Load ellama session from file.
• `ellama-session-delete': Delete ellama session.
• `ellama-session-switch': Change current active session.
• `ellama-session-kill': Select and kill one of active sessions.
• `ellama-session-rename': Rename current ellama session.
• `ellama-context-add-file': Add file to context.
• `ellama-context-add-directory': Add all files in directory to the
context.
• `ellama-context-add-buffer': Add buffer to context.
• `ellama-context-add-selection': Add selected region to context.
• `ellama-context-add-info-node': Add info node to context.
• `ellama-context-reset': Clear global context.
• `ellama-manage-context': Manage the global context. Inside context
management buffer you can see ellama context elements. Available
actions with key bindings:
• `n': Move to the next line.
• `p': Move to the previous line.
• `q': Quit the window.
• `g': Update context management buffer.
• `a': Open the transient context menu for adding new elements.
• `d': Remove the context element at the current point.
• `RET': Preview the context element at the current point.
• `ellama-preview-context-element-at-point': Preview ellama context
element at point. Works inside ellama context management buffer.
• `ellama-remove-context-element-at-point': Remove ellama context
element at point from global context. Works inside ellama context
management buffer.
• `ellama-chat-translation-enable': Chat translation enable.
• `ellama-chat-translation-disable': Chat translation disable.
• `ellama-solve-reasoning-problem': Solve reasoning problem with
Abstraction of Thought technique. It uses a chain of multiple
messages to LLM and help it to provide much better answers on
reasoning problems. Even small LLMs like phi3-mini provides much
better results on reasoning tasks using AoT.
• `ellama-solve-domain-specific-problem': Solve domain specific
problem with simple chain. It makes LLMs act like a professional and
adds a planning step.
• `ellama-community-prompts-select-blueprint': Select a prompt from
the community prompt collection. The user is prompted to choose a
role, and then a corresponding prompt is inserted into a blueprint
buffer.
• `ellama-community-prompts-update-variables': Prompt user for values
of variables found in current buffer and update them.
3 Keymap
════════
It's better to use a transient menu (`M-x ellama') instead of a
keymap. It offers a better user experience.
In any buffer where there is active ellama streaming, you can press
`C-g' and it will cancel current stream.
Here is a table of keybindings and their associated functions in
Ellama, using the `ellama-keymap-prefix' prefix (not set by default):
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
Keymap Function Description
───────────────────────────────────────────────────────────────────────
"w" ellama-write Write
"c c" ellama-code-complete Code complete
"c a" ellama-code-add Code add
"c e" ellama-code-edit Code edit
"c i" ellama-code-improve Code improve
"c r" ellama-code-review Code review
"c m" ellama-generate-commit-message Generate commit message
"s s" ellama-summarize Summarize
"s w" ellama-summarize-webpage Summarize webpage
"s c" ellama-summarize-killring Summarize killring
"s l" ellama-load-session Session Load
"s r" ellama-session-rename Session rename
"s d" ellama-session-delete Delete delete
"s a" ellama-session-switch Session activate
"P" ellama-proofread Proofread
"i w" ellama-improve-wording Improve wording
"i g" ellama-improve-grammar Improve grammar and spelling
"i c" ellama-improve-conciseness Improve conciseness
"m l" ellama-make-list Make list
"m t" ellama-make-table Make table
"m f" ellama-make-format Make format
"a a" ellama-ask-about Ask about
"a i" ellama-chat Chat (ask interactively)
"a l" ellama-ask-line Ask current line
"a s" ellama-ask-selection Ask selection
"t t" ellama-translate Text translate
"t b" ellama-translate-buffer Translate buffer
"t e" ellama-chat-translation-enable Translation enable
"t d" ellama-chat-translation-disable Translation disable
"t c" ellama-complete Text complete
"d w" ellama-define-word Define word
"x b" ellama-context-add-buffer Context add buffer
"x f" ellama-context-add-file Context add file
"x d" ellama-context-add-directory Context add directory
"x s" ellama-context-add-selection Context add selection
"x i" ellama-context-add-info-node Context add info node
"x r" ellama-context-reset Context reset
"p s" ellama-provider-select Provider select
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
4 Configuration
═══════════════
The following variables can be customized for the Ellama client:
• `ellama-enable-keymap': Enable the Ellama keymap.
• `ellama-keymap-prefix': The keymap prefix for Ellama.
• `ellama-user-nick': The user nick in logs.
• `ellama-assistant-nick': The assistant nick in logs.
• `ellama-language': The language for Ollama translation. Default
language is english.
• `ellama-provider': llm provider for ellama.
There are many supported providers: `ollama', `open ai', `vertex',
`GPT4All'. For more information see [llm documentation].
• `ellama-providers': association list of model llm providers with
name as key.
• `ellama-spinner-enabled': Enable spinner during text generation.
• `ellama-spinner-type': Spinner type for ellama. Default type is
`progress-bar'.
• `ellama-auto-scroll': If enabled ellama buffer will scroll
automatically during generation. Disabled by default.
• `ellama-fill-paragraphs': Option to customize ellama paragraphs
filling behaviour.
• `ellama-name-prompt-words-count': Count of words in prompt to
generate name.
• Prompt templates for every command.
• `ellama-chat-done-callback': Callback that will be called on ellama
chat response generation done. It should be a function with single
argument generated text string.
• `ellama-nick-prefix-depth': User and assistant nick prefix depth.
Default value is 2.
• `ellama-sessions-directory': Directory for saved ellama sessions.
• `ellama-major-mode': Major mode for ellama commands. Org mode by
default.
• `ellama-session-auto-save': Automatically save ellama sessions if
set. Enabled by default.
• `ellama-naming-scheme': How to name new sessions.
• `ellama-naming-provider': LLM provider for generating session names
by LLM. If not set `ellama-provider' will be used.
• `ellama-chat-translation-enabled': Enable chat translations if set.
• `ellama-translation-provider': LLM translation provider.
`ellama-provider' will be used if not set.
• `ellama-coding-provider': LLM coding tasks provider.
`ellama-provider' will be used if not set.
• `ellama-summarization-provider' LLM summarization provider.
`ellama-provider' will be used if not set.
• `ellama-show-quotes': Show quotes content in chat buffer. Disabled
by default.
• `ellama-chat-display-action-function': Display action function for
`ellama-chat'.
• `ellama-instant-display-action-function': Display action function
for `ellama-instant'.
• `ellama-translate-italic': Translate italic during markdown to org
transformations. Enabled by default.
• `ellama-extraction-provider': LLM provider for data extraction.
• `ellama-text-display-limit': Limit for text display in context
elements.
• `ellama-context-poshandler': Position handler for displaying context
buffer. `posframe-poshandler-frame-top-center' will be used if not
set.
• `ellama-context-border-width': Border width for the context buffer.
• `ellama-session-remove-reasoning': Remove internal reasoning from
the session after ellama provide an answer. This can improve
long-term communication with reasoning models. Enabled by default.
• `ellama-session-hide-org-quotes': Hide org quotes in the Ellama
session buffer. From now on, think tags will be replaced with quote
blocks. If this flag is enabled, reasoning steps will be collapsed
after generation and upon session loading. Enabled by default.
• `ellama-output-remove-reasoning': Eliminate internal reasoning from
ellama output to enhance the versatility of reasoning models across
diverse applications.
• `ellama-context-posframe-enabled': Enable showing posframe with
ellama context.
• `ellama-manage-context-display-action-function': Display action
function for `ellama-render-context'. Default value
`display-buffer-same-window'.
• `ellama-preview-context-element-display-action-function': Display
action function for `ellama-preview-context-element'.
• `ellama-context-line-always-visible': Make context header or mode
line always visible, even with empty context.
• `ellama-community-prompts-url': The URL of the community prompts
collection.
• `ellama-community-prompts-file': Path to the CSV file containing
community prompts. This file is expected to be located inside an
`ellama' subdirectory within your `user-emacs-directory'.
• `ellama-show-reasoning': Show reasoning in separate buffer if
enabled. Enabled by default.
• `ellama-reasoning-display-action-function': Display action function
for reasoning.
• `ellama-session-line-template': Template for formatting the current
session line.
[llm documentation] <https://elpa.gnu.org/packages/llm.html>
5 Context Management
════════════════════
Ellama allows you to provide context to the Large Language Model (LLM)
to improve the relevance and quality of responses. Context serves as
background information, data, or instructions that guide the LLM's
understanding of your prompt. Without context, the LLM relies solely
on its pre-existing knowledge, which may not always be appropriate.
A “global context” is maintained, which is a collection of text blocks
accessible to the LLM when responding to prompts. This global context
is prepended to your prompt before transmission to the
LLM. Additionally, Ellama supports an "ephemeral context," which is
temporary and only available for a single request.
5.1 Transient Menus for Context Management
──────────────────────────────────────────
Ellama provides a transient menu accessible through the main menu,
offering a streamlined way to manage context elements. This menu is
accessed via the “System” branch of the main transient menu, and then
selecting "Context Commands."
The Context Commands transient menu is structured as follows:
Context Commands:
• Options: Provides options for managing ephemeral context.
• “-e” "Use Ephemeral Context" `--ephemeral'
• Add: Provides options for adding content to the global or ephemeral
context.
• “b” "Add Buffer" `ellama-transient-add-buffer'
• “d” "Add Directory" `ellama-transient-add-directory'
• “f” "Add File" `ellama-transient-add-file'
• “s” "Add Selection" `ellama-transient-add-selection'
• “i” "Add Info Node" `ellama-transient-add-info-node'
• Manage: Provides options for managing the global context.
• “m” "Manage context" `ellama-context-manage' - Opens the context
management buffer.
• “D” "Delete element" `ellama-context-element-remove-by-name' -
Deletes an element by name.
• “r” "Context reset" `ellama-context-reset' - Clears the entire
global context.
• Quit: (“q” "Quit" `transient-quit-one') - Closes the context
commands transient menu.
5.2 Managing the Context
────────────────────────
`ellama-context-manage' opens a dedicated buffer, the context
management buffer, where you can view, modify, and organize the global
context. Within this buffer:
⁃ `n': Move to the next context element.
⁃ `p': Move to the previous context element.
⁃ `q': Quit the context management buffer.
⁃ `g': Refresh the contents of the context management buffer.
⁃ `a': Add a new context element (similar to
`ellama-context-add-selection').
⁃ `RET': Preview the content of the context element at the current
point.
5.3 Considerations
──────────────────
Large Language Models possess limited context window sizes,
restricting the total amount of text they can process. Be mindful of
the size of your context to avoid truncation or performance
degradation. Irrelevant context can dilute the information and hinder
the LLM’s focus. Ensure context remains up-to-date for accurate
information. Experimentation with different approaches to context
management can optimize performance for specific use cases.
6 Minor modes
═════════════
The Ellama package for Emacs offers a suite of minor modes designed to
enhance the user experience by providing context-specific information
directly within the editor's interface. These minor modes focus on
updating both the header line and mode line with relevant details,
making it easier to manage and navigate multiple sessions and buffers.
Key features include:
• Context Header Line Modes: `ellama-context-header-line-mode' and its
global counterpart, `ellama-context-header-line-global-mode', update
the header line to display what elements are added to the global
Ellama context. This is particularly useful for keeping track of
what information is currently in context.
• Context Mode Line Modes: Similarly, `ellama-context-mode-line-mode'
and `ellama-context-mode-line-global-mode' provide information about
the current global context directly within the mode line, ensuring
that users always have relevant information at a glance.
• Session Header Line Mode: `ellama-session-header-line-mode' and its
global version display the current Ellama session ID in the header
line, helping users manage multiple sessions efficiently.
• Session Mode Line Mode: `ellama-session-mode-line-mode' and its
global counterpart offer an additional way to track session IDs by
displaying them in the mode line.
These minor modes are easily toggled on or off using specific
commands, providing flexibility for users who may want to enable these
features globally across all buffers or selectively within individual
buffers.
6.1 ellama-context-header-line-mode
───────────────────────────────────
Description: Toggle the Ellama Context header line mode. This minor
mode updates the header line to display context-specific information.
Usage: To enable or disable `ellama-context-header-line-mode', use the
command:
M-x ellama-context-header-line-mode
When enabled, this mode adds a hook to `window-state-change-hook' to
update the header line whenever the window state changes. It also
calls `ellama-context-update-header-line' to initialize the header
line with context-specific information.
When disabled, it removes the evaluation of `(:eval
(ellama-context-line))' from `header-line-format'.
6.2 ellama-context-header-line-global-mode
──────────────────────────────────────────
Description: Globalized version of
`ellama-context-header-line-mode'. This mode ensures that
`ellama-context-header-line-mode' is enabled in all buffers.
Usage: To enable or disable `ellama-context-header-line-global-mode',
use the command:
M-x ellama-context-header-line-global-mode
This globalized minor mode provides a convenient way to ensure that
context-specific header line information is always available,
regardless of the buffer being edited.
6.3 ellama-context-mode-line-mode
─────────────────────────────────
Description: Toggle the Ellama Context mode line mode. This minor mode
updates the mode line to display context-specific information.
Usage: To enable or disable `ellama-context-mode-line-mode', use the
command:
M-x ellama-context-mode-line-mode
When enabled, this mode adds a hook to `window-state-change-hook' to
update the mode line whenever the window state changes. It also calls
`ellama-context-update-mode-line' to initialize the mode line with
context-specific information.
When disabled, it removes the evaluation of `(:eval
(ellama-context-line))' from `mode-line-format'.
6.4 ellama-context-mode-line-global-mode
────────────────────────────────────────
Description: Globalized version of
`ellama-context-mode-line-mode'. This mode ensures that
`ellama-context-mode-line-mode' is enabled in all buffers.
Usage: To enable or disable `ellama-context-mode-line-global-mode',
use the command:
M-x ellama-context-mode-line-global-mode
This globalized minor mode provides a convenient way to ensure that
context-specific mode line information is always available, regardless
of the buffer being edited.
6.5 Ellama Session Header Line Mode
───────────────────────────────────
The `ellama-session-header-line-mode' is a minor mode that allows you
to display the current Ellama session ID in the header line of your
Emacs buffers. This feature helps keep track of which session you are
working with, especially useful when managing multiple sessions.
6.5.1 Enabling and Disabling
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
To enable this mode, use the following command:
┌────
│ M-x ellama-session-header-line-mode
└────
This will toggle the display of the session ID in the header line. You
can also enable or disable it globally across all buffers using:
┌────
│ M-x ellama-session-header-line-global-mode
└────
6.5.2 Customization
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
The session ID is displayed with a customizable face called
`ellama-face'. You can customize this face to change its appearance.
6.6 Ellama Session Mode Line Mode
─────────────────────────────────
The `ellama-session-mode-line-mode' is a minor mode that allows you to
display the current Ellama session ID in the mode line of your Emacs
buffers. This feature provides an additional way to keep track of
which session you are working with, especially useful when managing
multiple sessions.
6.6.1 Enabling and Disabling
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
To enable this mode, use the following command:
┌────
│ M-x ellama-session-mode-line-mode
└────
This will toggle the display of the session ID in the mode line. You
can also enable or disable it globally across all buffers using:
┌────
│ M-x ellama-session-mode-line-global-mode
└────
6.6.2 Customization
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
The session ID is displayed with a customizable face called
`ellama-face'. You can customize this face to change its appearance.
7 Using Blueprints
══════════════════
Blueprints in Ellama refer to predefined templates or structures that
facilitate the creation and management of chat sessions. These
blueprints are designed to streamline the process of generating
consistent and high-quality outputs by providing a structured
framework for interactions.
7.1 Key Components of Ellama Blueprints
───────────────────────────────────────
1. Act: This is the primary identifier for a blueprint, representing
the
action or purpose of the blueprint.
1. Prompt: The content that will be used to initiate the chat
session. This
can include instructions, context, or any other relevant information
needed to guide the conversation.
1. For Developers: A flag indicating whether the blueprint is intended
for
developers.
7.2 Creating and Managing Blueprints
────────────────────────────────────
Ellama provides several functions to create, select, and manage
blueprints:
• `ellama-blueprint-create': This function allows users to create a
new blueprint from the current buffer. It prompts for a name and
whether the blueprint is for developers, then saves the content of
the current buffer as the prompt.
• `ellama-blueprint-new': This function creates a new buffer for a
blueprint, optionally inserting the content of the current region if
active.
• `ellama-blueprint-select': This function allows users to select a
prompt from the collection of blueprints. It filters prompts based
on whether they are for developers and their source (user-defined,
community, or all).
7.3 Variable Management
───────────────────────
Blueprints can include variables that need to be filled before running
the chat session. Ellama provides command to fill these variables:
• `ellama-blueprint-fill-variables': Prompts the user to enter values
for variables found in the current buffer and fills them.
7.4 Keymap and Mode
───────────────────
Ellama provides a local keymap `ellama-blueprint-mode-map' for
managing blueprints within buffers. The mode includes key bindings for
sending the buffer to a new chat session, killing the current buffer,
creating a new blueprint, and filling variables.
The `ellama-blueprint-mode' is a derived mode from `text-mode',
providing syntax highlighting for variables in curly braces and
setting up the local keymap.
When in `ellama-blueprint-mode', the following keybindings are
available:
• `C-c C-c': Send current buffer to a new chat session and kill the
current buffer.
• `C-c C-k': Kill the current buffer.
• `C-c c': Create a blueprint from the current buffer.
• `C-c v': Fill variables in the current blueprint.
7.5 Transient Menus
───────────────────
Ellama includes transient menus for easy access to blueprint
commands. The `ellama-transient-blueprint-menu' provides options for
chatting with a selected blueprint, creating a new blueprint, and
quitting the menu.
The `ellama-transient-main-menu' integrates the blueprint menu into
the main menu, providing a comprehensive interface for all Ellama
commands.
7.6 Running Blueprints programmatically
───────────────────────────────────────
The `ellama-blueprint-run' function initiates a chat session using a
specified blueprint. It pre-fills variables based on the provided
arguments.
┌────
│ (defun my-chat-with-morpheus ()
│ "Start chat with Morpheus."
│ (interactive)
│ (ellama-blueprint-run "Character" '(:character "Morpheus" :series "Matrix")))
│
│ (global-set-key (kbd "C-c e M") #'my-chat-with-morpheus)
└────
8 Acknowledgments
═════════════════
Thanks [Jeffrey Morgan] for excellent project [ollama]. This project
cannot exist without it.
Thanks [zweifisch] - I got some ideas from [ollama.el] what ollama
client in Emacs can do.
Thanks [Dr. David A. Kunz] - I got more ideas from [gen.nvim].
Thanks [Andrew Hyatt] for `llm' library. Without it only `ollama'
would be supported.
[Jeffrey Morgan] <https://github.com/jmorganca>
[ollama] <https://github.com/jmorganca/ollama>
[zweifisch] <https://github.com/zweifisch>
[ollama.el] <https://github.com/zweifisch/ollama>
[Dr. David A. Kunz] <https://github.com/David-Kunz>
[gen.nvim] <https://github.com/David-Kunz/gen.nvim>
[Andrew Hyatt] <https://github.com/ahyatt>
9 Contributions
═══════════════
To contribute, submit a pull request or report a bug. This library is
part of GNU ELPA; major contributions must be from someone with FSF
papers. Alternatively, you can write a module and share it on a
different archive like MELPA.
10 GNU Free Documentation License
═════════════════════════════════