본문 바로가기

쓰기

지금 ML_Trans라는 번역 플러그인을 만들고 있는데 좀 이해가 안가는 문제가 생기네요..
아랄에 적용시킨후 다른 번역 플러그인으로 바꿀때는 아무 문제가 안생깁니다
그러니까 번역 플러그인을  EzTransXp<->ML_Trans로 마구 여러번 바꾸어도 문제는 안일어 납니다.
(즉 플러그인의 OnPluginClose() - dll Free부분은 잘 작동된다는 의미)

그런데 게임을 종료 즉 아랄을 종료시킬때는 이 부분에서 오류창이 뜨네요...
충돌나는 지점은 J2kEngine.dll에서 뽑아쓰는 J2K_Terminate 함수 부분인데요
왜 Aral이 켜져있을때는 문제없이 작동되다가.. 
Aral이 종료될때는 오류창이 나는지 의문이네요..

머 게임 다끝난후에 나오는 오류이니까 사용자입장에서는 큰 문제는 아닐지 몰라도
J2kEngine.dll 이 FreeLib안된채로 끝나는건 많이 찝찝하니까요

참 번역엔진으로 사용하는 dll은 J2kEngine.dll  - v 1.5.1.10 입니다.
분류 :
Talk
조회 수 :
14864
등록일 :
2009.03.15
09:25:58
엮인글 :
https://arallab.hided.net/4300/81d/trackback
게시글 주소 :
https://arallab.hided.net/board_devtalk/4300

Hide_D

2009.03.16
03:08:59
이 문제로 몇가지 고민을 한 적이 있는데

저 같은 경우에는 MFC로 윈도우즈를 띄워둔 상태에서 Close가 들어올 때 자동으로 윈도우를 소멸시키는 코드를 만들었는데, 그냥 추가/제거 할때는 잘만 되다가 막상 게임을 꺼버리면 위의 경우와 같이 오류가 발생하더군요 -_-;

http://www.aralgood.com/zbxe/347148
이 글에 써놓은 것과 같이
아무래도 게임의 종료가 플러그인의 종료보다 우선적으로 일어나면서, 실제 라이브러리 자체가 미리 파괴되는 것 같습니다. 이걸 해결하기 위해서는 종료시에 게임 윈도우가 열려있는지 닫혀있는지를 확인해야 할건데... [흠]

호기

2009.03.25
22:52:25
아 히데님 말씀이 맞네요...
거의 소스라인마다 디버그 출력을 넣어서 확인해 보았는데...
정상 종료할 시간을 주질 않네요...
즉 게임이 종료하게 되면 OnClose함수가 미쳐 다 완료되기도 전에 중간에 끈겨버리네요 (게임에 따라서...)

기존 번역플러그인은 종료시에 하는일이 사실상
따로 생성한 스레드에서 new 로 잡은 버퍼하나민 바로 delete시키는게 다여서...
이문제를 잘피할수 있었지만...

Free과정이 어느정도 되는 플러그인들은 이문제를 피하기가 힘들어 보이네요~

아랄

2009.10.20
18:06:48
그래서 0.3 에서는 로드되는 모든 플러그인의 DLL 엔트리포인트(DllMain)를 후킹하도록 했습니다.
PROCESS_DETACH 였나?
아무튼 이 값을 감지해서 DLL이 떨어져나가기 전에 OnPluginClose()를 호출해 주도록 하고 있습니다.
List of Articles
번호 제목 글쓴이 날짜 조회 수sort
공지 Talk [필독] 테스트필터 사용시 주의사항 라파에 2008-08-03 155435
249 Talk 히데님께 문의 해요! [2] file 라파에 2008-09-21 11922
248 OtherFiles 10MB 파일 여는데 걸리는 시간을 테스트해봤습니다. [4] file Hide_D 2008-08-25 11922
247 Archive [번역툴]QuickTrans 0.0.10 RC4 [10] file HaruKaze 2009-02-09 11899
246 Archive [플러그인, 소스] CmdFilter 테스트 버전 20080714 [1] file whoami 2008-07-14 11895
245 Archive [소스] ATPluginFrame 프레임워크 20091220 테스트 버전 [2] file whoami 2009-12-20 11847
244 Archive TextFile Open/Save Library [5] file Hide_D 2009-02-01 11830
243 Archive [플러그인] DenyWord 테스트 버전 20081204 [1] file Hide_D 2008-12-04 11814
242 Talk Fixline용 텍스트 파일.... [3] file 처음처럼만 2008-12-29 11753
241 Archive [플러그인] CustomDic 0.3 20081125 [오류 =ㅅ=] [2] file Hide_D 2008-11-25 11748
240 Talk ATCode UI 버그 [1] Hide_D 2008-11-01 11730
239 Archive [소스] 플러그인 개발을 위한 기본 프레임워크 20080712 [2] file whoami 2008-07-12 11600
238 Talk 일단, 옵션창 이렇게 생기면 되나요? file Hide_D 2008-09-22 11569
237 Archive [플러그인, 소스] DenyWord 테스트 버전 20081203(4) [버그] [1] file Hide_D 2008-12-03 11557
236 Archive [소스] ATCode 테스트버전 20081203 file whoami 2008-12-16 11548
235 Talk 빈공간[...] file Hide_D 2008-08-16 11531
234 Talk 히데님이 말씀하신 테스트파일 [2] file 유르_리샤 2008-12-29 11530
233 Archive [플러그인] ATCode 테스트 버전 20081210 file whoami 2008-12-11 11500
232 Archive 번역용 작업툴 v0.2.2 [2] file HaruKaze 2009-01-06 11463
231 Archive [플러그인,소스] FixLine 테스트버전 081219 file Hide_D 2008-12-19 11449
230 Archive [플러그인,소스] EzTransXP with 사용자사전플러그인(테스트 버전) 20080720_1 [6] file Hide_D 2008-07-20 11445