正则表达式删除评论

时间:2013-02-20 08:57:38

标签: regex

我正在尝试编写一个正则表达式,用于查找文本中的所有注释。 例如,/* */之间的所有内容。 例如:

  

/ * Hello * /

当我这样做时:/\*.*\*/,它表现得很奇怪而且没有显示任何内容。这有什么问题?

编辑:评论可以分散在多行

7 个答案:

答案 0 :(得分:15)

与上面发布的示例不同,您尝试匹配跨越多行的注释。默认情况下,.与换行符不匹配。因此,您必须在正则表达式中启用多行模式以匹配多行注释。

此外,您可能需要使用.*?代替.*。否则,它将使最大匹配成为可能,这将是第一个公开评论和最后一个评论之间的所有内容。

我不知道如何在Sublime Text 2中启用多行匹配模式。我不确定它是否可用作模式。但是,您可以使用CTRL + Enter在实际模式中插入换行符。所以,我会建议这个替代方案:

/\*(.|\n)*?\*/

如果Sublime Text 2无法识别\n,您也可以使用CTRL + Enter在模式中插入换行符,代替\n

答案 1 :(得分:5)

几年前我遇到过这个问题wrote an entire article about it

如果您无法访问非贪婪匹配(并非所有正则表达式库都支持非贪婪),那么您应该使用此正则表达式:

/\*([^*]|[\r\n]|(\*+([^*/]|[\r\n])))*\*+/

如果您有权访问非贪婪匹配,则可以使用:

/\*(.|[\r\n])*?\*/

另外,请记住,正则表达式只是这个问题的启发式方法。正则表达式不支持某些内容似乎是对正则表达式的注释,但实际上并非如此:

someString = "An example comment: /* example */";

// The comment around this code has been commented out.
// /*
some_code();
// */

答案 2 :(得分:2)

只想添加HTML评论就是这个

from sympy import sieve
from sympy.utilities.iterables import multiset_combinations
from numpy import prod

def max_palindrome(prime_numbers):
    prime_numbers_list_unique_combinations = multiset_combinations(prime_numbers, 2)
    list_palindromes = ((prod(i), i) for i in prime_numbers_list_unique_combinations if \
                        str(prod(i)) == str(prod(i))[::-1])
    result = max(list_palindromes)
    return "The max palindrome is {0} which is producted of {1} and {2} numbers".format(result[0],\
                                                                                        result[1][0], result[1][1])

from timeit import default_timer
start = default_timer()

print max_palindrome((i for i in sieve.primerange(9999, 99999)))
# My wrong result: The max palindrome is 1997667991 which is producted of 69143 and 91009 numbers

end = default_timer()
print "The time of max_palindrome program's execution is {} sec".format(end - start)
# The time of max_palindrome program's execution is 876.579393732 sec

答案 3 :(得分:0)

正确答案 - 这是不可能的。您不能编写能够正确查找所有注释的正则表达式,甚至是一种注释类型 - 单行或多行。

正则表达式只能提供部分匹配,可以覆盖所有情况的90%,但就是这样。

正则表达式的语法非常复杂,只有通过执行完整表达式评估才能在100%的情况下正确识别它们,而完整的表达式评估又基于对代码进行标记。后者是一项艰巨的任务,今天所有AST解析器都实现了这项任务。见AST Explorer

只有正确编写的AST解析器才能准确地告诉您代码中所有正则表达式的位置。你必须根据它编写一个解析器。

或者,您可以使用其中一个已完成所有这些操作的库,例如decomment

RegEx示例,其中任何正面方法将会绊倒,无法通过注释块告诉正则表达式:

  • /\/*/ - 它会认为此注册表是单行注释
  • {{1}} - 它会认为此注册表开启多行评论

答案 4 :(得分:0)

  

只是关于使用正则表达式删除编程语言文件中的注释的附加说明。

警告!

执行此操作时,您不能忘记在代码中的字符串中包含字符串/**/的情况 - 如var string = "/*"; - (我们永远不知道您是否解析了一个巨大的代码不是你的!)

所以最好用编程语言解析文档并使用布尔值来保存打开字符串的状态(并忽略打开字符串中的任何匹配)。

同样由"分隔的字符串可以包含\",所以要注意正则表达式!

答案 5 :(得分:0)

/\s*\n*/\*[.*\s\w,\n\-\'\(\)"=/%:]*\*/\n*|\s*[^:]//.*$/

答案 6 :(得分:0)

user1919238 写的答案有效。只是在这里证实了这一点,尽管许多赞成票可能确实给了你一个线索。 它摆脱了所有这些烦人的块评论,放在这里只是为了显示有用/感谢 user1919238 节省时间:

/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9zdHlsZXMvZ2xvYmFscy5jc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUUsVUFBVTtFQUNWLFNBQVM7RUFDVDt3RUFDc0U7QUFDeEU7O0FBRUE7RUFDRSxjQUFjO0VBQ2QscUJBQXFCO0FBQ3ZCOztBQUVBO0VBQ0Usc0JBQXNCO0FBQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaHRtbCxcbmJvZHkge1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG4gIGZvbnQtZmFtaWx5OiAtYXBwbGUtc3lzdGVtLCBCbGlua01hY1N5c3RlbUZvbnQsIFNlZ29lIFVJLCBSb2JvdG8sIE94eWdlbixcbiAgICBVYnVudHUsIENhbnRhcmVsbCwgRmlyYSBTYW5zLCBEcm9pZCBTYW5zLCBIZWx2ZXRpY2EgTmV1ZSwgc2Fucy1zZXJpZjtcbn1cblxuYSB7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG59XG5cbioge1xuICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xufVxuIl0sInNvdXJjZVJvb3QiOiIifQ== */

/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9zdHlsZXMvSG9tZS5tb2R1bGUuY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0UsaUJBQWlCO0VBQ2pCLGlCQUFpQjtFQUNqQixhQUFhO0VBQ2Isc0JBQXNCO0VBQ3RCLHVCQUF1QjtFQUN2QixtQkFBbUI7QUFDckI7O0FBRUE7RUFDRSxlQUFlO0VBQ2YsU0FBTztFQUNQLGFBQWE7RUFDYixzQkFBc0I7RUFDdEIsdUJBQXVCO0VBQ3ZCLG1CQUFtQjtBQUNyQjs7QUFFQTtFQUNFLFdBQVc7RUFDWCxhQUFhO0VBQ2IsNkJBQTZCO0VBQzdCLGFBQWE7RUFDYix1QkFBdUI7RUFDdkIsbUJBQW1CO0FBQ3JCOztBQUVBO0VBQ0UsbUJBQW1CO0FBQ3JCOztBQUVBO0VBQ0UsYUFBYTtFQUNiLHVCQUF1QjtFQUN2QixtQkFBbUI7QUFDckI7O0FBRUE7RUFDRSxjQUFjO0VBQ2QscUJBQXFCO0FBQ3ZCOztBQUVBOzs7RUFHRSwwQkFBMEI7QUFDNUI7O0FBRUE7RUFDRSxTQUFTO0VBQ1QsaUJBQWlCO0VBQ2pCLGVBQWU7QUFDakI7O0FBRUE7O0VBRUUsa0JBQWtCO0FBQ3BCO0FBQ0E7RUFDRSxnQkFBZ0I7RUFDaEIsaUJBQWlCO0FBQ25COztBQUVBO0VBQ0UsbUJBQW1CO0VBQ25CLGtCQUFrQjtFQUNsQixnQkFBZ0I7RUFDaEIsaUJBQWlCO0VBQ2pCO29EQUNrRDtBQUNwRDs7QUFFQTtFQUNFLGFBQWE7RUFDYixtQkFBbUI7RUFDbkIsdUJBQXVCO0VBQ3ZCLGVBQWU7RUFDZixnQkFBZ0I7RUFDaEIsZ0JBQWdCO0FBQ2xCOztBQUVBO0VBQ0UsWUFBWTtFQUNaLGVBQWU7RUFDZixlQUFlO0VBQ2YsZ0JBQWdCO0VBQ2hCLGNBQWM7RUFDZCxxQkFBcUI7RUFDckIseUJBQXlCO0VBQ3pCLG1CQUFtQjtFQUNuQixxREFBcUQ7QUFDdkQ7O0FBRUE7OztFQUdFLGNBQWM7RUFDZCxxQkFBcUI7QUFDdkI7O0FBRUE7RUFDRSxrQkFBa0I7RUFDbEIsaUJBQWlCO0FBQ25COztBQUVBO0VBQ0UsU0FBUztFQUNULGtCQUFrQjtFQUNsQixnQkFBZ0I7QUFDbEI7O0FBRUE7RUFDRSxXQUFXO0FBQ2I7O0FBRUE7RUFDRTtJQUNFLFdBQVc7SUFDWCxzQkFBc0I7RUFDeEI7QUFDRiIsInNvdXJjZXNDb250ZW50IjpbIi5jb250YWluZXIge1xuICBtaW4taGVpZ2h0OiAxMDB2aDtcbiAgcGFkZGluZzogMCAwLjVyZW07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xufVxuXG4ubWFpbiB7XG4gIHBhZGRpbmc6IDVyZW0gMDtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG59XG5cbi5mb290ZXIge1xuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICNlYWVhZWE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xufVxuXG4uZm9vdGVyIGltZyB7XG4gIG1hcmdpbi1sZWZ0OiAwLjVyZW07XG59XG5cbi5mb290ZXIgYSB7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xufVxuXG4udGl0bGUgYSB7XG4gIGNvbG9yOiAjMDA3MGYzO1xuICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG59XG5cbi50aXRsZSBhOmhvdmVyLFxuLnRpdGxlIGE6Zm9jdXMsXG4udGl0bGUgYTphY3RpdmUge1xuICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbn1cblxuLnRpdGxlIHtcbiAgbWFyZ2luOiAwO1xuICBsaW5lLWhlaWdodDogMS4xNTtcbiAgZm9udC1zaXplOiA0cmVtO1xufVxuXG4udGl0bGUsXG4uZGVzY3JpcHRpb24ge1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG59XG4uZGVzY3JpcHRpb24ge1xuICBsaW5lLWhlaWdodDogMS41O1xuICBmb250LXNpemU6IDEuNXJlbTtcbn1cblxuLmNvZGUge1xuICBiYWNrZ3JvdW5kOiAjZmFmYWZhO1xuICBib3JkZXItcmFkaXVzOiA1cHg7XG4gIHBhZGRpbmc6IDAuNzVyZW07XG4gIGZvbnQtc2l6ZTogMS4xcmVtO1xuICBmb250LWZhbWlseTogTWVubG8sIE1vbmFjbywgTHVjaWRhIENvbnNvbGUsIExpYmVyYXRpb24gTW9ubywgRGVqYVZ1IFNhbnMgTW9ubyxcbiAgICBCaXRzdHJlYW0gVmVyYSBTYW5zIE1vbm8sIENvdXJpZXIgTmV3LCBtb25vc3BhY2U7XG59XG5cbi5ncmlkIHtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgbWF4LXdpZHRoOiA4MDBweDtcbiAgbWFyZ2luLXRvcDogM3JlbTtcbn1cblxuLmNhcmQge1xuICBtYXJnaW46IDFyZW07XG4gIGZsZXgtYmFzaXM6IDQ1JTtcbiAgcGFkZGluZzogMS41cmVtO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBib3JkZXI6IDFweCBzb2xpZCAjZWFlYWVhO1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICB0cmFuc2l0aW9uOiBjb2xvciAwLjE1cyBlYXNlLCBib3JkZXItY29sb3IgMC4xNXMgZWFzZTtcbn1cblxuLmNhcmQ6aG92ZXIsXG4uY2FyZDpmb2N1cyxcbi5jYXJkOmFjdGl2ZSB7XG4gIGNvbG9yOiAjMDA3MGYzO1xuICBib3JkZXItY29sb3I6ICMwMDcwZjM7XG59XG5cbi5jYXJkIGgzIHtcbiAgbWFyZ2luOiAwIDAgMXJlbSAwO1xuICBmb250LXNpemU6IDEuNXJlbTtcbn1cblxuLmNhcmQgcCB7XG4gIG1hcmdpbjogMDtcbiAgZm9udC1zaXplOiAxLjI1cmVtO1xuICBsaW5lLWhlaWdodDogMS41O1xufVxuXG4ubG9nbyB7XG4gIGhlaWdodDogMWVtO1xufVxuXG5AbWVkaWEgKG1heC13aWR0aDogNjAwcHgpIHtcbiAgLmdyaWQge1xuICAgIHdpZHRoOiAxMDAlO1xuICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIH1cbn1cbiJdLCJzb3VyY2VSb290IjoiIn0= */

/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack://styles/custom.module.css"],"names":[],"mappings":"AAAA;EACE,UAAU;EACV,SAAS;EACT;wEACsE;EACtE,kBAAkB;EAClB,kBAAkB;AACpB;AACA;EACE,UAAU;EACV,SAAS;EACT,cAAc;EACd,eAAe;AACjB;AACA;EACE,UAAU;EACV,SAAS;EACT,eAAe;EACf,cAAc;AAChB;AACA;EACE,eAAe;EACf,YAAY;AACd;AACA;;;EAGE,eAAe;EACf,cAAc;AAChB;AACA;EACE,kBAAkB;EAClB,YAAY;AACd;AACA;;;EAGE,eAAe;EACf,cAAc;AAChB;AACA;EACE,gBAAgB;EAChB,mBAAmB;AACrB;AACA;EACE,eAAe;EACf,4CAA4C;AAC9C;AACA;EACE,eAAe;EACf,4CAA4C;AAC9C;AACA;EACE,kBAAkB;EAClB,oBAAoB;EACpB,cAAc;EACd,0BAA0B;AAC5B;AACA;EACE,kBAAkB;EAClB,eAAe;AACjB;;AAEA;EACE,YAAY;EACZ,eAAe;EACf,eAAe;EACf,gBAAgB;EAChB,cAAc;EACd,qBAAqB;EACrB,yBAAyB;EACzB,mBAAmB;EACnB,qDAAqD;AACvD;;AAEA;EACE,kBAAkB;EAClB,iBAAiB;AACnB;;AAEA;EACE,SAAS;EACT,kBAAkB;EAClB,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,eAAe;EACf,eAAe;EACf,gBAAgB;EAChB,cAAc;EACd,qBAAqB;EACrB,yBAAyB;EACzB,mBAAmB;EACnB,qDAAqD;AACvD;AACA;;;EAGE,cAAc;EACd,qBAAqB;AACvB;AACA;EACE,YAAY;EACZ,mBAAmB;AACrB;AACA;;;EAGE,cAAc;EACd,qBAAqB;EACrB,eAAe;AACjB;AACA;EACE,aAAa;EACb,mBAAmB;EACnB,uBAAuB;EACvB,eAAe;EACf,gBAAgB;EAChB,gBAAgB;AAClB;AACA;EACE,mBAAmB;EACnB,mBAAmB;EACnB,uBAAuB;EACvB,iBAAiB;EACjB,gBAAgB;EAChB,gBAAgB;AAClB;AACA;EACE,iBAAiB;EACjB,mBAAmB;EACnB,uBAAuB;EACvB,iBAAiB;EACjB,gBAAgB;EAChB,gBAAgB;AAClB;AACA;EACE,mBAAmB;EACnB,mBAAmB;EACnB,uBAAuB;EACvB,iBAAiB;EACjB,gBAAgB;EAChB,gBAAgB;AAClB;AACA;EACE,iBAAiB;EACjB,iBAAiB;EACjB,aAAa;EACb,sBAAsB;EACtB,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,eAAe;EACf,SAAO;EACP,aAAa;EACb,sBAAsB;EACtB,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,WAAW;EACX,aAAa;EACb,6BAA6B;EAC7B,aAAa;EACb,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,mBAAmB;AACrB;;AAEA;EACE,aAAa;EACb,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,cAAc;EACd,qBAAqB;AACvB;;AAEA;;;EAGE,0BAA0B;AAC5B;;AAEA;EACE,SAAS;EACT,iBAAiB;EACjB,eAAe;AACjB;;AAEA;;EAEE,kBAAkB;AACpB;AACA;EACE,gBAAgB;EAChB,iBAAiB;AACnB;AACA;EACE,eAAe;EACf,gBAAgB;EAChB,iBAAiB;EACjB,kBAAkB;AACpB;AACA;EACE,mBAAmB;EACnB,kBAAkB;EAClB,gBAAgB;EAChB,iBAAiB;EACjB;oDACkD;AACpD;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,uBAAuB;EACvB,eAAe;EACf,gBAAgB;EAChB,gBAAgB;AAClB;AACA;EACE,YAAY;EACZ,eAAe;EACf,eAAe;EACf,gBAAgB;EAChB,cAAc;EACd,qBAAqB;EACrB,2BAAmB;UAAnB,mBAAmB;EACnB,4BAA4B;EAC5B,mBAAmB;EACnB,qDAAqD;AACvD;AACA;;;EAGE,YAAY;EACZ,mBAAmB;AACrB;AACA;EACE,kBAAkB;EAClB,iBAAiB;AACnB;;AAEA;EACE,SAAS;EACT,kBAAkB;EAClB,gBAAgB;AAClB;AACA;EACE,YAAY;EACZ,eAAe;EACf,eAAe;EACf,gBAAgB;EAChB,cAAc;EACd,qBAAqB;EACrB,2BAAmB;UAAnB,mBAAmB;EACnB,wBAAwB;EACxB,mBAAmB;EACnB,qDAAqD;AACvD;AACA;;;EAGE,aAAa;EACb,oBAAoB;AACtB;AACA;EACE,kBAAkB;EAClB,iBAAiB;AACnB;;AAEA;EACE,SAAS;EACT,kBAAkB;EAClB,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,eAAe;EACf,eAAe;EACf,gBAAgB;EAChB,cAAc;EACd,qBAAqB;EACrB,yBAAyB;EACzB,mBAAmB;EACnB,qDAAqD;AACvD;;AAEA;;;EAGE,cAAc;EACd,qBAAqB;AACvB;AACA;EACE,kBAAkB;EAClB,iBAAiB;AACnB;;AAEA;EACE,SAAS;EACT,kBAAkB;EAClB,gBAAgB;AAClB;;AAEA;EACE,WAAW;AACb;AACA;EACE,aAAa;AACf;AACA;EACE,aAAa;EACb,kBAAkB;EAClB,kBAAkB;AACpB;AACA;EACE,UAAU;AACZ;AACA;EACE,aAAa;AACf;AACA;EACE,WAAW;AACb;AACA;EACE,SAAS;AACX;AACA;EACE,iBAAiB;AACnB;AACA;EACE;AACF;AACA;EACE,kBAAkB;AACpB;AACA;EACE,aAAa;AACf;AACA;EACE,UAAU;AACZ;;;;;AAKA;EACE;IACE,WAAW;IACX,sBAAsB;EACxB;AACF","sourcesContent":[".linklink {\n  padding: 0;\n  margin: 0;\n  font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen,\n    Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;\n  font-style: italic;\n  font-size: inherit;\n}\n.linklink:hover {\n  padding: 1;\n  margin: 0;\n  color: #0070f3;\n  font-size: 110%;\n}\n.linklink:active {\n  padding: 1;\n  margin: 0;\n  font-size: 115%;\n  color: #ffac33;\n}\n.pagesymbol {\n  font-size: 3rem;\n  color: white;\n}\n.pagesymbol:hover,\n.pagesymbol:focus,\n.pagesymbol:active {\n  font-size: 6rem;\n  color: #0070f3;\n}\n.pagesymbol text {\n  font-size: 0.0005%;\n  color: white;\n}\n.pagesymbol text:hover,\n.pagesymbol text:focus,\n.pagesymbol text:active {\n  font-size: 2rem;\n  color: #ffac33;\n}\n.gigantic{\n  font-size: 200px;\n  text-align: inherit;\n}\n.workscited {\n  font-size: 12pt;\n  font-family: \"Times New Roman\", Times, serif;\n}\n.workscited pp {\n  font-size: 12pt;\n  font-family: \"Times New Roman\", Times, serif;\n}\n.href {\n  font-size: inherit;\n  font-weight: inherit;\n  color: #0070f3;\n  text-decoration: underline;\n}\n.scansion {\n  font-family: Menlo;\n  font-size: 11pt;\n}\n\n.checkboxcard {\n  margin: 1rem;\n  flex-basis: 45%;\n  padding: 1.5rem;\n  text-align: left;\n  color: inherit;\n  text-decoration: none;\n  border: 1px solid #eaeaea;\n  border-radius: 10px;\n  transition: color 0.15s ease, border-color 0.15s ease;\n}\n\n.checkboxcard h3 {\n  margin: 0 0 1rem 0;\n  font-size: 1.5rem;\n}\n\n.checboxcard p {\n  margin: 0;\n  font-size: 1.25rem;\n  line-height: 1.5;\n}\n\n.checkboxcard checkbox {\n  margin: 1rem;\n  flex-basis: 45%;\n  padding: 0.3rem;\n  text-align: left;\n  color: inherit;\n  text-decoration: none;\n  border: 1px solid #eaeaea;\n  border-radius: 10px;\n  transition: color 0.15s ease, border-color 0.15s ease;\n}\n.checkboxcard checkbox:hover,\n.checkboxcard checkbox:focus,\n.checkboxcard checkbox:active {\n  color: #0070f3;\n  border-color: #0070f3;\n}\n.checkboxcard oppositebox {\n  color: white;\n  border-color: white;\n}\n.checkboxcard oppositebox:hover,\n.checkboxcard oppositebox:focus,\n.checkboxcard oppositebox:active {\n  color: #0070f3;\n  border-color: #0070f3;\n  font-size: 2rem;\n}\n.grid {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-wrap: wrap;\n  max-width: 800px;\n  margin-top: 3rem;\n}\n.stack {\n  display: -moz-stack;\n  align-items: center;\n  justify-content: center;\n  flex-wrap: nowrap;\n  max-width: 800px;\n  margin-top: 3rem;\n}\n.box {\n  display: -moz-box;\n  align-items: center;\n  justify-content: center;\n  flex-wrap: nowrap;\n  max-width: 800px;\n  margin-top: 3rem;\n}\n.popup {\n  display: -moz-popup;\n  align-items: center;\n  justify-content: center;\n  flex-wrap: nowrap;\n  max-width: 800px;\n  margin-top: 3rem;\n}\n.container {\n  min-height: 100vh;\n  padding: 0 0.5rem;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n}\n\n.main {\n  padding: 5rem 0;\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n}\n\n.footer {\n  width: 100%;\n  height: 100px;\n  border-top: 1px solid #eaeaea;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.footer img {\n  margin-left: 0.5rem;\n}\n\n.footer a {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.title a {\n  color: #0070f3;\n  text-decoration: none;\n}\n\n.title a:hover,\n.title a:focus,\n.title a:active {\n  text-decoration: underline;\n}\n\n.title {\n  margin: 0;\n  line-height: 1.15;\n  font-size: 4rem;\n}\n\n.title,\n.description {\n  text-align: center;\n}\n.description {\n  line-height: 1.5;\n  font-size: 1.5rem;\n}\n.descriptleft {\n  line-height:1.5;\n  font-size:1.5rem;\n  text-align:center;\n  text-justify: left;\n}\n.code {\n  background: #fafafa;\n  border-radius: 5px;\n  padding: 0.75rem;\n  font-size: 1.1rem;\n  font-family: Menlo, Monaco, Lucida Console, Liberation Mono, DejaVu Sans Mono,\n    Bitstream Vera Sans Mono, Courier New, monospace;\n}\n\n.grid {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-wrap: wrap;\n  max-width: 800px;\n  margin-top: 3rem;\n}\n.correct {\n  margin: 1rem;\n  flex-basis: 45%;\n  padding: 1.5rem;\n  text-align: left;\n  color: inherit;\n  text-decoration: none;\n  text-emphasis: bold;\n  border: 1px solid lightgreen;\n  border-radius: 10px;\n  transition: color 0.15s ease, border-color 0.15s ease;\n}\n.correct:hover,\n.correct:focus,\n.correct:active {\n  color: green;\n  border-color: green;\n}\n.correct h3 {\n  margin: 0 0 1rem 0;\n  font-size: 1.5rem;\n}\n\n.correct p {\n  margin: 0;\n  font-size: 1.25rem;\n  line-height: 1.5;\n}\n.ok {\n  margin: 1rem;\n  flex-basis: 45%;\n  padding: 1.5rem;\n  text-align: left;\n  color: inherit;\n  text-decoration: none;\n  text-emphasis: bold;\n  border: 1px solid yellow;\n  border-radius: 10px;\n  transition: color 0.15s ease, border-color 0.15s ease;\n}\n.ok:hover,\n.ok:focus,\n.ok:active {\n  color: orange;\n  border-color: orange;\n}\n.ok h3 {\n  margin: 0 0 1rem 0;\n  font-size: 1.5rem;\n}\n\n.ok p {\n  margin: 0;\n  font-size: 1.25rem;\n  line-height: 1.5;\n}\n\n.card {\n  margin: 1rem;\n  flex-basis: 45%;\n  padding: 1.5rem;\n  text-align: left;\n  color: inherit;\n  text-decoration: none;\n  border: 1px solid #eaeaea;\n  border-radius: 10px;\n  transition: color 0.15s ease, border-color 0.15s ease;\n}\n\n.card:hover,\n.card:focus,\n.card:active {\n  color: #0070f3;\n  border-color: #0070f3;\n}\n.card h3 {\n  margin: 0 0 1rem 0;\n  font-size: 1.5rem;\n}\n\n.card p {\n  margin: 0;\n  font-size: 1.25rem;\n  line-height: 1.5;\n}\n\n.logo {\n  height: 1em;\n}\n.space2 {\n  line-height:2;\n}\n._215 {\n  line-height:2;\n  font-size: 1.25rem;\n  text-align: center;\n}\n.cyan {\n  color:cyan;\n}\n.magenta {\n  color:magenta;\n}\n.green {\n  color:green;\n}\n.red {\n  color:red;\n}\n.lcoral {\n  color: lightcoral;\n}\n.lsalmon{\n  color: lightsalmon\n}\n.greenyellow{\n  color: greenyellow;\n}\n.skyblue {\n  color:skyblue;\n}\n.blue {\n  color:blue;\n}\n\n\n\n\n@media (max-width: 600px) {\n  .grid {\n    width: 100%;\n    flex-direction: column;\n  }\n}\n"],"sourceRoot":""} */