mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-07 19:38:57 +03:00
704da08fdc
* Panic don't fatal on create new logger Fixes #5854 Signed-off-by: Andrew Thornton <art27@cantab.net> * partial broken * Update the logging infrastrcture Signed-off-by: Andrew Thornton <art27@cantab.net> * Reset the skip levels for Fatal and Error Signed-off-by: Andrew Thornton <art27@cantab.net> * broken ncsa * More log.Error fixes Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove nal * set log-levels to lowercase * Make console_test test all levels * switch to lowercased levels * OK now working * Fix vetting issues * Fix lint * Fix tests * change default logging to match current gitea * Improve log testing Signed-off-by: Andrew Thornton <art27@cantab.net> * reset error skip levels to 0 * Update documentation and access logger configuration * Redirect the router log back to gitea if redirect macaron log but also allow setting the log level - i.e. TRACE * Fix broken level caching * Refactor the router log * Add Router logger * Add colorizing options * Adjust router colors * Only create logger if they will be used * update app.ini.sample * rename Attribute ColorAttribute * Change from white to green for function * Set fatal/error levels * Restore initial trace logger * Fix Trace arguments in modules/auth/auth.go * Properly handle XORMLogger * Improve admin/config page * fix fmt * Add auto-compression of old logs * Update error log levels * Remove the unnecessary skip argument from Error, Fatal and Critical * Add stacktrace support * Fix tests * Remove x/sync from vendors? * Add stderr option to console logger * Use filepath.ToSlash to protect against Windows in tests * Remove prefixed underscores from names in colors.go * Remove not implemented database logger This was removed from Gogs on 4 Mar 2016 but left in the configuration since then. * Ensure that log paths are relative to ROOT_PATH * use path.Join * rename jsonConfig to logConfig * Rename "config" to "jsonConfig" to make it clearer * Requested changes * Requested changes: XormLogger * Try to color the windows terminal If successful default to colorizing the console logs * fixup * Colorize initially too * update vendor * Colorize logs on default and remove if this is not a colorizing logger * Fix documentation * fix test * Use go-isatty to detect if on windows we are on msys or cygwin * Fix spelling mistake * Add missing vendors * More changes * Rationalise the ANSI writer protection * Adjust colors on advice from @0x5c * Make Flags a comma separated list * Move to use the windows constant for ENABLE_VIRTUAL_TERMINAL_PROCESSING * Ensure matching is done on the non-colored message - to simpify EXPRESSION
106 lines
3.5 KiB
Go
106 lines
3.5 KiB
Go
// Copyright 2016 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build ignore
|
|
|
|
// mkpost processes the output of cgo -godefs to
|
|
// modify the generated types. It is used to clean up
|
|
// the sys API in an architecture specific manner.
|
|
//
|
|
// mkpost is run after cgo -godefs; see README.md.
|
|
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"go/format"
|
|
"io/ioutil"
|
|
"log"
|
|
"os"
|
|
"regexp"
|
|
)
|
|
|
|
func main() {
|
|
// Get the OS and architecture (using GOARCH_TARGET if it exists)
|
|
goos := os.Getenv("GOOS")
|
|
goarch := os.Getenv("GOARCH_TARGET")
|
|
if goarch == "" {
|
|
goarch = os.Getenv("GOARCH")
|
|
}
|
|
// Check that we are using the Docker-based build system if we should be.
|
|
if goos == "linux" {
|
|
if os.Getenv("GOLANG_SYS_BUILD") != "docker" {
|
|
os.Stderr.WriteString("In the Docker-based build system, mkpost should not be called directly.\n")
|
|
os.Stderr.WriteString("See README.md\n")
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
b, err := ioutil.ReadAll(os.Stdin)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
// Intentionally export __val fields in Fsid and Sigset_t
|
|
valRegex := regexp.MustCompile(`type (Fsid|Sigset_t) struct {(\s+)X__val(\s+\S+\s+)}`)
|
|
b = valRegex.ReplaceAll(b, []byte("type $1 struct {${2}Val$3}"))
|
|
|
|
// Intentionally export __fds_bits field in FdSet
|
|
fdSetRegex := regexp.MustCompile(`type (FdSet) struct {(\s+)X__fds_bits(\s+\S+\s+)}`)
|
|
b = fdSetRegex.ReplaceAll(b, []byte("type $1 struct {${2}Bits$3}"))
|
|
|
|
// If we have empty Ptrace structs, we should delete them. Only s390x emits
|
|
// nonempty Ptrace structs.
|
|
ptraceRexexp := regexp.MustCompile(`type Ptrace((Psw|Fpregs|Per) struct {\s*})`)
|
|
b = ptraceRexexp.ReplaceAll(b, nil)
|
|
|
|
// Replace the control_regs union with a blank identifier for now.
|
|
controlRegsRegex := regexp.MustCompile(`(Control_regs)\s+\[0\]uint64`)
|
|
b = controlRegsRegex.ReplaceAll(b, []byte("_ [0]uint64"))
|
|
|
|
// Remove fields that are added by glibc
|
|
// Note that this is unstable as the identifers are private.
|
|
removeFieldsRegex := regexp.MustCompile(`X__glibc\S*`)
|
|
b = removeFieldsRegex.ReplaceAll(b, []byte("_"))
|
|
|
|
// Convert [65]int8 to [65]byte in Utsname members to simplify
|
|
// conversion to string; see golang.org/issue/20753
|
|
convertUtsnameRegex := regexp.MustCompile(`((Sys|Node|Domain)name|Release|Version|Machine)(\s+)\[(\d+)\]u?int8`)
|
|
b = convertUtsnameRegex.ReplaceAll(b, []byte("$1$3[$4]byte"))
|
|
|
|
// Convert [1024]int8 to [1024]byte in Ptmget members
|
|
convertPtmget := regexp.MustCompile(`([SC]n)(\s+)\[(\d+)\]u?int8`)
|
|
b = convertPtmget.ReplaceAll(b, []byte("$1[$3]byte"))
|
|
|
|
// Remove spare fields (e.g. in Statx_t)
|
|
spareFieldsRegex := regexp.MustCompile(`X__spare\S*`)
|
|
b = spareFieldsRegex.ReplaceAll(b, []byte("_"))
|
|
|
|
// Remove cgo padding fields
|
|
removePaddingFieldsRegex := regexp.MustCompile(`Pad_cgo_\d+`)
|
|
b = removePaddingFieldsRegex.ReplaceAll(b, []byte("_"))
|
|
|
|
// Remove padding, hidden, or unused fields
|
|
removeFieldsRegex = regexp.MustCompile(`\b(X_\S+|Padding)`)
|
|
b = removeFieldsRegex.ReplaceAll(b, []byte("_"))
|
|
|
|
// Remove the first line of warning from cgo
|
|
b = b[bytes.IndexByte(b, '\n')+1:]
|
|
// Modify the command in the header to include:
|
|
// mkpost, our own warning, and a build tag.
|
|
replacement := fmt.Sprintf(`$1 | go run mkpost.go
|
|
// Code generated by the command above; see README.md. DO NOT EDIT.
|
|
|
|
// +build %s,%s`, goarch, goos)
|
|
cgoCommandRegex := regexp.MustCompile(`(cgo -godefs .*)`)
|
|
b = cgoCommandRegex.ReplaceAll(b, []byte(replacement))
|
|
|
|
// gofmt
|
|
b, err = format.Source(b)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
os.Stdout.Write(b)
|
|
}
|