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
터키행진곡 - 양반다리로 불쌍하게
이승훈의 제안으로 불쌍하게 쪼그려서 쳐보려 했다. 쪼그려 앉기는 너무 부담을 많이 줘서 그냥 양반다리로 했는데 동영상을 보더니 이승훈 이녀석이 불쌍하지도 않고 자세도 별로고 임팩트 없댄다. 그래서 동영상은
WebRTC와 씨름하는 새벽
아직도 Google WebRTC 코드와 시간을 보내고 있다. AV1 인코더는 요새 부쩍 빨라진 libaom 2.0을 써도 넷플릭스가 만든 svt-av1을 써도 어셈블리 반 러스트 반인 rav1e를 써도 라이브에
자유로부터의 도피 #인용
M. 스캇 펙의 아직도 가야 할 길의 61-62 페이지 인용합니다 . 우리는 자신의 행동에 따른 책임을 회피할 때, 그 책임을 다른 어떤 개인이나 조직 등에 떠넘긴다. 이것은 자신의 권리를 양도하는 것을