]>
git.saurik.com Git - apple/hfs.git/blob - fsck_hfs/fsck_hfs_strings.c
2 * Copyright (c) 2008-2011 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
23 #include "fsck_messages.h"
24 #include "fsck_hfs_msgnums.h"
27 * HFS-specific status messages -- just indicating what phase fsck_hfs is in.
28 * The structure is explained in fsck_strings.c
32 /* Message Number Message Type Verbosity Arguments */
34 { hfsExtBTCheck
, "Checking extents overflow file.", fsckMsgVerify
, fsckLevel0
, 0, },
35 { hfsCatBTCheck
, "Checking catalog file.", fsckMsgVerify
, fsckLevel0
, 0, },
36 { hfsCatHierCheck
, "Checking catalog hierarchy.", fsckMsgVerify
, fsckLevel0
, 0, },
37 { hfsExtAttrBTCheck
, "Checking extended attributes file.", fsckMsgVerify
, fsckLevel0
, 0, },
38 { hfsVolBitmapCheck
, "Checking volume bitmap.", fsckMsgVerify
, fsckLevel0
, 0, },
39 { hfsVolInfoCheck
, "Checking volume information.", fsckMsgVerify
, fsckLevel0
, 0, },
40 { hfsHardLinkCheck
, "Checking multi-linked files.", fsckMsgVerify
, fsckLevel0
, 0, },
41 { hfsRebuildExtentBTree
, "Rebuilding extents overflow B-tree.", fsckMsgVerify
, fsckLevel0
, 0, },
42 { hfsRebuildCatalogBTree
, "Rebuilding catalog B-tree.", fsckMsgVerify
, fsckLevel0
, 0, },
43 { hfsRebuildAttrBTree
, "Rebuilding extended attributes B-tree.", fsckMsgVerify
, fsckLevel0
, 0, },
46 { hfsCaseSensitive
, "Detected a case-sensitive volume.", fsckMsgVerify
, fsckLevel0
, 0, },
47 { hfsMultiLinkDirCheck
, "Checking multi-linked directories.", fsckMsgVerify
, fsckLevel0
, 0, },
48 { hfsJournalVolCheck
, "Checking Journaled HFS Plus volume.", fsckMsgVerify
, fsckLevel0
, 0, },
49 { hfsLiveVerifyCheck
, "Performing live verification.", fsckMsgVerify
, fsckLevel0
, 0, },
50 { hfsVerifyVolWithWrite
, "Verifying volume when it is mounted with write access.", fsckMsgVerify
, fsckLevel0
, 0, },
51 { hfsCheckHFS
, "Checking HFS volume.", fsckMsgVerify
, fsckLevel0
, 0, },
52 { hfsCheckNoJnl
, "Checking non-journaled HFS Plus Volume.", fsckMsgVerify
, fsckLevel0
, 0, },
54 /* End of the array */
59 * HFS-specific error messages. Most are repairable; some are not, but there's no indication of
60 * which is which here (see fsck_hfs_msgnums.h; negative values are non-repairable).
61 * Messages need not be in any particular order, as fsckAddMessages will sort everything.
65 /* Message Number Message Type Verbosity Arguments */
67 { E_PEOF
, "Incorrect block count for file %s", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeFile
} },
68 { E_LEOF
, "Incorrect size for file %s", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeFile
} },
69 { E_DirVal
, "Invalid directory item count", fsckMsgError
, fsckLevel1
, 0, } ,
70 { E_CName
, "Invalid length for file name", fsckMsgError
, fsckLevel1
, 0, } ,
71 { E_NHeight
, "Invalid node height", fsckMsgError
, fsckLevel1
, 0, } ,
72 { E_NoFile
, "Missing file record for file thread", fsckMsgError
, fsckLevel1
, 0, } ,
73 { E_ABlkSz
, "Invalid allocation block size", fsckMsgError
, fsckLevel1
, 0, } ,
74 { E_NABlks
, "Invalid number of allocation blocks", fsckMsgError
, fsckLevel1
, 0, },
75 { E_VBMSt
, "Invalid VBM start block", fsckMsgError
, fsckLevel1
, 0, },
76 { E_ABlkSt
, "Invalid allocation block start", fsckMsgError
, fsckLevel1
, 0, },
79 { E_ExtEnt
, "Invalid extent entry", fsckMsgError
, fsckLevel1
, 0, },
80 { E_OvlExt
, "Overlapped extent allocation (id = %u, %s)", fsckMsgError
, fsckLevel1
, 2, (const int[]){ fsckTypeInt
, fsckTypePath
} },
81 { E_LenBTH
, "Invalid BTH length", fsckMsgError
, fsckLevel1
, 0, } ,
82 { E_ShortBTM
, "BT map too short during repair", fsckMsgError
, fsckLevel1
, 0, } ,
83 { E_BTRoot
, "Invalid root node number", fsckMsgError
, fsckLevel1
, 0, },
84 { E_NType
, "Invalid node type", fsckMsgError
, fsckLevel1
, 0, },
85 { E_NRecs
, "Invalid record count", fsckMsgError
, fsckLevel1
, 0, },
86 { E_IKey
, "Invalid index key", fsckMsgError
, fsckLevel1
, 0, },
87 { E_IndxLk
, "Invalid index link", fsckMsgError
, fsckLevel1
, 0, },
88 { E_SibLk
, "Invalid sibling link", fsckMsgError
, fsckLevel1
, 0, },
91 { E_BadNode
, "Invalid node structure", fsckMsgError
, fsckLevel1
, 0, },
92 { E_OvlNode
, "Overlapped node allocation", fsckMsgError
, fsckLevel1
, 0, },
93 { E_MapLk
, "Invalid map node linkage", fsckMsgError
, fsckLevel1
, 0, },
94 { E_KeyLen
, "Invalid key length", fsckMsgError
, fsckLevel1
, 0, },
95 { E_KeyOrd
, "Keys out of order", fsckMsgError
, fsckLevel1
, 0, },
96 { E_BadMapN
, "Invalid map node", fsckMsgError
, fsckLevel1
, 0, },
97 { E_BadHdrN
, "Invalid header node", fsckMsgError
, fsckLevel1
, 0, },
98 { E_BTDepth
, "Exceeded maximum B-tree depth", fsckMsgError
, fsckLevel1
, 0, },
99 { E_CatRec
, "Invalid catalog record type", fsckMsgError
, fsckLevel1
, 0, },
100 { E_LenDir
, "Invalid directory record length", fsckMsgError
, fsckLevel1
, 0, },
103 { E_LenThd
, "Invalid thread record length", fsckMsgError
, fsckLevel1
, 0, },
104 { E_LenFil
, "Invalid file record length", fsckMsgError
, fsckLevel1
, 0, },
105 { E_NoRtThd
, "Missing thread record for root dir", fsckMsgError
, fsckLevel1
, 0, },
106 { E_NoThd
, "Missing thread record (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
107 { E_NoDir
, "Missing directory record (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
108 { E_ThdKey
, "Invalid key for thread record", fsckMsgError
, fsckLevel1
, 0, },
109 { E_ThdCN
, "Invalid parent CName in thread record", fsckMsgError
, fsckLevel1
, 0, },
110 { E_LenCDR
, "Invalid catalog record length", fsckMsgError
, fsckLevel1
, 0, },
111 { E_DirLoop
, "Loop in directory hierarchy", fsckMsgError
, fsckLevel1
, 0, },
112 { E_RtDirCnt
, "Invalid root directory count", fsckMsgError
, fsckLevel1
, 0, },
115 { E_RtFilCnt
, "Invalid root file count", fsckMsgError
, fsckLevel1
, 0, },
116 { E_DirCnt
, "Invalid volume directory count", fsckMsgError
, fsckLevel1
, 0, },
117 { E_FilCnt
, "Invalid volume file count", fsckMsgError
, fsckLevel1
, 0, },
118 { E_CatPEOF
, "Invalid catalog PEOF", fsckMsgError
, fsckLevel1
, 0, },
119 { E_ExtPEOF
, "Invalid extent file PEOF", fsckMsgError
, fsckLevel1
, 0, },
120 { E_CatDepth
, "Nesting of folders has exceeded %d folders", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
121 { E_NoFThdFlg
, "File thread flag not set in file record", fsckMsgError
, fsckLevel1
, 0, },
122 { E_CatalogFlagsNotZero
, "Reserved fields in the catalog record have incorrect data", fsckMsgError
, fsckLevel1
, 0, },
123 { E_BadFileName
, "Invalid file name", fsckMsgError
, fsckLevel1
, 0, },
124 { E_InvalidClumpSize
, "Invalid file clump size", fsckMsgError
, fsckLevel1
, 0, },
127 { E_InvalidBTreeHeader
, "Invalid B-tree header", fsckMsgError
, fsckLevel1
, 0, },
128 { E_LockedDirName
, "Directory name locked", fsckMsgError
, fsckLevel1
, 0, },
129 { E_EntryNotFound
, "Catalog file entry not found for extent", fsckMsgError
, fsckLevel1
, 0, },
130 { E_FreeBlocks
, "Invalid volume free block count", fsckMsgError
, fsckLevel1
, 0, },
131 { E_MDBDamaged
, "Master Directory Block needs minor repair", fsckMsgError
, fsckLevel1
, 0, },
132 { E_VolumeHeaderDamaged
, "Volume header needs minor repair", fsckMsgError
, fsckLevel1
, 0, },
133 { E_VBMDamaged
, "Volume bitmap needs repair for under-allocation", fsckMsgError
, fsckLevel0
, 0, },
134 { E_InvalidNodeSize
, "Invalid B-tree node size", fsckMsgError
, fsckLevel1
, 0, },
135 { E_LeafCnt
, "Invalid leaf record count", fsckMsgError
, fsckLevel1
, 0, },
136 { E_BadValue
, "(It should be %s instead of %s)", fsckMsgDamageInfo
,fsckLevel1
, 2, (const int[]){ fsckTypeString
, fsckTypeString
} },
139 { E_InvalidID
, "Invalid file or directory ID found", fsckMsgError
, fsckLevel1
, 0, },
140 { E_VolumeHeaderTooNew
, "I can't understand this version of HFS Plus", fsckMsgError
, fsckLevel1
, 0, },
141 { E_DiskFull
, "Disk full error", fsckMsgError
, fsckLevel1
, 0, },
142 { E_InternalFileOverlap
, "Internal files overlap (file %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
143 { E_InvalidVolumeHeader
, "Invalid volume header", fsckMsgError
, fsckLevel1
, 0, },
144 { E_InvalidMDBdrAlBlSt
, "HFS wrapper volume needs repair", fsckMsgError
, fsckLevel1
, 0, },
145 { E_InvalidWrapperExtents
, "Wrapper catalog file location needs repair", fsckMsgError
, fsckLevel1
, 0, },
146 { E_InvalidLinkCount
, "Indirect node %d needs link count adjustment", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
147 { E_UnlinkedFile
, "Orphaned open unlinked file %s", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeFile
} },
148 { E_InvalidPermissions
, "Invalid BSD file type", fsckMsgError
, fsckLevel1
, 0, },
151 { E_InvalidUID_Unused
, "Invalid BSD User ID", fsckMsgError
, fsckLevel1
, 0, },
152 { E_IllegalName
, "Illegal name", fsckMsgError
, fsckLevel1
, 0, },
153 { E_IncorrectNumThdRcd
, "Incorrect number of thread records", fsckMsgError
, fsckLevel1
, 0, },
154 { E_SymlinkCreate
, "Cannot create links to all corrupt files", fsckMsgError
, fsckLevel1
, 0, },
155 { E_BadJournal
, "Invalid content in journal", fsckMsgError
, fsckLevel1
, 0, },
156 { E_IncorrectAttrCount
, "Incorrect number of extended attributes", fsckMsgError
, fsckLevel1
, 0, },
157 { E_IncorrectSecurityCount
, "Incorrect number of Access Control Lists", fsckMsgError
, fsckLevel1
, 0, },
158 { E_PEOAttr
, "Incorrect block count for attribute %s of file %s", fsckMsgError
, fsckLevel1
, 2, (const int[]){ fsckTypeString
, fsckTypeFile
} },
159 { E_LEOAttr
, "Incorrect size for attribute %s of file %s", fsckMsgError
, fsckLevel1
, 2, (const int[]){ fsckTypeString
, fsckTypeFile
} },
160 { E_AttrRec
, "Invalid attribute record", fsckMsgError
, fsckLevel1
, 0, },
163 { E_FldCount
, "Incorrect folder count in a directory (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
164 { E_HsFldCount
, "HasFolderCount flag needs to be set (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
165 { E_BadPermPrivDir
, "Incorrect permissions for private directory", fsckMsgError
, fsckLevel1
, 0, },
166 { E_DirInodeBadFlags
, "Incorrect flags for directory inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
167 { E_DirInodeBadParent
, "Invalid parent for directory inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
168 { E_DirInodeBadName
, "Invalid name for directory inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
169 { E_DirHardLinkChain
, "Incorrect number of directory hard links", fsckMsgError
, fsckLevel1
, 0, },
170 { E_DirHardLinkOwnerFlags
, "Incorrect owner flags for directory hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
171 { E_DirHardLinkFinderInfo
, "Invalid Finder info for directory hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
172 { E_DirLinkAncestorFlags
, "Incorrect flags for directory hard link ancestor (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
175 { E_BadParentHierarchy
, "Bad parent directory hierarchy (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
} },
176 { E_DirHardLinkNesting
, "Maximum nesting of folders and directory hard links reached", fsckMsgError
, fsckLevel1
, 0, },
177 { E_MissingPrivDir
, "Missing private directory for directory hard links", fsckMsgError
, fsckLevel1
, 0, },
178 { E_InvalidLinkChainPrev
, "Previous ID in a hard link chain is incorrect (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
179 { E_InvalidLinkChainNext
, "Next ID in a hard link chain is incorrect (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
180 { E_FileInodeBadFlags
, "Incorrect flags for file inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
181 { E_FileInodeBadParent
, "Invalid parent for file inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
182 { E_FileInodeBadName
, "Invalid name for file inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
183 { E_FileHardLinkChain
, "Incorrect number of file hard links", fsckMsgError
, fsckLevel1
, 0, },
184 { E_FileHardLinkFinderInfo
, "Invalid Finder info for file hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
187 { E_InvalidLinkChainFirst
, "Invalid first link in hard link chain (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
188 { E_FileLinkBadFlags
, "Incorrect flags for file hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
189 { E_DirLinkBadFlags
, "Incorrect flags for directory hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
190 { E_OrphanFileLink
, "Orphaned file hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
191 { E_OrphanDirLink
, "Orphaned directory hard link (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
192 { E_OrphanFileInode
, "Orphaned file inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
193 { E_OrphanDirInode
, "Orphaned directory inode (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
194 { E_OvlExtID
, "Overlapped extent allocation (id = %d)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
195 { E_UnusedNodeNotZeroed
, "Unused node is not erased (node = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
196 { E_VBMDamagedOverAlloc
, "Volume bitmap needs minor repair for orphaned blocks", fsckMsgError
, fsckLevel1
, 0, },
199 { E_BadHardLinkDate
, "Bad hard link creation date", fsckMsgError
, fsckLevel1
, 0, },
200 { E_DirtyJournal
, "Journal need to be replayed but volume is read-only", fsckMsgError
, fsckLevel1
, 0, },
201 { E_LinkChainNonLink
, "File record has hard link chain flag (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
202 { E_LinkHasData
, "Hard link record has data extents (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
203 { E_FileLinkCountError
, "File has incorrect number of links (id = %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
204 { E_BTreeSplitNode
, "B-tree node is split across extents (file id %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
205 { E_BadSymLink
, "Bad information for symbolic link (file id %u)", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypeInt
, } },
206 { E_BadSymLinkLength
, "Symbolic link (file id %u) has bad length (is %u, should be %u)",
207 fsckMsgError
, fsckLevel1
, 3, (const int[]){ fsckTypeInt
, fsckTypeInt
, fsckTypeInt
} },
208 { E_BadSymLinkName
, "Bad symbolic link is `%s'", fsckMsgError
, fsckLevel1
, 1, (const int[]){ fsckTypePath
, } },
210 /* And all-zeroes to indicate the end */