Lines Matching refs:dj
3253 DIR dj; in f_open() local
3278 dj.obj.fs = fs; in f_open()
3287 res = follow_virentry(&dj.obj,path); in f_open()
3294 fs = dj.obj.fs; in f_open()
3298 res = follow_path(&dj, path); /* Follow the file path */ in f_open()
3301 if (dj.fn[NSFLAG] & NS_NONAME) { /* Origin directory itself? */ in f_open()
3306 res = chk_lock(&dj, (mode & ~FA_READ) ? 1 : 0); /* Check if the file can be used */ in f_open()
3316 res = enq_lock() ? dir_register(&dj) : FR_TOO_MANY_OPEN_FILES; in f_open()
3318 res = dir_register(&dj); in f_open()
3325 if (dj.obj.attr & (AM_RDO | AM_DIR)) { /* Cannot overwrite it (R/O or DIR) */ in f_open()
3336 st_dword(dj.dir + DIR_CrtTime, tm); /* Set created time */ in f_open()
3337 st_dword(dj.dir + DIR_ModTime, tm); /* Set modified time */ in f_open()
3339 st_dword(dj.dir + DIR_CrtTime, 0); /* Set created time as 0*/ in f_open()
3340 st_dword(dj.dir + DIR_ModTime, 0); /* Set modified time as 0*/ in f_open()
3342 dj.dir[DIR_Attr] = AM_ARC; /* Reset attribute */ in f_open()
3343 cl = ld_clust(fs, dj.dir); /* Get cluster chain */ in f_open()
3344 st_clust(fs, dj.dir, 0); /* Reset file allocation info */ in f_open()
3345 st_dword(dj.dir + DIR_FileSize, 0); in f_open()
3354 res = remove_chain(&dj.obj, cl, 0); in f_open()
3362 res = remove_chain(&dj.obj, cl, 0); in f_open()
3375 if (dj.obj.attr & AM_DIR) { /* File open against a directory */ in f_open()
3378 if ((mode & FA_WRITE) && (dj.obj.attr & AM_RDO)) { /* Write mode open against R/O file */ in f_open()
3391 fp->dir_ptr = dj.dir; in f_open()
3393 fp->obj.lockid = inc_lock(&dj, (mode & ~FA_READ) ? 1 : 0); /* Lock the file for this session */ in f_open()
3399 if (dj.fn[NSFLAG] & NS_NONAME) { /* Is it origin directory itself? */ in f_open()
3402 if (dj.obj.attr & AM_DIR) { /* Is it a directory? */ in f_open()
3411 fp->obj.sclust = ld_clust(fs, dj.dir); /* Get object allocation info */ in f_open()
3412 fp->obj.objsize = ld_dword(dj.dir + DIR_FileSize); in f_open()
3897 DIR dj; in f_chdir() local
3905 dj.obj.fs = fs; in f_chdir()
3907 res = follow_path(&dj, path); /* Follow the path */ in f_chdir()
3909 if (dj.fn[NSFLAG] & NS_NONAME) { /* Is it the start directory itself? */ in f_chdir()
3910 fs->cdir = dj.obj.sclust; in f_chdir()
3912 if (dj.obj.attr & AM_DIR) { /* It is a sub-directory */ in f_chdir()
3913 fs->cdir = ld_clust(fs, dj.dir); /* Sub-directory cluster */ in f_chdir()
3940 DIR dj; in f_getcwd() local
3959 dj.obj.fs = fs; in f_getcwd()
3965 dj.obj.sclust = fs->cdir; /* Start to follow upper directory from current directory */ in f_getcwd()
3966 while ((ccl = dj.obj.sclust) != 0) { /* Repeat while current directory is a sub-directory */ in f_getcwd()
3967 res = dir_sdi(&dj, 1 * SZDIRE); /* Get parent directory */ in f_getcwd()
3969 res = move_window(fs, dj.sect); in f_getcwd()
3971 dj.obj.sclust = ld_clust(fs, dj.dir); /* Goto parent directory */ in f_getcwd()
3972 res = dir_sdi(&dj, 0); in f_getcwd()
3975 res = DIR_READ_FILE(&dj); in f_getcwd()
3977 if (ccl == ld_clust(fs, dj.dir)) break; /* Found the entry */ in f_getcwd()
3978 res = dir_next(&dj, 0); in f_getcwd()
3982 get_fileinfo(&dj, &fno); /* Get the directory name and push it to the buffer */ in f_getcwd()
4367 DIR dj; in f_stat() local
4372 res = mount_volume(&path, &dj.obj.fs, 0); in f_stat()
4374 INIT_NAMBUF(dj.obj.fs); in f_stat()
4375 res = follow_path(&dj, path); /* Follow the file path */ in f_stat()
4377 if (dj.fn[NSFLAG] & NS_NONAME) { /* It is origin directory */ in f_stat()
4380 if (fno) get_fileinfo(&dj, fno); in f_stat()
4386 LEAVE_FF(dj.obj.fs, res); in f_stat()
4574 DIR dj, sdj; in f_unlink() local
4592 dj.obj.fs = fs; in f_unlink()
4605 res = follow_virentry(&dj.obj,path); in f_unlink()
4612 fs = dj.obj.fs; in f_unlink()
4616 res = follow_path(&dj, path); /* Follow the file path */ in f_unlink()
4617 if (FF_FS_RPATH && res == FR_OK && (dj.fn[NSFLAG] & NS_DOT)) { in f_unlink()
4622 dj.atrootdir = 0;rtclst = 2; in f_unlink()
4623 st_bak = PARENTFS(dj.obj.fs)->winsect; in f_unlink()
4641 if (dj.clust == rtclst) { in f_unlink()
4643 dj.atrootdir = 1; in f_unlink()
4646 rtclst = get_fat(&(dj.obj),rtclst); in f_unlink()
4649 if (dj.atrootdir == 1) { in f_unlink()
4659 res = move_window(dj.obj.fs,st_bak); in f_unlink()
4664 if (res == FR_OK) res = chk_lock(&dj, 2); /* Check if it is an open object */ in f_unlink()
4667 if (dj.fn[NSFLAG] & NS_NONAME) { in f_unlink()
4670 if (dj.obj.attr & AM_RDO) { in f_unlink()
4675 dclst = ld_clust(fs, dj.dir); in f_unlink()
4676 if (dj.obj.attr & AM_DIR) { /* Is it a sub-directory? */ in f_unlink()
4695 res = dir_remove(&dj); /* Remove the directory entry */ in f_unlink()
4697 res = remove_chain(&dj.obj, dclst, 0); in f_unlink()
4723 DIR dj; in f_mkdir() local
4737 dj.obj.fs = fs; in f_mkdir()
4741 dj.obj.sclust = 0; in f_mkdir()
4751 res = follow_virentry(&dj.obj,path); in f_mkdir()
4758 fs = dj.obj.fs; in f_mkdir()
4762 res = follow_path(&dj, path); /* Follow the file path */ in f_mkdir()
4764 if (FF_FS_RPATH && res == FR_NO_FILE && (dj.fn[NSFLAG] & NS_DOT)) { /* Invalid name? */ in f_mkdir()
4794 dir[SZDIRE + 1] = '.'; pcl = dj.obj.sclust; in f_mkdir()
4815 res = dir_register(&dj); /* Register the object to the directoy */ in f_mkdir()
4818 dir = dj.dir; in f_mkdir()
4837 remove_chain(&dj.obj, dcl, 0); /* Could not register, remove cluster chain */ in f_mkdir()
5021 DIR dj; local
5039 res = follow_virentry(&dj.obj,path);
5046 fs = dj.obj.fs;
5050 res = follow_path(&dj, path); /* Follow the file path */
5051 …if (res == FR_OK && (dj.fn[NSFLAG] & (NS_DOT | NS_NONAME))) res = FR_INVALID_NAME; /* Check object…
5054 dj.dir[DIR_Attr] = (attr & mask) | (dj.dir[DIR_Attr] & (BYTE)~mask); /* Apply attribute change */
5086 DIR dj; local
5093 dj.obj.fs = fs;
5095 res = follow_path(&dj, path); /* Follow the file path */
5096 …if (res == FR_OK && (dj.fn[NSFLAG] & (NS_DOT | NS_NONAME))) res = FR_INVALID_NAME; /* Check object…
5098 st_dword(dj.dir + DIR_ModTime, (DWORD)fno->fdate << 16 | fno->ftime);
5126 DIR dj; local
5136 dj.obj.fs = fs; dj.obj.sclust = 0; /* Open root directory */
5137 res = dir_sdi(&dj, 0);
5139 res = DIR_READ_LABEL(&dj); /* Find a volume label entry */
5143 wc = dj.dir[si++];
5145 if (dbc_1st((BYTE)wc) && si < 11) wc = wc << 8 | dj.dir[si++]; /* Is it a DBC? */
5195 DIR dj; local
5230 dj.obj.fs = fs; dj.obj.sclust = 0; /* Open root directory */
5231 res = dir_sdi(&dj, 0);
5233 res = DIR_READ_LABEL(&dj); /* Get volume label entry */
5236 mem_cpy(dj.dir, dirvn, 11); /* Change the volume label */
5238 dj.dir[DIR_Name] = DDEM; /* Remove the volume label */
5246 res = dir_alloc(&dj, 1); /* Allocate an entry */
5248 mem_set(dj.dir, 0, SZDIRE); /* Clean the entry */
5249 dj.dir[DIR_Attr] = AM_VOL; /* Create volume label entry */
5250 mem_cpy(dj.dir, dirvn, 11);