| // Copyright 2011 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. | |
| package sort_test | |
| import ( | |
| "fmt" | |
| "sort" | |
| ) | |
| type Grams int | |
| func (g Grams) String() string { return fmt.Sprintf("%dg", int(g)) } | |
| type Organ struct { | |
| Name string | |
| Weight Grams | |
| } | |
| type Organs []*Organ | |
| func (s Organs) Len() int { return len(s) } | |
| func (s Organs) Swap(i, j int) { s[i], s[j] = s[j], s[i] } | |
| // ByName implements sort.Interface by providing Less and using the Len and | |
| // Swap methods of the embedded Organs value. | |
| type ByName struct{ Organs } | |
| func (s ByName) Less(i, j int) bool { return s.Organs[i].Name < s.Organs[j].Name } | |
| // ByWeight implements sort.Interface by providing Less and using the Len and | |
| // Swap methods of the embedded Organs value. | |
| type ByWeight struct{ Organs } | |
| func (s ByWeight) Less(i, j int) bool { return s.Organs[i].Weight < s.Organs[j].Weight } | |
| func Example_sortWrapper() { | |
| s := []*Organ{ | |
| {"brain", 1340}, | |
| {"heart", 290}, | |
| {"liver", 1494}, | |
| {"pancreas", 131}, | |
| {"prostate", 62}, | |
| {"spleen", 162}, | |
| } | |
| sort.Sort(ByWeight{s}) | |
| fmt.Println("Organs by weight:") | |
| printOrgans(s) | |
| sort.Sort(ByName{s}) | |
| fmt.Println("Organs by name:") | |
| printOrgans(s) | |
| // Output: | |
| // Organs by weight: | |
| // prostate (62g) | |
| // pancreas (131g) | |
| // spleen (162g) | |
| // heart (290g) | |
| // brain (1340g) | |
| // liver (1494g) | |
| // Organs by name: | |
| // brain (1340g) | |
| // heart (290g) | |
| // liver (1494g) | |
| // pancreas (131g) | |
| // prostate (62g) | |
| // spleen (162g) | |
| } | |
| func printOrgans(s []*Organ) { | |
| for _, o := range s { | |
| fmt.Printf("%-8s (%v)\n", o.Name, o.Weight) | |
| } | |
| } | |