mirror of
https://git.openafs.org/openafs.git
synced 2025-01-18 15:00:12 +00:00
13ef511544
The default Xcode compiler options are insufficient to fail the build if a method is not found. For example, a typo in the name of method 'componentsJoinedByString' results in the following build warning: /TaskUtil.m:70:62: warning: instance method '-componentsJoinedBySting:' not found (return type defaults to 'id') [-Wobjc-method-access] NSLog(@"Task failed: %@ %@ status:%d.", taskName, [args componentsJoinedBySting:@", "], status); Because this is only flagged as a warning, the build completes successfully. When this code runs, the AFSBackgrounder merely logs a runtime exception every time it passes through the erroneous code. This is a silent failure, unless you happen to know how to check for AFSBackgrounder log messages: $ log show --predicate 'process=="AFSBackgrounder"' Add compiler flag '-Werror=objc-method-access' to all of our xcode-built project files to treat this case as an error instead of a warning, so the build will fail. [adeason@sinenomine.net: Update all xcode project files.] Change-Id: I69a9f45deb6710a50590bd79daf07466332a6ad1 Reviewed-on: https://gerrit.openafs.org/14586 Tested-by: BuildBot <buildbot@rampaginggeek.com> Reviewed-by: Mark Vitale <mvitale@sinenomine.net> Reviewed-by: Cheyenne Wills <cwills@sinenomine.net> Reviewed-by: Andrew Deason <adeason@sinenomine.net> |
||
---|---|---|
build-tools | ||
doc | ||
src | ||
tests | ||
.gitignore | ||
.gitreview | ||
.mailmap | ||
.splintrc | ||
acinclude.m4 | ||
CODING | ||
configure-libafs.ac | ||
configure.ac | ||
CONTRIBUTING | ||
INSTALL | ||
libafsdep | ||
LICENSE | ||
Makefile-libafs.in | ||
Makefile.in | ||
NEWS | ||
NTMakefile | ||
README | ||
README-WINDOWS | ||
regen.sh |
AFS is a distributed file system that enables users to share and access all of the files stored in a network of computers as easily as they access the files stored on their local machines. The file system is called distributed for this exact reason: files can reside on many different machines, but are available to users on every machine. OpenAFS 1.0 was originally released by IBM under the terms of the IBM Public License 1.0 (IPL10). For details on IPL10 see the LICENSE file in this directory. The current OpenAFS distribution is licensed under a combination of the IPL10 and many other licenses as granted by the relevant copyright holders. The LICENSE file in this directory contains more details, thought it is not a comprehensive statement. See INSTALL for information about building and installing OpenAFS on various platforms. See CODING for developer information and guidelines. See NEWS for recent changes to OpenAFS.