SEEK
From Atariki
(Różnice między wersjami)
Wersja z dnia 10:32, 29 sie 2009 KMK (Dyskusja | wkład) ← Previous diff |
Aktualna wersja KMK (Dyskusja | wkład) |
||
Linia 1: | Linia 1: | ||
'''Przeznaczenie:''' Funkcja [[DOS]]-u ustawiająca bieżącą pozycję odczytu/zapisu w pliku, liczoną względem początku tego pliku. Innymi słowy, ta pozycja to numer następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku. | '''Przeznaczenie:''' Funkcja [[DOS]]-u ustawiająca bieżącą pozycję odczytu/zapisu w pliku, liczoną względem początku tego pliku. Innymi słowy, ta pozycja to numer następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku. | ||
- | '''Dostępność:''' [[DOS 3.0]], [[DOS 4.0]], [[DOS XE]], [[SpartaDOS]] ([[Real.DOS]]), [[SpartaDOS X]] | + | '''Dostępność:''' [[DOS 3.0]], [[DOS 4.0]], [[DOS XE]], [[SpartaDOS]], [[Real.DOS]], [[BW-DOS]], [[SpartaDOS X]] |
'''Składnia [[Atari BASIC]]-a:''' | '''Składnia [[Atari BASIC]]-a:''' | ||
- | <code> | + | |
10 A=INT(''pos''/65536) | 10 A=INT(''pos''/65536) | ||
15 B=INT((''pos''-A*65536)/256) | 15 B=INT((''pos''-A*65536)/256) | ||
Linia 12: | Linia 12: | ||
35 POKE 846+''iocb''*16,A | 35 POKE 846+''iocb''*16,A | ||
40 XIO 37,#''iocb'',''x1'',''x2'',"D:" | 40 XIO 37,#''iocb'',''x1'',''x2'',"D:" | ||
- | </code> | ||
'''Składnia [[Turbo BASIC XL|Turbo BASIC-a XL]]:''' <code>POINT #''iocb'',''pos'' MOD 65536,''pos'' DIV 65536</code> | '''Składnia [[Turbo BASIC XL|Turbo BASIC-a XL]]:''' <code>POINT #''iocb'',''pos'' MOD 65536,''pos'' DIV 65536</code> | ||
Linia 18: | Linia 17: | ||
'''Kod w asemblerze:''' | '''Kod w asemblerze:''' | ||
- | <code> | ||
ldx #''iocb''*16 | ldx #''iocb''*16 | ||
+ | lda #<pos | ||
+ | sta icax3,x | ||
+ | lda #>pos | ||
+ | sta icax4,x | ||
+ | lda #^pos | ||
+ | sta icax5,x | ||
lda #37 | lda #37 | ||
sta iccmd,x | sta iccmd,x | ||
jsr [[Tablica skoków#JCIOMAIN|jciomain]] | jsr [[Tablica skoków#JCIOMAIN|jciomain]] | ||
- | </code> | ||
gdzie: | gdzie: | ||
- | * ''pos'' - wartość pozycji (z zakresu od 0 do 16777215). | + | * ''pos'' - wartość pozycji (z zakresu od 0 do 8388607 pod SpartaDOS lub od 0 do 16777215 pod SpartaDOS X). |
* ''iocb'' - numer kanału [[IOCB]] z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być '''otwarty''' dla danego pliku. | * ''iocb'' - numer kanału [[IOCB]] z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być '''otwarty''' dla danego pliku. | ||
* ''x1'' i ''x2'' powinny mieć takie same wartości jak odpowiednie parametry funkcji OPEN użytej do otwarcia tego pliku. | * ''x1'' i ''x2'' powinny mieć takie same wartości jak odpowiednie parametry funkcji OPEN użytej do otwarcia tego pliku. | ||
'''Uwagi:''' | '''Uwagi:''' | ||
- | * żądaną pozycję przekazujemy jako 24-bitowa liczbę w <code>icax3, icax4, icax5</code> (bajty, odpowiednio: młodszy, starszy, najstarszy). | + | * żądaną pozycję przekazujemy jako 24-bitową liczbę w <code>icax3, icax4, icax5</code> (bajty, odpowiednio: młodszy, starszy, najstarszy). |
* wynik próby ustawienia pozycji poza końcem pliku zależy od trybu dostępu do pliku: przy plikach otwartych do odczytu kończy się błędem, natomiast podczas zapisu jest to akceptowane, aczkolwiek może się skończyć powstaniem pliku nieciągłego (ang. [http://en.wikipedia.org/wiki/Sparse_file sparse file]). | * wynik próby ustawienia pozycji poza końcem pliku zależy od trybu dostępu do pliku: przy plikach otwartych do odczytu kończy się błędem, natomiast podczas zapisu jest to akceptowane, aczkolwiek może się skończyć powstaniem pliku nieciągłego (ang. [http://en.wikipedia.org/wiki/Sparse_file sparse file]). | ||
- | * ta funkcja jest '''niezgodna''' z funkcją [[POINT]] zaimplementowaną w [[DOS 1.0]] i pochodnych. Para funkcji [[TELL]]/SEEK będzie działać tak jak [[NOTE]] i POINT w innych DOS-ach tylko wtedy, kiedy SEEK zostanie używane do ponownego ustawiania pozycji odczytanej poprzednio przez TELL. | + | * ta funkcja jest '''niezgodna''' z funkcją [[POINT]] zaimplementowaną w [[DOS 1.0]] i pochodnych. Para funkcji [[TELL]]/SEEK będzie działać tak jak [[NOTE]] i POINT w innych DOS-ach tylko wtedy, kiedy SEEK będzie używane do ponownego ustawiania pozycji odczytanej poprzednio przez TELL. |
+ | * pod BW-DOS-em i starszymi wersjami SpartaDOS X SEEK nie będzie działał optymalnie dla plików przekraczających pewną określoną wielkość. Pod SpartaDOS X wielkość, po której przekroczeniu zaczną się kłopoty, zależy od liczby buforów i wielkości sektora, dla [[DD]] ta graniczna wartość wystąpi pomiędzy 95 a 500 KB. Poprawiono to w SpartaDOS X 4.40. | ||
'''Zwracana wartość:''' Procedura zwraca w rejestrze Y ujemny [[Kody błędów Atari OS|kod błędu]] albo wartość $01 w przypadku powodzenia, oraz odpowiednio do tego ustawia znacznik N rejestru znaczników. | '''Zwracana wartość:''' Procedura zwraca w rejestrze Y ujemny [[Kody błędów Atari OS|kod błędu]] albo wartość $01 w przypadku powodzenia, oraz odpowiednio do tego ustawia znacznik N rejestru znaczników. | ||
[[Kategoria:Niezbędnik kodera]] | [[Kategoria:Niezbędnik kodera]] |
Aktualna wersja
Przeznaczenie: Funkcja DOS-u ustawiająca bieżącą pozycję odczytu/zapisu w pliku, liczoną względem początku tego pliku. Innymi słowy, ta pozycja to numer następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku.
Dostępność: DOS 3.0, DOS 4.0, DOS XE, SpartaDOS, Real.DOS, BW-DOS, SpartaDOS X
Składnia Atari BASIC-a:
10 A=INT(pos/65536) 15 B=INT((pos-A*65536)/256) 20 C=pos-A*65536-B*256 25 POKE 844+iocb*16,C 30 POKE 845+iocb*16,B 35 POKE 846+iocb*16,A 40 XIO 37,#iocb,x1,x2,"D:"
Składnia Turbo BASIC-a XL: POINT #iocb,pos MOD 65536,pos DIV 65536
Kod w asemblerze:
ldx #iocb*16 lda #<pos sta icax3,x lda #>pos sta icax4,x lda #^pos sta icax5,x lda #37 sta iccmd,x jsr jciomain
gdzie:
- pos - wartość pozycji (z zakresu od 0 do 8388607 pod SpartaDOS lub od 0 do 16777215 pod SpartaDOS X).
- iocb - numer kanału IOCB z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być otwarty dla danego pliku.
- x1 i x2 powinny mieć takie same wartości jak odpowiednie parametry funkcji OPEN użytej do otwarcia tego pliku.
Uwagi:
- żądaną pozycję przekazujemy jako 24-bitową liczbę w
icax3, icax4, icax5
(bajty, odpowiednio: młodszy, starszy, najstarszy). - wynik próby ustawienia pozycji poza końcem pliku zależy od trybu dostępu do pliku: przy plikach otwartych do odczytu kończy się błędem, natomiast podczas zapisu jest to akceptowane, aczkolwiek może się skończyć powstaniem pliku nieciągłego (ang. sparse file).
- ta funkcja jest niezgodna z funkcją POINT zaimplementowaną w DOS 1.0 i pochodnych. Para funkcji TELL/SEEK będzie działać tak jak NOTE i POINT w innych DOS-ach tylko wtedy, kiedy SEEK będzie używane do ponownego ustawiania pozycji odczytanej poprzednio przez TELL.
- pod BW-DOS-em i starszymi wersjami SpartaDOS X SEEK nie będzie działał optymalnie dla plików przekraczających pewną określoną wielkość. Pod SpartaDOS X wielkość, po której przekroczeniu zaczną się kłopoty, zależy od liczby buforów i wielkości sektora, dla DD ta graniczna wartość wystąpi pomiędzy 95 a 500 KB. Poprawiono to w SpartaDOS X 4.40.
Zwracana wartość: Procedura zwraca w rejestrze Y ujemny kod błędu albo wartość $01 w przypadku powodzenia, oraz odpowiednio do tego ustawia znacznik N rejestru znaczników.