노랑님의 체계를 거의 따라갑니다. 키바인딩도 왠만하면 변경하지 않습니다. 노랑님 시스템에 익숙해 지고 나서, 최근 이맥스의 흐름을 반영하고자 합니다.
아래는 노랑님의 글을 대충 번역한 것이다. 읽어 보고 한글로 이해 안되면 원문을 보고 수정한다. 이해되는 수준이라면 번역이 별로여도 손대지 않는다. 손대기 시작하면 나의 문장으로 다시 써야 하는데 시간이 오래 걸리는 일이다.
Packages
STARTpost-init-org
Basic syntax
Hotkeys for creating headlines and moving them
Basic formatting
Links (org-insert-link, org-open-at-point)
Tables
Bulleted lists, checkboxes (s-M-RET to make new check item)
Source blocks
Inline code
Tasks (C-c C-t, org-todo)
Indentation 이슈 (2023-04-16) org-indent-mode 를 사용하면 adapt-indentation 은 자동 비활성화 startup-indent 를 켜면 org-indent-mode 활성화 org-modern, org-modern-indent-mode 는 터미널 모드에서 src block 문제 즉, Simple is Best. org-indent-mode 만 org-mode-hook 으로 추가!
Punch in (this starts the clock on the default task)
Look at the agenda and make a mental note of anything important to deal with today
Read email and news
create notes, and tasks for things that need responses with org-capture
Check refile tasks and respond to emails
Look at my agenda and work on important tasks for today
Clock it in
Work on it until it is DONE or it gets interrupted
Work on tasks
Make journal entries (C-c c j) for interruptions
Punch out for lunch and punch back in after lunch
work on more tasks
Refile tasks to empty the list
Tag tasks to be refiled with m collecting all tasks for the same target
Bulk refile the tasks to the target location with B r
Repeat (or refile individually with C-c C-w) until all refile tasks are gone
Mark habits done today as DONE
Punch out at the end of the work day
Keybinding Tables
I have the following custom key bindings set up for my emacs (sorted by frequency).
| Key | For | Used |
|---------|-------------------------------------------------|------------|
| F12 | Agenda (1 key less than C-c a) | Very Often |
| C-c b | Switch to org file | Very Often |
| F11 | Goto currently clocked item | Very Often |
| C-c c | Capture a task | Very Often |
| C-F11 | Clock in a task (show menu with prefix) | Often |
| f9 g | Gnus - I check mail regularly | Often |
| f5 | Show todo items for this subtree | Often |
| S-f5 | Widen | Often |
| f9 b | Quick access to bbdb data | Often |
| f9 c | Calendar access | Often |
| C-S-f12 | Save buffers and publish current project | Often |
| C-c l | Store a link for retrieval with C-c C-l | Often |
| f8 | Go to next org file in org-agenda-files | Sometimes |
| f9 r | Boxquote selected region | Sometimes |
| f9 t | Insert inactive timestamp | Sometimes |
| f9 v | Toggle visible mode (for showing/editing links) | Sometimes |
| C-f9 | Previous buffer | Sometimes |
| C-f10 | Next buffer | Sometimes |
| C-x n r | Narrow to region | Sometimes |
| f9 f | Boxquote insert a file | Sometimes |
| f9 i | Info manual | Sometimes |
| f9 I | Punch Clock In | Sometimes |
| f9 O | Punch Clock Out | Sometimes |
| f9 o | Switch to org scratch buffer | Sometimes |
| f9 s | Switch to scratch buffer | Sometimes |
| f9 h | Hide other tasks | Rare |
| f7 | Toggle line truncation/wrap | Rare |
| f9 T | Toggle insert inactive timestamp | Rare |
| C-c a | Enter Agenda (minimal emacs testing) | Rare |
Keybinding Codes
| Key | For | Used |
|-------------|-------------------------------|------------|
| C-n/p | org-next/prev-visible-heading | Very Often |
| M-n/p | org-next/prev-link | Very Often |
| C-c %/& | org-mark-ring-push/goto | Very Often |
| C-c @ | org-mark-subtree | |
| M-hjkl | org-meta hjkl | Very Often |
Use Emacs bookmarks for fast navigation
[2023-09-19 Tue 16:31]
I've started using emacs bookmarks to save a location and return to it easily. Normally I want to get back to my currently clocking task and that's easy - just hit F11. When I'm working down a long checklist I find it convenient to set a bookmark on the next item to check, then go away and work on it, and return to the checkbox to mark it done.
저는 위치를 저장하고 쉽게 돌아가기 위해 이맥 북마크를 사용하기 시작했습니다. 보통은 현재 진행 중인 작업으로 돌아가고 싶을 때 =F11=을 누르면 쉽게 돌아갈 수 있습니다. 긴 체크리스트를 작성할 때는 다음 항목에 북마크를 설정하여 체크한 다음 다른 곳으로 이동하여 작업하고 다시 확인란으로 돌아와서 완료를 표시하는 것이 편리하다는 것을 알게 되었습니다.
When I want to save the current location I just hit C-f6 and then I can return to it with f6 anytime. I overwrite the same bookmark each time I set a new position.
현재 위치를 저장하고 싶을 때 C-f6, 언제든지 =f6=을 눌러 해당 위치로 돌아갈 수 있습니다. 새 위치를 설정할 때마다 같은 책갈피를 덮어씁니다.
Junghanacs Keybinding
org-pomodoro
[2023-09-19 Tue 16:43]
Tasks and States
재미있는 부분이다. 본 문서에 보면 상태 다이어그램을 보여준다. 따라가자. 아래와 같은 더미 엔트리를 사용해서 개별 파일의 상태를 관리한다. 이는 글로벌 투두 메커니즘에 영향을 주지 않기에 효과적이다.
키워드는 기존에 내가 사용하던 로그시크 호환과는 약간 다르다. 그리고 NEXT 를 굉장히 효과적으로 관리한다. 전체 그림과 함께 사용해 보아야 한다.
태스트의 상태도를 그림으로 보여주는데 이미지 여기에 추가하자.
그리고 상태가 트리거 되면 태그가 붙는다.
Adding New Tasks Quickly
내가 쓰던 캡처는 일단 잊어라. 일단 리파일에 집중하고 처리 프로세스를 강화하자. 동작은 다 확인했다. 잘 된다.
The %a verb expands to a link to where one was when they called org-capture. This might, for example, be another file or an email.
%a 동작을 명시하면 =org-capture=를 호출했을 때 있었던 위치에 대한 링크로 확장됩니다. 예를 들어 다른 파일이나 이메일일 수 있습니다.
Refiling Tasks
Refiling tasks 는 쉽습니다. 캡처 모드를 사용하여 내 inbox.org 파일에서 많은 새 작업을 수집한 후, 해당하는 조직 파일 및 주제로 이동해야 합니다. 내 모든 활성 조직 파일은 내 org-agenda-files 에 설정하며 어젠다에서 볼 수 있습니다.
최대 일주일 동안 inbox.org 에서 캡처 작업을 수집합니다. 이것들은 이제 내 블록 안건에서 매일 눈에 띄고 보통 낮에 다시 정리합니다. 그리고 나는 refile 작업 목록을 비워 두는 것을 좋아합니다.
22/11/17--13:31 :: ido 가 켜지면 compleseus 레이어와 충돌이 난다. 그러느니 안쓰는게 더 현명하다. 아래에 보면 노랑님은 IDO 를 사용해서 리파일 타겟을 선택한다. 내 설정에서는 IDO 를 사용하지 않기 때문에 간단한 방법으로 수정한다. 22/12/03--16:41 :: 리파일 설정이 안되 있어서 불편해서 다시 왔다. 변경하자.
TODO 7.1 Refile Setup
[2022-12-02 Fri 11:20]
리파일 설정 관련 원문을 먼저 남긴다.
조직에서 작업을 다시 정리하려면 작업을 다시 정리할 위치를 알려줘야 합니다. 내 설정에서 나는 =org-agenda-files=의 모든 파일을 허용하고 현재 파일은 유효한 refile 대상 목록에 기여합니다.
나는 최근 IDO 를 사용하여 타겟 파일/헤딩을 직접 완성하고 있습니다. 이전 완료보다 더 빠른 것으로 나타났습니다. 처음에는 IDO 가 마음에 들지 않았지만 설명서를 다시 검토하고 대상 검색을 제한하는 C-SPC=에 대해 배운 후 IDO가 이전의 단계별 설정보다 훨씬 낫다는 것을 알았습니다. 이제 무언가를 다시 파일화하고 싶을 때 =C-c C-w=를 수행하여 다시 파일 프로세스를 시작한 다음 일치하는 대상을 얻기 위해 무언가를 입력한 다음 =C-SPC 일치 항목을 현재 목록으로 제한한 다음 다른 텍스트로 계속 검색합니다. 내가 필요한 대상을 찾기 위해. C-j 또한 현재 완료를 최종 대상으로 선택합니다. 나는 이것을 많이 좋아한다. 여러 하위 트리 또는 프로젝트에서 동일한 제목을 가질 수 있도록 대상에 전체 개요 경로를 표시하고 다시 정리하는 동안 구분할 수 있습니다.
이제 DONE 상태 작업을 유효한 재파일 대상으로 제외합니다. 이렇게 하면 refile 대상 목록을 적당한 크기로 유지하는 데 도움이 됩니다.
System Maintenance 아래의 norang.org 파일에 작업을 다시 정리하려면 작업에 커서를 놓고 =C-c C-w=를 누르고 =nor C-SPC sys RET=를 입력하면 완료됩니다. IDO 완성으로 대상을 쉽게 찾을 수 있습니다.
7.2 Refiling Tasks
Tasks to refile are in their own section of the block agenda. To find tasks to refile I run my agenda view with F12 SPC and scroll down to second section of the block agenda: Tasks to Refile. This view shows all tasks (even ones marked in a done state).
다시 제출할 작업은 블록 안건의 자체 섹션에 있습니다. 다시 정리할 작업을 찾기 위해 F12 SPC=를 사용하여 내 안건 보기를 실행하고 블록 안건의 두 번째 섹션인 =Refile할 작업=으로 스크롤합니다. 이 보기에는 모든 작업이 표시됩니다(=done 상태로 표시된 작업도 포함).
Bulk refiling in the agenda works very well for multiple tasks going to the same place. Just mark the tasks with m and then B r to refile all of them to a new location. Occasionally I'll also refile tasks as subtasks of the current clocking task using C-2 C-c C-w from the inbox.org file.
의제에서 대량 재작성은 동일한 장소로 이동하는 여러 작업에 매우 적합합니다. 작업을 m=으로 표시한 다음 =B r=로 표시하여 모든 작업을 새 위치로 다시 정리하십시오. 때때로 저는 =inbox.org 파일에서 =C-2 C-c C-w=를 사용하여 현재 클럭 작업의 하위 작업으로 작업을 다시 정리합니다.
Refiling all of my tasks tends to take less than a minute so I normally do this a couple of times a day.
내 모든 작업을 다시 작성하는 데 1 분도 채 걸리지 않는 경향이 있으므로 보통 하루에 두 번 이 작업을 수행합니다.
7.3 Refiling Notes
I keep a * Notes headline in most of my org-mode files. Notes have a NOTE tag which is created by the capture template for notes. This allows finding notes across multiple files easily using the agenda search functions.
나는 대부분의 조직 모드 파일에 * Notes 헤드라인을 유지합니다. 메모에는 메모에 대한 캡처 템플릿에 의해 생성된 NOTE 태그가 있습니다. 이를 통해 안건 검색 기능을 사용하여 여러 파일에서 메모를 쉽게 찾을 수 있습니다.
Notes created by capture tasks go first to inbox.org and are later refiled to the appropriate project file. Some notes that are project related get filed to the appropriate project instead of under the catchall * NOTES task. Generally these types of notes are specific to the project and not generally useful -- so removing them from the notes list when the project is archived makes sense.
캡처 작업으로 작성된 메모는 먼저 inbox.org=로 이동하고 나중에 적절한 프로젝트 파일로 다시 정리됩니다. 프로젝트와 관련된 일부 메모는 catchall =* NOTES 작업 대신 적절한 프로젝트에 보관됩니다. 일반적으로 이러한 유형의 메모는 프로젝트에 따라 다르며 일반적으로 유용하지 않습니다. 따라서 프로젝트가 보관될 때 메모 목록에서 메모를 제거하는 것이 좋습니다.
7.4 Refiling Phone Calls and Meetings
Phone calls and meetings are handled using capture mode. I time my calls and meetings using the capture mode template settings to clock in and out the capture task while the phone call or meeting is in progress.
전화 통화 및 회의는 캡처 모드를 사용하여 처리됩니다. 전화 통화 또는 회의가 진행되는 동안 캡처 모드 템플릿 설정을 사용하여 통화 및 회의 시간을 정하여 캡처 작업을 시작 및 종료합니다.
Phone call and meeting tasks collect in inbox.org and are later refiled to the appropriate location. Some phone calls are billable and we want these tracked in the appropriate category. I refile my phone call and meeting tasks under the appropriate project so time tracking and reports are as accurate as possible. 전화 통화 및 회의 작업은 =inbox.org=에 수집되고 나중에 적절한 위치에 다시 정리됩니다. 일부 전화 통화는 청구 가능하며 적절한 카테고리에서 추적하기를 원합니다. 시간 추적 및 보고서가 최대한 정확하도록 적절한 프로젝트에서 전화 통화 및 회의 작업을 다시 정리합니다.
Custom Agenda Views
여기서 보여주는 바대로 움직이자고 워크플로우가 존재한다. 슈퍼어젠다가 있던 뭐던 간에 워크플로우가 있어야 된다.
Overview
블락 어젠다 뷰에 나의 영혼을 맡긴다. 여기에는 나의 하루의 모든 것을 담았다. 노랑님이 작성한 시점은 09 년도다. 문서를 보면 나의 느린 Eee PC 를 고려했다는 이야기가 나온다. 서브 노트북으로 사용하신 것 같은데 나도 써봤다. 어젠다에서 다루게 결국 실시간 텍스트 파싱인데 처참한 싱글 스레드 성능으로 답이 없을게다. 지금이라고 천지가 개벽했나? 아니다. 조금 더 유연해졌을 뿐이다.
노랑님은 일전에 커스텀 뷰에 많은 필터 함수를 만들어서 사용했었다. 그러나 오그 모드가 개선되면서 많은 기능이 포함 되었다. 아마도 지금 시점에서는 커스텀 함수 없이도 노랑님의 워크플로우가 가능할 것 같다. 나중에 내가 할 숙제이다. -- 오그 모드 분석과 super-agenda 파악 해 볼 것
베당님 워크플로우 https://github.com/vedang/org-mode-crate 본 문서로 검색하면 자료가 꽤 나온다. 이맥서들이 한번씩 거쳐갔을 문서니까 대부분 올드해서 관심이 안간다. 베당님은 나와 똑같은 짓을 하고 있었다. 업뎃을 계속하고 있으니 보자. 뭘 튜닝을 한 것인가?
많이 내려놨구나. 최신 오그모드를 반영해서 좋다. 특히, 뒤쪽에 퍼블리시 파트는 역시 날려버리는게 옳다. 본질에 집중했다.
여기서 옮겨 올 부분도 있다. 다 넣을게 아니라 빼야 된다.
;; A big thanks to Bernt Hansen for providing an awesome guide to ;; beginners so that we can harness the power of org-mode. Almost all of the ;; customization here, and my complete day-to-day workflow, ;; is based on his document about org-mode which can be ;; found here: http://doc.norang.ca/org-mode.html
노랑님의 블록 어젠다의 기능은 위와 같다.
Code Block
어젠다 관련하여 옮기고 튜닝하는 코드
Setup :: Views
노랑님의 블록 어젠다는 기본 뷰와 프로젝트 뷰가 있다. 기본 커스텀 뷰로 들어가면, 위에 언급한 모든 내용을 쭉 보여준다. 프로젝트 뷰는 P 를 입력하면 보인다. (몰랐다...) 프로젝트 관련 태스크를 집중하여 보여준다.
노랑님은 어젠다에서 탑다운으로 일을 하는 편이라고 한다. 그냥 보여주는게 아니라 데드라인, 스케줄 등으로 정렬 된 것이다. 물론 커스텀 가능하다. 필터링을 하거나.
그래서 노랑님의 My day goes generally like this: 가 나온 것이다. 맨 위에 아마 넣었을 텐데 너무 위대하니 또 넣자. 보고 또 보고 해보면서 익히고 나에게 맞춰야 한다.
What do I work on next?
[2022-11-17 Thu 05:38]
데일리 어젠다 뷰에서 오늘이나 이전에 예정된 태스크로 시작하라. 그 다음엔 Next Tasks 목록을 뒤져서 다음 할 일을 찾는다. 나는 작업 중인 프로젝트들을 시작할 때 '오늘'로 스케줄을 설정하는 편이다. 이렇게 설정하면 어젠다를 열 때 마다 계속 상기시켜 주니까.
그리고, 나는 대개 오늘 어젠다에 1-2 개 프로젝트만 스케줄을 설정하고, 중요하지 않게 되었거나 오늘 관심이 가질 필요 없는 일정은 스케줄에서 제거한다.
작업할 새 작업을 찾을 때 일반적으로 =F12 SPC=를 눌러 블록 안건을 얻고 다음 순서를 따릅니다.
Pick something off today's agenda
deadline for today (do this first - it's not late yet)
deadline in the past (it's already late)
a scheduled task for today (it's supposed to be done today)
a scheduled task that is still on the agenda
deadline that is coming up soon
pick a NEXT task
If you run out of items to work on look for a NEXT task in the current context pick a task from the Tasks list of the current project.
Why keep it all on the NEXT list?
[2022-11-17 Thu 12:33]
나는 더 GTD 한 스타일로 방법을 바꿨다. 이제 NEXT 목록을 적극 사용합니다. 중단된 프로젝트는 NEXT 작업을 표시하거나, 생성해야 하기 때문에 NEXT 키워드가 있는 프로젝트만 태스크를 어젠다에 표기 한다.
NEXT 태스크는 1) 지금 작업이 가능한 상태인 녀석들이며, 2) 일부 프로젝트에서는 논리적 다음 순서 또는 단계를 의미하기도 한다.
나는 많은 일을 하고 시간을 측정하고 싶지만 실제로 시작/끝나지 않는 일에 대해 특별한 키워드 ONGOING=을 사용했습니다. 나는 시간을 기록하고 싶은 것을 쉽게 찾기 위해 끌어올 수 있는 =ONGOING 작업에 대한 특별한 의제 보기를 가지고 있었습니다.
그 이후로 나는 ONGOING todo 키워드를 사용하지 않게 되었습니다. NEXT 작업을 표시하는 안건 보기를 사용하면 시간을 정할 항목을 쉽게 선택할 수 있습니다. 그리고 작업을 찾을 때 ONGOING 목록을 봐야 하는지 아니면 NEXT 목록을 봐야 하는지 기억할 필요가 없습니다. 출근합니다. NEXT 목록은 기본적으로 '현재 상태'(프로젝트를 진행시키는 모든 작업)입니다. 가능한 한 빨리 작업할 항목을 찾고 실제로 작업을 수행하고 싶습니다. 시간을 기록해야 하는 작업을 찾기 위해 조직 파일을 뒤지는 데 시간을 낭비하지 않습니다.
NEXT 목록에서 작업을 삭제하려면 작업을 TODO 상태로 되돌리기만 하면 됩니다.
Reading email, newsgroups, and cohnversation on IRC
[2022-11-17 Thu 05:38]
When reading email, newsgroups, and conversations on IRC I just let the default task (normally ** Organization) clock the time I spend on these tasks. To read email I go to Gnus and read everything in my inboxes. If there are emails that require a response I use org-capture to create a new task with a heading of 'Respond to <user>' for each one. This automatically links to the email in the task and makes it easy to find later. Some emails are quick to respond to and some take research and a significant amount of time to complete. I clock each one in it's own task just in case I need that clocked time later. The capture template for Repond To tasks is now scheduled for today so I can refile the task to the appropriate org file without losing the task for a week.
Next, I go to my newly created tasks to be refiled from the block agenda with F12 a and clock in an email task and deal with it. Repeat this until all of the 'Respond to <user>' tasks are marked DONE.
I read email and newgroups in Gnus so I don't separate clocked time for quickly looking at things. If an article has a useful piece of information I want to remember I create a note for it with C-c c n and enter the topic and file it. This takes practically no time at all and I know the note is safely filed for later retrieval. The time I spend in the capture buffer is clocked with that capture note.
Filtering
[2022-11-17 Thu 05:38] 너무 많은 작업, 너무 적은 시간. 주어진 시간에 수백 개의 작업이 있습니다(현재 373 개). 보고 싶은 것들이 너무 많아서 부담스러울 수 있습니다. 이것은 의제 필터링이 하루를 절약하는 곳입니다.
오전 11 시 53 분이고 점심 시간 직전에 작업 모드에 있습니다. 지금은 업무와 관련 없는 작업을 보고 싶지 않습니다. 나도 점심시간 직전에 큰 프로젝트를 하고 싶지 않아... 그래서 목록에서 떼어낼 수 있는 작은 작업을 찾아야 한다.
어떻게 해야 할까요? 블록 아젠다에서 NEXT 작업 목록을 가져온 다음 필터링을 통해 범위를 좁힙니다. 작업은 예상 노력에 따라 NEXT 안건 보기에서 정렬되므로 짧은 작업이 먼저 표시됩니다. 맨 위에서 시작하여 아래로 작업하면 됩니다. 표시되는 안건 작업을 =/ + 1=을 사용하여 10 분 이하의 예상 작업으로 제한할 수 있으며 점심 식사를 위해 출발하기 전에 남은 시간에 맞는 작업을 선택할 수 있습니다.
Automatically removing context based task with / RET
[2022-11-17 Thu 14:07] =/ RET=를 사용하여 컨텍스트 기반 작업을 자동으로 제거
=/ RET=는 정말 유용합니다. 이 멋진 기능은 John Wiegley 에 의해 조직 모드에 추가되었습니다. 사용자가 제공한 기능을 기반으로 필터링하여 작업을 자동으로 제거합니다.
직장에서는 관리자가 할당한 프로젝트가 있습니다. 때때로 우선 순위가 변경되고 프로젝트가 미래의 어느 시점으로 지연됩니다. 즉, 이 작업을 즉시 중단해야 합니다. 프로젝트 작업을 HOLD=로 설정하고 다른 작업을 합니다. =/ RET 필터는 HOLD 작업 및 하위 작업을 제거합니다(태그 상속으로 인해).
집에는 farm 태그가 붙은 몇 가지 작업이 있습니다. 물리적으로 가족 농장에 있을 때 이러한 작업을 수행해야 하기 때문입니다. 자주 방문하지 않기 때문에 시스템의 자동 제외 태그 목록에 farm=을 추가했습니다. 물리적으로 그곳에 있을 때 =/ TAB farm RET=을 사용하여 =farm 작업으로 항상 명시적으로 필터링할 수 있습니다.
=/ RET=이 위의 설명을 기반으로 작업을 필터링할 수 있도록 다음과 같은 설정이 있습니다. bh/org-auto-exclude-function 이 이 역할을 합니다.
Time Clocking
어메이징한 것이 뭐냐? 시간 기록 관리 아니겠는가? 여기 코드만 딸랑 넣어 놨는데 원래 문서에는 장대한 설명이 있다. 그걸 알아야/해봐야 의미가 있다. 아니면 다 필요 없는 코드다.
시퀀스가 있다. 그걸 생각하고 써야 하는데, 그래서 키 바인딩도 그대로 가는 것이다. 왜? 문서에서 키바인딩만 나와 있는데 헷갈리니까 그냥 따라하는거다.
원문 요약 :: punch-in, punch-out
인정합니다. 오그 모드의 =타임 클락킹=은 가히 환상적입니다. 나는 일에 모든 것들을 클락킹 합니다. 오그 모드는 이 과정을 정말 쉽게 만들어 줍니다. 나는 부족한 것 보다 과하게라도 시간 기록을 하는 걸 선호합니다. 그러기에 쉽게 할 수 있어야 합니다.
기록하는 것은 지난 날을 회상하는 것도 가능하겠지만, 내가 어디에 시간을 많이 쓰고 있는지라든가 중요한 프로젝트에 얼마나 리소스를 투입하고 있는지 알게 해준다. 이는 무언가를 하는데 있어서 얼마나 시간이 필요한지 예측하는데 도움이 된다. 기록 할수록 나의 시간 감각, 측정 능력이 개선 된다.
여기서 나는 펀치 인/아웃이라는 개념을 활용한다. 일을 시작 할 때 인, 점심 먹을 때 아웃, 돌아와서 인, 집에 갈때 아웃. 펀치 인을 하는 동안 모든 시간이 기록 된다.
펀치 인을 하면 =기본 태스크=로 시간이 할당 된다. 특정 태스크에 클락 인을 하고 끝내면 다시 기본 태스크로 시간이 할당 된다. 이렇게 해야 시간을 잃지 않을 수 있다.
My clocking setup basically works like this:
Punch in (start the clock)
This clocks in a predefined task by org-id that is the default task to clock in whenever the clock normally stops
Clock in tasks normally, and let moving to a DONE state clock out
clocking out automatically clocks time on a parent task or moves back to the predefined default task if no parent exists.
Continue clocking whatever tasks you work on
Punch out (stop the clock)
워크 시퀀스 예제
[2022-11-16 Wed 11:39]
위를 보면 프로젝트 A 에 1, 2, 3 태스크가 있다. 1 에 다음이 있는 것으로 1 을 해야 한다. 그리고 태스트들의 하위로 소소한 태스크가 하나 할 일로 남겨져 있다. 이에 대해서 다음 시퀀스로 진행을 한다. 이게 오늘 할 일인가? 아무튼... >> 일을 쪼개는 것도 참 중요하다!
F9-I
: punch-in
F12-SPC
: org-agenda 의 custom-view 보기 여기서 'TODO Some miscellaneous task'를 다음에 처리하려고 한다. I=를 입력하여 =clock-in 하자. SPC ? 로 키맵을 보면 그렇게 매핑되어 있다. 따로 해줄 필요 없다. 아니면 Alt+SPC 눌러서 트랜지언트 맵을 보고 호출해도 된다. 이건 스맥스에서 만들어 놓은 것이다. 아무튼, 클락인이 되면 모드라인에 표기가 된다. 그리고 해당 태스크는 TODO -> NEXT 로 상태가 변경 된다. NEXT 가 마치 DOING 같네.
F11=로 현재 태스크로 이동 후, =C-c C-t d 완료 상태로 변경 모드라인에 시간은 흐르고 파일은 이래 저래 작업하고 있을 것이다. 그렇다면, 현재 클락인된 태스크로 이동하는 가장 빠른 방법은 F11 이다. 키바인딩에 매핑해 놓았다. 그러면 해당 위치로 이동한다. 완료로 바꿔야지?
완료로 바꾸는 방법은 위에 씌여 있는 이맥스다운 방법과 =t=를 입력하여 바꾸는 방법이 있다. 그리고 쉬프트와 방향키로 바꾸는 방법이 있다. 관련 설정을 꺼놨는데도 이게 여전히 먹힌다. 신중하게 상태 변경을 하는게 좋다. 태그 밎 타임 로깅이 바뀌기 때문에 지저분해진다. 꼬이는 거다. 나는 가장 불편한 방법으로 쓰련다.
완료하고 나면, 다시 기본 클럭으로 돌아간다. 훌륭하다. 아 근대 어젠다 구성이 별로네. 시간 단위 정보를 보여주는게 거의 없다. --> 캡처로 할 일 만들었다. 캡처하고 나니까 다시 기본 클락 으로 복귀. 훌륭하구만.
이제 프로젝트 A 의 1 번 태스크를 클락인 하자. I 누르면 클락인이다. 너무 쉽게 되니까 조심스럽네. 그렇다면 다 했다고 치고 완료해보라. F11, C-c C-t d 이다. 키바인딩 구리다. 내 키보드는 F 키도 없는데. 그래도 안 바꾼다. 밀고 가자. 완료하고 나면, 클락은 프로젝트 A 로 이동한다. 보자. 뭘 해야 하나?
아 잠시만, 태스트 1 은 처음 상태가 NEXT 였다. 클락인해도 그대로다. 태스크 2 를 클락인 했다. 상태는 NEXT 로 변경되고 모드라인데 작업 시간이 표기 된다. 완료 하자.
잠시만, 현재 클락은 어디에 있는가? 프로젝트 A 다. 지금 상황에서 태스트 3 을 끝내면 클락은 다시 기본으로 돌아간다. 근데 이게 프로젝트인데, 한 자리에서 다 끝낼 수가 있나?
다른 태스크를 보자. 어젠다에서 뒤져보자. 리파일에 있는 그냥 테스트 TODO 를 클락인 했다. "테스트로 생성합니다."라는 태스크다. 이건 아마 완료하면 기본 클락으로 돌아갈 것이다. 프로젝트가 아니기 때문이다.
프로젝트는 따로 구분하는 메커니즘은 두지 않는다고 했다. 문서에 보면 서브 테스크가 있는 것은 프로젝트라고 한다. Stuck Project 가 아래 GTD 에서 다룬다. 그리고 커스텀 어젠다에서도 표기를 강하게(?) 해준다.
이게 뭐냐? 스턱 프로젝트는 서브 태스크 중에 NEXT 가 없는 케이스에 해당 한다. 처음에는 뭔가 싶었는데... NEXT 가 없다는 것은 현재 작업 중이거나 다음에 할 태스크라고 명시해 놓은게 없다는 말이다. 납득이 완전 된다. 클락인하면 NEXT 로 바뀌니까 NEXT 는 작업 중인 태스크도 된다. 그러다가 퇴근하면 NEXT 상태로 클락아웃 된 것이다. 이게 아니여도 다음에 작업하기 위해서 NEXT 로 지정해 놓을 수도 있을 것이다. (NEXT 로 바꾸는 것 자체는 아무런 사이드 효과가 없다.)
뭐든 간에 TODO 만 있다는 것은 목표만 나열한 것과도 같다. 내가 잘하는 짓이다. TODO 가 산더미이고 완료되는게 없는 상태. 스턱된거다.
장난 아니다. 내용도 엄청 많은데. 실습해가면서 해봐야 한다. 이거 빡시다.
Clocking in
Setting a default clock task
내 todo.org 파일에는 기본 ** Organization 작업이 있는데, 이 작업은 기타 시계 시간을 설정하는 경향이 있습니다. 이것이 =F9-I=로 근무일을 시작할 때 시작하는 작업입니다. 조직 파일을 재구성하고, 이메일을 읽고, 받은 편지함을 비우고, 특정 프로젝트와 관련되지 않은 다른 계획 작업을 수행하는 동안 이 작업에 시간을 할애할 것입니다. 이 조직 작업에서 기본 작업으로 모든 시계를 펀치 인합니다.
Using the clock history to clock in old tasks
시계 기록을 사용하여 이전 작업 기록
시계 기록을 사용하여 시간을 기록한 이전 작업에서 시계를 다시 시작하거나 이전에 시간을 기록한 작업으로 바로 이동할 수 있습니다.
나는 이것을 주로 뭔가에 의해 중단된 것을 기록하는 데 사용합니다.
다음 시나리오를 고려하십시오.
You are working on and clocking Task A (Organization)
You get interrupted and switch to Task B (Document my use of org-mode)
You complete Task B (Document my use of org-mode)
Now you want to go back to Task A (Organization) again to continue
This is easy to deal with.
Clock in Task A, work on it
Go to Task B (or create a new task) and clock it in
When you are finished with Task B hit C-u C-c C-x C-i i
이렇게 하면 다음과 같은 시계 이력 선택 창이 표시되고 중단된 [i] 항목이 선택됩니다.
Clock history selection buffer for C-u C-c C-x C-i 아. org-journal-mode 라는게 있다. 그리고 지금은 아. org-capture-mode 겠구나. 아무튼 교육 프로그램에서 이맥스를 데일리로 써야 하는게 급선무라면 일단 기록을 해야 한다. 가장 좋은 것은 내가 쓰는 것 처럼 시간 입력에 따라서 뭔가를 쓰는 것이다. 그게 많거나 적거나 중요하지 않고 그냥 쓰는 것이다.
쓰다가 괜찮으면 캡처로 할 일을 만들어서 배치하고, 아니면 그냥 적어 놓고 끝. 다시 보지는 않기 마련인데. 그게 참 아쉬운 부분이긴 하겠다.
다행히 org-journal-mode 의 장점은 검색에 있다. 스트링 검색을 지원하기 때문에 주, 월, 년 단위로 디테일하게 조절해 가면서 지난 기록의 텍스트를 검색할 수 있다. 그러다가 걸리면 보면 되겠지. 아니면 언제 뭐 했나 궁금하기도 할 것이고.
아직 검토는 못했지만, 정해진 포멧으로 작성기 때문에 무엇이든 검색할 수 있다. 예를 들어, 지난 3 개월간 평일 오전에 주로 뭘 하는가 보려면 지난 3 개월, 오전 12 시까지의 기록을 버퍼에 뽑아 주면 된다. 그러면 보고나서 필요하면 별도로 저장할수도 있고 여기에서 더 가공을 하고 싶다면 embark 로 버퍼로 뽑고 거기서 추가적인 필터를 하면 될 것이다. 모든 데이터는 텍스트이고 날짜, 시간 정보가 있기 때문에 가공할 수 있다. 텍스트 모아봐야 공간을 차지 할 것도 없다. 검색 할 때마가 텍스트 파싱이 필요하기에 시간이 걸리는 일이 겠지만 그래서 더 자유롭기도 한 것이다. 그리고 정해진 양식이 있기에 복잡도는 크지 않다.
그래서 초보자들이 이맥스 편집, 라이프 매니징, 워크 플로우, 캡처 등을 차분하게 익숙해지려면 저널을 쓰기를 권하고 싶다. 아니 권해야 한다. 텍스트 편집에 익숙해 져야지 그 외에 일도 가능하다. 나도 텍스트 편집 자체에는 별 기능을 이용하는게 없다. 아예 없나? 싶다. 더 빠르게 뭘 하겠다는 생각도 없다. 입력하는 것 뿐이다. 앞에 글을 지우지도 않는다. 앞으로만 나아 간다.
Clock Everything - Capture new entry
모든 것을 기록하려면 모든 것에 대한 작업이 필요합니다. 계획된 프로젝트에는 괜찮지만 중단은 필연적으로 발생하며 해당 중단에 소비한 시간을 기록할 장소가 필요합니다.
이를 처리하기 위해 우리는 우리가 하려는 일을 기록하기 위해 새로운 캡처 작업을 만듭니다. 워크플로는 다음과 같습니다.
You are clocking some task and an interruption occurs
Create a quick capture task journal entry C-c c j
Type the heading
go do that thing (eat lunch, whatever)
file it C-c C-c, this restores the clock back to the previous clocking task
clock something else in or continue with the current clocking task
이것은 조직 파일 레이아웃에서 이 작업이 실제로 속한 위치와 같은 세부 정보를 무시하고 작업을 완료할 수 있음을 의미합니다. 작업을 다시 정리하는 것이 편리할 때 나중에 그룹에서 여러 작업을 다시 정리하면 장기적으로 시간이 절약됩니다.
커피 브레이크와 같이 흥미롭지 않은 일회성 작업인 경우 diary.org 날짜 트리로 이동하는 캡처 저널 항목을 만듭니다. 실제로 추적하고 완료로 표시하고 일부 프로젝트에 적용해야 하는 작업인 경우 inbox.org 에 파일로 저장하는 대신 캡처 작업을 만듭니다.
Finding tasks to clock in
clock history가 뭔지 모르겠네. 9.2에도 나오는 이야긴데
To find a task to work on I use one of the following options (generally listed most frequently used first)
Use the clock history C-u C-c C-x C-i Go back to something I was clocking that is not finished
Pick something off today's block agenda SCHEDULED or DEADLINE items that need to be done soon
Pick something off the NEXT tasks agenda view Work on some unfinished task to move to completion
Pick something off the other task list
Use an agenda view with filtering to pick something to work on
Punching in on the task you select will restrict the agenda view to that project so you can focus on just that thing for some period of time.
Editing clock entries
로그 모드에 엔트리 나오는게 없는데 어떻게 하는 거야?
때로는 시계 항목을 편집하여 현실을 반영해야 합니다. 일주일에 2~3 개 항목에 대해 이 작업을 수행합니다.
때때로 나는 내 컴퓨터에서 떨어져 있기 때문에 제 시간에 작업을 기록할 수 없습니다. 이 경우 이전 클럭 작업이 계속 실행 중이며 잘못된 두 작업의 시간을 계산합니다.
시간을 기록한 다음 컴퓨터로 돌아가서 올바른 작업을 기록하고 시작 시간과 종료 시간을 편집하여 시계 기록을 수정합니다.
항목에 대한 시계 라인을 빠르게 방문하려면 의제 로그 모드를 사용하십시오. F12 a l 오늘의 모든 클럭 라인을 보여줍니다. 적절한 클럭 라인으로 빠르게 이동하기 위해 이것을 사용합니다. F11 은 현재 시계가 있는 작업으로 이동하지만 의제 로그 모드는 이전 시계 항목을 찾고 방문하는 데 더 좋습니다.
=F12 a l=을 사용하여 로그 모드에서 의제를 열고 기록된 시계 시간만 표시합니다. 편집해야 하는 클럭 라인으로 커서를 이동하고 =TAB=을 누르면 됩니다.
시계 항목을 편집하려면 편집하려는 날짜 부분에 커서를 놓고(마우스가 아닌 키보드를 사용하십시오. 마우스로 타임스탬프를 클릭하면 해당 날짜의 의제로 돌아가기 때문입니다) S를 누르십시오. -<위쪽 화살표> 또는 S-<아래쪽 화살표> 키를 눌러 시간을 변경합니다.
다음 설정은 시간 편집에서 불연속적인 분 간격을 사용하도록 합니다(반올림 없음). (setq org-time-stamp-rounding-minutes (quote (1 1)))
이동 화살표 조합으로 시간을 편집하면 시계 라인의 총계도 업데이트되므로 매우 편리합니다.
I always check that I haven't created task overlaps when fixing time clock entries by viewing them with log mode on in the agenda. There is a new view in the agenda for this -- just hit v c in the daily agenda and clock gaps and overlaps are identified.
저는 항상 안건에서 로그 모드를 켜고 시계 항목을 확인하여 시간 기록 항목을 수정할 때 작업 중복을 생성하지 않았는지 확인합니다. 이에 대한 의제에 새로운 보기가 있습니다. 일일 의제에서 =v c=를 누르기만 하면 시간 간격과 중복이 식별됩니다.
내 시계 항목이 가능한 한 정확하기를 원합니다. 다음 설정은 1 분의 클럭킹 간격을 보여줍니다.
뽀모도로나 기타 활용하는 패키지들을 언급한다. 왜?! 스맥스에 있는 나의 코드도 여기에 밀어 넣어야 하는데 어디에 넣으려고?!
Code Block
Time Reporting and Tracking
고객사 요청에 따라서 작업한 시간 내역을 공유한다면 이 기능 없이 어떻게 가능하겠는가?! 나의 생산성을 검토할 수 있기에 메타 인지에 도움이 된다.
노랑님의 구성은 10 년 전 오그 모드 버전이다. 10 년 동안 오그 모드가 얼마나 변했겠는가? 더 정교해 졌으리라 믿는데. 사용법을 모른다. 인포 문서봐라!
Code Block
9 의 연장선에서 그림을 그리는 코드다. 이게 끝이 아니다. 시간 기록은 나도 열심히 해왔다. 근데 그게 뭐? 의미 있는 정보로 활용한 적은 없다. 그저 기록하고 있다라고 나를 압박하는 것일 뿐.
사회가 개인화 되고 개인의 역량에 대한 가치로 비용을 정산해야 하는 미래에는 대충 몇시간 했어요 돈 줘요 이렇게는 투명하지 않다.
시간 리포트를 같이 제출해야 할 것이다. 이게 얼마나 투명하게 할지는 깃헙에 이 데이터를 기록하게 하면 될 것이다. 아무튼 책상에 앉아 있을 때는 기록을 하자.
Billing clients based on clocked time
월초에 저는 지난 달에 수행한 작업에 대해 고객사들에 송장을 발행한다. 그 전에 여기에서 청구 할 금액에 대한 시간 데이터의 정확성을 검토한다.
수집된 시간의 청구 과정은 다음 단계로 진행 된다.
Verify that the clock data is complete and correct
Use clock reports to summarize time spent
Create an invoice based on the clock data
Archive complete tasks so they are out of the way. See Archiving for more details.
Verify that the clock data is complete and correct
시계 데이터가 완전하고 올바른지 확인하십시오.
작업을 자주 변경하기 때문에(때로는 1 분에 한 번 이상) 다음 설정을 사용하여 지속 시간이 0 인 시계 항목을 제거합니다.
(setq org-clock-out-remove-zero-time-clocks t)
이 설정은 내 시계 로그 항목을 깔끔하게 유지합니다. 시계 보고서에 들어 갈만한 항목만 유지합니다.
시계 시간에 대한 인보이스를 발행하기 전에 시간 데이터가 정확한지 확인하는 것이 중요합니다. 끝나지 않은 항목(즉, 종료 시간이 없음)이 있는 시계 시간이 있는 경우 시계 날짜의 공백이며 시계 보고서를 생성할 때 작업에 소요된 시간이 0 으로 계산됩니다. 0 으로 세는 것은 잘못된 것입니다.
종료가 제대로 안 된 항목을 확인하기 위해 어젠다에서 시계 검사를 사용합니다 (어젠다에서 v c). 이는 시계 데이터의 간격과 겹침을 보여줍니다.
To check the last month's clock data I use F12 a v m b v c which shows a full month in the agenda, moves to the previous month, and shows the clocked times only. It's important to remove any agenda restriction locks and filters when checking the logs for gaps and overlaps.
지난 달의 시계 데이터를 확인하기 위해 나는 =F12 a v m b vc=를 사용하여 안건에서 한 달 전체를 표시하고 이전 달로 이동하며 시계 시간만 표시합니다. 간격 및 겹침에 대한 로그를 확인할 때 의제 제한 잠금 및 필터를 제거하는 것이 중요합니다.
어젠다에 clocked-time 만 표시되므로 항목에 종료 시간이 누락되었는지 확인하기 위해 목록을 빠르게 스캔할 수 있습니다. 항목이 닫히지 않은 경우 해당 시간 주변의 다른 시계 정보를 기반으로 시계 항목을 수동으로 수정할 수 있습니다.
>> 실제 위에 동작되나?
Using clock reports to summarize time spent
시계 보고서를 사용하여 소요 시간 요약 클라이언트에 대한 청구 가능 시간은 별도의 오그 파일에 보관됩니다.
XYZ.org=의 작업에 소요된 시간 보고서를 받으려면 =XYZ.org 파일을 방문하고 =F12 < a v m b R=을 사용하여 지난 달의 일정 시계 보고서를 실행하기만 하면 됩니다. 이것은 의제를 이 하나의 파일로 제한하고 전체 월의 의제를 표시하고 지난 달로 이동하며 시계 보고서를 생성합니다.
My agenda org clock report settings show 5 levels of detail with links to the tasks. I like wider reports than the default compact setting so I override the :narrow value.
내 의제 조직 시계 보고서 설정에는 태스크에 대한 링크와 함께 다섯 가지의 세부 수준이 표시됩니다. 저는 조밀한 기본 설정보다 더 넓은 보고서를 선호하므로 :narrow 값을 재정의합니다.
setq org-agenda-clockreport-parameter-plist ... ; (:link t :maxlevel 2) 이맥스 기본 값 ; (:link t :maxlevel 5 :fileskip0 t :compact t :narrow 80))) 설정 값
나는 각 프로젝트 조직 파일에 월별 시계 보고서 동적 블록을 가지고 있었고 청구 주기가 끝날 때 수동으로 업데이트했습니다. 저는 이것을 고객의 프로젝트에 소요된 시간에 대해 비용을 청구하는 기준으로 사용했습니다. 한 달에 두 개 이상의 파일이 있는 경우 동적 블록을 업데이트하는 것이 상당히 지루하다는 것을 알았습니다.
이후 ~어젠다에 관련 기능~이 추가된 직후 내장된 시계 보고서 기능을 사용하도록 전환했습니다. 저는 이게 훨씬 편합니다. 데이터는 일반적으로 다른 사람이 소비하는 것이 아니므로 의제 시계 보고서 형식이 제 사용 사례에 적합합니다.
Task Estimates and column view
작업을 완료하는 데 걸리는 시간을 추정하는 것은 마스터하기 어려운 기술입니다. 조직 모드는 이러한 추정 과정을 쉽게 훈련하게 하며, 완료 하는데까지의 실제 소요 시간을 기록할 수 있다. 반복적인 연습과 노력을 통해서 예측 능력이 향상되게 될 것이다.
Creating a task estimate with column mode
properties 및 =column view=를 사용하여 프로젝트 추정을 수행합니다. 다음 헤드라인을 사용하여 열 보기를 전역적으로 설정했습니다.
보고서를 생성하기 위해 적절한 시간 프레임(오늘, 어제, 이번 주 또는 지난주)에 대한 의제를 가져오고 키 시퀀스 =l R=를 눌러 로그 보고서(클록킹 데이터 라인 없음) 및 시간 보고서를 뒤에 추가합니다.
그런 다음 결과 유용한 형식으로 내보내 다른 사람에게 제공하기만 하면 됩니다. =C-x C-w /tmp/agenda.html RET=는 HTML 로 내보내고 =C-x C-w /tmp/agenda.txt RET=는 일반 텍스트로 내보냅니다. 다른 형식도 있지만 저는 이 두 가지를 가장 많이 사용합니다.
이 내보내기를 태그 필터 및 =C-u R=과 결합하면 사람들이 관심을 갖는 태그로 보고서를 제한할 수 있습니다.
NEW org-clock-mode-line
[2023-04-28 Fri 12:56]
Tags and Categories
나도 태그를 좀 신경써서 구성했는데, 여기에 일단 맞춘다. 태그의 역할을 한정지어서 바라보면 안된다.
상속태그는 일단 기본으로 보이게 한다. 태그 시스템은 상당히 점진적으로 개선할 부분이다.
Intro
태그의 역할을 참으로 다양하다.
Tasks can have any number of arbitrary tags. Tags are used for:
filtering todo lists and agenda views providing context for tasks tagging notes tagging phone calls tagging meetings tagging tasks to be refiled tagging tasks in a WAITING state because a parent task is WAITING tagging cancelled tasks because a parent task is CANCELLED preventing export of some subtrees when publishing
Code Block
Handling Notes
메모는 하루 동안 접하게 되는 지식의 작은 보석입니다. 그들은 할 일이 없다는 점을 제외하고는 작업과 같습니다 (지식의 보석을 배우고 암기하는 것 제외). 불행히도 기억할 보석이 너무 많아서 생각만 해도 머리가 터질 지경입니다.
org-mode to the rescue! :: 구원자여! 종종 Gnus 에서 org-mode 및 git 메일링 목록을 읽는 동안 멋진 기능이나 기억하고 싶은 것을 찾게 됩니다. 메모를 작성하려면 메모 캡처 템플릿 =C-c c n=을 사용하고 메모 제목을 입력하고 =C-c C-c=를 입력하여 저장합니다. 할 수 있는 유일한 다른 작업은 (나중에) 적절한 프로젝트 파일로 다시 파일화하는 것입니다.
메모를 찾기 위해 의제보기가 있습니다. 메모는 적절한 프로젝트 파일 및 작업으로 다시 정리됩니다. 그것이 속한 특정 작업이 없으면 catchall * Notes 작업으로 이동합니다. 나는 일반적으로 모든 프로젝트 파일에 포괄적인 메모 작업을 가지고 있습니다. 메모는 캡처 템플릿에 의해 이미 적용된 NOTE 태그로 생성되므로 어디에서나 메모를 다시 정리할 수 있습니다. 노트가 내 의제에 기여하는 프로젝트 파일(예: org-agenda-files)에 있는 한 키 조합 =F12 N=을 눌러 내 노트 의제 보기로 쉽게 노트를 다시 찾을 수 있습니다. 표준 의제 태그 필터링을 사용하여 노트의 의제 보기를 자유롭게 제한할 수 있습니다.
의미 있는 헤드라인이 있는 짧은 노트는 =F12 N=을 사용하여 필요할 때 다시 찾는 방법 외에는 실제로 아무것도 기억할 필요가 없기 때문에 기술적인 세부 사항을 기억할 수 있는 매우 좋은 방법입니다.
프로젝트와 관련이 있고 일반적으로 유용하지 않은 메모는 프로젝트와 함께 보관하고 프로젝트가 제거될 때 의제에서 제거할 수 있습니다.
그래서 내 조직 노트는 org.org 에 들어가고 내 깃 관련 노트는 * Notes 아래에 있는 git.org 에 들어갑니다. 나는 그것들을 영원히 찾을 수 있을 것이다. 프로젝트와 함께 기억하고 싶은 일부 작업프로젝트 세부 사항에 대한 메모는 적절한 작업 조직 모드 파일 아래의 프로젝트 작업에 보관되며 결국 프로젝트가 완료되고 보관되면 의제에서 제거됩니다.
TODO Handling Phone Calls and Contacts
2023-09-05 bbdb 말고 ebdb 한번 고민해보자.
2023-04-07 bbdb 를 사용 안한다. org-contact 와 연동되도록 하자.
Phone calls are interruptions and I use capture mode to deal with these (like all interruptions). Most of the heavy lifting for phone calls is done by capture mode. I use a special capture template for phone calls combined with a custom function that replaces text with information from my bbdb addressbook database.
전화 통화는 중단이며 캡처 모드를 사용하여 이를 처리합니다(모든 중단과 마찬가지로). 전화 통화에 대한 대부분의 어려운 작업은 캡처 모드에서 수행됩니다. 내 bbdb 주소록 데이터베이스의 정보로 텍스트를 대체하는 사용자 지정 기능과 결합된 전화 통화용 특수 캡처 템플릿을 사용합니다.
C-c c p starts a capture task normally and I'm free to enter notes from the call in the template immediately. The cursor starts in the template normally where the name of the caller would be inserted. I can use a bbdb lookup function to insert the name with f9-p or I can just type in whatever is appropriate. If a bbdb entry needs to be created for the caller I can do that and replace the caller details with f9-p anytime that is convenient for me. I found that automatically calling the bbdb lookup function would interrupt my workflow during the call in cases where the information about the caller was not readily available. Sometimes I want to make notes first and get the caller details later during the call.
C-c c p 캡처 작업을 정상적으로 시작하고 템플릿의 호출에서 메모를 즉시 입력할 수 있습니다. 일반적으로 호출자의 이름이 삽입되는 템플릿에서 커서가 시작됩니다. bbdb 조회 기능을 사용하여 f9-p=로 이름을 삽입하거나 적절한 것을 입력할 수 있습니다. 발신자에 대해 =bbdb 항목을 생성해야 하는 경우 그렇게 할 수 있으며 언제든지 발신자 세부 정보를 =f9-p=로 바꿀 수 있습니다. 호출자에 대한 정보를 즉시 사용할 수 없는 경우 bbdb 조회 기능을 자동으로 호출하면 통화 중에 작업 흐름이 중단된다는 것을 알았습니다. 통화 중에 먼저 메모를 작성하고 나중에 발신자 세부 정보를 확인하고 싶을 때가 있습니다.
The phone call capture template starts the clock as soon as the phone rings and I'm free to lookup and replace the caller in bbdb anytime during or after the call. Capture mode starts the clock using the :clock-in t setting in the template.
전화 통화 캡처 템플릿은 전화가 울리는 즉시 시계를 시작하므로 통화 중이나 통화 후에 언제든지 bbdb 에서 발신자를 조회하고 교체할 수 있습니다. 캡처 모드는 템플릿의 :clock-in t 설정을 사용하여 시계를 시작합니다.
When the phone call ends I simple do C-c C-c to close the capture buffer and stop the clock. If I have to close it early and look up other information during the call I just do C-c C-c F9-SPC to close the capture buffer (which stops the clock) and then immediately switch back to the last clocked item to continue the clock in the phone call task. When the phone call ends I clock out which normally clocks in my default task again (if any).
전화 통화가 끝나면 간단히 =C-c C-c=를 수행하여 캡처 버퍼를 닫고 시계를 중지합니다. 일찍 닫고 통화 중에 다른 정보를 찾아야 하는 경우 =C-c C-c F9-SPC=를 수행하여 캡처 버퍼를 닫은 다음(시계를 중지함) 즉시 마지막 시계 항목으로 다시 전환하여 시계를 계속합니다. 전화 통화 작업에서. 전화 통화가 끝나면 정상적으로 다시 기본 작업(있는 경우)에서 시간을 기록합니다.
Here is my set up for phone calls. I would like to thank Gregory J. Grubbs for the original bbdb lookup functions which this version is based on.
다음은 전화 통화 설정입니다. 이 버전의 기반이 되는 원래 bbdb 조회 기능에 대해 Gregory J. Grubbs 에게 감사드립니다.
Below is the partial capture template showing the phone call template followed by the phone-call related lookup functions.
아래는 전화 통화 템플릿과 전화 통화 관련 조회 기능을 보여주는 부분 캡처 템플릿입니다.
GTD
GTD 에서 다루는 프로젝트 관리를 보자.
Overviews
[2022-11-17 Thu 13:15]
I'm using a new lazy project definition to mark tasks as projects. This requires zero effort from me. Any task with a subtask using a todo keyword is a project. Period.
작업을 프로젝트로 표시하기 위해 새로운 지연 프로젝트 정의를 사용하고 있습니다. 이것은 나의 노력이 전혀 필요하지 않습니다. todo 키워드를 사용하는 하위 작업이 있는 모든 작업은 프로젝트입니다. 기간.
Projects are 'stuck' if they have no subtask with a NEXT todo keyword task defined.
NEXT todo 키워드 작업이 정의된 하위 작업이 없으면 프로젝트가 '중단'됩니다.
The org-mode stuck projects agenda view lists projects that have no NEXT task defined. Stuck projects show up on my block agenda and I tend to assign a NEXT task so the list remains empty. This helps to keep projects moving forward.
조직 모드 고정 프로젝트 안건 보기에는 NEXT 작업이 정의되지 않은 프로젝트가 나열됩니다. 중단된 프로젝트가 내 블록 안건에 표시되고 NEXT 작업을 할당하여 목록이 비어 있도록 하는 경향이 있습니다. 이는 프로젝트를 계속 진행하는 데 도움이 됩니다.
I disable the default org-mode stuck projects agenda view with the following setting.
다음 설정으로 기본 조직 모드 고정 프로젝트 의제 보기를 비활성화합니다.
This prevents org-mode from trying to show incorrect data if I select the default stuck project view with F12 # from the agenda menu. My customized stuck projects view is part of my block agenda displayed with F12 SPC.
이렇게 하면 의사 일정 메뉴에서 =F12 #=를 사용하여 기본 고정 프로젝트 보기를 선택하는 경우 조직 모드가 잘못된 데이터를 표시하려고 시도하는 것을 방지할 수 있습니다. 내 사용자 지정 중단된 프로젝트 보기는 =F12 SPC=로 표시되는 내 블록 안건의 일부입니다.
Projects can have subprojects - and these subprojects can also be stuck. Any project that is stuck shows up on the stuck projects list so I can indicate or create a NEXT task to move that project forward.
프로젝트에는 하위 프로젝트가 있을 수 있으며 이러한 하위 프로젝트도 중단될 수 있습니다. 중단된 모든 프로젝트는 중단된 프로젝트 목록에 표시되므로 NEXT 작업을 표시하거나 생성하여 해당 프로젝트를 진행할 수 있습니다.
In the following example Stuck Project A is stuck because it has no subtask which is NEXT. Project C is not stuck because it has NEXT tasks SubTask G and Task I. Stuck Sub Project D is stuck because SubTask E is not NEXT and there are no other tasks available in this project.
다음 예에서 Stuck Project A=는 =NEXT=인 하위 작업이 없기 때문에 중단되었습니다. =프로젝트 C=는 =NEXT 작업 하위 작업 G 및 =작업 I=이 있기 때문에 중단되지 않습니다. =Stuck Sub Project D=는 =SubTask E=가 =NEXT=가 아니고 이 프로젝트에 사용 가능한 다른 작업이 없기 때문에 중단되었습니다.
All of the stuck projects and subprojects show up in the stuck projects list and that is my indication to assign or create NEXT tasks until the stuck projects list is empty. Occasionally some subtask is WAITING for something and the project is stuck until that condition is satisfied. In this case I leave it on the stuck project list and just work on something else. This stuck project 'bugs' me regularly when I see it on the block agenda and this prompts me to follow up on the thing that I'm waiting for.
중단된 모든 프로젝트 및 하위 프로젝트가 중단된 프로젝트 목록에 표시되며 이는 중단된 프로젝트 목록이 비워질 때까지 NEXT 작업을 할당하거나 생성하라는 표시입니다. 때때로 일부 하위 작업이 무언가에 대해 =WAITING=이고 해당 조건이 충족될 때까지 프로젝트가 중단됩니다. 이 경우에는 중단된 프로젝트 목록에 그대로 두고 다른 작업을 수행합니다. 이 정체된 프로젝트는 블록 의제에서 볼 때 정기적으로 저를 '버그'로 만들고 이것은 제가 기다리고 있는 것에 대한 후속 조치를 취하도록 유도합니다.
리마인더는 스맥스 문서를 보면 된다. 다만 당장 넣을 생각 없다. 그리고 여기 나온 코드는 너무 올드라 사용 불가하다.
Productivity Tools
Focus on Current Work
22/11/19--12:29 :: 필요해서 다시 넣는다. 다른데서 호출하더라. 일단 팔로우 모드를 기본으로 키맵으로 수정했다. 일부로 호출하지 않는 이상 사용하지는 않을 것이긴 하나 매우 유용한 기능임은 확실하다. 그리고 이미 기능이 바인딩 되어 있으므로 파악을 해야 오작동을 안한다.
Narrowing to a subtree with bh/org-todo
f5 및 =S-f5=는 아래에 정의된 것처럼 emacs 버퍼를 좁히고 넓히는 기능을 바인딩합니다.
이제 다음을 사용합니다.
T (tasks) for C-c / t on the current buffer
N (narrow) narrows to this task subtree
U (up) narrows to the immediate parent task subtree without moving
P (project) narrows to the parent project subtree without moving
F (file) narrows to the current file or file of the existing restriction
의제는 조직 버퍼를 계속 넓혀서 우리가 하고 있는 일에 집중할 수 있는 편리한 방법을 제공합니다. 이렇게 하면 보기를 이 작업 하위 트리로 제한하여 조직 파일의 다른 모든 세부 정보를 일시적으로 쉽게 숨길 수 있습니다. 완료되지 않은 작업만 표시되도록 작업이 접히고 강조 표시됩니다.
f5=(또는 =T 속도 키)를 많이 눌렀습니다. 이것은 기본적으로 org-narrow-to-subtree 및 C-c / t 조합을 수행하여 버퍼를 축소된 상태로 둡니다. S-f5=(또는 =U, W, =F=와 같은 다른 확장 속도 키)를 사용하여 일반 보기로 다시 확대합니다.
다음 헤드라인을 강제로 표시하는 다음 설정도 있습니다. (setq org-show-entry-below (quote ((default))))
이렇게 하면 접힌 트리 상태로 작업할 때 너무 많은 헤드라인이 함께 접히는 것을 방지할 수 있습니다.
Tuning the Agenda Views
다양한 사용자 정의는 일정 보기가 작업 세부 정보를 표시하는 방식에 영향을 미칩니다. 이 섹션에서는 내 작업 과정에서 사용하는 각 사용자 정의를 보여줍니다.
Highlight the current agenda line
내 .emacs 파일의 다음 코드는 현재 의제 행을 강조 표시합니다. 이렇게 하면 의제에서 발행된 명령에 의해 어떤 작업이 영향을 받을지 명확해집니다. 더 이상 실수로 잘못된 작업을 수행하지 마세요!
Use the Diary for Holidays and Appointments
[2022-11-20 Sun 12:03] 22/12/21--14:49 :: agenda-diary-file 사용. 캡처도 마찬가지긴 한데. 일단 이런 방식으로 써보는 것도 좋다. 하루가 일생아니겠는가?
저는 emacs Diary 를 아무 용도로 사용하지 않지만 일정에서 휴일을 보는 것을 좋아합니다. 이렇게 하면 일하지 않아도 되는 날을 계획하는 데 도움이 됩니다.
다이어리 파일은 캡처 모드 'appointment' 템플릿에서 생성된 date-tree 항목을 유지합니다. 나는 인터럽트 중에도 시간을 기록하고 싶은 기타 작업에도 이것을 사용합니다.
~/diary 파일을 더 이상 사용하지 않습니다. 그것은 Emacs 를 만족시키기 위해 길이가 0 인 파일로 존재합니다. 대신 조직 모드의 다이어리 함수를 사용합니다. emacs 아젠다에 i=가 있는 항목을 삽입하면 =~/sync/org/workflow/diary.org 파일에 날짜 항목이 생성됩니다.
다음과 같이 내 todo.org 파일에 있는 달력의 공휴일을 포함합니다.
제목의 모든 시간 문자열이 의제에 표시되도록 다음 설정을 사용합니다. > 22/11/21--17:23 :: 기본 값은 nil 인데. 일단 두자.
Searches include archive files
I keep a single archive file for each of my org-mode project files. This allows me to search the current file and the archive when I need to dig up old information from the archives.
I don't need this often but it sure is handy on the occasions that I do need it.
Agenda view tweaks
The following agenda customizations control
display of repeating tasks
display of empty dates on the agenda
task sort order
start the agenda weekly view with Sunday
display of the grid
habits at the bottom
I use a custom sorting function so that my daily agenda lists tasks in order of importance. Tasks on the daily agenda are listed in the following order:
tasks with times at the top so they are hard to miss
entries for today (active timestamp headlines that are not scheduled or deadline tasks)
deadlines due today
late deadline tasks
scheduled items for today
pending deadlines (due soon)
late scheduled items
habits
The lisp for this isn't particularly pretty but it works.
Sticky Agendas
[2022-11-21 Mon 17:25] 22/11/21--17:27 :: org-sticky-header 랑 다른 것이다. 23/01/09--14:01 :: OFF 2023-02-09 :: ON 다시 활성화 2023-03-23 :: OFF -- calendar 시나리오랑 겹치나 좀 거슬리네 2023-04-26 :: ON 다시 활성화 2023-07-14 :: OFF Roam 시나리오에 대응
Sticky agendas allow you to have more than one agenda view created simultaneously. You can quickly switch to the view without incurring an agenda rebuild by invoking the agenda custom command key that normally generates the agenda. If it already exists it will display the existing view. g forces regeneration of the agenda view.
I normally have two views displayed (F12 a for the daily/weekly agenda and F12 SPC for my project management view)
Checklist handling
리셋 체크 박스 t 보이지? 그거해서 넣으라고.
Handling blocked tasks
블락된 태스크는 완료가 안된 서브 태스크를 가진 태스크를 의미 한다. 어젠다에서 이러한 블락된 태스크는 그레이 폰트로 보인다. 아래의 설정은 서브 태스크가 완료가 아니면 부모 태스크가 완료 될 수 없게 한다.
아래 설정을 꼭 봐야 한다. 프로퍼티로 NOBLOCKING, ORDERED 를 보여준다. 노블로킹은 위 설정의 예외를 가능케 한다. ORDERED 는 서브 태스크가 순서대로 완료하게 한다. 훌륭하다.
Org Task structure and presentation
여러 세팅이 있는데, 어짜피 넘어야 할 세팅이다.
18.8 - 18.32
18.33 - 18.42
18.43 - 18.47
NEXT is for tasks not projects
NEXT keywords are for tasks and not projects. I've added a function to the todo state change hook and clock in hook so that any parent tasks marked NEXT automagically change from NEXT to TODO since they are now projects and not tasks.
NEXT 키워드는 *프로젝트*가 아닌 *작업*을 위한 키워드입니다. 할 일 상태 변경 훅과 클록 인 훅에 함수를 추가하여 =NEXT=로 표시된 상위 작업은 이제 작업이 아니라 프로젝트이기 때문에 자동으로 =NEXT=에서 =TODO=로 변경되도록 했습니다.
Preserving source block indentation
I do not preserve indentation for source blocks mainly because this doesn't look nice with indented org-files. The only reason I've found to preserve indentation is when TABs in files need to be preserved (e.g. Makefiles). I don't normally edit these files in org-mode so I leave this setting turned off.
저는 주로 들여쓰기된 조직 파일에서 보기 좋지 않기 때문에 소스 블록의 들여쓰기를 보존하지 않습니다. 들여쓰기를 보존해야 하는 유일한 이유는 파일의 탭을 보존해야 할 때입니다(예: Makefiles). 저는 일반적으로 이러한 파일을 조직 모드에서 편집하지 않기 때문에 이 설정을 해제해 두었습니다.
I've changed the default block indentation so that it is not indented from the text in the org file. This allows editing source blocks in place without requiring use of C-c ' so that code lines up correctly.
기본 블록 들여쓰기를 변경하여 조직 파일의 텍스트에서 들여쓰지 않도록 했습니다. 이렇게 하면 코드가 올바르게 정렬되도록 =C-c '=를 사용하지 않고도 소스 블록을 제자리에서 편집할 수 있습니다.
18.49 Diable keys
18.55 Create unique IDs for tasks when linking
The following setting creates a unique task ID for the heading in the PROPERTY drawer when I use C-c l. This allows me to move the task around arbitrarily in my org files and the link to it still works.
NEW Additional Customization
NEW org-support-shift-select and shift-select-mode
[2023-09-18 Mon 18:06] 다시 켜본다. [2022-11-21 Mon 15:02]
NEW org-pretty-entities
[2023-04-28 Fri 12:45]
NEW org-ellipsis, imenu-depth, capture-bookmark
[2023-04-28 Fri 12:46]
OFF NEW Disable org-element-cache
[2023-04-28 Fri 12:46]
NEW org-mouse-1-follows-link
[2023-04-28 Fri 12:48]
NEW org block and hide leading stars
[2023-09-13 Wed 21:52] 모던도 빼고 정말 가볍게 간다. 그게 갈끔하다.
[2023-08-29 Tue 21:41] 완벽한 내 스타일을 갖춘다. 터미널에서 아주 좋다. 여기에 모던을 입히면 그래픽 모드도 좋다.