diff options
author | victor <victor@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2004-11-20 22:24:23 +0800 |
---|---|---|
committer | victor <victor@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2004-11-20 22:24:23 +0800 |
commit | 6b285d3fd87cdb14d12d4d835bacd86283aa0b9e (patch) | |
tree | ea91b09c7ad99e4d1555b5e93537658dac3bd3ee | |
parent | c28b22f9df8800338a59bc7c793255d4cccf4506 (diff) | |
download | pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.tar pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.tar.gz pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.tar.bz2 pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.tar.lz pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.tar.xz pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.tar.zst pttbbs-6b285d3fd87cdb14d12d4d835bacd86283aa0b9e.zip |
add "cdoc" (just like javadoc) to grab prototype and comments of functions
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@2344 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
-rw-r--r-- | docs/proto/Makefile | 18 | ||||
-rwxr-xr-x | docs/proto/cdoc | 75 | ||||
-rw-r--r-- | mbbsd/read.c | 22 |
3 files changed, 114 insertions, 1 deletions
diff --git a/docs/proto/Makefile b/docs/proto/Makefile new file mode 100644 index 00000000..63086b38 --- /dev/null +++ b/docs/proto/Makefile @@ -0,0 +1,18 @@ + +#.SUFFIXES: .c .txt + +# XXX 這有沒有比較好的作法? +# 直接用 .c.txt 好像會先去看目前目錄有沒有 xxx.c @_@ + +NAME!= cd ../../mbbsd/ && ls *.c | sed -e "s/\.c//" +SRC!= cd ../../mbbsd/ && ls *.c | sed -e "s/\.c/.txt/" + +all: $(SRC) + +.for fn in $(NAME) +$(fn).txt: ../../mbbsd/$(fn).c + ./cdoc ../../mbbsd/$(fn).c > $(fn).txt +.endfor + +clean: + rm -f *.txt diff --git a/docs/proto/cdoc b/docs/proto/cdoc new file mode 100755 index 00000000..e9403589 --- /dev/null +++ b/docs/proto/cdoc @@ -0,0 +1,75 @@ +#!/usr/bin/perl + +# follow javadoc +# @see http://java.sun.com/j2se/javadoc/writingdoccomments/ + +use strict; + +=cut + +oӵ{iHq C {XACXҦ statis/non-static functionsC +C function eiH javadoc-style ѡCdҦpUG + +/** + * Function of the function func. + * @param x variable, if there are more than one @-style description, it + * will end with the next @-style description. + * @return void + */ +void func(int x) +{ + ... +} +=cut + +my $content; + +foreach my $f (@ARGV) { + makedoc($f); +} + + +sub grep_desc +{ + my $name = '\w+'; + my $type = '\w+\s*\*?'; + my $sentence = '.*'; + + my $one_desc = "$name\\s+$sentence"; + my $desc_head = "\\/\\*\\*\n"; + my $desc_tail = "\\s*\\*\\/\n"; + my $desc_line = "\\s*\\*.*\n"; + my $paramdesc = "\@param\\s+$one_desc(?:\n$desc_line)*"; + my $returndesc = "\@return\\s+$sentence(?:\n$desc_line)*"; + my $seedesc = "\@see\\s+$sentence(?:\n$desc_line)*"; + my $desc = "$desc_head(?:$desc_line)*$desc_tail"; + + my $modifier = '(?:static|inline)\\s+'; + my $one_param = "$type\\s*$name"; + my $more_param = ",\\s*$one_param"; + my $param = "(?:$one_param(?:$more_param)*)?"; + my $func_proto = "(?:$modifier)?$type\\s+$name\\($param\\)"; + + $content =~ s/($desc_head(?:$desc_line)*$desc_tail)?($func_proto)\s*{//mo + or return undef; + my $comment = $1; + my $function = $2; + $function =~ s/\n/ /g; + $function =~ s/\s+/ /g; + + # check comment style here + + return "$function;\n".($comment ? $comment : "/* no comment */\n"); +} + +sub makedoc +{ + $_ = shift @_; + open SRC, "<$_"; + $content = join "",<SRC>; + close SRC; + print "/* vim:ft=c */\n\n"; + while ($_ = grep_desc()) { + print "$_\n"; + } +} diff --git a/mbbsd/read.c b/mbbsd/read.c index 3e665913..1927d929 100644 --- a/mbbsd/read.c +++ b/mbbsd/read.c @@ -9,6 +9,11 @@ static int last_line; // PTT: last_line Хi̫@ /* ----------------------------------------------------- */ /* Tag List */ /* ----------------------------------------------------- */ + +/** + * @param locus + * @return void + */ void UnTagger(int locus) { @@ -262,7 +267,22 @@ cursor_pos(keeploc_t * locmem, int val, int from_top, int isshow) return isshow ? PARTUPDATE : HEADERS_RELOAD; } -/* ھ stypen ܤW/U@g峹 */ +/** + * ھ stypen ܤW/U@g峹 + * + * @param locmem ΨӦsbYݪOЦm structureC + * @param stypen вʪk + * CURSOR_FIRST, CURSOR_NEXT, CURSOR_PREV: + * PХثem峹PD Ĥ@g/U@g/e@g 峹C + * RELATE_FIRST, RELATE_NEXT, RELATE_PREV: + * Pثe\Ū峹PD Ĥ@g/U@g/e@g 峹C + * NEWPOST_NEXT, NEWPOST_PREV: + * U@/e@ thread Ĥ@gC + * AUTHOR_NEXT, AUTHOR_PREV: + * XXX o\ثenSΨ? + * + * @return sЦm + */ static int thread(keeploc_t * locmem, int stypen) { |