mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-04 00:42:24 -06: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)
 | 
						|
}
 |