pintos: Avoid literal control character in Perl variable name.
[pintos-anon] / src / Makefile
index 72b234a1312739b7d8dafaf735409f6fde5e3012..229f85d1dcc3deb707c897033bc0327f10eddc4d 100644 (file)
@@ -1,10 +1,29 @@
+BUILD_SUBDIRS = threads userprog vm filesys
+
 all::
-       @echo "Run 'make' in the threads, userprog, filesys, or vm directory."
+       @echo "Run 'make' in subdirectories: $(BUILD_SUBDIRS)."
        @echo "This top-level make has only 'clean' targets."
 
+CLEAN_SUBDIRS = $(BUILD_SUBDIRS) examples utils
+
 clean::
-       for d in threads; do $(MAKE) -C $$d $@; done
+       for d in $(CLEAN_SUBDIRS); do $(MAKE) -C $$d $@; done
+       rm -f TAGS tags
 
-distclean::
-       $(MAKE) clean
+distclean:: clean
        find . -name '*~' -exec rm '{}' \;
+
+TAGS_SUBDIRS = $(BUILD_SUBDIRS) devices lib
+TAGS_SOURCES = find $(TAGS_SUBDIRS) -name \*.[chS] -print
+
+TAGS::
+       etags --members `$(TAGS_SOURCES)`
+
+tags::
+       ctags -T --no-warn `$(TAGS_SOURCES)`
+
+cscope.files::
+       $(TAGS_SOURCES) > cscope.files
+
+cscope:: cscope.files
+       cscope -b -q -k