| | @@ -49,11 +49,16 @@ |
| 49 | 49 | ** * The UUID |
| 50 | 50 | ** * The record ID |
| 51 | 51 | ** * mtime and ctime |
| 52 | 52 | ** * who signed it |
| 53 | 53 | */ |
| 54 | | -void show_common_info(int rid, const char *zUuidName, int showComment){ |
| 54 | +void show_common_info( |
| 55 | + int rid, /* The rid for the check-in to display info for */ |
| 56 | + const char *zUuidName, /* Name of the UUID */ |
| 57 | + int showComment, /* True to show the check-in comment */ |
| 58 | + int showFamily /* True to show parents and children */ |
| 59 | +){ |
| 55 | 60 | Stmt q; |
| 56 | 61 | char *zComment = 0; |
| 57 | 62 | char *zTags; |
| 58 | 63 | char *zDate; |
| 59 | 64 | char *zUuid; |
| | @@ -68,38 +73,42 @@ |
| 68 | 73 | free(zUuid); |
| 69 | 74 | free(zDate); |
| 70 | 75 | } |
| 71 | 76 | if( zUuid && showComment ){ |
| 72 | 77 | zComment = db_text(0, |
| 73 | | - "SELECT coalesce(ecomment,comment) || ' (user: ' || coalesce(euser,user,'?') || ')' FROM event WHERE objid=%d", |
| 78 | + "SELECT coalesce(ecomment,comment) || " |
| 79 | + " ' (user: ' || coalesce(euser,user,'?') || ')' " |
| 80 | + " FROM event WHERE objid=%d", |
| 74 | 81 | rid |
| 75 | 82 | ); |
| 76 | 83 | } |
| 77 | | - db_prepare(&q, "SELECT uuid, pid FROM plink JOIN blob ON pid=rid " |
| 78 | | - " WHERE cid=%d", rid); |
| 79 | | - while( db_step(&q)==SQLITE_ROW ){ |
| 80 | | - const char *zUuid = db_column_text(&q, 0); |
| 81 | | - zDate = db_text("", |
| 82 | | - "SELECT datetime(mtime) || ' UTC' FROM event WHERE objid=%d", |
| 83 | | - db_column_int(&q, 1) |
| 84 | | - ); |
| 85 | | - printf("parent: %s %s\n", zUuid, zDate); |
| 86 | | - free(zDate); |
| 87 | | - } |
| 88 | | - db_finalize(&q); |
| 89 | | - db_prepare(&q, "SELECT uuid, cid FROM plink JOIN blob ON cid=rid " |
| 90 | | - " WHERE pid=%d", rid); |
| 91 | | - while( db_step(&q)==SQLITE_ROW ){ |
| 92 | | - const char *zUuid = db_column_text(&q, 0); |
| 93 | | - zDate = db_text("", |
| 94 | | - "SELECT datetime(mtime) || ' UTC' FROM event WHERE objid=%d", |
| 95 | | - db_column_int(&q, 1) |
| 96 | | - ); |
| 97 | | - printf("child: %s %s\n", zUuid, zDate); |
| 98 | | - free(zDate); |
| 99 | | - } |
| 100 | | - db_finalize(&q); |
| 84 | + if( showFamily ){ |
| 85 | + db_prepare(&q, "SELECT uuid, pid FROM plink JOIN blob ON pid=rid " |
| 86 | + " WHERE cid=%d", rid); |
| 87 | + while( db_step(&q)==SQLITE_ROW ){ |
| 88 | + const char *zUuid = db_column_text(&q, 0); |
| 89 | + zDate = db_text("", |
| 90 | + "SELECT datetime(mtime) || ' UTC' FROM event WHERE objid=%d", |
| 91 | + db_column_int(&q, 1) |
| 92 | + ); |
| 93 | + printf("parent: %s %s\n", zUuid, zDate); |
| 94 | + free(zDate); |
| 95 | + } |
| 96 | + db_finalize(&q); |
| 97 | + db_prepare(&q, "SELECT uuid, cid FROM plink JOIN blob ON cid=rid " |
| 98 | + " WHERE pid=%d", rid); |
| 99 | + while( db_step(&q)==SQLITE_ROW ){ |
| 100 | + const char *zUuid = db_column_text(&q, 0); |
| 101 | + zDate = db_text("", |
| 102 | + "SELECT datetime(mtime) || ' UTC' FROM event WHERE objid=%d", |
| 103 | + db_column_int(&q, 1) |
| 104 | + ); |
| 105 | + printf("child: %s %s\n", zUuid, zDate); |
| 106 | + free(zDate); |
| 107 | + } |
| 108 | + db_finalize(&q); |
| 109 | + } |
| 101 | 110 | zTags = info_tags_of_checkin(rid, 0); |
| 102 | 111 | if( zTags && zTags[0] ){ |
| 103 | 112 | printf("tags: %s\n", zTags); |
| 104 | 113 | } |
| 105 | 114 | free(zTags); |
| | @@ -153,19 +162,19 @@ |
| 153 | 162 | printf("server-code: %s\n", db_get("server-code", "")); |
| 154 | 163 | vid = db_lget_int("checkout", 0); |
| 155 | 164 | if( vid==0 ){ |
| 156 | 165 | printf("checkout: nil\n"); |
| 157 | 166 | }else{ |
| 158 | | - show_common_info(vid, "checkout:", 1); |
| 167 | + show_common_info(vid, "checkout:", 1, 1); |
| 159 | 168 | } |
| 160 | 169 | }else{ |
| 161 | 170 | int rid; |
| 162 | 171 | rid = name_to_rid(g.argv[2]); |
| 163 | 172 | if( rid==0 ){ |
| 164 | 173 | fossil_panic("no such object: %s\n", g.argv[2]); |
| 165 | 174 | } |
| 166 | | - show_common_info(rid, "uuid:", 1); |
| 175 | + show_common_info(rid, "uuid:", 1, 1); |
| 167 | 176 | } |
| 168 | 177 | } |
| 169 | 178 | |
| 170 | 179 | /* |
| 171 | 180 | ** Show information about all tags on a given node. |
| 172 | 181 | |