Prolblem z Formą w DLLce obsługującą bazę

Prolblem z Formą w DLLce obsługującą bazę
OL
  • Rejestracja:prawie 21 lat
  • Ostatnio:ponad 6 lat
0

Wiec.........

tego typu problem, chce wyrzucic do DLL'elek wszystkei formy z programu nie ważne dla czego, powiedzmy ze widze w tym jakis cel...:)
Aplikacja jest bazodanowa, na pierwszej (i jak dobrze pójdzie jedynej w samym programie) mam komponent bazodanowy IBDataBase, który łaczy mi sie z bazą i takie tam. Chcę aby na podstawie tego komponentu działały wszystikie komponenty bazodanowe w bibliotekach. I wszystko mi sumie działa....ale..........

wiec tak... po stronie programu jest nie za wiele
wywołuje procedure z DLL tworzącą formę i przypisuje jej uchwyt aplikacji oraz w/w kompnent IBDataBase;

procedure stworzForme(AppHandle: integer; BAZA : TIBDataBase); stdcall external 'formadll.dll';

tak ją wywołuję

stworzForme(Application.Handle, IBBaza);

po stronie DLL wygląda to tak:

procedure stworzForme(AppHandle: integer; BAZA : TIBDataBase);stdcall;
begin
Application.Handle := AppHandle;
dllForm:=TDLLForm.Create(Application);
dllForm.Bazunia:=TIBDataBase.Create(dllForm);
dllForm.Bazunia:=Baza;
dllForm.IBQuery1.Database:=dllForm.Bazunia;
dllForm.IBQuery1.Open;
dllForm.ShowModal;
dllForm.IBQuery1.Close;
dllForm.Free;
end;

i wszystko smiga jak burza tyle ze po zakonczeniu działania programu wywala mi acces vaiolation itp...

chyba ze nie dam OPEN dla IBQuery to smiga bez błędów....

z góry dzieki za pomoc


Piotr
0

Prawdopodobnie (nie mam jak teraz tego sprawdzić) chodzi o to, że Application w DLL to zupełnie inne Application, niż w programie :)

RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

Chciałem założyć wątek podobny ale podepnę się pod kolegę.

Problem podobny, w Dll'ce mam Tframe i powrzucane na nim komponenty. Wszystko jest ok powiedzmy (na ile to możliwe w VCL).
Problem pojawia się dopiero gdy moduł podpięty do dll zawierający mój TFrame korzysta z innych modułów zawierających sekcje initialize i finalize, a w nich ajkieś zmienne no i TCriticalSection. Na razie obchodzę to w ten sposób że te sekcje a raczej ich wykonanie przenosze do kodu przy ładowaniu i zwalnianiu bibloiteki (DllMain) i wtedy gra. Niestety wiąże się to z ingerencją w kodzie innych modułów jak np. (VirtualTrees z VirtualTreeView) :(
Pytanie moje jest takie czy można w jakiś inny sposób zwolnić inny moduł bądź uruchomić w nim sekcję finalize przed zwolnieniem biblioteki.


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
0

Bez oglądania konkretnego kodu trudno orzekać, ale na 99.9% przyczyną problemów jest to, że dll mają osobne zarządzanie pamięcią (własny stos etc).
Prawdopodobnie da się to obejść przez zastosowanie bpl - polecam przejrzenie delphi.about.com pod kątem bpl vs dll.
W JEDI jest nawet gotowiec do wtyczek z możliwością tworzenia/ładowania bpl. Inne, darmowe do prywatnego użytku, narzędzie to TMS Plugin System.

b0bik
  • Rejestracja:około 22 lata
  • Ostatnio:16 dni
  • Postów:1112
0

A formatki z dll'a wywołujesz modalnie czy niemodalnie ? Bo jak modalnie, to może to z finalize możesz przenieść do funkcji eksportowej (po zakończeniu pracy z formatką).

RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

Właśnie problem w tym że nic wolał bym nie przenosić z sekcji finalize by nie ingerować w kod innych modułów :(, a co do bpl to miałem taki sam problem jak ty b0bik w TDE.

Może jest jakaś opcja by zwalniać moduły przed odmontowaniem dll, jeżeli nie to cóż zostanę przy swoim sposobie choć mnie on trochę uwiera.


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
b0bik
  • Rejestracja:około 22 lata
  • Ostatnio:16 dni
  • Postów:1112
0
RudyBestyj napisał(a)

...Problem pojawia się dopiero gdy moduł podpięty do dll zawierający mój TFrame korzysta z innych modułów zawierających sekcje initialize i finalize, a w nich ajkieś zmienne no i TCriticalSection. ...

A na czym ten problem dokładnie polega ? Może coś źle zdiagnozowałeś że to kwestia występowania tych sekcji. Wylatują jakieś AV'y ?

RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

podczas działania aplikacji wszytko pięknie współgra. Problem pojawia się gdy zamykam aplikację to pojawia się:
"The exception unknow software exception ...i cos tam"
a potem
"Runtime error at ... "

\trochę się rozpanoszyłem w wątku kolegi. Sorry Olej.


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
0

Zamiast się wachlować kodem - przeczytajcie ten i pokrewne artykuły:

http://delphi.about.com/library/weekly/aa020805a.htm

Mnie na bpl formy, nawet modalne, chodzą bez pudła.

0

Miało być oczywiście "nawet MDI", sorki :)

RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

Wielkie dzięki TBSO
W zeszłym tygodniu bawiłem się bpl'ami gdy trafiłem na wspomniany wcześniej przez ciebie art bpl vs dll i próbowałem przerobić ten kod:
http://delphi.about.com/od/objectpascalide/l/aa012301b.htm
z dynamicznych TForm na dynamicznie osdzone na formie TFrame i miełem problemy, aż doszedłem do znanego mi z dll 'cannot assign TFont to a TFont' i się poddałem.
Jak widać nie potrzebnie bo po przerobieniu kodu z linka który podałeś wszystko hula jak trzeba. [green]
Myślałem że to wina TDE Może zmęczony byłem wtedy [wstyd]
[browar] jeszcze raz dzięki TBSO
mam nadzieję że koledze @Olejowi też to pomorze ;-)


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
b0bik
  • Rejestracja:około 22 lata
  • Ostatnio:16 dni
  • Postów:1112
0

Z tym "TFont to a TFont", też się kiedyś wyłożyłem, ale (jakto często bywa) po jakimś czasie od odpuszczenia tematu znalazłem odpowiedź. Jak sobie przypomnę to podrzucę. Trzeba było oprócz Application i Screen, zrobić jeszcze jakąś wspólną globalną zmienną. Nie wiem czy to się nie wiązało z modyfikacją jakiegoś unita w Delphi.

RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

Wiem @b0bik bo dorwałem gdzieś twojego posta na forum gdzie dałeś odnośnik do tej strony http://www.zaoxue.com/article/tech-57739.htm. Chodziło o modyfikację Uintu Controls i zmienną globalna ControlAtom. Ale po podmianie u mnie problem nadal istniał. Rozwiązałem to przez ustawienie ParentWindow zamiast Parent. Ale został problem o którym pisałem parę postów wyżej.

Znowu gdy chciałem spróbować na bpl'ach to nieuważnie przeczytałem arta [glowa] i nie dodałem rtl do "build the application using run-time packages" i niechciało się skompilować a gdy odznaczyłem "build the application using run-time packages" to miałem "cannot assign a TFont to a TFont"

Ale po poście TBSO spróbowałem jeszcze raz i jest jak być powinno [green]

Konkluzja taka że tworząc aplikację VCL lepiej korzystać bpl'ów niż dll'ek bo bpl'ki są zintegrowane ze środowiskiem VCL.


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
b0bik
  • Rejestracja:około 22 lata
  • Ostatnio:16 dni
  • Postów:1112
0

Czyli reasumując, zrobiłeś MDI na bpl'ach w TDE ? Nie wyskakuje Ci ten komunikat "Your version of application ... " ?

RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

Ja przerobiłem na dynamicznie tworzone TFrame'y na panelach. Ale jak wejdziesz na stronkę z odnośnika TBSO to są do ściągnięcia źródła programu MDI na bpl.

I na TDE chodzi bez przeszkód.


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
OL
  • Rejestracja:prawie 21 lat
  • Ostatnio:ponad 6 lat
0

WIec...........nie wspomne ze wszyscy mnie olali i zaczęli prowadzić własne dyskusje na moze i podobne tematy ale mój problem pozoostał nierozwiązany.... z resztą jak zwykle poradziłem sobie sam (musiałem)....:) choc juz łapałem sie wszystkieg. Okazało sie jak zwykle najprostsze wystarczyło dodac do projketu w usesach sharemem, wczesniej miałem go w formie dll'kowej myśląc ze to wystarczy, jednak nie...:)

pozdrawiam


Piotr
RudyBestyj
  • Rejestracja:ponad 19 lat
  • Ostatnio:ponad 9 lat
  • Postów:103
0

Jak tworzysz Dll'kę pod Delphi to w module masz:
{ Important note about DLL memory management: ShareMem must be the
first unit in your library's USES clause AND your project's (select
Project-View Source) USES clause if your DLL exports any procedures or
functions that pass strings as parameters or function results. This
applies to all strings passed to and from your DLL--even those that
are nested in records and classes. ShareMem is the interface unit to
the BORLNDMM.DLL shared memory manager, which must be deployed along
with your DLL. To avoid using BORLNDMM.DLL, pass string information
using PChar or ShortString parameters. }


Nie dyskutuj z głupcem - sprowadzi cię do swojego poziomu i pokona doświadczeniem.
OL
  • Rejestracja:prawie 21 lat
  • Ostatnio:ponad 6 lat
0

teraz to i ja sobie na spokojnie doczytałem... nie mozna było tak od razu.......... :)


Piotr
Kliknij, aby dodać treść...

Pomoc 1.18.8

Typografia

Edytor obsługuje składnie Markdown, w której pojedynczy akcent *kursywa* oraz _kursywa_ to pochylenie. Z kolei podwójny akcent **pogrubienie** oraz __pogrubienie__ to pogrubienie. Dodanie znaczników ~~strike~~ to przekreślenie.

Możesz dodać formatowanie komendami , , oraz .

Ponieważ dekoracja podkreślenia jest przeznaczona na linki, markdown nie zawiera specjalnej składni dla podkreślenia. Dlatego by dodać podkreślenie, użyj <u>underline</u>.

Komendy formatujące reagują na skróty klawiszowe: Ctrl+B, Ctrl+I, Ctrl+U oraz Ctrl+S.

Linki

By dodać link w edytorze użyj komendy lub użyj składni [title](link). URL umieszczony w linku lub nawet URL umieszczony bezpośrednio w tekście będzie aktywny i klikalny.

Jeżeli chcesz, możesz samodzielnie dodać link: <a href="link">title</a>.

Wewnętrzne odnośniki

Możesz umieścić odnośnik do wewnętrznej podstrony, używając następującej składni: [[Delphi/Kompendium]] lub [[Delphi/Kompendium|kliknij, aby przejść do kompendium]]. Odnośniki mogą prowadzić do Forum 4programmers.net lub np. do Kompendium.

Wspomnienia użytkowników

By wspomnieć użytkownika forum, wpisz w formularzu znak @. Zobaczysz okienko samouzupełniające nazwy użytkowników. Samouzupełnienie dobierze odpowiedni format wspomnienia, zależnie od tego czy w nazwie użytkownika znajduje się spacja.

Znaczniki HTML

Dozwolone jest używanie niektórych znaczników HTML: <a>, <b>, <i>, <kbd>, <del>, <strong>, <dfn>, <pre>, <blockquote>, <hr/>, <sub>, <sup> oraz <img/>.

Skróty klawiszowe

Dodaj kombinację klawiszy komendą notacji klawiszy lub skrótem klawiszowym Alt+K.

Reprezentuj kombinacje klawiszowe używając taga <kbd>. Oddziel od siebie klawisze znakiem plus, np <kbd>Alt+Tab</kbd>.

Indeks górny oraz dolny

Przykład: wpisując H<sub>2</sub>O i m<sup>2</sup> otrzymasz: H2O i m2.

Składnia Tex

By precyzyjnie wyrazić działanie matematyczne, użyj składni Tex.

<tex>arcctg(x) = argtan(\frac{1}{x}) = arcsin(\frac{1}{\sqrt{1+x^2}})</tex>

Kod źródłowy

Krótkie fragmenty kodu

Wszelkie jednolinijkowe instrukcje języka programowania powinny być zawarte pomiędzy obróconymi apostrofami: `kod instrukcji` lub ``console.log(`string`);``.

Kod wielolinijkowy

Dodaj fragment kodu komendą . Fragmenty kodu zajmujące całą lub więcej linijek powinny być umieszczone w wielolinijkowym fragmencie kodu. Znaczniki ``` lub ~~~ umożliwiają kolorowanie różnych języków programowania. Możemy nadać nazwę języka programowania używając auto-uzupełnienia, kod został pokolorowany używając konkretnych ustawień kolorowania składni:

```javascript
document.write('Hello World');
```

Możesz zaznaczyć również już wklejony kod w edytorze, i użyć komendy  by zamienić go w kod. Użyj kombinacji Ctrl+`, by dodać fragment kodu bez oznaczników języka.

Tabelki

Dodaj przykładową tabelkę używając komendy . Przykładowa tabelka składa się z dwóch kolumn, nagłówka i jednego wiersza.

Wygeneruj tabelkę na podstawie szablonu. Oddziel komórki separatorem ; lub |, a następnie zaznacz szablonu.

nazwisko;dziedzina;odkrycie
Pitagoras;mathematics;Pythagorean Theorem
Albert Einstein;physics;General Relativity
Marie Curie, Pierre Curie;chemistry;Radium, Polonium

Użyj komendy by zamienić zaznaczony szablon na tabelkę Markdown.

Lista uporządkowana i nieuporządkowana

Możliwe jest tworzenie listy numerowanych oraz wypunktowanych. Wystarczy, że pierwszym znakiem linii będzie * lub - dla listy nieuporządkowanej oraz 1. dla listy uporządkowanej.

Użyj komendy by dodać listę uporządkowaną.

1. Lista numerowana
2. Lista numerowana

Użyj komendy by dodać listę nieuporządkowaną.

* Lista wypunktowana
* Lista wypunktowana
** Lista wypunktowana (drugi poziom)

Składnia Markdown

Edytor obsługuje składnię Markdown, która składa się ze znaków specjalnych. Dostępne komendy, jak formatowanie , dodanie tabelki lub fragmentu kodu są w pewnym sensie świadome otaczającej jej składni, i postarają się unikać uszkodzenia jej.

Dla przykładu, używając tylko dostępnych komend, nie możemy dodać formatowania pogrubienia do kodu wielolinijkowego, albo dodać listy do tabelki - mogłoby to doprowadzić do uszkodzenia składni.

W pewnych odosobnionych przypadkach brak nowej linii przed elementami markdown również mógłby uszkodzić składnie, dlatego edytor dodaje brakujące nowe linie. Dla przykładu, dodanie formatowania pochylenia zaraz po tabelce, mogłoby zostać błędne zinterpretowane, więc edytor doda oddzielającą nową linię pomiędzy tabelką, a pochyleniem.

Skróty klawiszowe

Skróty formatujące, kiedy w edytorze znajduje się pojedynczy kursor, wstawiają sformatowany tekst przykładowy. Jeśli w edytorze znajduje się zaznaczenie (słowo, linijka, paragraf), wtedy zaznaczenie zostaje sformatowane.

  • Ctrl+B - dodaj pogrubienie lub pogrub zaznaczenie
  • Ctrl+I - dodaj pochylenie lub pochyl zaznaczenie
  • Ctrl+U - dodaj podkreślenie lub podkreśl zaznaczenie
  • Ctrl+S - dodaj przekreślenie lub przekreśl zaznaczenie

Notacja Klawiszy

  • Alt+K - dodaj notację klawiszy

Fragment kodu bez oznacznika

  • Alt+C - dodaj pusty fragment kodu

Skróty operujące na kodzie i linijkach:

  • Alt+L - zaznaczenie całej linii
  • Alt+, Alt+ - przeniesienie linijki w której znajduje się kursor w górę/dół.
  • Tab/⌘+] - dodaj wcięcie (wcięcie w prawo)
  • Shit+Tab/⌘+[ - usunięcie wcięcia (wycięcie w lewo)

Dodawanie postów:

  • Ctrl+Enter - dodaj post
  • ⌘+Enter - dodaj post (MacOS)