Subversion Repositories Kolibri OS

Rev

Rev 864 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
750 victor 1
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2
;;                                                              ;;
3
;; Copyright (C) KolibriOS team 2004-2007. All rights reserved. ;;
4
;; Distributed under terms of the GNU General Public License    ;;
5
;;                                                              ;;
6
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
7
 
488 spraid 8
;-------------------------------------------------------------------------
9
;
530 mikedld 10
;  File path partial substitution (according to configuration)
488 spraid 11
;
12
;
13
;     SPraid
14
;
15
;-------------------------------------------------------------------------
16
 
593 mikedld 17
$Revision: 1066 $
18
 
19
 
521 diamond 20
iglobal
21
; pointer to memory for path replace table,
22
; size of one record is 128 bytes: 64 bytes for search pattern + 64 bytes for replace string
512 spraid 23
 
525 diamond 24
; start with one entry: sys -> 
521 diamond 25
full_file_name_table dd sysdir_name
26
.size           dd      1
501 serge 27
 
521 diamond 28
tmp_file_name_size dd   1
29
endg
488 spraid 30
 
521 diamond 31
uglobal
525 diamond 32
; Parser_params will initialize: sysdir_name = "sys", sysdir_path = 
521 diamond 33
sysdir_name     rb      64
34
sysdir_path     rb      64
35
tmp_file_name_table dd  ?
36
endg
501 serge 37
 
535 spraid 38
; use bx_from_load and init system directory /sys
543 spraid 39
proc Parser_params
40
locals
41
  buff db 4 dup(?)		; for test cd
42
endl
855 serge 43
  mov eax,[_bx_from_load+OS_BASE+_16BIT_BASE]
521 diamond 44
  mov ecx,sysdir_path
525 diamond 45
  mov [ecx-64],dword 'sys'
535 spraid 46
  cmp al,'r' ; if ram disk
521 diamond 47
  jnz @f
48
  mov [ecx],dword 'RD/?'
49
  mov [ecx+3],byte ah
50
  mov [ecx+4],byte 0
51
  ret
488 spraid 52
@@:
543 spraid 53
  cmp al,'m' ; if ram disk
54
  jnz @f
55
  mov [ecx],dword 'CD?/'	; if cd disk {m}
56
  mov [ecx+4],byte '1'
57
  mov [ecx+5],dword '/KOL'
58
  mov [ecx+9],dword 'IBRI'
59
  mov [ecx+13],byte 0
60
.next_cd:
61
  mov [ecx+2],byte ah
62
  inc ah
63
  cmp ah,'5'
64
  je  .not_found_cd
65
  lea edx,[buff]
66
  pushad
67
  stdcall read_file,read_firstapp,edx,0,4
68
  popad
69
  cmp [edx],dword 'MENU'
70
  jne .next_cd
71
  jmp .ok
847 serge 72
 
543 spraid 73
@@:
521 diamond 74
  sub al,49
535 spraid 75
  mov [ecx],dword 'HD?/'	; if hard disk
521 diamond 76
  mov [ecx+2],byte al
77
  mov [ecx+4],byte ah
78
  mov [ecx+5],dword '/KOL'
79
  mov [ecx+9],dword 'IBRI'
80
  mov [ecx+13],byte 0
543 spraid 81
.ok:
82
.not_found_cd:
521 diamond 83
  ret
543 spraid 84
endp
501 serge 85
 
521 diamond 86
proc load_file_parse_table
501 serge 87
 
1066 serge 88
           call _alloc_page
864 serge 89
           add eax, OS_BASE
90
           mov [tmp_file_name_table],eax
91
           mov edi,eax
92
           mov esi,sysdir_name
93
           mov ecx,128/4
94
           rep movsd
488 spraid 95
 
864 serge 96
           invoke ini.enum_keys,conf_fname,conf_path_sect,get_every_key
97
 
98
           mov eax,[tmp_file_name_table]
99
           mov [full_file_name_table],eax
100
           mov eax,[tmp_file_name_size]
101
           mov [full_file_name_table.size],eax
102
           ret
488 spraid 103
endp
104
 
521 diamond 105
uglobal
106
def_val_1 db 0
107
endg
488 spraid 108
 
521 diamond 109
proc get_every_key stdcall, f_name, sec_name, key_name
110
        mov     esi, [key_name]
111
        mov     ecx, esi
112
        cmp     byte [esi], '/'
113
        jnz     @f
114
        inc     esi
488 spraid 115
@@:
521 diamond 116
        mov     edi, [tmp_file_name_size]
117
        shl     edi, 7
118
        cmp     edi, 0x1000
119
        jae     .stop_parse
120
        add     edi, [tmp_file_name_table]
121
        lea     ebx, [edi+64]
122
@@:
123
        cmp     edi, ebx
124
        jae     .skip_this_key
125
        lodsb
126
        test    al, al
127
        jz      @f
128
        or      al, 20h
129
        stosb
130
        jmp     @b
131
@@:
132
        stosb
501 serge 133
 
521 diamond 134
        invoke  ini.get_str, [f_name],[sec_name],ecx,ebx,64,def_val_1
488 spraid 135
 
521 diamond 136
        cmp     byte [ebx], '/'
137
        jnz     @f
138
        lea     esi, [ebx+1]
139
        mov     edi, ebx
140
        mov     ecx, 63
141
        rep     movsb
488 spraid 142
@@:
521 diamond 143
        push    ebp
144
        mov     ebp, [tmp_file_name_table]
145
        mov     ecx, [tmp_file_name_size]
146
        jecxz   .noreplace
147
        mov     eax, ecx
148
        dec     eax
149
        shl     eax, 7
150
        add     ebp, eax
151
.replace_loop:
152
        mov     edi, ebx
153
        mov     esi, ebp
488 spraid 154
@@:
521 diamond 155
        lodsb
156
        test    al, al
157
        jz      .doreplace
158
        mov     dl, [edi]
159
        inc     edi
160
        test    dl, dl
161
        jz      .replace_loop_cont
162
        or      dl, 20h
163
        cmp     al, dl
164
        jz      @b
165
        jmp     .replace_loop_cont
166
.doreplace:
167
        cmp     byte [edi], 0
168
        jz      @f
169
        cmp     byte [edi], '/'
170
        jnz     .replace_loop_cont
488 spraid 171
@@:
521 diamond 172
        lea     esi, [ebp+64]
173
        call    .replace
174
        jc      .skip_this_key2
175
.replace_loop_cont:
176
        sub     ebp, 128
177
        loop    .replace_loop
178
.noreplace:
179
        pop     ebp
488 spraid 180
 
521 diamond 181
        inc     [tmp_file_name_size]
182
.skip_this_key:
183
        xor     eax, eax
184
        inc     eax
185
        ret
186
.skip_this_key2:
187
        pop     ebp
188
        jmp     .skip_this_key
189
.stop_parse:
190
        xor     eax, eax
191
        ret
501 serge 192
endp
193
 
521 diamond 194
proc get_every_key.replace
195
; in: ebx->destination, esi->first part of name, edi->second part of name
196
; maximum length is 64 bytes
197
; out: CF=1 <=> overflow
198
; 1) allocate temporary buffer in stack
199
        sub     esp, 64
200
; 2) save second part of name to temporary buffer
201
        push    esi
202
        lea     esi, [esp+4]    ; esi->tmp buffer
203
        xchg    esi, edi        ; edi->tmp buffer, esi->source
488 spraid 204
@@:
521 diamond 205
        lodsb
206
        stosb
207
        test    al, al
208
        jnz     @b
209
; 3) copy first part of name to destination
210
        pop     esi
211
        mov     edi, ebx
512 spraid 212
@@:
521 diamond 213
        lodsb
214
        test    al, al
215
        jz      @f
216
        stosb
217
        jmp     @b
218
@@:
219
; 4) restore second part of name from temporary buffer to destination
220
; (may cause overflow)
221
        lea     edx, [ebx+64]   ; limit of destination
222
        mov     esi, esp
223
@@:
224
        cmp     edi, edx
225
        jae     .overflow
226
        lodsb
227
        stosb
228
        test    al, al
229
        jnz     @b
230
; all is OK
231
        add     esp, 64         ; CF is cleared
232
        ret
233
.overflow:
234
; name is too long
235
        add     esp, 64
236
        stc
237
        ret
512 spraid 238
endp