mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	* Add a storage layer for attachments * Fix some bug * fix test * Fix copyright head and lint * Fix bug * Add setting for minio and flags for migrate-storage * Add documents * fix lint * Add test for minio store type on attachments * fix test * fix test * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Add warning when storage migrated successfully * Fix drone * fix test * rebase * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * refactor the codes * add trace * Fix test * remove log on xorm * Fi download bug * Add a storage layer for attachments * Add setting for minio and flags for migrate-storage * fix lint * Add test for minio store type on attachments * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Fix drone * fix test * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * refactor the codes * add trace * Fix test * Add URL function to serve attachments directly from S3/Minio * Add ability to enable/disable redirection in attachment configuration * Fix typo * Add a storage layer for attachments * Add setting for minio and flags for migrate-storage * fix lint * Add test for minio store type on attachments * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Fix drone * fix test * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * don't change unrelated files * Fix lint * Fix build * update go.mod and go.sum * Use github.com/minio/minio-go/v6 * Remove unused function * Upgrade minio to v7 and some other improvements * fix lint * Fix go mod Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: Tyler <tystuyfzand@gmail.com>
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| package reflect2
 | |
| 
 | |
| import "unsafe"
 | |
| 
 | |
| //go:linkname unsafe_New reflect.unsafe_New
 | |
| func unsafe_New(rtype unsafe.Pointer) unsafe.Pointer
 | |
| 
 | |
| //go:linkname typedmemmove reflect.typedmemmove
 | |
| func typedmemmove(rtype unsafe.Pointer, dst, src unsafe.Pointer)
 | |
| 
 | |
| //go:linkname unsafe_NewArray reflect.unsafe_NewArray
 | |
| func unsafe_NewArray(rtype unsafe.Pointer, length int) unsafe.Pointer
 | |
| 
 | |
| // typedslicecopy copies a slice of elemType values from src to dst,
 | |
| // returning the number of elements copied.
 | |
| //go:linkname typedslicecopy reflect.typedslicecopy
 | |
| //go:noescape
 | |
| func typedslicecopy(elemType unsafe.Pointer, dst, src sliceHeader) int
 | |
| 
 | |
| //go:linkname mapassign reflect.mapassign
 | |
| //go:noescape
 | |
| func mapassign(rtype unsafe.Pointer, m unsafe.Pointer, key, val unsafe.Pointer)
 | |
| 
 | |
| //go:linkname mapaccess reflect.mapaccess
 | |
| //go:noescape
 | |
| func mapaccess(rtype unsafe.Pointer, m unsafe.Pointer, key unsafe.Pointer) (val unsafe.Pointer)
 | |
| 
 | |
| // m escapes into the return value, but the caller of mapiterinit
 | |
| // doesn't let the return value escape.
 | |
| //go:noescape
 | |
| //go:linkname mapiterinit reflect.mapiterinit
 | |
| func mapiterinit(rtype unsafe.Pointer, m unsafe.Pointer) *hiter
 | |
| 
 | |
| //go:noescape
 | |
| //go:linkname mapiternext reflect.mapiternext
 | |
| func mapiternext(it *hiter)
 | |
| 
 | |
| //go:linkname ifaceE2I reflect.ifaceE2I
 | |
| func ifaceE2I(rtype unsafe.Pointer, src interface{}, dst unsafe.Pointer)
 | |
| 
 | |
| // A hash iteration structure.
 | |
| // If you modify hiter, also change cmd/internal/gc/reflect.go to indicate
 | |
| // the layout of this structure.
 | |
| type hiter struct {
 | |
| 	key   unsafe.Pointer // Must be in first position.  Write nil to indicate iteration end (see cmd/internal/gc/range.go).
 | |
| 	value unsafe.Pointer // Must be in second position (see cmd/internal/gc/range.go).
 | |
| 	// rest fields are ignored
 | |
| }
 | |
| 
 | |
| // add returns p+x.
 | |
| //
 | |
| // The whySafe string is ignored, so that the function still inlines
 | |
| // as efficiently as p+x, but all call sites should use the string to
 | |
| // record why the addition is safe, which is to say why the addition
 | |
| // does not cause x to advance to the very end of p's allocation
 | |
| // and therefore point incorrectly at the next block in memory.
 | |
| func add(p unsafe.Pointer, x uintptr, whySafe string) unsafe.Pointer {
 | |
| 	return unsafe.Pointer(uintptr(p) + x)
 | |
| }
 | |
| 
 | |
| // arrayAt returns the i-th element of p,
 | |
| // an array whose elements are eltSize bytes wide.
 | |
| // The array pointed at by p must have at least i+1 elements:
 | |
| // it is invalid (but impossible to check here) to pass i >= len,
 | |
| // because then the result will point outside the array.
 | |
| // whySafe must explain why i < len. (Passing "i < len" is fine;
 | |
| // the benefit is to surface this assumption at the call site.)
 | |
| func arrayAt(p unsafe.Pointer, i int, eltSize uintptr, whySafe string) unsafe.Pointer {
 | |
| 	return add(p, uintptr(i)*eltSize, "i < len")
 | |
| }
 |