mirror of
				https://github.com/ggml-org/llama.cpp.git
				synced 2025-10-31 08:51:55 +00:00 
			
		
		
		
	 355c80f49e
			
		
	
	355c80f49e
	
	
	
		
			
			Uses builtin json_encode and json_decode functions to simplify escaping Removes the need for temp files
		
			
				
	
	
		
			24 lines
		
	
	
		
			772 B
		
	
	
	
		
			VimL
		
	
	
	
	
	
			
		
		
	
	
			24 lines
		
	
	
		
			772 B
		
	
	
	
		
			VimL
		
	
	
	
	
	
| function! Llm()
 | |
| 
 | |
|   let url = "http://127.0.0.1:8080/completion"
 | |
| 
 | |
|   " Get the content of the current buffer
 | |
|   let buffer_content = join(getline(1, '$'), "\n")
 | |
| 
 | |
|   " Create the JSON payload
 | |
|   let json_payload = {"temp":0.72,"top_k":100,"top_p":0.73,"repeat_penalty":1.100000023841858,"n_predict":10,"stream": v:false}
 | |
|   let json_payload.prompt = buffer_content
 | |
| 
 | |
|   " Define the curl command
 | |
|   let curl_command = 'curl -k -s -X POST -H "Content-Type: application/json" -d @- ' . url
 | |
|   let response = system(curl_command, json_encode(json_payload))
 | |
| 
 | |
|   " Extract the content field from the response
 | |
|   let content = json_decode(response).content
 | |
| 
 | |
|   " Insert the content at the cursor position
 | |
|   call setline(line('.'), getline('.') . content)
 | |
| endfunction
 | |
| 
 | |
| command! Llm call Llm()
 |