mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 01:12:24 -05:00 
			
		
		
		
	* Add Swagger spec test script * Fix Swagger spec errors not related to statuses with polls * Add API tests that post a status with a poll * Fix creating a status with a poll from form params * Fix Swagger spec errors related to statuses with polls (this is the last error) * Fix Swagger spec warnings not related to unused definitions * Suppress a duplicate list update params definition that was somehow causing wrong param names * Add Swagger test to CI - updates Drone config - vendorizes go-swagger - fixes a file extension issue that caused the test script to generate JSON instead of YAML with the vendorized version * Put `Sample: ` on its own line everywhere * Remove unused id param from emojiCategoriesGet * Add 5 more pairs of profile fields to account update API Swagger * Remove Swagger prefix from dummy fields It makes the generated code look weird * Manually annotate params for statusCreate operation * Fix all remaining Swagger spec warnings - Change some models into operation parameters - Ignore models that already correspond to manually documented operation parameters but can't be trivially changed (those with file fields) * Documented that creating a status with scheduled_at isn't implemented yet * sign drone.yml * Fix filter API Swagger errors * fixup! Fix filter API Swagger errors --------- Co-authored-by: tobi <tobi.smethurst@protonmail.com>
		
			
				
	
	
		
			65 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright (C) MongoDB, Inc. 2017-present.
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License"); you may
 | |
| // not use this file except in compliance with the License. You may obtain
 | |
| // a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
| package bsoncodec
 | |
| 
 | |
| import "fmt"
 | |
| 
 | |
| type mode int
 | |
| 
 | |
| const (
 | |
| 	_ mode = iota
 | |
| 	mTopLevel
 | |
| 	mDocument
 | |
| 	mArray
 | |
| 	mValue
 | |
| 	mElement
 | |
| 	mCodeWithScope
 | |
| 	mSpacer
 | |
| )
 | |
| 
 | |
| func (m mode) String() string {
 | |
| 	var str string
 | |
| 
 | |
| 	switch m {
 | |
| 	case mTopLevel:
 | |
| 		str = "TopLevel"
 | |
| 	case mDocument:
 | |
| 		str = "DocumentMode"
 | |
| 	case mArray:
 | |
| 		str = "ArrayMode"
 | |
| 	case mValue:
 | |
| 		str = "ValueMode"
 | |
| 	case mElement:
 | |
| 		str = "ElementMode"
 | |
| 	case mCodeWithScope:
 | |
| 		str = "CodeWithScopeMode"
 | |
| 	case mSpacer:
 | |
| 		str = "CodeWithScopeSpacerFrame"
 | |
| 	default:
 | |
| 		str = "UnknownMode"
 | |
| 	}
 | |
| 
 | |
| 	return str
 | |
| }
 | |
| 
 | |
| // TransitionError is an error returned when an invalid progressing a
 | |
| // ValueReader or ValueWriter state machine occurs.
 | |
| type TransitionError struct {
 | |
| 	parent      mode
 | |
| 	current     mode
 | |
| 	destination mode
 | |
| }
 | |
| 
 | |
| func (te TransitionError) Error() string {
 | |
| 	if te.destination == mode(0) {
 | |
| 		return fmt.Sprintf("invalid state transition: cannot read/write value while in %s", te.current)
 | |
| 	}
 | |
| 	if te.parent == mode(0) {
 | |
| 		return fmt.Sprintf("invalid state transition: %s -> %s", te.current, te.destination)
 | |
| 	}
 | |
| 	return fmt.Sprintf("invalid state transition: %s -> %s; parent %s", te.current, te.destination, te.parent)
 | |
| }
 |