기본 콘텐츠로 건너뛰기

Linux에서 find결과를 시간 순서대로 정렬하기

최근 글

Rockylinux Powertools 저장소 사용하기

CentOS8 때문에 이모저모 힘든게 많다. 그중에 glibc-static 같은 패키지는 epel-release에도 없길래 찾아 보니, Powertools라는 저장소에서 관리하고 있더라. 참조: https://www.how2shout.com/linux/how-to-enable-powertools-repository-on-rocky-linux-8/ dnf install -y dnf-plugins-core dnf config-manager --set-enabled powertools yum -y install glibc-static

초코 커피

Shorts에서 컵 위에 초콜렛 올려놓고, 커피머신에서 바로 에스프레소를 추출해서 초코커피를 만드는게 계속 나오길래, 한 번 해봤다. 가까운 편의점에서 씁쓸한 허쉬 초콜렛을 찾았는데, 밀크 초콜렛 밖에 없더라. 싫은데... 실패영상 보니까, 초콜렛이 충분히 녹지 못해서 커피머신 밖으로 쏟아지더라. 살아남기 위해 조각 내서 안에 넣었다. 추출! 에스프레소 아메리카노 맛은 별루다. 커피향은 온데간데 없고, 밍밍한 코코아만 남았다. 그나마 에스프레소 버전이 나은 듯. 튜닝의 끝은 순정이어라...

CMake에서 GIT Tag 가져오기

먼 옛 날, CVS, Subversion 등에서 소스의 특정 태그를 커밋로그나 뭐 그런 걸로 수정해주는 경우가 있었는데, GIT에서는 그런 거 얄짤 없고, CMake에서도 정식 모듈로 주어지는 것이 없으니, 사부작사부작 만들어 보았다. find_package(Git) # GIT 태그를 읽어와 GIT_TAG_VERSION_RAW 이라는 변수로 넣는다. execute_process( COMMAND "${GIT_EXECUTABLE}" describe HEAD --tags WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" OUTPUT_VARIABLE GIT_TAG_VERSION_RAW ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE) # GIT 브랜치를 읽어와 GIT_BRANCH 라는 변수로 넣는다. execute_process( COMMAND "${GIT_EXECUTABLE}" rev-parse --abbrev-ref HEAD WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" OUTPUT_VARIABLE GIT_BRANCH ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE) # vX.X.X 형식을 x.x.x 형태로 변환한다. string(REGEX REPLACE "^v([0-9]+)\\.([0-9]+)\\.([0-9]+)$" "\\1.\\2.\\3" GIT_TAG_VERSION "${GIT_TAG_VERSION_RAW}") # 프로젝트 버전 세팅 project(myProject VERSION ${GIT_TAG_VERSION}) # CPack용 버전 세팅 set(CPACK_PACKAGE_NAME ${PROJECT_NAME}) set(CPACK_PACKAGE_VERS

/proc/{PID}/environ 출력하기

/proc/{PID}/environ 파일은 각 환경변수마다 0x00으로 끝나는 형식을 가지고 있다. 이것을 cat 하면 제대로 볼 수 없는데, xargs를 이용하면 간단하게 볼 수 있다. $ xargs -0 -L1 -a /proc/${PID}/environ 참조: https://askubuntu.com/questions/978711/how-do-i-split-a-proc-environ-file-in-separate-lines

잘~들 살아 계신가?

문재인 대통령 찍은 손가락을 분지르고 싶다고 페이스북에 공개글로 남긴 이. 그딴 글 일일이 반론하고 뭐하기도 지쳐서, 페이스북도 탈퇴했는데, 대통령 된 지 3개월도 되지 않아 지지율 폭락이고, 금리는 폭등인데, 안녕하신가? 잘~~~들 살아보셔~

이 블로그의 인기 게시물

Bash Array, Map 정리

Bash에서 Array, Map에 대한 정리. (매번 찾기 귀찮) 찾아보진 않았지만, Bash에서 Array든 Map이든 동일하게 Map(C++에서 Unordered Map)으로 동작하는 것 같다. 왜냐하면, Array의 Index가 연속하지 않아도 동작한다. 그저 Key가 0 이상의 정수인 Map이랑 비슷하게 동작한다. 예) 1, 2, 3, 9, 10 Array # 생성 declare -a empty_array declare -a ar=(haha hoho baba "long string haha hoho") # 접근 echo "ar[0]=${ar[0]}" echo "all as array=${ar[@]}" # 큰따옴표 안에서 각 원소를 따로따로 전달한다. echo "all as one=${ar[*]}" # 큰따옴표 안에서 각 원소를 문자열 하나로 합쳐 전달한다. echo "indexes=${!ar[@]}" echo "indexes=${!ar[*]}" echo "length=${#ar[@]}" echo "length=${#ar[*]}" echo "last=${ar[-1]}" echo "last=${ar[@]: -1}" # 콜론 뒤에 빈 칸이 꼭 필요하다. 옛 방식 # 현재 상황 declare -p ar #(출력) declare -a ar=([0]="haha" [1]="hoho" [2]="baba" [3]="long string haha hoho") ar[100]=hello # 인덱스를 건너 뛰어도 동작한다. declare -p ar #(출력) declare -a ar=([0]="haha" [1]="hoho" [2]="baba" [3]=&

Linux에서 find결과를 시간 순서대로 정렬하기

때때로 어떤 디렉토리 내용을 수정시간 순서(보통 역순)대로 정렬할 필요가 있다. 그럴 때 사용할 수 있는 옵션이 -printf 옵션이다. %T+는 마지막 수정시간을 YYYY-MM-DD+HH:MM:SS.ssssssssss 형태로 출력한다. 참조: https://man7.org/linux/man-pages/man1/find.1.html find /path/something/ -mindepth 1 -maxdepth 1 -type d \ -name 'myapp-*' -printf "%T+\t%p\n" | \ sort -r | awk -F'\t' '{print $2}'