;; prefix
(setq repl-default-proc "ansi-term")
(setq repl-second-proc "browser-repl") ;; we can sent to secondary using b, c is primary
(defun repl-set-default-proc ()
"set default process for evaluation"
(interactive)
(setq repl-default-roc (read-string "set default proc (default: ansi-term): " nil nil "ansi-term")))
(defun repl-set-second-proc ()
"set second process for evaluation"
(interactive)
(setq repl-second-roc (read-string "set second proc (default: browser-repl): " nil nil "browser-repl")))
;; todo: assign key
(defface my-highlight-face
'((t (:background "##f0f8ff"))) ; Customize background color here
"Face for highlighting text."
:group 'basic-faces)
(defun repl-create-proc (name)
"create persistence repl process"
(interactive)
(let ((current-buffer (current-buffer)))
(if (get-buffer (format "*%s*" name))
(get-buffer-process (format "*%s*" name))
(get-buffer-process (ansi-term "/bin/zsh" name))
(switch-to-buffer current-buffer)
(message "repl-process created"))));; TODO: fix need to sent twice when starting
(defun repl-send-to (proc str)
"repl send message to proces"
(interactive)
(let ((proc (repl-create-proc proc)))
(comint-send-string proc str)
(comint-send-string proc "\n")
(message "repl sent .")))
;; main functions
(defun repl-send-last-exp (&optional proc)
"send last expression"
(interactive)
(let* ((begin (save-excursion
(backward-sexp)
(move-beginning-of-line nil)
(point)))
(end (point))
(str (buffer-substring-no-properties begin end)))
;;(highlight-region begin end)
(repl-send-to (or proc repl-default-proc) str)))
(defun repl-send-line (&optional proc)
"send line"
(interactive)
(let* ((begin (save-excursion (beginning-of-line) (point)))
(end (save-excursion (end-of-line) (point)))
(str (buffer-substring-no-properties begin end)))
;;(highlight-region begin end)
(repl-send-to (or proc repl-default-proc) str)))
(defun repl-send-paragraph (&optional proc)
"Send region if selected, otherwise send the current paragraph."
(interactive)
(let* ((start (progn (backward-paragraph) (point)))
(end (progn (forward-paragraph) (point)))
(str (buffer-substring-no-properties start end)))
;;(highlight-region begin end)
(repl-send-to (or proc repl-default-proc) str)))
(defun repl-send-region (&optional proc)
"Send the selected region to the process PROC."
(interactive)
(when (use-region-p)
(let ((start (region-beginning))
(end (region-end)))
(repl-send-to (or proc repl-default-proc)
(buffer-substring-no-properties start end)))))
;; todo: sent buffer or region
(defun repl-send-buffer (&optional proc)
"send the whole buffer"
(interactive)
;;(highlight-region (point-min) (point-max))
(repl-send-to (or proc repl-default-proc) (buffer-substring-no-properties (point-min) (point-max))))
(defun repl-send-markdown-block (&optional proc)
"send current markdown code block, search block backwarnd and then forward"
(interactive)
(save-excursion
(let ((starting-pos (progn (re-search-backward "^```" (point-min) t) (match-end 0)))
(end-pos (progn (re-search-forward md-block-end (point-max) t) (match-beginning 0))))
(let ((file-ref (or (progn (re-search-backward "```" starting-pos t) (match-string 1)) nil))
(start-content (progn (goto-char starting-pos) (beginning-of-line) (forward-line 1) (point))))
;;(highlight-region start-content end-pos)
(repl-send-to (or proc repl-default-proc) (buffer-substring-no-properties start-content end-pos))))))
;; TODO: send markdown block using defined proc in the code blocks it selfs
(defun repl-b-send-last-exp ()
"send last expression to secondary proc"
(interactive)
(repl-send-last-exp repl-second-proc))
(defun repl-b-send-line ()
"send line to secondary proc"
(interactive)
(repl-send-line repl-second-proc))
;; todo: buffer is sent or region selected
(defun repl-b-send-buffer ()
"send buffer to secondary proc"
(interactive)
(repl-send-buffer repl-second-proc))
(defun repl-b-send-paragraph ()
"send paragraph to secondary proc"
(interactive)
(repl-send-paragraph repl-second-proc))
(defun repl-b-send-region ()
"send region to secondary proc"
(interactive)
(repl-send-region repl-second-proc))
(defun repl-b-send-markdown-block ()
"send markdown-block to secondary proc"
(interactive)
(repl-send-markdown-block repl-second-proc))
(setq repl-mark "reload()") ;; default mark
(defun repl-set-mark ()
(interactive)
(setq repl-mark (read-string "set repl-mark: ")))
(defun repl-send-mark () ;; todo: make it able to send to the second process
"send marked interctive"
(interactive)
(repl-send-to repl-default-proc repl-mark))
;; todo: send buffer or region ;;;
(defvar tmux-last-target nil
"Stores the last tmux target used.")
(defun tmux-set-target (target)
"Set the tmux TARGET for subsequent commands."
(interactive "sTmux target (e.g., session:window.pane): ")
(setq tmux-last-target target)
(message "Tmux target set to: %s" tmux-last-target))
(defun tmux-get-target ()
"Get the current tmux target, or prompt if none is set."
(or tmux-last-target
(read-string "No target set. Specify tmux target (e.g., session:window.pane): ")))
(defun tmux-send-keys (target command)
"Send a COMMAND string to a specific tmux TARGET (session:window.pane).
Escape special characters like $ and \" before sending."
(let* ((step1 (replace-regexp-in-string "\"" "\\\"" command t t))
(step2 (replace-regexp-in-string "\\$" "\\$" step1 t t))
(step3 (replace-regexp-in-string "`" "\\`" step2 t t))
(formatted-command (concat "tmux send-keys -t " target " \"" step3 "\" C-m")))
(start-process-shell-command "tmux-send-keys" nil formatted-command)
(message "Sent to tmux: %s" command)))
(defun tmux-send-control-key (key)
"Send a control KEY (e.g., C-c, C-d, C-z) to the last tmux target."
(let ((target (tmux-get-target))
(control-key (pcase key
('C-c "C-c")
('C-d "C-d")
('C-z "C-z")
(_ (error "Unsupported control key")))))
(let ((formatted-command (format "tmux send-keys -t %s %s" target control-key)))
(start-process-shell-command "tmux-send-keys" nil formatted-command)
(message "Sent to tmux: %s" control-key))))
(defun tmux-send-last-command (command)
"Send COMMAND to the last tmux target."
(tmux-send-keys (tmux-get-target) command))
(defun tmux-send-line-to-repl ()
"Send the current line to the tmux target."
(interactive)
(let ((line-text (thing-at-point 'line t)))
(tmux-send-last-command line-text)))
(defun tmux-send-region-to-repl (start end)
"Send the selected region (START to END) to the tmux target."
(interactive "r")
(let ((region-text (buffer-substring-no-properties start end)))
(tmux-send-last-command region-text)))
(defun tmux-send-paragraph-to-repl ()
"Send the current paragraph to the tmux target."
(interactive)
(let ((paragraph-text (thing-at-point 'paragraph t)))
(tmux-send-last-command paragraph-text)))
(defun tmux-send-control-c ()
"Send C-c to the tmux target."
(interactive)
(tmux-send-control-key 'C-c))
(defun tmux-send-control-d ()
"Send C-d to the tmux target."
(interactive)
(tmux-send-control-key 'C-d))
(defun tmux-send-control-z ()
"Send C-z to the tmux target."
(interactive)
(tmux-send-control-key 'C-z))
(defun tmux-send-region-or-paragraph-with-cat (start end)
"Send the selected region or the current paragraph to the tmux target,
wrapped in a 'cat > FILENAME <<'EOF' ... EOF' block."
(interactive "r")
(let* ((filename (read-string "Enter filename: "))
(content (if (use-region-p)
(buffer-substring-no-properties start end)
(thing-at-point 'paragraph t)))
(wrapped-content (format "cat > %s <<'EOF'\n%s\nEOF" filename content)))
(tmux-send-last-command wrapped-content)))
(defun tmux-send-region-evaluate (start end)
"send region to last command"
(interactive "r")
(let* ((expression (if (use-region-p)
(buffer-substring-no-properties start end)
(thing-at-point 'paragraph t)))
(escape-expr (replace-regexp-in-string "\"" "\\\"" expression t t))
(json-command (format "{\"id\": 1, \"method\":\"Runtime.evaluate\", \"params\":{ \"expression\":\"%s\"}}" escape-expr)))
(tmux-send-last-command json-command)))
(global-set-key (kbd "C-c t b") 'tmux-send-region-evaluate)
snippet
simplify version without file path contents
(defvar snippets (make-hash-table :test 'equal))
(puthash "node" "foo\nbar\nbar" snippets);
(puthash "html" "<html>\n <head>\n <meta name=\"viewport\" content=\"width=device-width,initial-scale=1.0\">\n </head>\n <body></body>\n</html>" snippets);
(puthash "http" "var {createServer, startServer response, findFile} = require('@zaeny/http');\n\nvar index = (req, res) => findFile('./index.html')\nvar notFound = () => ({body:'', headers:{}, status: 404});\n\nvar routes = {\n 'GET /': index,\n \"GET /_\": responseBuffer,\n \"GET /favico.ico\": notFound, \n}\n\nvar handler = (req, res) => {\n let resolve = routes[`${req.method} ${req.path}`]; \n if(resolve) return resolve(req, res);\n return index(req, res); // no not found\n}\nvar server = server || startServer(createServer({ port: 8081, handler: (req, res) => handler(req, res)}))\nvar reload = () => responseWith(`window.location=window.location;`);\nvar watchReload = (file, callback) => require('fs').watchFile(file, { persistent:true, interval:500 }, (prev, cur)=> callback());\nvar watcher = watcher || watchReload('./index.html', reload);\n" snippets)
(puthash "addHttp" "\nvar evaluate= (...args) => {\n let [vm=require('vm'), ctx=global, addCtx={console, require, module}] = args;\n return (res) => {\n let context = vm.createContext(ctx);\n return vm.runInContext(res, Object.assign(context, addCtx));\n }\n}\nvar addDeps = (url, file) => fetch(url).then(res => res.text()).then(evaluate());\nvar httpUrl = \"https://raw.githubusercontent.com/azizzaeny/http/main/dist/index.js\";\naddDeps(httpUrl);" snippets)
(puthash "devjs" "\nvar dev = url => fetch(url).then(res => res.text()).then(res => (eval(res), setTimeout(()=>dev(url), 200)));\n" snippets)
(defun abbrev-at-point ()
"Return the abbreviation at point."
(let* ((end (point))
(start (save-excursion
(skip-chars-backward "a-zA-Z0-9_:|-!<>")
(point))))
(buffer-substring-no-properties start end)))
(defun insert-content-abbrev (content)
(interactive)
(progn
(backward-kill-word 1)
(insert content)))
(defun expand-abbrev-snippet ()
(interactive)
(let* ((abbrev (abbrev-at-point))
(snippet-content (gethash abbrev snippets)))
(if snippet-content
(insert-content-abbrev snippet-content))))
(defun region-to-single-line ()
"Replace newlines in region with '\\n' and concatenate into a single line."
(interactive)
(when (region-active-p)
(let ((start (region-beginning))
(end (region-end)))
(save-excursion
(goto-char start)
(let ((region-text (buffer-substring-no-properties start end)))
(setq region-text (replace-regexp-in-string "\n" "\\\\n" (replace-regexp-in-string "\"" "\\\\\"" region-text)))
(kill-new region-text))))))
snippets with file path contents
;; simple versions
(defvar custom-snippets-file-path (expand-file-name "snippets.json" user-emacs-directory)
"Path to the custom snippets JSON file.")
(defun load-custom-snippets ()
"Load custom snippets from JSON file."
(when (file-exists-p custom-snippets-file-path)
(let ((json-object-type 'hash-table))
(json-read-file custom-snippets-file-path))))
(defvar custom-snippets-hash (load-custom-snippets)
"Hash table of custom snippets.")
(defun reload-snippets ()
(interactive)
(setq custom-snippets-hash (load-custom-snippets))
(message "snippet reloaded"))
;; customize things at point word
(defun abbreviation-at-point ()
"Return the abbreviation at point."
(let* ((end (point))
(start (save-excursion
(skip-chars-backward "a-zA-Z0-9_:|-!<>")
(point))))
(buffer-substring-no-properties start end)))
(defun custom-snippet-expand ()
"Expand custom snippet."
(interactive)
(let* ((abbrev (abbreviation-at-point))
;;(abbrev (thing-at-point 'word))
;;(expansion (gethash abbrev custom-snippets-hash)))
(relative-snippet-path (gethash abbrev custom-snippets-hash))
(snippet-path (when relative-snippet-path
(expand-file-name relative-snippet-path user-emacs-directory)))
(expansion (when snippet-path
(with-temp-buffer
(insert-file-contents snippet-path)
;;(insert "foo\nbar")
(buffer-string)))))
(message snippet-path)
(if expansion
(progn
(backward-kill-word 1)
(insert expansion))
(message "No snippet found for abbreviation: %s" abbrev))))
(defun custom-snippet-eval ()
"Evaluate the content of the snippet as Emacs Lisp code."
(interactive)
(let* ((abbrev (thing-at-point 'word))
(relative-snippet-path (gethash abbrev custom-snippets-hash))
(snippet-path (when relative-snippet-path
(expand-file-name relative-snippet-path user-emacs-directory)))
(code (when snippet-path
(with-temp-buffer
(insert-file-contents snippet-path)
(buffer-string)))))
(if code
(eval (read code))
(message "No code found for abbreviation: %s" abbrev))))
repl and evaluation
(defvar repl-process "*ansi-term*") ;; main repl process window
(defvar repl-wrap "%s")
(defface my-highlight-face
'((t (:background "##f0f8ff"))) ; Customize background color here
"Face for highlighting text."
:group 'basic-faces)
(defun highlight-region (start end)
(let ((region-highlight (make-overlay start end)))
(overlay-put region-highlight 'face 'my-highlight-face)
(run-at-time "0.3 sec" nil #'delete-overlay region-highlight))
(deactivate-mark))
(defun repl-start-ansi ()
(interactive)
(setq cmd (read-string "Enter cmd: " "/bin/zsh"))
(ansi-term cmd)
(messsage "Started %s REPL" repl-process))
(defun repl-set-process ()
"set interactive repl process"
(interactive)
(setq repl-process (read-string "Enter repl process: "))) ;; change main process window
(defun repl-set-wrap ()
"set interactive repl-wrap as client"
(interactive)
(setq repl-wrap (read-string "Enter wrap text: ")))
(defun repl-send-content (content)
"simulate entering into repl-process"
(interactive)
(with-current-buffer repl-process
(goto-char (point-max))
(term-line-mode)
(insert (format repl-wrap content))
(term-send-input)
(term-char-mode))
)
(defun repl-send-buffer ()
"send the whole buffer"
(interactive)
(highlight-region (point-min) (point-max))
(message "send b")
(repl-send-content (buffer-substring-no-properties (point-min) (point-max))))
(defun escape-backtick (str)
"Replace all occurrences of backtick (`) with escaped form (\\`)"
(replace-regexp-in-string "`" "\\\\`" str))
(defun repl-send-buffer-escape ()
"send the whole buffer escape backtick"
(interactive)
(highlight-region (point-min) (point-max))
(message "send b escape")
(repl-send-content (escape-backtick (buffer-substring-no-properties (point-min) (point-max)))))
(defun repl-send-line ()
"Send the current line to the REPL."
(interactive)
(save-excursion
(let ((start (progn (beginning-of-line) (point)))
(end (progn (end-of-line) (point))))
(highlight-region start end)
(message "send n: %s %s" start end)
(repl-send-content (buffer-substring-no-properties start end))
;; (repl-send-content (thing-at-point 'line t))
)))
(defun repl-send-paragraph ()
"Send the current paragraph to the REPL."
(interactive)
(save-excursion
(let ((start (progn (backward-paragraph) (point)))
(end (progn (forward-paragraph) (point))))
(highlight-region start end)
(message "send e: %s %s" start end)
(repl-send-content (buffer-substring-no-properties start end))
;;(repl-send-content (thing-at-point 'paragraph t))
)))
(defun repl-send-region (start end)
"Send the region between START and END to the REPL."
(interactive "r")
(highlight-region start end)
(message "send r: %s %s" start end)
(repl-send-content (buffer-substring-no-properties start end)))
(defun repl-send-md-block ()
(interactive)
(save-excursion
(let ((starting-pos (progn (re-search-backward "^```" (point-min) t) (match-end 0)))
(end-pos (progn (re-search-forward md-block-end (point-max) t) (match-beginning 0))))
(let ((file-ref (or (progn (re-search-backward "```" starting-pos t) (match-string 1)) nil))
(start-content (progn (goto-char starting-pos) (beginning-of-line) (forward-line 1) (point))))
(highlight-region start-content end-pos)
(message "send m: %s %s" start-content end-pos)
(repl-send-content (buffer-substring-no-properties start-content end-pos))
)
)))
(defun repl-send-eol ()
"utility tools to make it easier for us to create files for this entire buffer"
(interactive)
(let ((file-loc (read-string "Path:")))
(repl-send-content (format "cat > %s <<'EOL'" file-loc))))
(defun repl-send-eol-output-region ()
"utility tools to make it easier for us to create files for this entire buffer"
(interactive)
(let ((file-loc (read-string "Path:"))
(content (buffer-substring-no-properties (region-beginning) (region-end))))
(repl-send-content (format "cat > %s <<'EOL'\n%s\nEOL" file-loc content))))
(defun repl-send-eol-output-buffer ()
"utility tools to make it easier for us to create files for this entire buffer"
(interactive)
(let ((file-loc (read-string "Path:"))
(content (buffer-substring-no-properties (point-min) (point-max))))
(repl-send-content (format "cat > %s <<'EOL'\n%sEOL" file-loc content))))
(defun repl-send-reload ()
"send default funciton reload"
(interactive)
(repl-send-content "reload()"))
(defun repl-send-main ()
"send default funciton reload"
(interactive)
(repl-send-content "main()"))
(defun repl-send-client-region (start end)
"Send region pre configured string"
(interactive "r")
(message "send r: %s %s" start end)
(highlight-region start end)
(setq repl-wrap "responseWith(`%s`)")
(repl-send-content (buffer-substring-no-properties start end))
(setq repl-wrap "%s"))
(message "repl loaded")
markdown
(message "markdown loaded")
(defvar md-block-header "^```elisp")
(defvar md-block-end "^```$")
(defun write-to-file (file-location contents)
(interactive)
(unless (file-exists-p file-location)
(let ((dir (file-name-directory file-location)))
(unless (file-exists-p dir)
(make-directory dir t))))
(with-temp-buffer
(insert contents)
(write-region (point-min) (point-max) file-location)))
(defun search-first-emacs-lisp ()
(interactive)
(let ((contents (buffer-substring-no-properties (point-min) (point-max))))
(with-temp-buffer
(insert contents)
(goto-char (point-min))
(let (( s (progn (re-search-forward "^```emacs-lisp" (point-max) t) (match-end 0) (forward-line 1) (point)))
( e (progn (re-search-forward "^```$" (point-max) t) (match-beginning 0))))
(buffer-substring-no-properties s e)))))
;; (search-first-emacs-lisp) 1093 1836
(defvar init-el-location "~/.emacs.d/init.el")
(defvar init-md-location "~/.emacs.d/emacs.md")
(defun generate-init-el ()
(interactive)
(let ((source (search-first-emacs-lisp))
(location init-el-location))
(write-to-file location source)))
(defun generate-emacs-md ()
(interactive)
(let ((source (buffer-substring-no-properties (point-min) (point-max))))
(write-to-file init-md-location source)))
(defvar tangle-md-file-ref "path=\\([^\s+]+\\)")
(defun tangle-md-block ()
(interactive)
(save-excursion
(let ((starting-pos (progn (re-search-backward "^```" (point-min) t) (match-end 0)))
(end-pos (progn (re-search-forward md-block-end (point-max) t) (match-beginning 0))))
(let ((file-ref (or (progn (re-search-backward tangle-md-file-ref starting-pos t) (match-string 1)) nil))
(start-content (progn (goto-char starting-pos) (beginning-of-line) (forward-line 1) (point))))
(when file-ref
(write-to-file file-ref (buffer-substring-no-properties start-content end-pos)))
))))
(defun tangle-md-buffer ())
align
(message "align loaded")
(defun align-to-colon (begin end)
"Align region to colon"
(interactive "r")
(align-regexp begin end
(rx (group (zero-or-more (syntax whitespace))) ":" ) 1 1 ))
(defun align-to-comma (begin end)
"Align region to comma signs"
(interactive "r")
(align-regexp begin end
(rx "," (group (zero-or-more (syntax whitespace))) ) 1 1 ))
(defun align-to-equals (begin end)
"Align region to equal signs"
(interactive "r")
(align-regexp begin end
(rx (group (zero-or-more (syntax whitespace))) "=") 1 1 ))
(defun align-to-hash (begin end)
"Align region to hash ( => ) signs"
(interactive "r")
(align-regexp begin end
(rx (group (zero-or-more (syntax whitespace))) "=>") 1 1 ))
;; work with this
(defun align-to-comma-before (begin end)
"Align region to equal signs"
(interactive "r")
(align-regexp begin end
(rx (group (zero-or-more (syntax whitespace))) ",") 1 1 ))
note
(defun note-open-today (&optional year month day)
"Open a note for a specific YEAR, MONTH, and DAY. If not provided, use today's date. If the file doesn't exist, create it."
(interactive)
(unless year
(let ((current-date (decode-time (current-time))))
(setq year (nth 5 current-date)
month (nth 4 current-date)
day (nth 3 current-date))))
(let* ((directory "~/daily-note-contents/contents/")
(filename (format "notes-%04d%02d%02d.md" year month day))
(fullpath (concat directory filename)))
(find-file fullpath)
(when (not (file-exists-p fullpath))
(insert (format "## Note - %04d%02d%02d\n\n" year month day))
(save-buffer))))
(defun note-open-n-day (n)
"Open note n days before"
(interactive "p")
(let* ((target-date (time-subtract (current-time) (days-to-time n)))
(year (string-to-number (format-time-string "%Y" target-date)))
(month (string-to-number (format-time-string "%m" target-date)))
(day (string-to-number (format-time-string "%d" target-date)))
(directory "~/daily-note-contents/contents/")
(filename (format "notes-%04d%02d%02d.md" year month day))
(fullpath (concat directory filename)))
(if (file-exists-p fullpath)
(find-file fullpath)
(message "Note for date %s does not exist." (format-time-string "%Y-%m-%d" target-date)))))
(defun note-open-yesterday ()
"open yesterday notes"
(interactive)
(note-open-n-day 1))
(defun note-open-n2 ()
"open n day -2"
(interactive)
(note-open-n-day 2))
(defun note-open-n3 ()
"open n day -3"
(interactive)
(note-open-n-day 3))
(defun note-open-n4 ()
"open n day -4"
(interactive)
(note-open-n-day 4))
(defun note-open-n5 ()
"open n day 5"
(interactive)
(note-open-n-day 5))
(defun note-open-n6 ()
"open n day 6"
(interactive)
(note-open-n-day 6))
(defun note-open-n7 ()
"open n day 7"
(interactive)
(note-open-n-day 7))
tcp-client
(defun my-tcp-client (host port)
"Connect to HOST on PORT via TCP."
(let ((buffer (generate-new-buffer "*TCP Client*")))
(set-process-filter
(open-network-stream "tcp-client" buffer host port)
'my-tcp-client-filter)
(display-buffer buffer)))
(defun strip-ansi-escape-sequences (string)
"Strip ANSI escape sequences from STRING."
(replace-regexp-in-string "\\(\\x1b\\[[0-9;]+[a-zA-Z]\\)" "" string))
(defun my-tcp-client-filter (process string)
"Filter function to handle received data."
(with-current-buffer (process-buffer process)
(insert string)
(goto-char (point-max))
(while (re-search-backward "\n" (line-beginning-position) t)
(let ((line (buffer-substring (point) (line-end-position))))
(message (strip-ansi-escape-sequences line)))
(delete-region (point-min) (1+ (line-end-position))))))
;; Example usage
(my-tcp-client "51.255.87.159" 30300)
another try
(require 'json)
(require 'subr-x)
(require 'ansi-color)
(defvar my-tcp-client-buffer "*TCP Client*")
(defun my-tcp-client-connect (host port)
"Connect to HOST on PORT."
(let ((process (open-network-stream "my-tcp-client" my-tcp-client-buffer host port)))
(set-process-filter process 'my-tcp-client-receive)))
;; (defun my-tcp-client-receive (process message)
;; "Process received MESSAGE from PROCESS."
;; (with-current-buffer (get-buffer-create my-tcp-client-buffer)
;; (save-excursion
;; (goto-char (point-max))
;; (insert (concat (substring-no-properties message) "\n")))
;; (message "%s" (substring-no-properties message))))
(defun my-tcp-client-receive (process message)
"Process received MESSAGE from PROCESS."
(with-current-buffer (get-buffer-create my-tcp-client-buffer)
(save-excursion
(goto-char (point-max))
(insert (ansi-color-apply message) "\n"))
(message "%s" (ansi-color-apply message))))
;; (defun my-tcp-client-receive (process message)
;; "Process received MESSAGE from PROCESS."
;; (let ((clean-message (replace-regexp-in-string "\r" "" (ansi-color-apply message))))
;; (message "%s" clean-message)))
;; (defun my-tcp-client-receive (process message)
;; "Process received MESSAGE from PROCESS."
;; (with-current-buffer (get-buffer-create my-tcp-client-buffer)
;; (save-excursion
;; (goto-char (point-max))
;; (insert (ansi-color-apply (replace-regexp-in-string "\r" "" message)) "\n"))
;; (message "%s" (ansi-color-apply (replace-regexp-in-string "\r" "" message)))))
(defun my-tcp-client-hide-buffer ()
"Hide the TCP client buffer, showing only new messages."
(interactive)
(let ((window (get-buffer-window my-tcp-client-buffer)))
(when window
(delete-window window))))
(defun my-tcp-client-disconnect ()
"Disconnect from the TCP server."
(interactive)
(let ((process (get-buffer-process my-tcp-client-buffer)))
(when process
(delete-process process)
(kill-buffer my-tcp-client-buffer))))
(defun my-tcp-client (host port)
"Connect to HOST on PORT as a TCP client."
(interactive "sHost: \nnPort: ")
(my-tcp-client-connect host port))
(defvar my-tcp-client-process nil
"Variable to store the TCP client process.")
(defun my-tcp-client (host port)
"Connect to HOST on PORT via TCP."
(interactive "sEnter host: \nnEnter port: ")
(setq my-tcp-client-process (open-network-stream "my-tcp-client"
"*TCP Client*"
host port))
(set-process-filter my-tcp-client-process 'my-tcp-client-filter))
(defun my-tcp-client-filter (proc message)
"Filter function to handle incoming messages from the TCP server."
(with-current-buffer "*TCP Client*"
(let ((buffer-read-only nil))
(goto-char (point-max))
(insert message)
(insert "\n")
(delete-duplicate-lines (point-min) (point-max))
(if (> (count-lines (point-min) (point-max)) 10)
(progn
(goto-char (point-min))
(delete-region (line-beginning-position) (line-end-position))
(insert "...\n")))
(when (called-interactively-p 'any)
(pop-to-buffer (current-buffer))
(message "%s" (substring-no-properties message))
))))
(defun my-tcp-client-send (message)
"Send MESSAGE over the TCP connection."
(interactive "sEnter message: ")
(if (process-live-p my-tcp-client-process)
(progn
(process-send-string my-tcp-client-process message)
(process-send-string my-tcp-client-process "\n"))
(message "TCP connection is not established.")))
binding keys settings
rules for windows we use C-x
(global-unset-key (kbd "C-t")) ;; tranpose
(global-unset-key (kbd "C-h")) ;; help
(global-unset-key (kbd "C-x C-t")) ;;transpse line
(global-set-key (kbd "C-s") 'swiper)
(global-set-key (kbd "C-g") 'minibuffer-keyboard-quit)
;; (global-set-key (kbd "C-s") 'counsel-grep-or-swiper)
(global-set-key (kbd "C-s") 'swiper)
(global-unset-key (kbd "C-r"))
(global-set-key (kbd "C-r") 'replace-string)
(global-set-key (kbd "C-x C-f") 'counsel-find-file)
(global-set-key (kbd "C-x f") 'counsel-find-library)
;; moving
(global-set-key (kbd "C-x g") 'goto-line)
(global-set-key (kbd "C-x <up>") 'windmove-up)
(global-set-key (kbd "C-x <up>") 'windmove-up)
(global-set-key (kbd "C-x <down>") 'windmove-down)
(global-set-key (kbd "C-x <left>") 'windmove-left)
(global-set-key (kbd "C-x <right>") 'windmove-right)
(global-set-key (kbd "C-x C-<left>") 'windmove-left)
(global-set-key (kbd "C-x C-<right>") 'windmove-right)
;; markdonw
(global-set-key (kbd "C-c f") 'polymode-next-chunk)
;;(global-set-key (kbd "C-c c f") 'polymode-next-chunk)
(global-set-key (kbd "C-c p") 'polymode-previous-chunk)
;;(global-set-key (kbd "C-c C-f") 'markdown-forward-same-level)
;;(global-set-key (kbd "C-c C-p") 'markdown-backward-same-level)
;;(global-set-key (kbd "C-c m") 'polymode-mark-or-extend-chunk)
;; push view
(global-set-key (kbd "C-x v v") 'ivy-push-view)
(global-set-key (kbd "C-x v p") 'ivy-pop-view)
;; evaling
(global-unset-key (kbd "C-x e"))
(global-set-key (kbd "C-x e") 'eval-region)
;; wrap-un-wrap text
(global-set-key (kbd "C-x w v") 'visual-line-mode)
;; line number mode
(global-unset-key (kbd "C-x l"))
(global-set-key (kbd "C-x l") 'global-display-line-numbers-mode)
;; ansi-term
(global-unset-key (kbd "C-x r"))
(global-unset-key (kbd "C-x a"))
(global-set-key (kbd "C-x a a") 'ansi-term)
(global-set-key (kbd "C-x r b") 'rename-buffer)
;; code folding
(global-set-key (kbd "C-c b m") 'hs-minor-mode)
(global-set-key (kbd "C-c b h") 'hs-hide-block)
(global-set-key (kbd "C-c b s") 'hs-show-block)
;; align
(global-set-key (kbd "C-c a c") 'align-to-colon)
(global-set-key (kbd "C-c a e") 'align-to-equals)
(global-set-key (kbd "C-c a a") 'aggressive-indent-indent-defun)
;; expand region
(global-set-key (kbd "C-c e") 'er/expand-region)
;; the snippets
;; (global-set-key (kbd "C-c s e") 'custom-snippet-expand)
;; (global-set-key (kbd "C-c s v") 'custom-snippet-eval)
;; (global-set-key (kbd "C-c s r") 'reload-snippets)
(global-set-key (kbd "C-c s e") 'expand-abbrev-snippet)
(global-set-key (kbd "C-c s l") 'region-to-single-line)
;; the notes
(global-set-key (kbd "C-c c n") 'note-open-today)
;; (global-set-key (kbd "C-c n 1") 'note-open-yesterday)
;; (global-set-key (kbd "C-c n 2") 'note-open-n2)
;; (global-set-key (kbd "C-c n 3") 'note-open-n3)
;; (global-set-key (kbd "C-c n 4") 'note-open-n4)
;; (global-set-key (kbd "C-c n 5") 'note-open-n5)
;; (global-set-key (kbd "C-c n 6") 'note-open-n6)
;; (global-set-key (kbd "C-c n 7") 'note-open-n7)
;; the repl
(global-set-key (kbd "C-c c p") 'repl-set-process)
;; (global-set-key (kbd "C-c c c") 'repl-connect-socket);
(global-set-key (kbd "C-c c d") 'repl-disconnect-socket);
(global-set-key (kbd "C-c c s") 'repl-start-ansi)
(global-set-key (kbd "C-c c w") 'repl-set-wrap)
(global-set-key (kbd "C-c c l") 'repl-send-line)
(global-set-key (kbd "C-c c r") 'repl-send-region)
(global-set-key (kbd "C-c c o") 'repl-send-eol-output-region)
(global-set-key (kbd "C-c c b") 'repl-send-buffer)
(global-set-key (kbd "C-c c g") 'repl-send-buffer-escape)
(global-set-key (kbd "C-c c e") 'repl-send-paragraph)
(global-set-key (kbd "C-c c m") 'repl-send-md-block)
(global-set-key (kbd "C-c c c") 'repl-send-client-region);
(global-set-key (kbd "C-c c k") 'repl-send-reload);
(global-set-key (kbd "C-c c j") 'repl-send-main);
;; Multi Cursrs
(global-set-key (kbd "C-S-c C-S-c") 'mc/edit-lines)
(global-set-key (kbd "C->") 'mc/mark-next-like-this)
(global-set-key (kbd "C-<") 'mc/mark-previous-like-this)
(global-set-key (kbd "C-c C-<") 'mc/mark-all-like-this)
;; Define a prefix keymap
;; (define-prefix-command 'my-custom-prefix-map)
;; (global-set-key (kbd "C-c c") 'my-custom-prefix-map)
;; ;; Define a keymap for the sequence "b u" under the prefix
;; (define-key my-custom-prefix-map (kbd "b u") 'my-custom-command)
;; ;; Define the custom command bound to "b u"
;; (defun my-custom-command ()
;; (interactive)
;; (message "You pressed C-c c b u! This is a custom command."))