2017-07-28 15:04:54 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2017 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#include "SkOSFile.h"
|
|
|
|
#include "SkOSPath.h"
|
|
|
|
|
2018-11-01 13:29:36 +00:00
|
|
|
#include "parserCommon.h"
|
|
|
|
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
void ParserCommon::checkLineLength(size_t len, const char* str) {
|
|
|
|
if (!fWritingIncludes) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
int column = fColumn;
|
|
|
|
const char* lineStart = str;
|
|
|
|
for (size_t index = 0; index < len; ++index) {
|
|
|
|
if ('\n' == str[index]) {
|
|
|
|
if (column > 100) {
|
|
|
|
SkDebugf("> 100 columns in %s line %d\n", fFileName.c_str(), fLinesWritten);
|
|
|
|
SkDebugf("%.*s\n", &str[index + 1] - lineStart, lineStart);
|
|
|
|
SkDebugf(""); // convenient place to set breakpoints
|
|
|
|
}
|
|
|
|
fLinesWritten++;
|
|
|
|
column = 0;
|
|
|
|
lineStart = &str[index + 1];
|
|
|
|
} else {
|
|
|
|
column++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-31 16:14:03 +00:00
|
|
|
// change Xxx_Xxx to xxx xxx
|
|
|
|
string ParserCommon::ConvertRef(const string str, bool first) {
|
|
|
|
string substitute;
|
|
|
|
for (char c : str) {
|
|
|
|
if ('_' == c) {
|
|
|
|
c = ' ';
|
|
|
|
} else if (isupper(c) && !first) {
|
|
|
|
c = tolower(c);
|
|
|
|
}
|
|
|
|
substitute += c;
|
|
|
|
first = false;
|
|
|
|
}
|
|
|
|
return substitute;
|
|
|
|
}
|
|
|
|
|
2018-08-28 18:53:37 +00:00
|
|
|
void ParserCommon::CopyToFile(string oldFile, string newFile) {
|
|
|
|
int bufferSize;
|
|
|
|
char* buffer = ParserCommon::ReadToBuffer(newFile, &bufferSize);
|
|
|
|
FILE* oldOut = fopen(oldFile.c_str(), "wb");
|
|
|
|
if (!oldOut) {
|
|
|
|
SkDebugf("could not open file %s\n", oldFile.c_str());
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
fwrite(buffer, 1, bufferSize, oldOut);
|
|
|
|
fclose(oldOut);
|
|
|
|
remove(newFile.c_str());
|
|
|
|
}
|
|
|
|
|
2018-10-31 16:14:03 +00:00
|
|
|
string ParserCommon::HtmlFileName(string bmhFileName) {
|
|
|
|
SkASSERT("docs" == bmhFileName.substr(0, 4));
|
|
|
|
SkASSERT('\\' == bmhFileName[4] || '/' == bmhFileName[4]);
|
|
|
|
SkASSERT(".bmh" == bmhFileName.substr(bmhFileName.length() - 4));
|
|
|
|
string result = bmhFileName.substr(5, bmhFileName.length() - 4 - 5);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-04-03 12:43:27 +00:00
|
|
|
bool ParserCommon::parseFile(const char* fileOrPath, const char* suffix, OneFile oneFile) {
|
2018-10-31 16:14:03 +00:00
|
|
|
fRawFilePathDir = string(fileOrPath);
|
2017-11-27 15:44:06 +00:00
|
|
|
if (!sk_isdir(fileOrPath)) {
|
|
|
|
if (!this->parseFromFile(fileOrPath)) {
|
|
|
|
SkDebugf("failed to parse %s\n", fileOrPath);
|
|
|
|
return false;
|
|
|
|
}
|
2018-04-03 12:43:27 +00:00
|
|
|
} else if (OneFile::kNo == oneFile) {
|
2017-11-27 15:44:06 +00:00
|
|
|
SkOSFile::Iter it(fileOrPath, suffix);
|
|
|
|
for (SkString file; it.next(&file); ) {
|
2018-05-21 15:56:57 +00:00
|
|
|
// FIXME: skip difficult file for now
|
|
|
|
if (string::npos != string(file.c_str()).find("SkFontArguments")) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (string::npos != string(file.c_str()).find("SkFontStyle")) {
|
|
|
|
continue;
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
SkString p = SkOSPath::Join(fileOrPath, file.c_str());
|
|
|
|
const char* hunk = p.c_str();
|
|
|
|
if (!SkStrEndsWith(hunk, suffix)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!this->parseFromFile(hunk)) {
|
|
|
|
SkDebugf("failed to parse %s\n", hunk);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-12-11 21:03:17 +00:00
|
|
|
bool ParserCommon::parseStatus(const char* statusFile, const char* suffix, StatusFilter filter) {
|
2018-10-31 16:14:03 +00:00
|
|
|
fRawFilePathDir = string(statusFile);
|
2017-12-11 21:03:17 +00:00
|
|
|
StatusIter iter(statusFile, suffix, filter);
|
|
|
|
if (iter.empty()) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-10-08 18:57:48 +00:00
|
|
|
for (string file; iter.next(&file, nullptr); ) {
|
2017-12-11 21:03:17 +00:00
|
|
|
SkString p = SkOSPath::Join(iter.baseDir().c_str(), file.c_str());
|
|
|
|
const char* hunk = p.c_str();
|
|
|
|
if (!this->parseFromFile(hunk)) {
|
|
|
|
SkDebugf("failed to parse %s\n", hunk);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2017-07-28 15:04:54 +00:00
|
|
|
bool ParserCommon::parseSetup(const char* path) {
|
|
|
|
sk_sp<SkData> data = SkData::MakeFromFileName(path);
|
|
|
|
if (nullptr == data.get()) {
|
|
|
|
SkDebugf("%s missing\n", path);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
const char* rawText = (const char*) data->data();
|
|
|
|
bool hasCR = false;
|
|
|
|
size_t dataSize = data->size();
|
|
|
|
for (size_t index = 0; index < dataSize; ++index) {
|
|
|
|
if ('\r' == rawText[index]) {
|
|
|
|
hasCR = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
string name(path);
|
|
|
|
if (hasCR) {
|
|
|
|
vector<char> lfOnly;
|
|
|
|
for (size_t index = 0; index < dataSize; ++index) {
|
|
|
|
char ch = rawText[index];
|
|
|
|
if ('\r' == rawText[index]) {
|
|
|
|
ch = '\n';
|
|
|
|
if ('\n' == rawText[index + 1]) {
|
|
|
|
++index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
lfOnly.push_back(ch);
|
|
|
|
}
|
|
|
|
fLFOnly[name] = lfOnly;
|
|
|
|
dataSize = lfOnly.size();
|
|
|
|
rawText = &fLFOnly[name].front();
|
|
|
|
}
|
|
|
|
fRawData[name] = data;
|
|
|
|
fStart = rawText;
|
|
|
|
fLine = rawText;
|
|
|
|
fChar = rawText;
|
|
|
|
fEnd = rawText + dataSize;
|
|
|
|
fFileName = string(path);
|
|
|
|
fLineCount = 1;
|
|
|
|
return true;
|
|
|
|
}
|
2017-10-26 11:58:48 +00:00
|
|
|
|
2018-10-08 18:57:48 +00:00
|
|
|
void ParserCommon::stringAppend(string& result, char ch) const {
|
|
|
|
if (fDebugWriteCodeBlock) {
|
|
|
|
SkDebugf("%c", ch);
|
|
|
|
}
|
|
|
|
result += ch;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ParserCommon::stringAppend(string& result, string str) const {
|
|
|
|
string condense;
|
|
|
|
char last = result.size() ? result.back() : '\n';
|
|
|
|
for (auto c : str) {
|
|
|
|
if (' ' == c && ' ' == last) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
condense += c;
|
|
|
|
if ('\n' != last || ' ' != c) {
|
|
|
|
last = c;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (fDebugWriteCodeBlock) {
|
|
|
|
SkDebugf("%s", condense.c_str());
|
|
|
|
}
|
|
|
|
result += condense;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ParserCommon::stringAppend(string& result, const Definition* def) const {
|
|
|
|
this->stringAppend(result, string(def->fContentStart, def->length()));
|
|
|
|
}
|
|
|
|
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
bool ParserCommon::writeBlockIndent(int size, const char* data, bool ignoreIdent) {
|
2018-05-30 13:21:49 +00:00
|
|
|
bool wroteSomething = false;
|
2017-10-26 11:58:48 +00:00
|
|
|
while (size && ' ' >= data[size - 1]) {
|
|
|
|
--size;
|
|
|
|
}
|
|
|
|
bool newLine = false;
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
char firstCh = 0;
|
2017-10-26 11:58:48 +00:00
|
|
|
while (size) {
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
while (size && (' ' > data[0] || (' ' == data[0] && ignoreIdent))) {
|
2017-10-26 11:58:48 +00:00
|
|
|
++data;
|
|
|
|
--size;
|
|
|
|
}
|
|
|
|
if (!size) {
|
2018-05-30 13:21:49 +00:00
|
|
|
return wroteSomething;
|
2017-10-26 11:58:48 +00:00
|
|
|
}
|
2018-06-07 13:59:07 +00:00
|
|
|
if (fReturnOnWrite) {
|
|
|
|
return true;
|
|
|
|
}
|
2017-10-26 11:58:48 +00:00
|
|
|
if (newLine) {
|
|
|
|
this->lf(1);
|
|
|
|
}
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
int indent = fIndent;
|
|
|
|
if (!firstCh) {
|
|
|
|
firstCh = data[0];
|
|
|
|
} else if ('(' == firstCh) {
|
|
|
|
indent += 1;
|
|
|
|
}
|
2017-10-26 11:58:48 +00:00
|
|
|
TextParser parser(fFileName, data, data + size, fLineCount);
|
|
|
|
const char* lineEnd = parser.strnchr('\n', data + size);
|
|
|
|
int len = lineEnd ? (int) (lineEnd - data) : size;
|
|
|
|
this->writePending();
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
this->indentToColumn(indent);
|
2018-10-31 16:14:03 +00:00
|
|
|
FPRINTF("%.*s", len, data);
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
checkLineLength(len, data);
|
2017-10-26 11:58:48 +00:00
|
|
|
size -= len;
|
|
|
|
data += len;
|
|
|
|
newLine = true;
|
2018-05-30 13:21:49 +00:00
|
|
|
wroteSomething = true;
|
2017-10-26 11:58:48 +00:00
|
|
|
}
|
2018-05-30 13:21:49 +00:00
|
|
|
return wroteSomething;
|
2017-10-26 11:58:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool ParserCommon::writeBlockTrim(int size, const char* data) {
|
2018-06-07 13:59:07 +00:00
|
|
|
SkASSERT(size >= 0);
|
|
|
|
if (!fReturnOnWrite && fOutdentNext) {
|
2017-10-26 11:58:48 +00:00
|
|
|
fIndent -= 4;
|
|
|
|
fOutdentNext = false;
|
|
|
|
}
|
|
|
|
while (size && ' ' >= data[0]) {
|
|
|
|
++data;
|
|
|
|
--size;
|
|
|
|
}
|
|
|
|
while (size && ' ' >= data[size - 1]) {
|
|
|
|
--size;
|
|
|
|
}
|
|
|
|
if (size <= 0) {
|
2018-06-07 13:59:07 +00:00
|
|
|
if (!fReturnOnWrite) {
|
|
|
|
fLastChar = '\0';
|
|
|
|
}
|
2017-10-26 11:58:48 +00:00
|
|
|
return false;
|
|
|
|
}
|
2018-06-07 13:59:07 +00:00
|
|
|
if (fReturnOnWrite) {
|
|
|
|
return true;
|
|
|
|
}
|
2018-07-02 19:20:10 +00:00
|
|
|
SkASSERT(size < 20000);
|
2017-10-26 11:58:48 +00:00
|
|
|
if (size > 3 && !strncmp("#end", data, 4)) {
|
|
|
|
fMaxLF = 1;
|
|
|
|
}
|
|
|
|
if (this->leadingPunctuation(data, (size_t) size)) {
|
|
|
|
fPendingSpace = 0;
|
|
|
|
}
|
|
|
|
this->writePending();
|
2018-10-31 16:14:03 +00:00
|
|
|
FPRINTF("%.*s", size, data);
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
checkLineLength(size, data);
|
2018-05-16 11:07:07 +00:00
|
|
|
fWroteSomething = true;
|
2017-10-26 11:58:48 +00:00
|
|
|
int added = 0;
|
|
|
|
fLastChar = data[size - 1];
|
|
|
|
while (size > 0 && '\n' != data[--size]) {
|
|
|
|
++added;
|
|
|
|
}
|
|
|
|
fColumn = size ? added : fColumn + added;
|
|
|
|
fSpaces = 0;
|
|
|
|
fLinefeeds = 0;
|
|
|
|
fMaxLF = added > 2 && !strncmp("#if", &data[size + (size > 0)], 3) ? 1 : 2;
|
|
|
|
if (fOutdentNext) {
|
|
|
|
fIndent -= 4;
|
|
|
|
fOutdentNext = false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ParserCommon::writePending() {
|
2018-06-07 13:59:07 +00:00
|
|
|
SkASSERT(!fReturnOnWrite);
|
2017-10-26 11:58:48 +00:00
|
|
|
fPendingLF = SkTMin(fPendingLF, fMaxLF);
|
|
|
|
bool wroteLF = false;
|
|
|
|
while (fLinefeeds < fPendingLF) {
|
|
|
|
if (fDebugOut) {
|
|
|
|
SkDebugf("\n");
|
|
|
|
}
|
|
|
|
fprintf(fOut, "\n");
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
checkLineLength(1, "\n");
|
2017-10-26 11:58:48 +00:00
|
|
|
++fLinefeeds;
|
|
|
|
wroteLF = true;
|
|
|
|
}
|
|
|
|
fPendingLF = 0;
|
|
|
|
if (wroteLF) {
|
|
|
|
SkASSERT(0 == fColumn);
|
|
|
|
SkASSERT(fIndent >= fSpaces);
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
SkASSERT(fIndent - fSpaces < 80);
|
2017-10-26 11:58:48 +00:00
|
|
|
if (fDebugOut) {
|
|
|
|
SkDebugf("%*s", fIndent - fSpaces, "");
|
|
|
|
}
|
|
|
|
fprintf(fOut, "%*s", fIndent - fSpaces, "");
|
|
|
|
fColumn = fIndent;
|
|
|
|
fSpaces = fIndent;
|
|
|
|
}
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
SkASSERT(!fWritingIncludes || fColumn + fPendingSpace < 100);
|
2017-10-26 11:58:48 +00:00
|
|
|
for (int index = 0; index < fPendingSpace; ++index) {
|
|
|
|
if (fDebugOut) {
|
|
|
|
SkDebugf(" ");
|
|
|
|
}
|
|
|
|
fprintf(fOut, " ");
|
|
|
|
++fColumn;
|
|
|
|
}
|
|
|
|
fPendingSpace = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ParserCommon::writeString(const char* str) {
|
2018-06-07 13:59:07 +00:00
|
|
|
SkASSERT(!fReturnOnWrite);
|
2017-10-26 11:58:48 +00:00
|
|
|
const size_t len = strlen(str);
|
|
|
|
SkASSERT(len > 0);
|
|
|
|
SkASSERT(' ' < str[0]);
|
|
|
|
fLastChar = str[len - 1];
|
|
|
|
SkASSERT(' ' < fLastChar);
|
|
|
|
SkASSERT(!strchr(str, '\n'));
|
|
|
|
if (this->leadingPunctuation(str, strlen(str))) {
|
|
|
|
fPendingSpace = 0;
|
|
|
|
}
|
|
|
|
this->writePending();
|
2018-10-31 16:14:03 +00:00
|
|
|
FPRINTF("%s", str);
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
checkLineLength(strlen(str), str);
|
2017-10-26 11:58:48 +00:00
|
|
|
fColumn += len;
|
|
|
|
fSpaces = 0;
|
|
|
|
fLinefeeds = 0;
|
|
|
|
fMaxLF = 2;
|
2018-01-04 21:11:51 +00:00
|
|
|
}
|
|
|
|
|
2018-06-08 19:57:37 +00:00
|
|
|
char* ParserCommon::ReadToBuffer(string filename, int* size) {
|
2018-01-04 21:11:51 +00:00
|
|
|
FILE* file = fopen(filename.c_str(), "rb");
|
|
|
|
if (!file) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
fseek(file, 0L, SEEK_END);
|
|
|
|
*size = (int) ftell(file);
|
|
|
|
rewind(file);
|
|
|
|
char* buffer = new char[*size];
|
|
|
|
memset(buffer, ' ', *size);
|
|
|
|
SkAssertResult(*size == (int)fread(buffer, 1, *size, file));
|
|
|
|
fclose(file);
|
|
|
|
return buffer;
|
|
|
|
}
|
|
|
|
|
2018-06-08 19:57:37 +00:00
|
|
|
char* ParserCommon::FindDateTime(char* buffer, int size) {
|
|
|
|
int index = -1;
|
|
|
|
int lineCount = 8;
|
|
|
|
while (++index < size && ('\n' != buffer[index] || --lineCount))
|
|
|
|
;
|
|
|
|
if (lineCount) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
if (strncmp("\n on 20", &buffer[index], 9)) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return &buffer[index];
|
|
|
|
}
|
|
|
|
|
2018-08-28 18:53:37 +00:00
|
|
|
bool ParserCommon::WrittenFileDiffers(string filename, string readname) {
|
2018-01-04 21:11:51 +00:00
|
|
|
int writtenSize, readSize;
|
2018-08-28 18:53:37 +00:00
|
|
|
char* written = ParserCommon::ReadToBuffer(filename, &writtenSize);
|
2018-01-04 21:11:51 +00:00
|
|
|
if (!written) {
|
|
|
|
return true;
|
|
|
|
}
|
2018-08-28 18:53:37 +00:00
|
|
|
char* read = ParserCommon::ReadToBuffer(readname, &readSize);
|
2018-01-04 21:11:51 +00:00
|
|
|
if (!read) {
|
|
|
|
delete[] written;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
#if 0 // enable for debugging this
|
|
|
|
int smaller = SkTMin(writtenSize, readSize);
|
|
|
|
for (int index = 0; index < smaller; ++index) {
|
|
|
|
if (written[index] != read[index]) {
|
|
|
|
SkDebugf("%.*s\n", 40, &written[index]);
|
|
|
|
SkDebugf("%.*s\n", 40, &read[index]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
if (readSize != writtenSize) {
|
|
|
|
return true;
|
|
|
|
}
|
2018-06-08 19:57:37 +00:00
|
|
|
// force the date/time to be the same, if present in both
|
|
|
|
const char* newDateTime = FindDateTime(written, writtenSize);
|
|
|
|
char* oldDateTime = FindDateTime(read, readSize);
|
|
|
|
if (newDateTime && oldDateTime) {
|
|
|
|
memcpy(oldDateTime, newDateTime, 26);
|
|
|
|
}
|
2018-01-04 21:11:51 +00:00
|
|
|
bool result = !!memcmp(written, read, writtenSize);
|
|
|
|
delete[] written;
|
|
|
|
delete[] read;
|
|
|
|
return result;
|
2017-10-26 11:58:48 +00:00
|
|
|
}
|
2017-12-11 21:03:17 +00:00
|
|
|
|
|
|
|
StatusIter::StatusIter(const char* statusFile, const char* suffix, StatusFilter filter)
|
|
|
|
: fSuffix(suffix)
|
|
|
|
, fFilter(filter) {
|
|
|
|
if (!this->parseFromFile(statusFile)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static const char* block_names[] = {
|
|
|
|
"Completed",
|
|
|
|
"InProgress",
|
|
|
|
};
|
|
|
|
|
|
|
|
string StatusIter::baseDir() {
|
2019-02-06 14:41:58 +00:00
|
|
|
SkASSERT(fStack.back().fArray);
|
2017-12-11 21:03:17 +00:00
|
|
|
SkASSERT(fStack.size() > 2);
|
|
|
|
string dir;
|
|
|
|
for (unsigned index = 2; index < fStack.size(); ++index) {
|
|
|
|
dir += fStack[index].fName;
|
|
|
|
if (index < fStack.size() - 1) {
|
|
|
|
dir += SkOSPath::SEPARATOR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return dir;
|
|
|
|
}
|
|
|
|
|
|
|
|
// FIXME: need to compare fBlockName against fFilter
|
|
|
|
// need to compare fSuffix against next value returned
|
2018-10-08 18:57:48 +00:00
|
|
|
bool StatusIter::next(string* strPtr, StatusFilter *filter) {
|
|
|
|
string str;
|
2017-12-11 21:03:17 +00:00
|
|
|
JsonStatus* status;
|
2018-10-08 18:57:48 +00:00
|
|
|
StatusFilter blockType = StatusFilter::kCompleted;
|
2017-12-11 21:03:17 +00:00
|
|
|
do {
|
|
|
|
do {
|
|
|
|
if (fStack.empty()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
status = &fStack.back();
|
2019-02-06 14:41:58 +00:00
|
|
|
if (!status->atEnd()) {
|
2017-12-11 21:03:17 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
fStack.pop_back();
|
|
|
|
} while (true);
|
|
|
|
if (1 == fStack.size()) {
|
|
|
|
do {
|
2018-10-08 18:57:48 +00:00
|
|
|
blockType = StatusFilter::kUnknown;
|
2019-02-06 14:41:58 +00:00
|
|
|
SkASSERT(status->fObject);
|
2017-12-11 21:03:17 +00:00
|
|
|
for (unsigned index = 0; index < SK_ARRAY_COUNT(block_names); ++index) {
|
2019-02-06 14:41:58 +00:00
|
|
|
if (!strcmp(status->fObjectIter->fKey.begin(), block_names[index])) {
|
2017-12-11 21:03:17 +00:00
|
|
|
blockType = (StatusFilter) index;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (blockType <= fFilter) {
|
|
|
|
break;
|
|
|
|
}
|
2019-02-06 14:41:58 +00:00
|
|
|
status->advance();
|
|
|
|
} while (!status->atEnd());
|
|
|
|
if (status->atEnd()) {
|
2017-12-11 21:03:17 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
2019-02-06 14:41:58 +00:00
|
|
|
if (!status->fArray) {
|
|
|
|
SkASSERT(status->fObjectIter != status->fObject->end());
|
|
|
|
JsonStatus block = JsonStatus::Make(status->current(),
|
|
|
|
status->fObjectIter->fKey.begin(),
|
|
|
|
blockType);
|
2017-12-11 21:03:17 +00:00
|
|
|
fStack.emplace_back(block);
|
|
|
|
status = &(&fStack.back())[-1];
|
2019-02-06 14:41:58 +00:00
|
|
|
status->advance();
|
2017-12-11 21:03:17 +00:00
|
|
|
status = &fStack.back();
|
|
|
|
continue;
|
|
|
|
}
|
2019-02-06 14:41:58 +00:00
|
|
|
if (const skjson::StringValue* sv = status->current()) {
|
|
|
|
str = sv->begin();
|
|
|
|
} else {
|
|
|
|
str = status->current().toString().c_str();
|
|
|
|
}
|
2018-10-08 18:57:48 +00:00
|
|
|
if (strPtr) {
|
|
|
|
*strPtr = str;
|
|
|
|
}
|
|
|
|
if (filter) {
|
|
|
|
*filter = status->fStatusFilter;
|
|
|
|
}
|
2019-02-06 14:41:58 +00:00
|
|
|
status->advance();
|
2018-10-08 18:57:48 +00:00
|
|
|
if (str.length() - strlen(fSuffix) == str.find(fSuffix)) {
|
2017-12-11 21:03:17 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
} while (true);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-07-18 19:10:08 +00:00
|
|
|
bool JsonCommon::parseFromFile(const char* path) {
|
2017-12-11 21:03:17 +00:00
|
|
|
sk_sp<SkData> json(SkData::MakeFromFileName(path));
|
|
|
|
if (!json) {
|
|
|
|
SkDebugf("file %s:\n", path);
|
|
|
|
return this->reportError<bool>("file not readable");
|
|
|
|
}
|
2019-02-06 14:41:58 +00:00
|
|
|
fDom.reset(new skjson::DOM((const char*)json->data(), json->size()));
|
|
|
|
if (!fDom->root().is<skjson::ObjectValue>()) {
|
2017-12-11 21:03:17 +00:00
|
|
|
SkDebugf("file %s:\n", path);
|
|
|
|
return this->reportError<bool>("file not parsable");
|
|
|
|
}
|
2019-02-06 14:41:58 +00:00
|
|
|
JsonStatus block = JsonStatus::Make(fDom->root(), "", StatusFilter::kUnknown);
|
2017-12-11 21:03:17 +00:00
|
|
|
fStack.emplace_back(block);
|
|
|
|
return true;
|
|
|
|
}
|