NOTE

From Atariki

(Różnice między wersjami)
Jump to: navigation, search
Wersja z dnia 09:26, 29 sie 2009
KMK (Dyskusja | wkład)

← Previous diff
Wersja z dnia 10:17, 29 sie 2009
KMK (Dyskusja | wkład)

Next diff →
Linia 17: Linia 17:
* ''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.
-* ''sector'' - numer sektora+* ''sector'' - numer sektora przypisanego do pliku. Jest to fizyczny numer sektora dyskietki, a nie numer kolejny sektora w pliku.
* ''byte'' - numer bajtu w sektorze * ''byte'' - numer bajtu w sektorze

Wersja z dnia 10:17, 29 sie 2009

Przeznaczenie: Funkcja DOS-u zwracająca bieżącą pozycję odczytu/zapisu w pliku, podaną w postaci numeru sektora i numeru bajtu w sektorze. Innymi słowy, ta pozycja to fizyczne koordynaty następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku.

Dostępność: wszystkie DOS-y oprócz SpartaDOS (Real.DOS), SpartaDOS X

Składnia BASIC-a: NOTE #iocb,sector,byte

Kod w asemblerze:

    ldx #iocb*16
    lda #38
    sta iccmd,x
    jsr jciomain

gdzie:

  • iocb - numer kanału IOCB z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być otwarty dla danego pliku.
  • sector - numer sektora przypisanego do pliku. Jest to fizyczny numer sektora dyskietki, a nie numer kolejny sektora w pliku.
  • byte - numer bajtu w sektorze

Uwagi: w SpartaDOS (i pokrewnych) ten sam kod operacyjny (XIO 38) zajmuje funkcja TELL.

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. W przypadku powodzenia w icax3, icax4 wskazanego kanału iocb zostanie zapisany numer sektora (w kolejności bajtów, odpowiednio: młodszy, starszy), a w icax5 numer bajtu w sektorze.