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
민들레 영토 스터디 마지막날
오늘이 바로 민토 스터디 마지막날이다. 이제 무더운 여름날 명동에 오지 않아도 되겠군. 대신 한강에 가야할까? 승훈: 가야지. 아니 가야한다! 안가면 중는다. 항상 이래.. 휴...
그대는 원하지도 않는 수많은 일을 계속한다
그대는 원하지도 않는 수많은 일을 계속한다. 누가 그대를 강요하는가? 그대는 표류하고 있다. 아무도 그대를 강요하지 않는다. 그대는 왜 그런 일들을 하는가? 그대는 깨어 있지 못하다. 이것은 사슬과 같다. 한 가지
미투 구글리더를 소개합니다.
미투 구글리더를 소개합니다. 미투 구글리더는, 구글리더에서 마음에 드는 피드를 공유했을 때 이를 미투데이에 포스팅해주는 매쉬업입니다. 물론 노트와 함께 공유했을 경우 노트 내용이 함께 포스팅 되어 딱딱하지 않은