Flutter 하면서 WebP 이미지 도배했었다. WebP가 좋아 보였기 때문이다. 요새 웹 버전 만들다 보니까 WebP 미지원 브라우저 때문에 CDN 마이그레이션 해야 해서 좀 귀찮았다. 그래서 WebP polyfill을 찾았다. 이미지 디코딩은 잘 되지만 document에 의존성이 있고, package.json이 엉망이라 관리도 안 돼서 탈락이었다. 동시에 여러 이미지를 표시해야 해서 main 디코딩 스레드는 절대 쓸 수 없었다. 그래서 worker 스레드에서 돌아야 했다.
원본을 찾아보니까 구글이 만든 libwebp 기반이었다.
libwebp-1.1.0.tar.gz 찾아서 cmake로 빌드를 시작했다.
그런데 LLVM to JavaScript 컴파일러 없다고 에러가 났다.
문서 보고 Emscripten을 설치했다.
다시 libwebp를 빌드하려고 했는데 Emscripten 쪽에서 에러가 났다.
결국 Emscripten 파이썬 코드 일부를 수정했다.
그렇게 libwebp 빌드해서 겨우 webp.js를 뽑아냈는데, 웹킷에서 Atomics가 없어서 또 에러가 났다.
LLVM 말고 fastcomp 백엔드로 빌드해야 된다는 걸 몰라서 몇 시간을 더 날렸다.
그래도 결국엔 빌드 성공했고, 각종 브라우저에서 다 동작하는 것까지는 확인했다.
근데 libwebp가 제공한 webp_to_sdl.c로는 offscreen 드로잉도 안 되고, 리턴값도 전역 변수로 줘서 확장성이 1도 없었다.
잠깐 당황했지만, 어차피 이거 WebAssembly니까 괜찮다고 생각했다.
그래서 webp_to_jpg.c 만들기 시작했다.
하다 보니 resize도 하고 싶어져서 그 기능도 넣기 시작했다.
다 만들면 Emscripten이 알아서 내 C 코드를 JS로 만들어주겠지, 하고 생각했다.
잠깐만… CDN 마이그레이션 했으면 벌써 끝났을 텐데… 😔
Continue Reading
Discover more thoughts and insights
책임감 중독
책임감 중독이란 책을 읽었습니다. 최근 몇달간 이유 모를 슬럼프에 계속 빠져있었는데, 매년 슬럼프에 빠질 때마다 이유가 무엇인지 찾곤 했습니다. 정말 여러가지 이유가 있습니다. 모든 것에 한가지 공통적인, 어떤
4학년 2학기 중간고사 시간표
Lifepod 으로 정리해봤다. 학교는 왜 다니고 있는지 모르겠단 말이지.. 공부도 안하고 열심히 하는 척도 안하고. 휴학을 하는 게 옳은데 아무 생각없이 등록해버렸다. 이번 학기만 다니면 졸업한다는 사실에
영화와 프로그래밍은 기억을 지운다
나는 영화 보기와 프로그래밍을 비슷하게 취급하는 경향이 있다. 둘 다 한 번 시작하면 적어도 2~3시간은 다른 짓을 못하기 때문에 머리에서 굴리고 있던 것들이 부서져버린다. 그래서 시작하기를 꺼린다. 일단 시작하게