1 /*
2  * Copyright (C) 2018 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #include "DocComment.h"
18 
19 #include <hidl-util/StringHelper.h>
20 
21 #include <cctype>
22 #include <sstream>
23 
24 namespace android {
25 
26 DocComment::DocComment(const std::string& comment) {
27     std::vector<std::string> lines;
28     StringHelper::SplitString(comment, '\n', &lines);
29 
30     bool foundFirstLine = false;
31 
32     std::ostringstream is;
33     for (size_t l = 0; l < lines.size(); l++) {
34         const std::string& line = lines[l];
35 
36         // Delete prefixes like "    * ", "   *", or "    ".
37         size_t idx = 0;
38         for (; idx < line.size() && isspace(line[idx]); idx++)
39             ;
40         if (idx < line.size() && line[idx] == '*') idx++;
41         if (idx < line.size() && line[idx] == ' ') idx++;
42 
43         if (idx < line.size()) {
44             foundFirstLine = true;
45         }
46 
47         if (!foundFirstLine) continue;
48 
49         is << line.substr(idx);
50 
51         if (l + 1 < lines.size()) {
52             is << "\n";
53         }
54     }
55 
56     mComment = is.str();
57 }
58 
59 void DocComment::merge(const DocComment* comment) {
60     mComment = mComment + "\n\n" + comment->mComment;
61 }
62 
63 void DocComment::emit(Formatter& out) const {
64     out << "/**\n";
65     out.setLinePrefix(" * ");
66     out << mComment;
67     out.unsetLinePrefix();
68     out << " */\n";
69 }
70 
71 }  // namespace android
72