정웅이와 Flex 수다를 떨다가 labs.adobe.com 에 갔다가 CLI 매니아 눈에게 바로 들어온.
Flex Compiler Shell !!!
처음에 아무 생각없이 클릭했다가 나를 광분하게 만든 문장은 바로 이것.
It works very similarly to the mxmlc and compc command line compilers, but it compiles faster than the mxmlc and compc command-line compilers. One reason is that by keeping everything in memory, fcsh eliminates the overhead of launching the JVM and loading the compiler classes. Another reason is that compilation results (for example, type information) can be kept in memory for subsequent compilations.
잽싸 깔아보기로 한다. 아 참, fcsh은 Flex 2.0.1 이상에서만 돌아간다. 그 이하 버전을 사용하고 있다면 에러를 두두두 만나게 될 것이다. (거친마루님께서 알려주셨다)
자자 그럼 얼마나 빨라졌는지 구경할 시간 ![]()
[mxmlc로 그냥 컴파일 했을 때]
[rath@desk files]$ time mxmlc MoviePlayer.mxml
Loading configuration file /home/rath/flex2/frameworks/flex-config.xml
/home/rath/files/MoviePlayer.swf (168826 bytes)
real <b>0m7.640s</b>
user 0m7.378s
sys 0m0.252s
[rath@desk files]$
[fcsh에서 컴파일 했을 때]
(fcsh) <b>mxmlc -benchmark=true MoviePlayer.mxml</b>
fcsh: Assigned <font color="blue">2</font> as the compile target id
Loading configuration file /home/rath/flex2/frameworks/flex-config.xml
Initial setup: 10ms
Loaded 8 SWCs: 846ms
Files: 334 Time: 3674ms
Linking... 28ms
Optimizing... 384ms
SWF Encoding... 175ms
/home/rath/files/MoviePlayer.swf (168826 bytes)
Total time: <b>5121ms</b>
Peak memory usage: 77 MB (Heap: 51, Non-Heap: 26)
(fcsh) <font color=#336699>(이 부분에서 MoviePlayer.mxml 소스를 살짝 고쳤음)</font>
(fcsh) compile <font color="blue">2</font>
Loading configuration file /home/rath/flex2/frameworks/flex-config.xml
Initial setup: 8ms
Loaded 8 SWCs: 17ms
Recompile: /home/rath/files/MoviePlayer.mxml
Reason: The source file or one of the included files has been updated.
Files changed: 1 Files affected: 0
Files: 334 Time: 540ms
Total time: <b>566ms</b>
Peak memory usage: 83 MB (Heap: 57, Non-Heap: 26)
Linking... 16ms
Optimizing... 177ms
SWF Encoding... 68ms
/home/rath/files/MoviePlayer.swf (168830 bytes)
Total time: <b>263ms</b>
Peak memory usage: 85 MB (Heap: 59, Non-Heap: 26)
기존 mxmlc 사용시 7.640초
fcsh 사용시 최초 빌드시 5.121초
두번째 빌드때부터는 (소스코드 고치고) 0.828초! (왕창 절약 ㅋㅋ)
매번 compile n 쳐주기 귀찮아서 리버스 엔지니어링으로 살짝 fcsh.jar (24KB)를 고쳐보았다. !를 입력하면 마지막 명령 반복을 해주고, compile 3 대신에 3만 쳐도 컴파일되고 mxmlc 의 약어 m도 먹게 고쳐놨다. 좀 더 편하고자 하시는 분은 사용해보길 바란다.
어예! ![]()
Continue Reading
Discover more thoughts and insights
T-Mobile USB 모뎀의 진실
7월 25일에 런던에 입국한 나, shared room을 빌려 256Byte/s 의 인터넷 속도를 즐기다가. 8월 15일 광복절을 맞이하야 -\_- 새 집으로 이사를 왔다. 4층 건물의 꼭대기층이라 천장이 아주
상냥함
사회에서 사람들에게 내가 시전하는 상냥함이나 배려에는 아무런 의미도 없다. 기저핵이 모든 것을 관장한다. 전전두엽을 활성화했다면 상대방을 활용하려는 것이다. 상대방을 활용한다니 너무 부정적으로 보는 것이 아니냐-
자급자족 개발자
언젠가부터 만든 프로그램을 외부에 노출하지 않기 시작했다. 제작년에 만들었던 Android 용 MSN 클론 때문이다. public release 는 대단히 고통스럽고 에너지가 많이 소모되는 일이다. Total